/* ═══════════════════════════════════════════════════════
   LOCI BRAND GUIDE Feb 2026
   Background:#080C16  Line:#282828  Light:#EDEDED  Grey:#9C9A9A
   Green:#14B8A6  Blue:#37A7E7
   Gradient: #4ade80→#34d399→#2dd4bf→#22d3ee  Font: Inter
═══════════════════════════════════════════════════════ */
:root {
  --bg:#080C16; --bg2:#0c1120; --bg3:#111827;
  --line:#282828; --surface:#0f1523; --surface2:#161e2e;
  --text:#EDEDED; --grey:#9C9A9A;
  --green:#14B8A6; --blue:#37A7E7;
  --green-dim:rgba(20,184,166,0.1); --blue-dim:rgba(55,167,231,0.1);
  --green-b:rgba(20,184,166,0.25);  --blue-b:rgba(55,167,231,0.25);
  --danger:#ef4444; --warn:#f59e0b;
  --r:6px; --r-lg:10px; --font:'Inter',sans-serif;
  --content-max-width:1198px; --content-pad-x:24px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::after{content:'';position:fixed;inset:0;z-index:0;background-image:radial-gradient(circle,rgba(255,255,255,0.028) 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.orb{position:fixed;border-radius:50%;filter:blur(110px);pointer-events:none;z-index:0}
.orb-teal{width:560px;height:560px;background:radial-gradient(circle,rgba(20,184,166,0.09) 0%,transparent 65%);top:-180px;left:-140px}
.orb-blue{width:480px;height:480px;background:radial-gradient(circle,rgba(55,167,231,0.06) 0%,transparent 65%);bottom:0;right:-100px}

/* ── NAV ── */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:200;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 40px;background:rgba(8,12,22,0.94);backdrop-filter:blur(20px);border-bottom:1px solid var(--line)}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;cursor:default;pointer-events:none;flex-shrink:0}
.nav-logo-mark{width:36px;height:36px;background:linear-gradient(135deg,var(--green) 0%,#22d3ee 100%);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#080C16;flex-shrink:0;letter-spacing:-1px}
.nav-logo-text{display:flex;flex-direction:row;align-items:baseline;gap:6px}
.nav-logo-loci{font-size:16px;font-weight:700;color:var(--text);letter-spacing:0.3px}
.nav-logo-sub{font-size:12px;font-weight:400;color:var(--grey);letter-spacing:0.2px}
.nav-cta{display:inline-flex;align-items:center;padding:9px 22px;background:transparent;border:1.5px solid var(--blue);border-radius:50px;font-size:13px;font-weight:500;color:var(--blue);text-decoration:none;cursor:pointer;font-family:var(--font);letter-spacing:0.2px;transition:border-color 0.18s,color 0.18s,box-shadow 0.18s;white-space:nowrap}
.nav-cta:hover,.nav-cta:focus{border-color:var(--text);color:var(--text);box-shadow:0 0 0 3px rgba(55,167,231,0.18);outline:none}
.nav-signout{display:inline-flex;align-items:center;padding:9px 22px;background:transparent;border:1.5px solid var(--blue);border-radius:50px;font-size:13px;font-weight:500;color:var(--blue);cursor:pointer;font-family:var(--font);letter-spacing:0.2px;transition:border-color 0.18s,color 0.18s,box-shadow 0.18s;white-space:nowrap}
.nav-signout:hover,.nav-signout:focus{border-color:var(--text);color:var(--text);box-shadow:0 0 0 3px rgba(55,167,231,0.18);outline:none}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-user-email{font-size:13px;color:var(--grey)}

/* ── BADGES ── */
.grounding-badge{display:inline-flex;align-items:center;padding:5px 14px;border:1px solid var(--green-b);border-radius:20px;letter-spacing:1.5px;text-transform:uppercase;background:var(--green-dim);font-family:var(--e-global-typography-b2dd3a8-font-family),Sans-serif;font-size:var(--e-global-typography-b2dd3a8-font-size,11px);font-weight:var(--e-global-typography-b2dd3a8-font-weight,600);line-height:var(--e-global-typography-b2dd3a8-line-height,1.4);color:var(--e-global-color-1e0a375,var(--green))}
.ea-text{background:linear-gradient(90deg,#4ade80 0%,#2dd4bf 50%,#22d3ee 100%);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline}

/* ── SHARED FORM ELEMENTS ── */
.form-field{margin-bottom:18px}
.form-field label{display:block;font-size:12px;font-weight:500;color:var(--grey);margin-bottom:7px;letter-spacing:0.2px}
.form-field input,.form-field select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:11px 14px;font-size:14px;font-weight:400;color:var(--text);font-family:var(--font);outline:none;transition:border-color 0.2s,box-shadow 0.2s;appearance:none}
.form-field input::placeholder{color:#363d50}
.form-field input:focus,.form-field select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(20,184,166,0.1)}
.form-field select option{background:var(--bg3);color:var(--text)}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px}
.form-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--grey);cursor:pointer}
.form-check input[type="checkbox"]{width:14px;height:14px;accent-color:var(--green)}
.form-forgot{font-size:13px;color:var(--green);text-decoration:none;transition:opacity 0.2s}
.form-forgot:hover{opacity:0.7}
.form-hint{font-size:11px;color:var(--grey);margin-top:5px}

/* ── BUTTONS ── */
.btn-primary{width:100%;padding:13px 20px;background:var(--green);color:#080C16;font-family:var(--font);font-size:14px;font-weight:600;border:none;border-radius:var(--r);cursor:pointer;letter-spacing:0.2px;transition:all 0.2s}
.btn-primary:hover{background:#1dd1be;transform:translateY(-1px);box-shadow:0 6px 20px rgba(20,184,166,0.3)}
.btn-primary:active{transform:translateY(0)}
.btn-secondary{padding:9px 18px;background:transparent;color:var(--green);font-family:var(--font);font-size:13px;font-weight:600;border:1px solid var(--green-b);border-radius:var(--r);cursor:pointer;transition:all 0.2s}
.btn-secondary:hover{background:var(--green-dim);border-color:var(--green)}
.btn-ghost-sm{padding:7px 14px;background:transparent;color:var(--grey);font-family:var(--font);font-size:12px;font-weight:500;border:1px solid rgba(255,255,255,0.18);border-radius:var(--r);cursor:pointer;transition:all 0.2s}
.btn-ghost-sm:hover{border-color:rgba(255,255,255,0.35);color:var(--text)}
.btn-danger-sm{padding:7px 14px;background:transparent;color:var(--danger);font-family:var(--font);font-size:12px;font-weight:500;border:1px solid rgba(239,68,68,0.3);border-radius:var(--r);cursor:pointer;transition:all 0.2s}
.btn-danger-sm:hover{background:rgba(239,68,68,0.08);border-color:var(--danger)}
.btn-icon{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(255,255,255,0.16);border-radius:var(--r);cursor:pointer;font-size:14px;color:var(--grey);transition:all 0.15s;font-family:var(--font)}
.btn-icon:hover{border-color:rgba(255,255,255,0.3);color:var(--text)}
.btn-icon.danger:hover{border-color:var(--danger);color:var(--danger)}

/* ── LANDING PAGE ── */
#page-login{position:relative;z-index:1;min-height:100vh;display:grid;grid-template-columns:1fr 1fr;padding-top:68px}
.landing-left{display:flex;flex-direction:column;justify-content:center;padding:60px 56px 60px 64px;position:relative}
.landing-right{display:flex;align-items:center;justify-content:center;padding:40px 64px 40px 40px;border-left:1px solid var(--line);background:rgba(15,21,35,0.5)}
.landing-eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:28px}
.landing-headline{font-size:clamp(34px,4.5vw,56px);font-weight:800;line-height:1.1;letter-spacing:-1.5px;color:var(--text);margin-bottom:18px}
.landing-sub{font-size:16px;color:var(--grey);line-height:1.7;margin-bottom:36px;max-width:420px;font-weight:400}
.landing-features{display:flex;flex-direction:column;gap:14px;margin-bottom:0}
.lf-item{display:flex;align-items:flex-start;gap:12px}
.lf-icon{width:32px;height:32px;border-radius:8px;background:var(--green-dim);border:1px solid var(--green-b);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;margin-top:1px}
.lf-text .lf-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.lf-text .lf-desc{font-size:12px;color:var(--grey);line-height:1.5}
.social-proof{display:flex;align-items:center;gap:10px;margin-top:40px;padding-top:32px;border-top:1px solid var(--line)}
.sp-avatars{display:flex}
.sp-avatar{width:28px;height:28px;border-radius:50%;border:2px solid var(--bg);margin-right:-8px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.sp-avatar:nth-child(1){background:linear-gradient(135deg,var(--green),#22d3ee)}
.sp-avatar:nth-child(2){background:linear-gradient(135deg,var(--blue),#7c3aed)}
.sp-avatar:nth-child(3){background:linear-gradient(135deg,#f59e0b,#ef4444)}
.sp-avatar:nth-child(4){background:linear-gradient(135deg,#8b5cf6,var(--blue))}
.sp-text{font-size:12px;color:var(--grey);margin-left:6px;line-height:1.4}
.sp-text strong{color:var(--text);font-weight:600}

/* ── ONBOARDING CARD (right panel) ── */
.onboard-card{width:100%;max-width:400px}
.oc-logo-row{display:flex;justify-content:center;margin-bottom:28px}
.oc-title{font-size:22px;font-weight:700;color:var(--text);text-align:center;margin-bottom:6px;letter-spacing:-0.3px}
.oc-sub{font-size:13px;color:var(--grey);text-align:center;margin-bottom:28px;line-height:1.5}
/* Google button */
.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:13px 20px;background:#fff;color:#1f2328;font-family:var(--font);font-size:14px;font-weight:600;border:none;border-radius:var(--r);cursor:pointer;letter-spacing:0.1px;transition:all 0.2s;position:relative;overflow:hidden}
.btn-google:hover{background:#f1f3f4;transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,0.3)}
.btn-google:active{transform:translateY(0)}
.btn-google svg{flex-shrink:0}
.btn-google-divider{display:flex;align-items:center;gap:10px;margin:16px 0;color:var(--grey);font-size:11px;letter-spacing:0.5px}
.btn-google-divider::before,.btn-google-divider::after{content:'';flex:1;height:1px;background:var(--line)}
.oc-email-btn{width:100%;padding:13px 20px;background:transparent;color:var(--text);font-family:var(--font);font-size:14px;font-weight:500;border:1.5px solid rgba(255,255,255,0.18);border-radius:var(--r);cursor:pointer;letter-spacing:0.1px;transition:all 0.2s;text-align:center}
.oc-email-btn:hover{border-color:var(--green);color:var(--green)}
.oc-terms{font-size:11px;color:var(--grey);text-align:center;margin-top:16px;line-height:1.6}
.oc-terms a{color:var(--green);text-decoration:none}
.oc-terms a:hover{text-decoration:underline}
/* Sign in link row */
.oc-signin-row{margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,0.1);text-align:center}
.oc-signin-row p{font-size:12px;color:var(--grey);margin-bottom:10px}
.oc-signin-row button{background:transparent;border:1.5px solid rgba(255,255,255,0.18);border-radius:var(--r);padding:9px 20px;font-size:13px;font-weight:500;color:var(--grey);cursor:pointer;font-family:var(--font);width:100%;transition:all 0.18s}
.oc-signin-row button:hover{border-color:rgba(255,255,255,0.35);color:var(--text)}

/* ── INLINE SIGN IN DRAWER (collapses in right panel) ── */
.signin-drawer{display:none;margin-top:0}
.signin-drawer.open{display:block}
.signin-drawer-inner{background:var(--bg);border:1px solid rgba(255,255,255,0.12);border-radius:var(--r-lg);padding:22px;margin-top:14px;position:relative;overflow:hidden}
.signin-drawer-inner::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#4ade80,#2dd4bf,#22d3ee);opacity:0.5}
.sd-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:14px}

/* ── AUTH CARD SHARED (signup flow uses this) ── */
.auth-page{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:100px 20px 60px}
.auth-wrap{width:100%;max-width:480px}
.auth-badge-row{display:flex;justify-content:center;margin-bottom:22px}
.auth-headline{font-size:clamp(26px,5vw,36px);font-weight:700;line-height:1.18;color:var(--text);text-align:center;margin-bottom:10px;letter-spacing:-0.5px}
.auth-sub{font-size:14px;font-weight:400;color:var(--grey);text-align:center;margin-bottom:32px;line-height:1.6}
.auth-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 36px 30px;position:relative;overflow:hidden}
.auth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#4ade80,#2dd4bf,#22d3ee);opacity:0.65}
.auth-footer{text-align:center;margin-top:18px;font-size:13px;color:var(--grey)}
.auth-footer a{color:var(--green);text-decoration:none}
.auth-footer a:hover{text-decoration:underline}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--grey);font-size:12px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--line)}

/* ── LANDING RESPONSIVE ── */
@media(max-width:860px){
    #page-login{grid-template-columns:1fr;padding-top:68px}
    .landing-left{display:none}
    .landing-right{border-left:none;padding:40px 20px;border-top:none;min-height:calc(100vh - 68px)}
}

/* ── USER TYPE SELECTOR ── */
.type-selector{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:22px}
.type-card{background:var(--bg);border:1.5px solid var(--line);border-radius:var(--r-lg);padding:18px 16px;cursor:pointer;transition:all 0.18s;text-align:center}
.type-card:hover{border-color:rgba(255,255,255,0.18)}
.type-card.selected{border-color:var(--green);background:var(--green-dim)}
.type-card .tc-icon{font-size:26px;margin-bottom:10px;display:block;line-height:1}
.type-card .tc-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}
.type-card .tc-desc{font-size:11px;color:var(--grey);line-height:1.5}

/* ── STEP INDICATOR ── */
.step-bar{display:flex;align-items:center;gap:0;margin-bottom:28px}
.step-item{display:flex;align-items:center;flex:1}
.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;border:2px solid var(--line);color:var(--grey);background:var(--bg);transition:all 0.2s}
.step-dot.active{border-color:var(--green);color:var(--green);background:var(--green-dim)}
.step-dot.done{border-color:var(--green);color:#080C16;background:var(--green)}
.step-label{font-size:11px;color:var(--grey);margin-left:8px;white-space:nowrap}
.step-label.active{color:var(--text)}
.step-line{flex:1;height:1px;background:var(--line);margin:0 8px}
.step-line.done{background:var(--green)}

/* ── SECTION DIVIDER ── */
.section-sep{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--grey);margin:20px 0 14px;display:flex;align-items:center;gap:10px}
.section-sep::after{content:'';flex:1;height:1px;background:var(--line)}

/* ── PLAN SELECT CARDS (signup) ── */
.plan-select-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:4px}
.plan-select-card{background:var(--bg);border:1.5px solid var(--line);border-radius:var(--r-lg);padding:20px;cursor:pointer;transition:all 0.18s;position:relative}
.plan-select-card:hover{border-color:rgba(255,255,255,0.18)}
.plan-select-card.selected{border-color:var(--green);background:var(--green-dim)}
.plan-select-card .psc-name{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}
.plan-select-card .psc-price{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-0.5px;margin-bottom:2px}
.plan-select-card .psc-price sub{font-size:12px;font-weight:400;color:var(--grey);vertical-align:baseline}
.plan-select-card .psc-note{font-size:11px;color:var(--grey);margin-bottom:12px}
.plan-select-card ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.plan-select-card ul li{font-size:12px;color:var(--grey);display:flex;align-items:flex-start;gap:6px}
.plan-select-card ul li .y{color:var(--green);flex-shrink:0}
.plan-select-card ul li .n{color:#333;flex-shrink:0}
.seat-counter{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:10px 14px;margin-top:12px}
.seat-counter label{font-size:12px;color:var(--grey);flex:1}
.seat-counter .sc-ctrl{display:flex;align-items:center;gap:8px}
.seat-counter .sc-btn{width:26px;height:26px;border-radius:50%;border:1px solid var(--line);background:var(--bg3);color:var(--text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;font-family:var(--font)}
.seat-counter .sc-btn:hover{border-color:var(--green);color:var(--green)}
.seat-counter .sc-num{font-size:15px;font-weight:700;color:var(--text);min-width:24px;text-align:center}
.seat-total{font-size:12px;color:var(--grey);margin-top:8px;text-align:right}
.seat-total strong{color:var(--green)}

/* ── SUCCESS STATE ── */
.success-screen{text-align:center;padding:20px 0}
.success-icon{width:64px;height:64px;border-radius:50%;background:var(--green-dim);border:2px solid var(--green);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 20px}
.success-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:8px}
.success-sub{font-size:14px;color:var(--grey);margin-bottom:24px;line-height:1.6}

/* ── DASHBOARD ── */
#dashboard-page{display:none;position:relative;z-index:1;min-height:100vh;padding-top:68px}
.dash-hero{max-width:var(--content-max-width);margin:0 auto;padding:48px var(--content-pad-x) 36px;border-bottom:1px solid var(--line)}
.dash-badge-row{margin-bottom:14px;display:flex;align-items:center;gap:12px}
.dash-headline-row{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap}
.dash-headline{font-size:clamp(26px,4vw,40px);font-weight:700;line-height:1.15;color:var(--text);letter-spacing:-0.6px}
.plan-chip{display:inline-flex;align-items:center;gap:7px;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:0.2px}
.plan-chip.premium{background:var(--green-dim);border:1px solid var(--green-b);color:var(--green)}
.plan-chip.free{background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--grey)}
.plan-chip.company{background:rgba(55,167,231,0.1);border:1px solid rgba(55,167,231,0.3);color:var(--blue)}
.plan-chip .pulse{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse-anim 2s ease-in-out infinite}
@keyframes pulse-anim{0%,100%{opacity:1}50%{opacity:0.3}}

/* ── TABS ── */
.tabs-nav{display:flex;max-width:var(--content-max-width);margin:0 auto;padding:0 var(--content-pad-x);border-bottom:1px solid var(--line)}
.tab-btn{padding:16px 0;margin-right:36px;font-size:14px;font-weight:400;color:var(--text);background:transparent;border:none;cursor:pointer;font-family:var(--font);position:relative;transition:color 0.18s;white-space:nowrap;letter-spacing:0.1px}
.tab-btn:hover{color:var(--green)}
.tab-btn.active{color:var(--green);font-weight:600}
.tab-panel{display:none;max-width:var(--content-max-width);margin:0 auto;padding:40px var(--content-pad-x)}
.tab-panel.active{display:block}

/* ── METRICS ── */
.metrics-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:20px}
.metric-cell{background:var(--surface);padding:26px 26px 20px;transition:background 0.15s}
.metric-cell:hover{background:var(--surface2)}
.metric-label{font-size:11px;font-weight:600;color:var(--grey);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.metric-dot{width:5px;height:5px;border-radius:50%;background:var(--green)}
.metric-value{font-size:36px;font-weight:700;line-height:1;letter-spacing:-1.5px;margin-bottom:7px;color:var(--text)}
.metric-unit{font-size:13px;font-weight:400;color:var(--grey);margin-left:5px;letter-spacing:0}
.metric-delta{font-size:12px;font-weight:500;display:flex;align-items:center;gap:4px}
.metric-delta.up{color:var(--green)}
.metric-delta.down{color:var(--blue)}
.metric-delta.flat{color:var(--grey)}

/* ── TOKENS ── */
.tokens-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 28px;margin-bottom:20px;position:relative;overflow:hidden}
.tokens-card::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,184,166,0.04) 0%,transparent 55%);pointer-events:none}
.tokens-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--grey);margin-bottom:8px}
.tokens-value{font-size:42px;font-weight:700;color:var(--green);line-height:1;letter-spacing:-2px}
.tokens-value span{font-size:17px;font-weight:400;color:var(--grey);letter-spacing:0;margin-left:6px}
.tokens-sub{font-size:13px;color:var(--grey);margin-top:5px}

