/* ELUCENS app — auth (tenant login) + onboarding (connect first source).
   Pairs with app.css (tokens, buttons). Wrap pages in .app for tokens. */

/* ===================== AUTH / LOGIN ===================== */
.auth{display:grid;grid-template-columns:1.06fr .94fr;min-height:100vh}
.auth__brand{background:var(--pine);color:var(--on-dark);padding:54px 52px;display:flex;flex-direction:column;position:relative;overflow:hidden}
.auth__brand .wm{font-size:26px}
.auth__lead{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.1vw,44px);letter-spacing:-.03em;line-height:1.08;color:var(--on-dark);max-width:15ch;margin-top:auto}
.auth__lead em{font-style:normal;color:var(--accent)}
.auth__pts{display:flex;flex-direction:column;gap:15px;margin-top:30px}
.auth__pt{display:flex;align-items:flex-start;gap:12px;font-size:15px;line-height:1.5;color:var(--on-dark-2);max-width:40ch}
.auth__pt .seed{margin-top:7px}
.auth__pt b{color:var(--on-dark);font-weight:700}
.auth__foot{font-family:var(--font-body);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--on-dark-3);margin-top:42px}
.auth__panel{display:flex;align-items:center;justify-content:center;padding:48px;background:var(--paper)}
.auth__card{width:100%;max-width:404px}
.auth__h{font-family:var(--font-display);font-weight:700;font-size:32px;letter-spacing:-.03em;color:var(--ink);margin:14px 0 8px;line-height:1.05}
.auth__sub{font-size:15px;line-height:1.55;color:var(--ink-2);margin-bottom:28px}
.afield{margin-bottom:16px}
.afield label{display:block;font-weight:700;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
.afield input{width:100%;font-family:var(--font-body);font-size:15px;color:var(--ink);background:var(--paper-2);border:1.5px solid var(--line-2);border-radius:var(--radius-sm);padding:13px 15px;outline:none;transition:.15s}
.afield input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.afield input::placeholder{color:var(--ink-3)}
.auth__or{display:flex;align-items:center;gap:14px;margin:24px 0;color:var(--ink-3);font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.auth__or::before,.auth__or::after{content:"";flex:1;height:1px;background:var(--line)}
.tpick{display:flex;align-items:center;gap:13px;padding:13px 15px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper-2);cursor:pointer;transition:.14s;margin-bottom:10px;width:100%;text-align:left}
.tpick:hover{border-color:var(--accent);box-shadow:0 14px 30px -24px rgba(6,37,35,.4);transform:translateY(-1px)}
.tpick__logo{width:38px;height:38px;border-radius:10px;background:var(--pine);color:var(--on-dark);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:17px;flex:0 0 auto}
.tpick__meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.tpick__name{font-weight:700;font-size:14.5px;color:var(--ink)}
.tpick__url{font-size:12px;color:var(--ink-3);font-weight:600}
.tpick__ar{color:var(--ink-3);transition:transform .18s;flex:0 0 auto}
.tpick:hover .tpick__ar{transform:translateX(3px);color:var(--accent-deep)}
.auth__alt{text-align:center;margin-top:24px;font-size:13.5px;color:var(--ink-2)}
.auth__alt a{color:var(--accent-deep);font-weight:700;text-decoration:none}
.auth__alt a:hover{text-decoration:underline}
.auth__back{display:inline-flex;align-items:center;gap:7px;background:none;border:0;cursor:pointer;font-family:var(--font-body);font-weight:700;font-size:12.5px;color:var(--ink-3);margin-bottom:18px;padding:0}
.auth__back:hover{color:var(--ink)}
.auth__tenant{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper-2);margin-bottom:22px}
.auth__tenant-logo{width:36px;height:36px;border-radius:9px;background:var(--pine);color:var(--on-dark);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:16px;flex:0 0 auto}
.auth__tenant-meta{flex:1;min-width:0;display:flex;flex-direction:column}
.auth__tenant-name{font-weight:700;font-size:14px;color:var(--ink)}
.auth__tenant-url{font-size:12px;color:var(--ink-3);font-weight:600}
.auth__tenant-url b{color:var(--accent-deep)}
.auth__rowline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:6px 0 16px;font-size:13px}
.auth__remember{display:inline-flex;align-items:center;gap:8px;color:var(--ink-2);font-weight:600;cursor:pointer;white-space:nowrap}
.auth__remember input{accent-color:var(--accent);width:15px;height:15px}
.auth__link{color:var(--accent-deep);font-weight:700;text-decoration:none;white-space:nowrap}
.auth__link:hover{text-decoration:underline}

/* ===================== ONBOARDING ===================== */
.onb{min-height:100vh;background:var(--paper);display:flex;flex-direction:column}
.onb__top{display:flex;align-items:center;justify-content:space-between;padding:20px 40px;border-bottom:1px solid var(--line);flex:0 0 auto}
.onb__top .wm{font-size:24px}
.onb__steps{display:flex;align-items:center;gap:11px}
.ostep{display:flex;align-items:center;gap:8px;font-weight:700;font-size:12.5px;color:var(--ink-3)}
.ostep__n{width:22px;height:22px;border-radius:50%;background:var(--paper-3);color:var(--ink-3);display:flex;align-items:center;justify-content:center;font-size:11px;font-family:var(--font-display)}
.ostep.on .ostep__n{background:var(--accent);color:#fff}
.ostep.done .ostep__n{background:var(--ok);color:#fff}
.ostep.on{color:var(--ink)}
.ostep__line{width:28px;height:2px;background:var(--line-2);border-radius:2px}
.onb__body{flex:1;overflow-y:auto;padding:46px 40px 40px}
.onb__inner{max-width:940px;margin:0 auto}
.onb__eyebrow{margin-bottom:14px}
.onb__h{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.3vw,44px);letter-spacing:-.03em;line-height:1.06;color:var(--ink)}
.onb__h em{font-style:normal;color:var(--accent-deep)}
.onb__sub{font-size:17px;line-height:1.55;color:var(--ink-2);margin-top:14px;max-width:58ch}
.onb__meter{margin:30px 0 6px;display:flex;align-items:center;gap:16px}
.onb__track{flex:1;height:10px;border-radius:999px;background:var(--paper-3);overflow:hidden}
.onb__fill{height:100%;background:var(--accent);border-radius:999px;transition:width .45s cubic-bezier(.4,0,.1,1)}
.onb__pct{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--ink);white-space:nowrap}
.onb__metalabel{font-size:13px;color:var(--ink-3);font-weight:600;margin-bottom:4px}
.onb__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.osrc{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;transition:.16s}
.osrc.connected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.osrc__top{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.osrc__logo{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;background:var(--paper-2);border:1px solid var(--line)}
.osrc__name{font-weight:700;font-size:15px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.osrc__meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.osrc__cat{font-size:12px;color:var(--ink-3);font-weight:600;margin-top:1px}
.osrc__desc{font-size:13px;line-height:1.5;color:var(--ink-2);flex:1;margin-bottom:16px}
.onb__bar{position:sticky;bottom:0;background:var(--paper);border-top:1px solid var(--line);padding:16px 40px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex:0 0 auto}
.onb__barmsg{font-size:14px;color:var(--ink-2);font-weight:600;display:flex;align-items:center;gap:9px}
.onb__barmsg b{color:var(--ink)}

@media(max-width:860px){
  .auth{grid-template-columns:1fr}
  .auth__brand{display:none}
  .onb__grid{grid-template-columns:1fr}
  .onb__top,.onb__body,.onb__bar{padding-left:22px;padding-right:22px}
  .onb__steps .ostep span{display:none}
}