/* ── QUOTA ── */
.quota-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 28px;margin-bottom:20px}
.quota-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;flex-wrap:wrap;gap:8px}
.quota-title{font-size:13px;font-weight:500;color:var(--text)}
.quota-nums{font-size:13px;color:var(--grey)}
.quota-nums strong{color:var(--text);font-weight:600}
.bar-track{height:5px;background:var(--bg3);border-radius:10px;overflow:hidden}
.bar-fill{height:100%;border-radius:10px;background:linear-gradient(90deg,var(--green),#22d3ee);transition:width 1.2s cubic-bezier(0.4,0,0.2,1)}
.bar-fill.warn{background:linear-gradient(90deg,var(--warn),#fb923c)}
.quota-note{margin-top:8px;font-size:12px;color:var(--grey)}
.quota-note a{color:var(--green);text-decoration:none}

/* ── CHART ── */
.section-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.section-title .badge{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;background:var(--green-dim);color:var(--green);padding:2px 8px;border-radius:20px;margin-left:8px}
.view-toggle{display:flex;background:var(--bg3);border:1px solid var(--line);border-radius:5px;padding:3px;gap:2px}
.view-btn{padding:5px 14px;font-size:12px;font-weight:500;border:none;border-radius:3px;cursor:pointer;background:transparent;color:var(--grey);font-family:var(--font);transition:all 0.15s}
.view-btn.active{background:var(--green);color:#080C16;font-weight:600}
.view-btn:not(.active):hover{color:var(--text)}
.chart-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;margin-bottom:20px}
.chart-area{height:160px;display:flex;align-items:flex-end;gap:6px;position:relative;padding-bottom:22px}
.chart-grid-lines{position:absolute;top:0;left:0;right:0;bottom:22px;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}
.cgl{width:100%;height:1px;background:var(--line);position:relative}
.cgl::after{content:attr(data-v);position:absolute;right:0;top:-9px;font-size:10px;color:#3d4455;font-weight:500}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:4px}
.bar-col .c-bar{width:100%;border-radius:3px 3px 0 0;background:linear-gradient(180deg,var(--green) 0%,rgba(20,184,166,0.25) 100%);transition:height 0.4s cubic-bezier(0.4,0,0.2,1);cursor:pointer;min-height:3px}
.bar-col .c-bar.today{background:linear-gradient(180deg,var(--blue) 0%,rgba(55,167,231,0.25) 100%)}
.bar-col .c-bar:hover{filter:brightness(1.18)}
.bar-col .x-lbl{font-size:10px;color:#3d4455;font-weight:500;white-space:nowrap}
.chart-tip{position:absolute;background:var(--surface2);border:1px solid var(--line);border-radius:5px;padding:6px 11px;font-size:12px;font-weight:500;color:var(--text);pointer-events:none;opacity:0;transition:opacity 0.15s;z-index:10;white-space:nowrap}

/* ── USAGE GRID: ACTIVITY + SPEND SCATTER CHARTS ── */
.usage-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:20px}
@media (max-width:980px){.usage-grid{grid-template-columns:1fr}}
.usage-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 26px;display:flex;flex-direction:column;min-width:0}
.chart-panel .chart-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.chart-panel .chart-title{font-size:18px;font-weight:600;color:var(--text);letter-spacing:-0.2px}
.chart-panel .chart-sub{font-size:11px;color:var(--grey);font-weight:500}
.chart-panel .usage-chart{width:100%;height:auto;display:block;cursor:default}
.chart-panel .usage-chart circle{transition:r 0.12s,filter 0.12s}
.chart-panel .usage-chart circle:hover{filter:brightness(1.25)}
.chart-legend{margin-top:6px;display:flex;justify-content:center;gap:22px;font-size:13px;color:var(--text);font-weight:500}
.chart-legend .lg-item{display:inline-flex;align-items:center;gap:7px}
.chart-legend .lg-dot{width:9px;height:9px;border-radius:50%;display:inline-block}

/* ── ACTIVITY TABLE ── */
.act-table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.act-table{width:100%;border-collapse:collapse}
.act-table th{font-size:11px;font-weight:600;color:var(--grey);text-transform:uppercase;letter-spacing:0.8px;padding:13px 20px;text-align:left;border-bottom:1px solid var(--line);background:var(--bg2)}
.act-table td{padding:12px 20px;font-size:13px;border-bottom:1px solid rgba(40,40,40,0.55);color:var(--text);transition:background 0.12s}
.act-table tr:last-child td{border-bottom:none}
.act-table tr:hover td{background:var(--surface2)}
.type-pill{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;letter-spacing:0.3px}
.type-pill.analysis{background:rgba(20,184,166,0.1);color:var(--green)}
.type-pill.review{background:rgba(55,167,231,0.1);color:var(--blue)}
.type-pill.grounding{background:rgba(245,158,11,0.1);color:var(--warn)}
.td-file{color:var(--grey);font-size:12px;font-family:'Courier New',monospace}
.td-time{color:var(--grey);font-size:12px}
.td-tok{color:var(--green);font-size:12px;font-weight:600}

/* ── LICENCE TAB ── */
.plans-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.plan-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;position:relative;overflow:hidden;transition:border-color 0.2s}
.plan-card.active{border-color:var(--green);background:linear-gradient(155deg,rgba(20,184,166,0.05) 0%,var(--surface) 55%)}
.plan-card.active::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#4ade80,#2dd4bf,#22d3ee)}
.plan-card:not(.active):hover{border-color:rgba(255,255,255,0.1)}
.plan-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.plan-name{font-size:18px;font-weight:700;color:var(--text)}
.plan-cur-tag{font-size:10px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;background:var(--green);color:#080C16;padding:3px 10px;border-radius:20px}
.plan-price{font-size:32px;font-weight:700;color:var(--text);letter-spacing:-1px;margin-bottom:3px}
.plan-price sub{font-size:13px;font-weight:400;color:var(--grey);vertical-align:baseline;letter-spacing:0}
.plan-period{font-size:13px;color:var(--grey);margin-bottom:20px}
.plan-features{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.plan-features li{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--grey)}
.feat-y{color:var(--green);flex-shrink:0;margin-top:1px}
.feat-n{color:#333;flex-shrink:0;margin-top:1px}
.btn-plan{width:100%;padding:11px 20px;font-family:var(--font);font-size:13px;font-weight:600;border-radius:var(--r);cursor:pointer;transition:all 0.2s;letter-spacing:0.2px}
.btn-plan.upgrade{background:var(--green);color:#080C16;border:none}
.btn-plan.upgrade:hover{background:#1dd1be;transform:translateY(-1px);box-shadow:0 6px 18px rgba(20,184,166,0.25)}
.btn-plan.current{background:transparent;color:var(--green);border:1px solid var(--green-b);cursor:default}
.btn-plan.downgrade{background:transparent;color:var(--grey);border:1px solid var(--line)}
.btn-plan.downgrade:hover{border-color:var(--danger);color:var(--danger)}

/* ── LICENCE DETAILS TABLE ── */
.lic-block{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:20px}
.lic-block-title{padding:14px 24px;font-size:13px;font-weight:600;color:var(--text);border-bottom:1px solid var(--line);background:var(--bg2);display:flex;align-items:center;justify-content:space-between}
.lic-table{width:100%;border-collapse:collapse}
.lic-table th{padding:12px 24px;font-size:11px;font-weight:600;color:var(--grey);text-transform:uppercase;letter-spacing:0.8px;border-bottom:1px solid rgba(40,40,40,0.55);text-align:left}
.lic-table td{padding:12px 24px;font-size:13px;border-bottom:1px solid rgba(40,40,40,0.55);color:var(--text);vertical-align:middle;transition:background 0.12s}
.lic-table tr:last-child td{border-bottom:none}
.lic-table tr:hover td{background:var(--surface2)}
.lic-table td:first-child{font-size:11px;font-weight:600;color:var(--grey);text-transform:uppercase;letter-spacing:0.8px;width:180px}
#billing-history-table td:first-child{font-size:13px;font-weight:400;color:var(--text);text-transform:none;letter-spacing:0;width:auto}
.lic-val{font-size:13px;font-weight:500;color:var(--text)}
.lic-val.green{color:var(--green)}
.lic-val.mono{font-size:12px;letter-spacing:0.4px;color:var(--grey);font-family:'Courier New',monospace}
.bill-row{display:flex;align-items:center;gap:14px;padding:12px 24px;border-bottom:1px solid rgba(40,40,40,0.55);transition:background 0.12s}
.bill-row:last-child{border-bottom:none}
.bill-row:hover{background:var(--surface2)}
.bill-date{font-size:12px;color:var(--grey);min-width:92px}
.bill-desc{flex:1;font-size:13px;color:var(--grey)}
.bill-amount{font-size:13px;font-weight:600;color:var(--text);min-width:56px;text-align:right}
.bill-status{font-size:10px;font-weight:600;letter-spacing:0.5px;text-transform:uppercase;padding:2px 9px;border-radius:20px}
.bill-status.paid{background:var(--green-dim);color:var(--green)}
.bill-pdf{font-size:12px;color:var(--grey);cursor:pointer;background:none;border:none;font-family:var(--font);text-decoration:underline;text-decoration-style:dotted}
.bill-pdf:hover{color:var(--green)}
.btn-text-link{background:none;border:none;cursor:pointer;font-size:12px;color:var(--green);font-family:var(--font);padding:0;text-decoration:underline;text-decoration-style:dotted}
.btn-text-link:hover{opacity:0.7}

/* ══════════════════════════════════════════
   COMPANY ADMIN TAB
══════════════════════════════════════════ */
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:24px}
.admin-stat{background:var(--surface);padding:20px 22px;transition:background 0.15s}
.admin-stat:hover{background:var(--surface2)}
.admin-stat .as-label{font-size:11px;font-weight:600;color:var(--grey);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:8px}
.admin-stat .as-val{font-size:28px;font-weight:700;color:var(--text);letter-spacing:-1px;line-height:1}
.admin-stat .as-sub{font-size:12px;color:var(--grey);margin-top:4px}
.admin-stat .as-val.green{color:var(--green)}
.admin-stat .as-val.blue{color:var(--blue)}
.admin-stat .as-val.warn{color:var(--warn)}

.users-table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:24px}
.users-table{width:100%;border-collapse:collapse}
.users-table th{font-size:11px;font-weight:600;color:var(--grey);text-transform:uppercase;letter-spacing:0.8px;padding:13px 20px;text-align:left;border-bottom:1px solid var(--line);background:var(--bg2)}
.users-table td{padding:13px 20px;font-size:13px;border-bottom:1px solid rgba(40,40,40,0.55);color:var(--text);vertical-align:middle;transition:background 0.12s}
.users-table tr:last-child td{border-bottom:none}
.users-table tr:hover td{background:var(--surface2)}
.user-avatar-sm{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.user-avatar-sm.green{background:rgba(20,184,166,0.15);color:var(--green)}
.user-avatar-sm.blue{background:rgba(55,167,231,0.15);color:var(--blue)}
.user-avatar-sm.grey{background:rgba(156,154,154,0.15);color:var(--grey)}
.user-cell{display:flex;align-items:center;gap:10px}
.user-name-email .un{font-size:13px;font-weight:500;color:var(--text)}
.user-name-email .ue{font-size:11px;color:var(--grey)}
.role-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 9px;border-radius:20px;letter-spacing:0.3px}
.role-badge.admin{background:rgba(55,167,231,0.1);color:var(--blue)}
.role-badge.user{background:rgba(156,154,154,0.1);color:var(--grey)}
.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:5px}
.status-dot.active{background:var(--green)}
.status-dot.pending{background:var(--warn)}
.status-dot.inactive{background:#3a3a3a}
.td-actions{display:flex;align-items:center;gap:6px}

/* ── ADD USER / MODAL ── */
.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(8,12,22,0.85);display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:0;width:100%;max-width:500px;position:relative;overflow:hidden}
.modal-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#4ade80,#2dd4bf,#22d3ee);opacity:0.65}
.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:700;color:var(--text)}
.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--line);border-radius:6px;cursor:pointer;color:var(--grey);font-size:16px;font-family:var(--font);transition:all 0.15s}
.modal-close:hover{border-color:var(--danger);color:var(--danger)}
.modal-body{padding:22px 24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:flex-end;gap:10px}
.permission-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}
.perm-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--grey);cursor:pointer;padding:8px 10px;border:1px solid var(--line);border-radius:var(--r);transition:all 0.15s}
.perm-check:hover{border-color:rgba(255,255,255,0.12);color:var(--text)}
.perm-check input[type="checkbox"]{width:14px;height:14px;accent-color:var(--green)}

/* ── COST SUMMARY ── */
.cost-banner{background:linear-gradient(90deg,rgba(20,184,166,0.08),rgba(55,167,231,0.06));border:1px solid var(--green-b);border-radius:var(--r-lg);padding:16px 22px;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.cost-banner .cb-label{font-size:12px;color:var(--grey)}
.cost-banner .cb-val{font-size:22px;font-weight:700;color:var(--green);letter-spacing:-0.5px}
.cost-banner .cb-note{font-size:11px;color:var(--grey)}

/* ── RESPONSIVE ── */
@media(max-width:700px){
  .site-nav{padding:0 18px}
  .dash-hero{padding:28px 18px 22px}
  .tabs-nav{padding:0 18px;overflow-x:auto}
  .tab-panel{padding:20px 18px}
  .metrics-row{grid-template-columns:1fr}
  .plans-grid{grid-template-columns:1fr}
  .admin-stats{grid-template-columns:1fr 1fr}
  .form-row-2{grid-template-columns:1fr}
  .auth-page{padding:90px 14px 40px}
  .auth-wrap{max-width:100%}
}

/* Google button — outline variant for dark UI */
.btn-google-outline{
    width:100%;display:flex;align-items:center;justify-content:center;gap:10px;
    padding:12px 20px;
    background:transparent;
    color:var(--text);
    font-family:var(--font);font-size:14px;font-weight:500;
    border:1.5px solid rgba(255,255,255,0.18);
    border-radius:var(--r);cursor:pointer;
    letter-spacing:0.1px;
    transition:border-color 0.2s,background 0.2s;
}
.btn-google-outline:hover{
    border-color:rgba(255,255,255,0.35);
    background:rgba(255,255,255,0.04);
}
/* ── UNIFIED SIGN-IN CARD ── */
/* Sign In: green outline — same weight/shape as company admin but green */
.btn-signin-outline-green{
    width:100%;padding:12px 20px;
    background:transparent;color:var(--green);
    font-family:var(--font);font-size:14px;font-weight:600;
    border:1.5px solid rgba(20,184,166,0.45);border-radius:var(--r);cursor:pointer;
    letter-spacing:0.2px;
    transition:all 0.2s;
    margin-bottom:10px;
}
.btn-signin-outline-green:hover{
    border-color:var(--green);
    background:var(--green-dim);
    box-shadow:0 0 0 3px rgba(20,184,166,0.1);
}
/* Company admin: blue outline */
.btn-signin-company{
    width:100%;padding:11px 20px;
    background:transparent;color:var(--blue);
    font-family:var(--font);font-size:13px;font-weight:500;
    border:1.5px solid rgba(55,167,231,0.35);border-radius:var(--r);cursor:pointer;
    letter-spacing:0.2px;
    transition:all 0.2s;
}
.btn-signin-company:hover{
    border-color:var(--blue);
    background:var(--blue-dim);
}
/* New account — prominent launch banner */
.signin-new-account{
    margin-top:22px;
    padding-top:20px;
    border-top:1px solid rgba(255,255,255,0.07);
}
.new-account-label{
    font-size:11px;font-weight:700;
    text-transform:uppercase;letter-spacing:1.2px;
    color:var(--green);
    margin-bottom:10px;
    text-align:center;
}
.btn-new-account{
    display:block;
    width:100%;padding:14px 20px;
    background:linear-gradient(90deg,#4ade80,#2dd4bf,#22d3ee);
    color:#080C16;
    font-family:var(--font);font-size:14px;font-weight:700;
    border-radius:var(--r);
    text-align:center;text-decoration:none;
    letter-spacing:0.1px;
    transition:all 0.2s;
    box-shadow:0 4px 20px rgba(34,211,238,0.22);
}
.btn-new-account:hover{
    filter:brightness(1.08);
    transform:translateY(-1px);
    box-shadow:0 8px 28px rgba(34,211,238,0.32);
}
.btn-new-account:active{transform:translateY(0)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.a1{animation:fadeUp 0.44s ease both}
.a2{animation:fadeUp 0.44s ease 0.07s both}
.a3{animation:fadeUp 0.44s ease 0.14s both}
.a4{animation:fadeUp 0.44s ease 0.21s both}
.a5{animation:fadeUp 0.44s ease 0.28s both}
@keyframes slideIn{from{opacity:0;transform:scale(0.96)}to{opacity:1;transform:scale(1)}}
.modal-box{animation:slideIn 0.2s ease}

.form-field input:-webkit-autofill,
.form-field input:-webkit-autofill:hover,
.form-field input:-webkit-autofill:focus,
.form-field input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 1000px #080C16 inset;
    box-shadow: 0 0 0 1000px #080C16 inset;
    -webkit-text-fill-color: #EDEDED;
    caret-color: #EDEDED;
    transition: background-color 600000s ease-in-out 0s, color 600000s ease-in-out 0s;
}
.form-field input:-webkit-autofill::first-line {
    color: #EDEDED;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    font-weight: 400;
}