/* ═══════════════════════════════════════════════
   NOMOS AI — My Wakili
   Stylesheet: nomos-styles.css
   Links to: nomos-index.html
═══════════════════════════════════════════════ */
/* ══════════════════════════════════════════
   NOMOS AI — DESIGN SYSTEM
   Serif: Cormorant Garamond | Sans: DM Sans
   Theme: Dark Navy + Warm Gold + Teal
══════════════════════════════════════════ */
:root{
  --n950:#030d16;--n900:#04121e;--n850:#071828;--n800:#0b2035;
  --n700:#112840;--n600:#1a3a58;--n500:#254d72;--n400:#3a6490;
  --s400:#5a7a95;--s300:#8aa5be;--s200:#b8cdd9;--s100:#e2eaf0;
  --g600:#7a5c0e;--g500:#a8791a;--g400:#c9a84c;--g300:#dfc278;
  --g200:#e8c875;--g100:#f5e7c0;--gg:rgba(201,168,76,.22);
  --t500:#0e7a8c;--t400:#14a3b8;--t300:#4dc4d4;
  --err:#ef4444;--suc:#22c55e;--warn:#f59e0b;
  --surf0:#030d16;--surf1:#060f1a;--surf2:#0b1a27;--surf3:#10212f;--surf4:#162a3a;
  --gb:rgba(255,255,255,.04);--gbord:rgba(255,255,255,.08);
  --gbord-g:rgba(201,168,76,.2);--gsh:0 24px 64px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.05);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --r4:4px;--r8:8px;--r12:12px;--r16:16px;--r20:20px;--r28:28px;--r36:36px;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --spring:cubic-bezier(.34,1.56,.64,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sans);background:var(--surf0);color:var(--s200);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--gg);color:var(--g200)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
input,select,textarea,button{font-family:var(--sans)}
.container{max-width:1200px;margin:0 auto;padding:0 28px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ═══ PAGE ROUTER ═══ */
.page{display:none}
.page.active{display:block}

/* ═══ GLASS ═══ */
.glass{background:var(--gb);border:1px solid var(--gbord);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}

/* ═══════════════════════════
   BUTTONS
═══════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:var(--sans);font-weight:600;transition:all .25s var(--ease);position:relative;overflow:hidden;white-space:nowrap}
.btn-gold{background:linear-gradient(135deg,var(--g400),var(--g200));color:var(--n900);border-radius:var(--r12);padding:12px 26px;font-size:.9rem}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,168,76,.4)}
.btn-gold.lg{padding:16px 36px;font-size:1rem;border-radius:var(--r20)}
.btn-gold.sm{padding:8px 18px;font-size:.82rem;border-radius:var(--r8)}
.btn-outline{background:transparent;color:var(--s200);border:1.5px solid rgba(255,255,255,.18);border-radius:var(--r12);padding:11px 24px;font-size:.9rem}
.btn-outline:hover{border-color:var(--g400);color:var(--g300)}
.btn-outline.lg{padding:15px 34px;font-size:1rem;border-radius:var(--r20)}
.btn-ghost{background:var(--gb);color:var(--s200);border:1px solid var(--gbord);border-radius:var(--r12);padding:11px 22px;font-size:.88rem;backdrop-filter:blur(12px)}
.btn-ghost:hover{border-color:var(--g400);color:var(--g300)}
.btn-danger{background:rgba(239,68,68,.15);color:var(--err);border:1px solid rgba(239,68,68,.3);border-radius:var(--r8);padding:9px 18px;font-size:.85rem}
.btn-danger:hover{background:rgba(239,68,68,.25)}
.btn-teal{background:linear-gradient(135deg,var(--t500),var(--t400));color:#fff;border-radius:var(--r12);padding:12px 24px;font-size:.9rem}
.btn-teal:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(14,122,140,.4)}
.btn-full{width:100%;justify-content:center}

/* ═══════════════════════════
   NAVBAR
═══════════════════════════ */
#navbar{position:fixed;top:0;left:0;right:0;z-index:900;height:68px;display:flex;align-items:center;padding:0 clamp(16px,4vw,48px);background:rgba(3,13,22,.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.06);gap:28px;transition:box-shadow .3s}
#navbar.scrolled{box-shadow:0 8px 40px rgba(0,0,0,.5)}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;cursor:pointer}
.logo-shield{width:36px;height:36px;border-radius:var(--r8);background:linear-gradient(135deg,var(--g400),var(--g600));display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.logo-wordmark{font-family:var(--sans);font-size:1.15rem;font-weight:700;color:#fff;letter-spacing:-.01em}
.logo-wordmark em{color:var(--g400);font-style:normal}
.nav-links{display:flex;list-style:none;gap:2px;flex:1}
.nav-link-item a{display:block;color:var(--s300);font-size:.88rem;font-weight:500;padding:8px 14px;border-radius:var(--r8);transition:all .2s}
.nav-link-item a:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{display:block;width:22px;height:2px;background:var(--s300);border-radius:2px;transition:all .25s}

/* ═══════════════════════════
   COMMAND BAR
═══════════════════════════ */
.cmd-bar-btn{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r8);padding:7px 14px;color:var(--s400);font-size:.8rem;cursor:pointer;transition:all .2s}
.cmd-bar-btn:hover{border-color:var(--g400);color:var(--s200)}
.cmd-bar-btn kbd{background:var(--surf3);border:1px solid var(--gbord);border-radius:4px;padding:1px 6px;font-size:.7rem}
.cmd-overlay{position:fixed;inset:0;z-index:1100;background:rgba(3,13,22,.85);backdrop-filter:blur(8px);display:none;align-items:flex-start;justify-content:center;padding-top:10vh}
.cmd-overlay.open{display:flex}
.cmd-box{width:100%;max-width:620px;margin:0 24px;background:var(--surf2);border:1px solid var(--gbord-g);border-radius:var(--r28);overflow:hidden;box-shadow:0 40px 80px rgba(0,0,0,.7);animation:cmdIn .2s var(--spring)}
@keyframes cmdIn{from{transform:translateY(-16px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.cmd-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--gbord)}
.cmd-head input{flex:1;background:transparent;border:none;outline:none;font-size:.98rem;color:#fff;font-family:var(--sans)}
.cmd-head input::placeholder{color:var(--s400)}
.cmd-esc{background:var(--surf3);border:1px solid var(--gbord);color:var(--s400);font-size:.72rem;padding:3px 8px;border-radius:5px;cursor:pointer}
.cmd-body{padding:8px;max-height:380px;overflow-y:auto}
.cmd-sec{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--s400);font-weight:600;padding:10px 12px 6px}
.cmd-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r8);cursor:pointer;font-size:.88rem;color:var(--s200);transition:background .15s}
.cmd-row:hover,.cmd-row.focused{background:rgba(201,168,76,.08);color:#fff}
.cmd-row-ico{width:28px;height:28px;border-radius:var(--r8);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.cmd-foot{display:flex;gap:16px;padding:10px 20px;border-top:1px solid var(--gbord)}
.cmd-foot span{font-size:.7rem;color:var(--s400)}

/* ═══════════════════════════
   LANDING — HERO
═══════════════════════════ */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding:100px 0 80px}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(201,168,76,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.035) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 90% 90% at 50% 40%,#000 0%,transparent 70%)}
.hero-glow{position:absolute;border-radius:50%;filter:blur(90px)}
.hg1{width:700px;height:700px;top:-150px;right:-150px;background:radial-gradient(circle,rgba(37,77,114,.35) 0%,transparent 70%)}
.hg2{width:450px;height:450px;bottom:-80px;left:-120px;background:radial-gradient(circle,rgba(14,122,140,.2) 0%,transparent 70%)}
.hg3{width:280px;height:280px;top:45%;left:40%;background:radial-gradient(circle,rgba(201,168,76,.07) 0%,transparent 70%)}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.hero-eyebrow{display:flex;align-items:center;gap:10px;font-size:.75rem;font-weight:600;color:var(--s400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:22px}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--suc);box-shadow:0 0 0 0 rgba(34,197,94,.5);animation:lp 2s ease-out infinite;flex-shrink:0}
.live-dot.sm{width:6px;height:6px}
@keyframes lp{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.hero-title{font-family:var(--serif);font-size:clamp(2.8rem,5vw,5.2rem);font-weight:700;color:#fff;line-height:1.06;letter-spacing:-.02em;margin-bottom:22px}
.hero-title .line2{color:var(--g400);text-shadow:0 0 40px rgba(201,168,76,.3)}
.hero-title .line3{font-style:italic;color:var(--s100)}
.hero-sub{font-size:1.02rem;color:var(--s400);line-height:1.8;max-width:460px;margin-bottom:36px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.hero-trust{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.ht-stat strong{display:block;font-size:1.35rem;font-weight:700;color:#fff;line-height:1}
.ht-stat span{font-size:.72rem;color:var(--s400);text-transform:uppercase;letter-spacing:.06em}
.ht-div{width:1px;height:30px;background:rgba(255,255,255,.1)}

/* Hero Visual — AI Window */
.hero-visual{position:relative;height:640px;padding-bottom:80px}
.hv-win{position:absolute;inset:0;border-radius:var(--r28);overflow:hidden;animation:flt 7s ease-in-out infinite}
@keyframes flt{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hv-winbar{display:flex;align-items:center;gap:10px;padding:13px 18px;border-bottom:1px solid var(--gbord);background:rgba(255,255,255,.02)}
.win-dots{display:flex;gap:6px}
.win-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.13)}
.win-title-txt{font-size:.8rem;color:var(--s400);flex:1;text-align:center}
.win-status{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--suc);font-weight:600}
.hv-chat{padding:18px;display:flex;flex-direction:column;gap:14px;max-height:380px;overflow:hidden}
.hv-msg{display:flex;gap:10px;align-items:flex-start}
.hv-msg.u{flex-direction:row-reverse}
.hv-av{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700}
.hv-av.ai{background:linear-gradient(135deg,var(--g400),var(--g200));color:var(--n900)}
.hv-av.usr{background:linear-gradient(135deg,var(--n600),var(--n500));color:#fff}
.hv-bub{border-radius:14px;padding:11px 14px;font-size:.8rem;line-height:1.65;max-width:86%}
.hv-bub.ai{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);color:var(--s200);border-top-left-radius:3px}
.hv-bub.usr{background:linear-gradient(135deg,var(--n600),var(--n500));color:#fff;border-top-right-radius:3px}
.hv-cite{margin-top:8px;display:flex;flex-direction:column;gap:4px}
.cite-pill{background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.15);border-radius:6px;padding:5px 10px;font-size:.72rem;color:var(--g300)}
.cite-n{font-weight:700;margin-right:5px}
.hv-str{display:flex;align-items:center;gap:8px;margin-top:8px}
.str-lbl{font-size:.7rem;color:var(--s400);white-space:nowrap}
.str-track{flex:1;height:5px;background:rgba(255,255,255,.09);border-radius:3px;overflow:hidden}
.str-fill{height:100%;background:linear-gradient(90deg,var(--g400),var(--g200));border-radius:3px}
.str-pct{font-size:.72rem;font-weight:700;color:var(--g300)}
.hv-typing{display:flex;gap:10px;align-items:center}
.typing-dots{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:9px 14px;display:flex;gap:4px;align-items:center}
.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--s400);animation:db 1.4s ease-in-out infinite}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes db{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}
.hv-inputbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--gbord);background:rgba(255,255,255,.02)}
.hv-inputbar input{flex:1;background:transparent;border:none;outline:none;font-size:.82rem;color:var(--s300)}
.hv-inputbar input::placeholder{color:var(--s400)}
.hv-send{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--g400),var(--g200));border:none;cursor:pointer;font-size:.8rem;color:var(--n900);font-weight:700;display:flex;align-items:center;justify-content:center}
/* Floating stat */
.hv-badge{position:absolute;bottom:55px;left:-24px;border-radius:var(--r16);padding:13px 16px;display:flex;align-items:center;gap:12px;z-index:2;animation:flt2 5s ease-in-out 1s infinite}
@keyframes flt2{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-10px) rotate(0deg)}}
.hvb-icon{font-size:1.3rem}
.hvb-label{font-size:.7rem;color:var(--s400)}
.hvb-val{font-size:1rem;font-weight:700;color:#fff}
.hvb-trend{font-size:.72rem;color:var(--suc);font-weight:600}
/* Floating doc */
.hv-docbadge{position:absolute;bottom:-42px;right:-16px;border-radius:var(--r16);padding:11px 14px;display:flex;align-items:center;gap:10px;z-index:2;animation:flt3 6s ease-in-out .5s infinite}
@keyframes flt3{0%,100%{transform:translateY(0) rotate(1deg)}50%{transform:translateY(-8px) rotate(0deg)}}
.docb-name{font-size:.78rem;font-weight:600;color:#fff}
.docb-meta{font-size:.7rem;color:var(--s400)}
.docb-chip{font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:20px;background:rgba(251,191,36,.13);color:#fbbf24;border:1px solid rgba(251,191,36,.25);white-space:nowrap}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--s400);font-size:.72rem;letter-spacing:.08em}
.scroll-bar{width:1px;height:36px;background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent);animation:sb 2s ease-in-out infinite}
@keyframes sb{0%,100%{height:18px;opacity:.3}50%{height:36px;opacity:1}}

/* ═══════════════════════════
   TRUST BAND
═══════════════════════════ */
.trust-band{border-top:1px solid var(--gbord);border-bottom:1px solid var(--gbord);background:var(--surf1);padding:18px 0}
.tb-inner{display:flex;flex-direction:column;align-items:center;gap:12px}
.tb-lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--s400);font-weight:600}
.tb-logos{display:flex;gap:28px;flex-wrap:wrap;justify-content:center}
.tb-pill{font-size:.78rem;font-weight:600;color:var(--s400);padding:5px 16px;border:1px solid rgba(255,255,255,.07);border-radius:20px;transition:all .2s;cursor:default}
.tb-pill:hover{border-color:var(--gbord-g);color:var(--g300)}

/* ═══════════════════════════
   SECTIONS
═══════════════════════════ */
.section{padding:104px 0}
.sec-dark{background:var(--surf1)}
.sec-alt{background:var(--surf2)}
.sec-header{text-align:center;max-width:600px;margin:0 auto 68px}
.eyebrow{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--g400);margin-bottom:14px;position:relative;padding-left:18px}
.eyebrow::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:10px;height:1.5px;background:var(--g400)}
.eyebrow.light{color:var(--g300)}
.eyebrow.light::before{background:var(--g300)}
.sec-title{font-family:var(--serif);font-size:clamp(1.9rem,3.2vw,3rem);font-weight:700;color:#fff;line-height:1.15;margin-bottom:14px;letter-spacing:-.01em}
.sec-title em{color:var(--g400);font-style:italic}
.sec-body{font-size:.98rem;color:var(--s400);line-height:1.75}

/* ═══════════════════════════
   FEATURES BENTO
═══════════════════════════ */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bc{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r20);padding:32px;transition:all .3s var(--ease);position:relative;overflow:hidden}
.bc::after{content:'';position:absolute;inset:0;border-radius:var(--r20);background:linear-gradient(135deg,rgba(201,168,76,.04),transparent);opacity:0;transition:opacity .3s}
.bc:hover{border-color:rgba(201,168,76,.22);transform:translateY(-4px);box-shadow:0 20px 48px rgba(0,0,0,.35)}
.bc:hover::after{opacity:1}
.bc.span2{grid-column:span 2}
.bc.dark{background:var(--surf1)}
.bc.accent{background:linear-gradient(135deg,rgba(37,77,114,.35),rgba(14,122,140,.18));border-color:rgba(14,122,140,.28)}
.bc.gold-tint{background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(201,168,76,.02))}
.bc-badge{display:inline-block;background:rgba(201,168,76,.13);border:1px solid rgba(201,168,76,.22);color:var(--g300);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 10px;border-radius:20px;margin-bottom:12px}
.bc-icon{font-size:2rem;margin-bottom:14px}
.bc h3{font-family:var(--serif);font-size:1.45rem;color:#fff;font-weight:600;margin-bottom:10px}
.bc p{font-size:.88rem;color:var(--s400);line-height:1.7;margin-bottom:18px}
.bc-link{font-size:.85rem;font-weight:600;color:var(--g400);display:inline-flex;align-items:center;gap:5px;transition:gap .18s}
.bc-link:hover{gap:10px}

/* ── BENTO SERVICE LOGO ── */
.bc-logo-wrap{display:flex;justify-content:center;align-items:center;margin-bottom:18px;}
.bc-logo-svg{width:52px;height:52px;border-radius:var(--r16);display:flex;align-items:center;justify-content:center;transition:transform .3s var(--ease)}
.bc:hover .bc-logo-svg{transform:scale(1.08) rotate(-3deg)}

/* Court Activations — now in middle row beside Probono Network */
.bc-court-activations{grid-column:2}

/* Secure & Private — centered at bottom row (column 2) */
.bc-secure-centered{grid-column:2}

/* ═══════════════════════════
   USER TYPES
═══════════════════════════ */
.user-types-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ut-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r20);padding:28px;display:flex;flex-direction:column;gap:0;transition:all .3s var(--ease);cursor:pointer}
.ut-card:hover{border-color:rgba(201,168,76,.25);transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.ut-card.active-type{border-color:var(--g400);background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(201,168,76,.02))}
.ut-emoji{font-size:2.2rem;margin-bottom:14px}
.ut-card h4{font-family:var(--serif);font-size:1.2rem;color:#fff;font-weight:600;margin-bottom:12px}
.ut-list{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:24px;flex:1}
.ut-list li{font-size:.82rem;color:var(--s400);padding-left:14px;position:relative}
.ut-list li::before{content:'→';position:absolute;left:0;color:var(--g400);font-size:.75rem}

/* ═══════════════════════════
   STATS STRIP
═══════════════════════════ */
.stats-strip{padding:56px 0;background:var(--surf1);border-top:1px solid var(--gbord);border-bottom:1px solid var(--gbord)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.sc{background:var(--gb);border:1px solid var(--gbord);border-radius:var(--r20);padding:28px;transition:all .3s;position:relative;overflow:hidden}
.sc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--g400),transparent);opacity:0;transition:opacity .3s}
.sc:hover{border-color:rgba(201,168,76,.2);transform:translateY(-3px)}
.sc:hover::before{opacity:1}
.sc-num{font-family:var(--serif);font-size:2.8rem;font-weight:700;color:var(--g400);line-height:1;margin-bottom:6px}
.sc-lbl{font-size:.92rem;font-weight:600;color:#fff;margin-bottom:4px}
.sc-sub{font-size:.78rem;color:var(--s400);margin-bottom:14px}
.sc-bar{height:3px;background:rgba(255,255,255,.07);border-radius:2px;overflow:hidden}
.sc-fill{height:100%;background:linear-gradient(90deg,var(--g400),var(--g200));border-radius:2px;width:0;transition:width 1.5s var(--ease)}

/* ═══════════════════════════
   TESTIMONIALS
═══════════════════════════ */
.testi-wrap{max-width:820px;margin:0 auto}
.testi-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r28);padding:40px;display:none;position:relative;animation:tcIn .5s ease}
@keyframes tcIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.testi-card.visible{display:block}
.testi-card::before{content:'"';font-family:var(--serif);font-size:7rem;color:rgba(201,168,76,.08);position:absolute;top:-10px;left:28px;line-height:1}
.testi-quote{font-family:var(--serif);font-size:1.15rem;font-style:italic;color:var(--s200);line-height:1.8;margin-bottom:28px}
.testi-author{display:flex;align-items:center;gap:14px}
.ta-av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0}
.ta-name{font-size:.92rem;font-weight:700;color:#fff}
.ta-role{font-size:.78rem;color:var(--s400)}
.ta-stars{margin-left:auto;color:var(--g400);letter-spacing:2px;font-size:.85rem}
.testi-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px}
.tn-btn{width:40px;height:40px;border-radius:50%;background:var(--surf2);border:1px solid var(--gbord);color:var(--s300);cursor:pointer;font-size:1rem;transition:all .2s;display:flex;align-items:center;justify-content:center}
.tn-btn:hover{border-color:var(--g400);color:var(--g300)}
.tn-dots{display:flex;gap:8px}
.tn-dot{width:7px;height:7px;border-radius:50%;background:var(--surf4);cursor:pointer;transition:all .2s}
.tn-dot.active{background:var(--g400);width:22px;border-radius:4px}

/* ═══════════════════════════
   HOW IT WORKS
═══════════════════════════ */
.hiw-steps{display:flex;align-items:flex-start;gap:0}
.hiw-step{flex:1;text-align:center;padding:0 20px}
.hiw-num{font-family:var(--serif);font-size:3.5rem;font-weight:700;color:rgba(201,168,76,.1);line-height:1;display:block;margin-bottom:-12px}
.hiw-ico{width:60px;height:60px;border-radius:var(--r16);background:var(--surf3);border:1px solid var(--gbord);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 14px;transition:all .3s}
.hiw-step:hover .hiw-ico{background:rgba(201,168,76,.08);border-color:rgba(201,168,76,.3);transform:scale(1.08)}
.hiw-step h4{font-size:.95rem;font-weight:600;color:#fff;margin-bottom:8px}
.hiw-step p{font-size:.82rem;color:var(--s400);line-height:1.7}
.hiw-conn{display:flex;align-items:center;padding-top:72px;flex-shrink:0}
.hiw-line{width:50px;height:1px;background:linear-gradient(90deg,rgba(201,168,76,.35),rgba(201,168,76,.1))}

/* ═══════════════════════════
   CTA BANNER
═══════════════════════════ */
.cta-section{position:relative;overflow:hidden;padding:104px 0;background:var(--surf1);border-top:1px solid var(--gbord)}
.cta-glow-bg{position:absolute;width:600px;height:600px;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(201,168,76,.055) 0%,transparent 65%);border-radius:50%;pointer-events:none}
.cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.cta-title{font-family:var(--serif);font-size:clamp(2.2rem,3.8vw,3.6rem);color:#fff;line-height:1.1;margin-bottom:14px}
.cta-title em{color:var(--g400);font-style:italic}
.cta-sub{font-size:.98rem;color:var(--s400);margin-bottom:34px;line-height:1.75}
.cta-btns{display:flex;gap:14px;flex-wrap:wrap}
.cta-phone{background:var(--gb);border:1px solid var(--gbord);border-radius:var(--r28);overflow:hidden;max-width:260px;margin:0 auto;animation:flt 6s ease-in-out .5s infinite}
.cp-head{text-align:center;padding:14px;border-bottom:1px solid var(--gbord);font-size:.82rem;font-weight:600;color:var(--g300)}
.cp-chat{padding:14px;display:flex;flex-direction:column;gap:9px}
.cp-bub{padding:9px 13px;border-radius:12px;font-size:.78rem;line-height:1.55;max-width:88%}
.cp-bub.ai{background:rgba(255,255,255,.05);border:1px solid var(--gbord);color:var(--s200)}
.cp-bub.usr{background:linear-gradient(135deg,var(--g400),var(--g200));color:var(--n900);font-weight:500;align-self:flex-end}

/* ═══════════════════════════
   FOOTER
═══════════════════════════ */
footer{background:var(--surf1);border-top:1px solid var(--gbord)}
.foot-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding:68px 0 44px}
.foot-brand .logo-wordmark{font-size:1.1rem}
.foot-brand p{font-size:.85rem;color:var(--s400);line-height:1.7;max-width:250px;margin:14px 0 18px}
.foot-socials{display:flex;gap:10px}
.foot-socials a{width:34px;height:34px;border-radius:var(--r8);border:1px solid var(--gbord);display:flex;align-items:center;justify-content:center;color:var(--s400);font-size:.82rem;transition:all .2s}
.foot-socials a:hover{border-color:var(--g400);color:var(--g300)}
.foot-col h5{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--s400);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-col ul li a{font-size:.85rem;color:var(--s400);transition:color .18s}
.foot-col ul li a:hover{color:var(--g300)}
.foot-bottom{border-top:1px solid var(--gbord);padding:18px 0}
.foot-bottom .container{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.foot-bottom p{font-size:.75rem;color:var(--s400)}
.foot-right{display:flex;gap:20px;font-size:.75rem;color:var(--s400)}

/* ═══════════════════════════════════════════
   AUTH PAGES (Login / Register / User Type)
═══════════════════════════════════════════ */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;position:relative;overflow:hidden;background:var(--surf0)}
.auth-bg-glow{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(37,77,114,.3) 0%,transparent 70%);pointer-events:none}
.auth-bg-glow.r{right:-100px;top:-100px}
.auth-bg-glow.l{left:-100px;bottom:-100px;background:radial-gradient(circle,rgba(14,122,140,.2) 0%,transparent 70%)}
.auth-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r28);padding:44px 40px;width:100%;max-width:480px;position:relative;z-index:1;box-shadow:0 32px 80px rgba(0,0,0,.45)}
.auth-logo{display:flex;justify-content:center;margin-bottom:28px}
.auth-title{font-family:var(--serif);font-size:1.9rem;text-align:center;color:#fff;margin-bottom:6px}
.auth-sub{text-align:center;color:var(--s400);font-size:.88rem;margin-bottom:30px}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--s200);margin-bottom:7px}
.form-input{width:100%;padding:12px 16px;background:var(--surf3);border:1.5px solid var(--gbord);border-radius:var(--r12);color:#fff;font-size:.92rem;transition:border-color .2s;outline:none}
.form-input::placeholder{color:var(--s400)}
.form-input:focus{border-color:var(--g400);background:var(--surf4)}
.form-input.error{border-color:var(--err)!important}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-divider{text-align:center;color:var(--s400);font-size:.8rem;margin:16px 0;position:relative}
.form-divider::before,.form-divider::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:var(--gbord)}
.form-divider::before{left:0}
.form-divider::after{right:0}
.form-link{font-size:.82rem;color:var(--s400);text-align:center;margin-top:16px}
.form-link a{color:var(--g400);font-weight:600}
.form-link a:hover{color:var(--g300)}
.form-check{display:flex;align-items:flex-start;gap:10px;font-size:.82rem;color:var(--s400)}
.form-check input{accent-color:var(--g400);width:14px;height:14px;flex-shrink:0;margin-top:2px}
.forgot-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.forgot-row .form-check{margin-bottom:0}
.forgot-row a{font-size:.8rem;color:var(--g400)}
/* validation error message */
.field-err{font-size:.75rem;color:var(--err);margin-top:4px;display:none}
.field-err.show{display:block}
/* form-level alert */
.form-alert{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:var(--r8);padding:10px 14px;font-size:.82rem;color:var(--err);margin-bottom:16px;display:none}
.form-alert.show{display:block}
/* User type selector */
.utype-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.utype-btn{background:var(--surf3);border:2px solid var(--gbord);border-radius:var(--r12);padding:18px 14px;cursor:pointer;text-align:left;transition:all .2s}
.utype-btn:hover{border-color:rgba(201,168,76,.35);background:rgba(201,168,76,.05)}
.utype-btn.selected{border-color:var(--g400);background:rgba(201,168,76,.08)}
.utype-emoji{font-size:1.6rem;display:block;margin-bottom:8px}
.utype-name{font-size:.88rem;font-weight:700;color:#fff;display:block;margin-bottom:4px}
.utype-desc{font-size:.75rem;color:var(--s400);line-height:1.4}

/* ═══════════════════════════════════════════
   DASHBOARD
═══════════════════════════════════════════ */
.dash-layout{display:flex;min-height:100vh;padding-top:0}
/* Sidebar */
.dash-sidebar{width:256px;flex-shrink:0;background:var(--surf1);border-right:1px solid var(--gbord);position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:100;transition:transform .3s}
.dash-sidebar.collapsed{transform:translateX(-256px)}
.ds-top{padding:20px 16px 12px}
.ds-user-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r12);padding:14px;display:flex;align-items:center;gap:12px;margin-bottom:16px}
.dsu-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--g400),var(--g600));display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:700;color:var(--n900);flex-shrink:0}
.dsu-name{font-size:.88rem;font-weight:700;color:#fff;line-height:1.2}
.dsu-type{font-size:.72rem;color:var(--g400);font-weight:600}
.ds-nav{display:flex;flex-direction:column;gap:2px;padding:0 8px}
.ds-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r8);cursor:pointer;color:var(--s300);font-size:.86rem;font-weight:500;transition:all .18s}
.ds-nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.ds-nav-item.active{background:rgba(201,168,76,.1);color:var(--g300);border:1px solid rgba(201,168,76,.18)}
.ds-nav-icon{width:20px;text-align:center;font-size:.95rem;flex-shrink:0}
.ds-section-lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--s400);padding:14px 20px 6px;font-weight:700}
.ds-bottom{padding:16px;border-top:1px solid var(--gbord);margin-top:auto}
/* Main */
.dash-main{flex:1;margin-left:256px;min-height:100vh;background:var(--surf0)}
.dash-main.full{margin-left:0}
.dash-topbar{height:60px;background:rgba(3,13,22,.9);border-bottom:1px solid var(--gbord);display:flex;align-items:center;padding:0 28px;gap:16px;backdrop-filter:blur(12px);position:sticky;top:0;z-index:50}
.dtb-title{font-weight:700;color:#fff;font-size:.95rem}
.dtb-breadcrumb{font-size:.8rem;color:var(--s400)}
.dtb-spacer{flex:1}
.dtb-actions{display:flex;align-items:center;gap:10px}
.notif-btn{width:36px;height:36px;border-radius:var(--r8);background:var(--surf2);border:1px solid var(--gbord);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;color:var(--s300);transition:all .18s}
.notif-btn:hover{border-color:var(--g400);color:var(--g300)}
.notif-badge{position:absolute;top:-3px;right:-3px;width:16px;height:16px;border-radius:50%;background:var(--err);font-size:.6rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center}
.dash-content{padding:32px 28px}
/* Widgets */
.dash-greeting{margin-bottom:28px}
.dash-greeting h2{font-family:var(--serif);font-size:1.9rem;color:#fff;font-weight:600}
.dash-greeting p{font-size:.88rem;color:var(--s400);margin-top:4px}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px}
.kpi-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r16);padding:22px;position:relative;overflow:hidden;transition:all .25s}
.kpi-card:hover{border-color:rgba(201,168,76,.2);transform:translateY(-2px)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--kpi-color,var(--g400)),transparent);opacity:.8}
.kpi-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--s400);margin-bottom:10px;font-weight:600}
.kpi-num{font-family:var(--serif);font-size:2rem;font-weight:700;color:#fff;line-height:1;margin-bottom:4px}
.kpi-change{font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:4px}
.kpi-up{color:var(--suc)}
.kpi-down{color:var(--err)}
.kpi-icon{position:absolute;top:20px;right:20px;font-size:1.6rem;opacity:.35}
/* Dashboard grid */
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px}
.dash-grid.triple{grid-template-columns:1fr 1fr 1fr}
/* Dash card */
.dash-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r20);overflow:hidden}
.dc-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--gbord)}
.dc-title{font-size:.9rem;font-weight:700;color:#fff}
.dc-action{font-size:.78rem;color:var(--g400);cursor:pointer;font-weight:600}
.dc-action:hover{color:var(--g300)}
.dc-body{padding:18px 22px}
/* Case timeline */
.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:16px;padding-bottom:20px;position:relative}
.tl-item:not(:last-child)::before{content:'';position:absolute;left:15px;top:32px;bottom:0;width:1px;background:var(--gbord)}
.tl-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0;z-index:1;border:2px solid}
.tl-dot.done{background:rgba(34,197,94,.15);border-color:var(--suc);color:var(--suc)}
.tl-dot.active{background:rgba(201,168,76,.15);border-color:var(--g400);color:var(--g400)}
.tl-dot.pending{background:var(--surf3);border-color:var(--gbord);color:var(--s400)}
.tl-content{flex:1;padding-top:4px}
.tl-title{font-size:.85rem;font-weight:600;color:#fff;margin-bottom:3px}
.tl-date{font-size:.75rem;color:var(--s400)}
.tl-note{font-size:.78rem;color:var(--s400);margin-top:4px;line-height:1.5}
/* Doc vault */
.doc-list{display:flex;flex-direction:column;gap:10px}
.doc-row{display:flex;align-items:center;gap:12px;padding:12px;background:var(--surf3);border-radius:var(--r12);border:1px solid var(--gbord);transition:all .18s;cursor:pointer}
.doc-row:hover{border-color:rgba(201,168,76,.2);background:rgba(201,168,76,.04)}
.doc-ico{width:36px;height:36px;border-radius:var(--r8);background:rgba(201,168,76,.1);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.doc-row-name{font-size:.85rem;font-weight:600;color:#fff;margin-bottom:2px}
.doc-row-meta{font-size:.72rem;color:var(--s400)}
.doc-chip{font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:20px;margin-left:auto;white-space:nowrap}
.doc-chip.ok{background:rgba(34,197,94,.12);color:var(--suc);border:1px solid rgba(34,197,94,.25)}
.doc-chip.warn{background:rgba(245,158,11,.12);color:var(--warn);border:1px solid rgba(245,158,11,.25)}
.doc-chip.draft{background:rgba(90,122,149,.12);color:var(--s300);border:1px solid rgba(90,122,149,.25)}
/* Lawyer match */
.match-list{display:flex;flex-direction:column;gap:12px}
.match-card{background:var(--surf3);border:1px solid var(--gbord);border-radius:var(--r16);padding:16px;display:flex;gap:14px;align-items:flex-start;transition:all .2s;cursor:pointer}
.match-card:hover{border-color:rgba(201,168,76,.25);background:rgba(201,168,76,.03)}
.match-av{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff}
.match-name{font-size:.88rem;font-weight:700;color:#fff;margin-bottom:3px}
.match-spec{font-size:.75rem;color:var(--g400);font-weight:600;margin-bottom:4px}
.match-meta{font-size:.75rem;color:var(--s400)}
.match-badge{font-size:.68rem;font-weight:700;padding:4px 9px;border-radius:20px;margin-left:auto;white-space:nowrap;flex-shrink:0}
.match-badge.avail{background:rgba(34,197,94,.12);color:var(--suc);border:1px solid rgba(34,197,94,.2)}
.match-badge.busy{background:rgba(245,158,11,.12);color:var(--warn);border:1px solid rgba(245,158,11,.2)}
/* Quick actions */
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.qa-btn{background:var(--surf3);border:1px solid var(--gbord);border-radius:var(--r12);padding:16px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:all .2s;text-align:left}
.qa-btn:hover{border-color:rgba(201,168,76,.25);transform:translateY(-2px)}
.qa-btn-icon{font-size:1.3rem}
.qa-btn-label{font-size:.82rem;font-weight:600;color:#fff}
.qa-btn-sub{font-size:.72rem;color:var(--s400)}
/* Activity feed */
.activity-feed{display:flex;flex-direction:column;gap:12px}
.af-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--surf3);border-radius:var(--r12);border:1px solid var(--gbord)}
.af-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}
.af-dot.gold{background:var(--g400)}
.af-dot.teal{background:var(--t400)}
.af-dot.green{background:var(--suc)}
.af-dot.red{background:var(--err)}
.af-text{font-size:.82rem;color:var(--s200);line-height:1.5}
.af-time{font-size:.72rem;color:var(--s400);margin-top:2px}
/* Chat widget in dash */
.dash-chat-window{height:420px;display:flex;flex-direction:column}
.dcw-messages{flex:1;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.dcw-msg{display:flex;gap:10px;align-items:flex-start;max-width:88%}
.dcw-msg.u{flex-direction:row-reverse;align-self:flex-end}
.dcw-bub{background:rgba(255,255,255,.05);border:1px solid var(--gbord);border-radius:14px;padding:10px 14px;font-size:.82rem;color:var(--s200);line-height:1.6}
.dcw-bub.user{background:linear-gradient(135deg,var(--n600),var(--n500));color:#fff;border-top-right-radius:3px}
.dcw-bub.ai{border-top-left-radius:3px}
.dcw-footer{padding:12px 16px;border-top:1px solid var(--gbord);display:flex;gap:8px}
.dcw-input{flex:1;background:var(--surf3);border:1.5px solid var(--gbord);border-radius:var(--r12);padding:10px 14px;color:#fff;font-size:.85rem;outline:none;transition:border-color .2s}
.dcw-input:focus{border-color:var(--g400)}
.dcw-input::placeholder{color:var(--s400)}
/* Dashboard tabs */
.dash-tabs{display:flex;gap:4px;border-bottom:1px solid var(--gbord);margin-bottom:24px;overflow-x:auto;padding-bottom:0}
.dash-tab{padding:10px 18px;font-size:.86rem;font-weight:600;color:var(--s400);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:all .18s;margin-bottom:-1px}
.dash-tab.active{color:var(--g400);border-bottom-color:var(--g400)}
.dash-tab:hover{color:var(--s200)}
/* Panel */
.dash-panel{display:none}
.dash-panel.active{display:block}

/* ═══════════════════════════
   MOBILE / RESPONSIVE
═══════════════════════════ */
@media(max-width:1100px){
  .user-types-grid{grid-template-columns:1fr 1fr}
  .dash-sidebar{transform:translateX(-256px)}
  .dash-sidebar.open{transform:translateX(0)}
  .dash-main{margin-left:0}
  .kpi-row{grid-template-columns:1fr 1fr}
  .bento{grid-template-columns:1fr 1fr}
  .bc.span2{grid-column:span 2}
}
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{display:none}
  .hero{min-height:auto;padding:90px 0 60px}
  .cta-inner{grid-template-columns:1fr;text-align:center}
  .cta-btns{justify-content:center}
  .hiw-steps{flex-direction:column;gap:28px;align-items:center}
  .hiw-conn{display:none}
  .stats-row{grid-template-columns:1fr 1fr}
  .foot-inner{grid-template-columns:1fr 1fr;gap:32px}
  .dash-grid{grid-template-columns:1fr}
  .dash-grid.triple{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links,.nav-actions{display:none}
  .hamburger{display:flex}
  .mobile-nav-open .nav-links{display:flex;flex-direction:column;position:absolute;top:68px;left:0;right:0;background:var(--surf1);border-bottom:1px solid var(--gbord);padding:12px 0;gap:0}
  .mobile-nav-open .nav-links li a{padding:12px 24px;font-size:.95rem}
  .mobile-nav-open .nav-actions{display:flex;flex-direction:column;padding:12px 24px;border-top:1px solid var(--gbord);position:absolute;top:calc(68px + (var(--nav-items,5) * 44px));left:0;right:0;background:var(--surf1)}
  #navbar{position:fixed}
  .bento{grid-template-columns:1fr}
  .bc.span2{grid-column:span 1}
  .user-types-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .utype-grid{grid-template-columns:1fr 1fr}
  .kpi-row{grid-template-columns:1fr 1fr}
  .dash-grid.triple{grid-template-columns:1fr}
  .auth-card{padding:32px 24px}
  .stats-row{grid-template-columns:1fr 1fr}
}
@media(max-width:500px){
  .hero-trust{flex-wrap:wrap;gap:12px}
  .kpi-row{grid-template-columns:1fr}
  .user-types-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr}
}

/* ═══════════════════════════
   REVEAL ANIMATIONS
═══════════════════════════ */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].revealed{opacity:1;transform:none}
[data-reveal][data-delay="100"]{transition-delay:.1s}
[data-reveal][data-delay="200"]{transition-delay:.2s}
[data-reveal][data-delay="300"]{transition-delay:.3s}
/* ═══════════════════════════════════════════════
   NOMOS AI — My Wakili
   Stylesheet: nomos-styles.css
   Links to: nomos-index.html
═══════════════════════════════════════════════ */
/* ══════════════════════════════════════════
   NOMOS AI — DESIGN SYSTEM
   Serif: Cormorant Garamond | Sans: DM Sans
   Theme: Dark Navy + Warm Gold + Teal
══════════════════════════════════════════ */
:root{
  --n950:#030d16;--n900:#04121e;--n850:#071828;--n800:#0b2035;
  --n700:#112840;--n600:#1a3a58;--n500:#254d72;--n400:#3a6490;
  --s400:#5a7a95;--s300:#8aa5be;--s200:#b8cdd9;--s100:#e2eaf0;
  --g600:#7a5c0e;--g500:#a8791a;--g400:#c9a84c;--g300:#dfc278;
  --g200:#e8c875;--g100:#f5e7c0;--gg:rgba(201,168,76,.22);
  --t500:#0e7a8c;--t400:#14a3b8;--t300:#4dc4d4;
  --err:#ef4444;--suc:#22c55e;--warn:#f59e0b;
  --surf0:#030d16;--surf1:#060f1a;--surf2:#0b1a27;--surf3:#10212f;--surf4:#162a3a;
  --gb:rgba(255,255,255,.04);--gbord:rgba(255,255,255,.08);
  --gbord-g:rgba(201,168,76,.2);--gsh:0 24px 64px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.05);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --r4:4px;--r8:8px;--r12:12px;--r16:16px;--r20:20px;--r28:28px;--r36:36px;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --spring:cubic-bezier(.34,1.56,.64,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sans);background:var(--surf0);color:var(--s200);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--gg);color:var(--g200)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
input,select,textarea,button{font-family:var(--sans)}
.container{max-width:1200px;margin:0 auto;padding:0 28px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ═══ PAGE ROUTER ═══ */
.page{display:none}
.page.active{display:block}

/* ═══ GLASS ═══ */
.glass{background:var(--gb);border:1px solid var(--gbord);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}

/* ═══════════════════════════
   BUTTONS
═══════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:var(--sans);font-weight:600;transition:all .25s var(--ease);position:relative;overflow:hidden;white-space:nowrap}
.btn-gold{background:linear-gradient(135deg,var(--g400),var(--g200));color:var(--n900);border-radius:var(--r12);padding:12px 26px;font-size:.9rem}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,168,76,.4)}
.btn-gold.lg{padding:16px 36px;font-size:1rem;border-radius:var(--r20)}
.btn-gold.sm{padding:8px 18px;font-size:.82rem;border-radius:var(--r8)}
.btn-outline{background:transparent;color:var(--s200);border:1.5px solid rgba(255,255,255,.18);border-radius:var(--r12);padding:11px 24px;font-size:.9rem}
.btn-outline:hover{border-color:var(--g400);color:var(--g300)}
.btn-outline.lg{padding:15px 34px;font-size:1rem;border-radius:var(--r20)}
.btn-ghost{background:var(--gb);color:var(--s200);border:1px solid var(--gbord);border-radius:var(--r12);padding:11px 22px;font-size:.88rem;backdrop-filter:blur(12px)}
.btn-ghost:hover{border-color:var(--g400);color:var(--g300)}
.btn-danger{background:rgba(239,68,68,.15);color:var(--err);border:1px solid rgba(239,68,68,.3);border-radius:var(--r8);padding:9px 18px;font-size:.85rem}
.btn-danger:hover{background:rgba(239,68,68,.25)}
.btn-teal{background:linear-gradient(135deg,var(--t500),var(--t400));color:#fff;border-radius:var(--r12);padding:12px 24px;font-size:.9rem}
.btn-teal:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(14,122,140,.4)}
.btn-full{width:100%;justify-content:center}

/* ═══════════════════════════
   NAVBAR
═══════════════════════════ */
#navbar{position:fixed;top:0;left:0;right:0;z-index:900;height:68px;display:flex;align-items:center;padding:0 clamp(16px,4vw,48px);background:rgba(3,13,22,.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(255,255,255,.06);gap:28px;transition:box-shadow .3s}
#navbar.scrolled{box-shadow:0 8px 40px rgba(0,0,0,.5)}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;cursor:pointer}
.logo-shield{width:36px;height:36px;border-radius:var(--r8);background:linear-gradient(135deg,var(--g400),var(--g600));display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.logo-wordmark{font-family:var(--sans);font-size:1.15rem;font-weight:700;color:#fff;letter-spacing:-.01em}
.logo-wordmark em{color:var(--g400);font-style:normal}
.nav-links{display:flex;list-style:none;gap:2px;flex:1}
.nav-link-item a{display:block;color:var(--s300);font-size:.88rem;font-weight:500;padding:8px 14px;border-radius:var(--r8);transition:all .2s}
.nav-link-item a:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{display:block;width:22px;height:2px;background:var(--s300);border-radius:2px;transition:all .25s}

/* ═══════════════════════════
   COMMAND BAR
═══════════════════════════ */
.cmd-bar-btn{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r8);padding:7px 14px;color:var(--s400);font-size:.8rem;cursor:pointer;transition:all .2s}
.cmd-bar-btn:hover{border-color:var(--g400);color:var(--s200)}
.cmd-bar-btn kbd{background:var(--surf3);border:1px solid var(--gbord);border-radius:4px;padding:1px 6px;font-size:.7rem}
.cmd-overlay{position:fixed;inset:0;z-index:1100;background:rgba(3,13,22,.85);backdrop-filter:blur(8px);display:none;align-items:flex-start;justify-content:center;padding-top:10vh}
.cmd-overlay.open{display:flex}
.cmd-box{width:100%;max-width:620px;margin:0 24px;background:var(--surf2);border:1px solid var(--gbord-g);border-radius:var(--r28);overflow:hidden;box-shadow:0 40px 80px rgba(0,0,0,.7);animation:cmdIn .2s var(--spring)}
@keyframes cmdIn{from{transform:translateY(-16px) scale(.97);opacity:0}to{transform:none;opacity:1}}
.cmd-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--gbord)}
.cmd-head input{flex:1;background:transparent;border:none;outline:none;font-size:.98rem;color:#fff;font-family:var(--sans)}
.cmd-head input::placeholder{color:var(--s400)}
.cmd-esc{background:var(--surf3);border:1px solid var(--gbord);color:var(--s400);font-size:.72rem;padding:3px 8px;border-radius:5px;cursor:pointer}
.cmd-body{padding:8px;max-height:380px;overflow-y:auto}
.cmd-sec{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--s400);font-weight:600;padding:10px 12px 6px}
.cmd-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r8);cursor:pointer;font-size:.88rem;color:var(--s200);transition:background .15s}
.cmd-row:hover,.cmd-row.focused{background:rgba(201,168,76,.08);color:#fff}
.cmd-row-ico{width:28px;height:28px;border-radius:var(--r8);display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.cmd-foot{display:flex;gap:16px;padding:10px 20px;border-top:1px solid var(--gbord)}
.cmd-foot span{font-size:.7rem;color:var(--s400)}

/* ═══════════════════════════
   LANDING — HERO
═══════════════════════════ */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding:100px 0 80px}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(201,168,76,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,.035) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 90% 90% at 50% 40%,#000 0%,transparent 70%)}
.hero-glow{position:absolute;border-radius:50%;filter:blur(90px)}
.hg1{width:700px;height:700px;top:-150px;right:-150px;background:radial-gradient(circle,rgba(37,77,114,.35) 0%,transparent 70%)}
.hg2{width:450px;height:450px;bottom:-80px;left:-120px;background:radial-gradient(circle,rgba(14,122,140,.2) 0%,transparent 70%)}
.hg3{width:280px;height:280px;top:45%;left:40%;background:radial-gradient(circle,rgba(201,168,76,.07) 0%,transparent 70%)}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.hero-eyebrow{display:flex;align-items:center;gap:10px;font-size:.75rem;font-weight:600;color:var(--s400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:22px}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--suc);box-shadow:0 0 0 0 rgba(34,197,94,.5);animation:lp 2s ease-out infinite;flex-shrink:0}
.live-dot.sm{width:6px;height:6px}
@keyframes lp{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.hero-title{font-family:var(--serif);font-size:clamp(2.8rem,5vw,5.2rem);font-weight:700;color:#fff;line-height:1.06;letter-spacing:-.02em;margin-bottom:22px}
.hero-title .line2{color:var(--g400);text-shadow:0 0 40px rgba(201,168,76,.3)}
.hero-title .line3{font-style:italic;color:var(--s100)}
.hero-sub{font-size:1.02rem;color:var(--s400);line-height:1.8;max-width:460px;margin-bottom:36px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.hero-trust{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.ht-stat strong{display:block;font-size:1.35rem;font-weight:700;color:#fff;line-height:1}
.ht-stat span{font-size:.72rem;color:var(--s400);text-transform:uppercase;letter-spacing:.06em}
.ht-div{width:1px;height:30px;background:rgba(255,255,255,.1)}

/* Hero Visual — AI Window */
.hero-visual{position:relative;height:640px;padding-bottom:80px}
.hv-win{position:absolute;inset:0;border-radius:var(--r28);overflow:hidden;animation:flt 7s ease-in-out infinite}
@keyframes flt{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hv-winbar{display:flex;align-items:center;gap:10px;padding:13px 18px;border-bottom:1px solid var(--gbord);background:rgba(255,255,255,.02)}
.win-dots{display:flex;gap:6px}
.win-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.13)}
.win-title-txt{font-size:.8rem;color:var(--s400);flex:1;text-align:center}
.win-status{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--suc);font-weight:600}
.hv-chat{padding:18px;display:flex;flex-direction:column;gap:14px;max-height:380px;overflow:hidden}
.hv-msg{display:flex;gap:10px;align-items:flex-start}
.hv-msg.u{flex-direction:row-reverse}
.hv-av{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700}
.hv-av.ai{background:linear-gradient(135deg,var(--g400),var(--g200));color:var(--n900)}
.hv-av.usr{background:linear-gradient(135deg,var(--n600),var(--n500));color:#fff}
.hv-bub{border-radius:14px;padding:11px 14px;font-size:.8rem;line-height:1.65;max-width:86%}
.hv-bub.ai{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);color:var(--s200);border-top-left-radius:3px}
.hv-bub.usr{background:linear-gradient(135deg,var(--n600),var(--n500));color:#fff;border-top-right-radius:3px}
.hv-cite{margin-top:8px;display:flex;flex-direction:column;gap:4px}
.cite-pill{background:rgba(201,168,76,.07);border:1px solid rgba(201,168,76,.15);border-radius:6px;padding:5px 10px;font-size:.72rem;color:var(--g300)}
.cite-n{font-weight:700;margin-right:5px}
.hv-str{display:flex;align-items:center;gap:8px;margin-top:8px}
.str-lbl{font-size:.7rem;color:var(--s400);white-space:nowrap}
.str-track{flex:1;height:5px;background:rgba(255,255,255,.09);border-radius:3px;overflow:hidden}
.str-fill{height:100%;background:linear-gradient(90deg,var(--g400),var(--g200));border-radius:3px}
.str-pct{font-size:.72rem;font-weight:700;color:var(--g300)}
.hv-typing{display:flex;gap:10px;align-items:center}
.typing-dots{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:9px 14px;display:flex;gap:4px;align-items:center}
.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--s400);animation:db 1.4s ease-in-out infinite}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes db{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-6px)}}
.hv-inputbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--gbord);background:rgba(255,255,255,.02)}
.hv-inputbar input{flex:1;background:transparent;border:none;outline:none;font-size:.82rem;color:var(--s300)}
.hv-inputbar input::placeholder{color:var(--s400)}
.hv-send{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--g400),var(--g200));border:none;cursor:pointer;font-size:.8rem;color:var(--n900);font-weight:700;display:flex;align-items:center;justify-content:center}
/* Floating stat */
.hv-badge{position:absolute;bottom:55px;left:-24px;border-radius:var(--r16);padding:13px 16px;display:flex;align-items:center;gap:12px;z-index:2;animation:flt2 5s ease-in-out 1s infinite}
@keyframes flt2{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-10px) rotate(0deg)}}
.hvb-icon{font-size:1.3rem}
.hvb-label{font-size:.7rem;color:var(--s400)}
.hvb-val{font-size:1rem;font-weight:700;color:#fff}
.hvb-trend{font-size:.72rem;color:var(--suc);font-weight:600}
/* Floating doc */
.hv-docbadge{position:absolute;bottom:-52px;right:-16px;border-radius:var(--r16);padding:11px 14px;display:flex;align-items:center;gap:10px;z-index:2;animation:flt3 6s ease-in-out .5s infinite}
@keyframes flt3{0%,100%{transform:translateY(0) rotate(1deg)}50%{transform:translateY(-8px) rotate(0deg)}}
.docb-name{font-size:.78rem;font-weight:600;color:#fff}
.docb-meta{font-size:.7rem;color:var(--s400)}
.docb-chip{font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:20px;background:rgba(251,191,36,.13);color:#fbbf24;border:1px solid rgba(251,191,36,.25);white-space:nowrap}
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--s400);font-size:.72rem;letter-spacing:.08em}
.scroll-bar{width:1px;height:36px;background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent);animation:sb 2s ease-in-out infinite}
@keyframes sb{0%,100%{height:18px;opacity:.3}50%{height:36px;opacity:1}}

/* ═══════════════════════════
   TRUST BAND
═══════════════════════════ */
.trust-band{border-top:1px solid var(--gbord);border-bottom:1px solid var(--gbord);background:var(--surf1);padding:18px 0}
.tb-inner{display:flex;flex-direction:column;align-items:center;gap:12px}
.tb-lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--s400);font-weight:600}
.tb-logos{display:flex;gap:28px;flex-wrap:wrap;justify-content:center}
.tb-pill{font-size:.78rem;font-weight:600;color:var(--s400);padding:5px 16px;border:1px solid rgba(255,255,255,.07);border-radius:20px;transition:all .2s;cursor:default}
.tb-pill:hover{border-color:var(--gbord-g);color:var(--g300)}

/* ═══════════════════════════
   SECTIONS
═══════════════════════════ */
.section{padding:104px 0}
.sec-dark{background:var(--surf1)}
.sec-alt{background:var(--surf2)}
.sec-header{text-align:center;max-width:600px;margin:0 auto 68px}
.eyebrow{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--g400);margin-bottom:14px;position:relative;padding-left:18px}
.eyebrow::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:10px;height:1.5px;background:var(--g400)}
.eyebrow.light{color:var(--g300)}
.eyebrow.light::before{background:var(--g300)}
.sec-title{font-family:var(--serif);font-size:clamp(1.9rem,3.2vw,3rem);font-weight:700;color:#fff;line-height:1.15;margin-bottom:14px;letter-spacing:-.01em}
.sec-title em{color:var(--g400);font-style:italic}
.sec-body{font-size:.98rem;color:var(--s400);line-height:1.75}

/* ═══════════════════════════
   FEATURES BENTO
═══════════════════════════ */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.bc{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r20);padding:32px;transition:all .3s var(--ease);position:relative;overflow:hidden}
.bc::after{content:'';position:absolute;inset:0;border-radius:var(--r20);background:linear-gradient(135deg,rgba(201,168,76,.04),transparent);opacity:0;transition:opacity .3s}
.bc:hover{border-color:rgba(201,168,76,.22);transform:translateY(-4px);box-shadow:0 20px 48px rgba(0,0,0,.35)}
.bc:hover::after{opacity:1}
.bc.span2{grid-column:span 2}
.bc.dark{background:var(--surf1)}
.bc.accent{background:linear-gradient(135deg,rgba(37,77,114,.35),rgba(14,122,140,.18));border-color:rgba(14,122,140,.28)}
.bc.gold-tint{background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(201,168,76,.02))}
.bc-badge{display:inline-block;background:rgba(201,168,76,.13);border:1px solid rgba(201,168,76,.22);color:var(--g300);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 10px;border-radius:20px;margin-bottom:12px}
.bc-icon{font-size:2rem;margin-bottom:14px}
.bc h3{font-family:var(--serif);font-size:1.45rem;color:#fff;font-weight:600;margin-bottom:10px}
.bc p{font-size:.88rem;color:var(--s400);line-height:1.7;margin-bottom:18px}
.bc-link{font-size:.85rem;font-weight:600;color:var(--g400);display:inline-flex;align-items:center;gap:5px;transition:gap .18s}
.bc-link:hover{gap:10px}

/* ── BENTO SERVICE LOGO ── */
.bc-logo-wrap{display:flex;justify-content:center;align-items:center;margin-bottom:18px;}
.bc-logo-svg{width:52px;height:52px;border-radius:var(--r16);display:flex;align-items:center;justify-content:center;transition:transform .3s var(--ease)}
.bc:hover .bc-logo-svg{transform:scale(1.08) rotate(-3deg)}

/* ═══════════════════════════
   USER TYPES
═══════════════════════════ */
.user-types-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ut-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r20);padding:28px;display:flex;flex-direction:column;gap:0;transition:all .3s var(--ease);cursor:pointer}
.ut-card:hover{border-color:rgba(201,168,76,.25);transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.ut-card.active-type{border-color:var(--g400);background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(201,168,76,.02))}
.ut-emoji{font-size:2.2rem;margin-bottom:14px}
.ut-card h4{font-family:var(--serif);font-size:1.2rem;color:#fff;font-weight:600;margin-bottom:12px}
.ut-list{list-style:none;display:flex;flex-direction:column;gap:7px;margin-bottom:24px;flex:1}
.ut-list li{font-size:.82rem;color:var(--s400);padding-left:14px;position:relative}
.ut-list li::before{content:'→';position:absolute;left:0;color:var(--g400);font-size:.75rem}

/* ═══════════════════════════
   STATS STRIP
═══════════════════════════ */
.stats-strip{padding:56px 0;background:var(--surf1);border-top:1px solid var(--gbord);border-bottom:1px solid var(--gbord)}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.sc{background:var(--gb);border:1px solid var(--gbord);border-radius:var(--r20);padding:28px;transition:all .3s;position:relative;overflow:hidden}
.sc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--g400),transparent);opacity:0;transition:opacity .3s}
.sc:hover{border-color:rgba(201,168,76,.2);transform:translateY(-3px)}
.sc:hover::before{opacity:1}
.sc-num{font-family:var(--serif);font-size:2.8rem;font-weight:700;color:var(--g400);line-height:1;margin-bottom:6px}
.sc-lbl{font-size:.92rem;font-weight:600;color:#fff;margin-bottom:4px}
.sc-sub{font-size:.78rem;color:var(--s400);margin-bottom:14px}
.sc-bar{height:3px;background:rgba(255,255,255,.07);border-radius:2px;overflow:hidden}
.sc-fill{height:100%;background:linear-gradient(90deg,var(--g400),var(--g200));border-radius:2px;width:0;transition:width 1.5s var(--ease)}

/* ═══════════════════════════
   TESTIMONIALS
═══════════════════════════ */
.testi-wrap{max-width:820px;margin:0 auto}
.testi-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r28);padding:40px;display:none;position:relative;animation:tcIn .5s ease}
@keyframes tcIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.testi-card.visible{display:block}
.testi-card::before{content:'"';font-family:var(--serif);font-size:7rem;color:rgba(201,168,76,.08);position:absolute;top:-10px;left:28px;line-height:1}
.testi-quote{font-family:var(--serif);font-size:1.15rem;font-style:italic;color:var(--s200);line-height:1.8;margin-bottom:28px}
.testi-author{display:flex;align-items:center;gap:14px}
.ta-av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0}
.ta-name{font-size:.92rem;font-weight:700;color:#fff}
.ta-role{font-size:.78rem;color:var(--s400)}
.ta-stars{margin-left:auto;color:var(--g400);letter-spacing:2px;font-size:.85rem}
.testi-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px}
.tn-btn{width:40px;height:40px;border-radius:50%;background:var(--surf2);border:1px solid var(--gbord);color:var(--s300);cursor:pointer;font-size:1rem;transition:all .2s;display:flex;align-items:center;justify-content:center}
.tn-btn:hover{border-color:var(--g400);color:var(--g300)}
.tn-dots{display:flex;gap:8px}
.tn-dot{width:7px;height:7px;border-radius:50%;background:var(--surf4);cursor:pointer;transition:all .2s}
.tn-dot.active{background:var(--g400);width:22px;border-radius:4px}

/* ═══════════════════════════
   HOW IT WORKS
═══════════════════════════ */
.hiw-steps{display:flex;align-items:flex-start;gap:0}
.hiw-step{flex:1;text-align:center;padding:0 20px}
.hiw-num{font-family:var(--serif);font-size:3.5rem;font-weight:700;color:rgba(201,168,76,.1);line-height:1;display:block;margin-bottom:-12px}
.hiw-ico{width:60px;height:60px;border-radius:var(--r16);background:var(--surf3);border:1px solid var(--gbord);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto 14px;transition:all .3s}
.hiw-step:hover .hiw-ico{background:rgba(201,168,76,.08);border-color:rgba(201,168,76,.3);transform:scale(1.08)}
.hiw-step h4{font-size:.95rem;font-weight:600;color:#fff;margin-bottom:8px}
.hiw-step p{font-size:.82rem;color:var(--s400);line-height:1.7}
.hiw-conn{display:flex;align-items:center;padding-top:72px;flex-shrink:0}
.hiw-line{width:50px;height:1px;background:linear-gradient(90deg,rgba(201,168,76,.35),rgba(201,168,76,.1))}

/* ═══════════════════════════
   CTA BANNER
═══════════════════════════ */
.cta-section{position:relative;overflow:hidden;padding:104px 0;background:var(--surf1);border-top:1px solid var(--gbord)}
.cta-glow-bg{position:absolute;width:600px;height:600px;top:50%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(201,168,76,.055) 0%,transparent 65%);border-radius:50%;pointer-events:none}
.cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.cta-title{font-family:var(--serif);font-size:clamp(2.2rem,3.8vw,3.6rem);color:#fff;line-height:1.1;margin-bottom:14px}
.cta-title em{color:var(--g400);font-style:italic}
.cta-sub{font-size:.98rem;color:var(--s400);margin-bottom:34px;line-height:1.75}
.cta-btns{display:flex;gap:14px;flex-wrap:wrap}
.cta-phone{background:var(--gb);border:1px solid var(--gbord);border-radius:var(--r28);overflow:hidden;max-width:260px;margin:0 auto;animation:flt 6s ease-in-out .5s infinite}
.cp-head{text-align:center;padding:14px;border-bottom:1px solid var(--gbord);font-size:.82rem;font-weight:600;color:var(--g300)}
.cp-chat{padding:14px;display:flex;flex-direction:column;gap:9px}
.cp-bub{padding:9px 13px;border-radius:12px;font-size:.78rem;line-height:1.55;max-width:88%}
.cp-bub.ai{background:rgba(255,255,255,.05);border:1px solid var(--gbord);color:var(--s200)}
.cp-bub.usr{background:linear-gradient(135deg,var(--g400),var(--g200));color:var(--n900);font-weight:500;align-self:flex-end}

/* ═══════════════════════════
   FOOTER
═══════════════════════════ */
footer{background:var(--surf1);border-top:1px solid var(--gbord)}
.foot-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding:68px 0 44px}
.foot-brand .logo-wordmark{font-size:1.1rem}
.foot-brand p{font-size:.85rem;color:var(--s400);line-height:1.7;max-width:250px;margin:14px 0 18px}
.foot-socials{display:flex;gap:10px}
.foot-socials a{width:34px;height:34px;border-radius:var(--r8);border:1px solid var(--gbord);display:flex;align-items:center;justify-content:center;color:var(--s400);font-size:.82rem;transition:all .2s}
.foot-socials a:hover{border-color:var(--g400);color:var(--g300)}
.foot-col h5{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--s400);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-col ul li a{font-size:.85rem;color:var(--s400);transition:color .18s}
.foot-col ul li a:hover{color:var(--g300)}
.foot-bottom{border-top:1px solid var(--gbord);padding:18px 0}
.foot-bottom .container{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.foot-bottom p{font-size:.75rem;color:var(--s400)}
.foot-right{display:flex;gap:20px;font-size:.75rem;color:var(--s400)}

/* ═══════════════════════════════════════════
   AUTH PAGES (Login / Register / User Type)
═══════════════════════════════════════════ */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px;position:relative;overflow:hidden;background:var(--surf0)}
.auth-bg-glow{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(37,77,114,.3) 0%,transparent 70%);pointer-events:none}
.auth-bg-glow.r{right:-100px;top:-100px}
.auth-bg-glow.l{left:-100px;bottom:-100px;background:radial-gradient(circle,rgba(14,122,140,.2) 0%,transparent 70%)}
.auth-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r28);padding:44px 40px;width:100%;max-width:480px;position:relative;z-index:1;box-shadow:0 32px 80px rgba(0,0,0,.45)}
.auth-logo{display:flex;justify-content:center;margin-bottom:28px}
.auth-title{font-family:var(--serif);font-size:1.9rem;text-align:center;color:#fff;margin-bottom:6px}
.auth-sub{text-align:center;color:var(--s400);font-size:.88rem;margin-bottom:30px}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--s200);margin-bottom:7px}
.form-input{width:100%;padding:12px 16px;background:var(--surf3);border:1.5px solid var(--gbord);border-radius:var(--r12);color:#fff;font-size:.92rem;transition:border-color .2s;outline:none}
.form-input::placeholder{color:var(--s400)}
.form-input:focus{border-color:var(--g400);background:var(--surf4)}
.form-input.error{border-color:var(--err)!important}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-divider{text-align:center;color:var(--s400);font-size:.8rem;margin:16px 0;position:relative}
.form-divider::before,.form-divider::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:var(--gbord)}
.form-divider::before{left:0}
.form-divider::after{right:0}
.form-link{font-size:.82rem;color:var(--s400);text-align:center;margin-top:16px}
.form-link a{color:var(--g400);font-weight:600}
.form-link a:hover{color:var(--g300)}
.form-check{display:flex;align-items:flex-start;gap:10px;font-size:.82rem;color:var(--s400)}
.form-check input{accent-color:var(--g400);width:14px;height:14px;flex-shrink:0;margin-top:2px}
.forgot-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.forgot-row .form-check{margin-bottom:0}
.forgot-row a{font-size:.8rem;color:var(--g400)}
/* validation error message */
.field-err{font-size:.75rem;color:var(--err);margin-top:4px;display:none}
.field-err.show{display:block}
/* form-level alert */
.form-alert{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:var(--r8);padding:10px 14px;font-size:.82rem;color:var(--err);margin-bottom:16px;display:none}
.form-alert.show{display:block}
/* User type selector */
.utype-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.utype-btn{background:var(--surf3);border:2px solid var(--gbord);border-radius:var(--r12);padding:18px 14px;cursor:pointer;text-align:left;transition:all .2s}
.utype-btn:hover{border-color:rgba(201,168,76,.35);background:rgba(201,168,76,.05)}
.utype-btn.selected{border-color:var(--g400);background:rgba(201,168,76,.08)}
.utype-emoji{font-size:1.6rem;display:block;margin-bottom:8px}
.utype-name{font-size:.88rem;font-weight:700;color:#fff;display:block;margin-bottom:4px}
.utype-desc{font-size:.75rem;color:var(--s400);line-height:1.4}

/* ═══════════════════════════════════════════
   DASHBOARD
═══════════════════════════════════════════ */
.dash-layout{display:flex;min-height:100vh;padding-top:0}
/* Sidebar */
.dash-sidebar{width:256px;flex-shrink:0;background:var(--surf1);border-right:1px solid var(--gbord);position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:100;transition:transform .3s}
.dash-sidebar.collapsed{transform:translateX(-256px)}
.ds-top{padding:20px 16px 12px}
.ds-user-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r12);padding:14px;display:flex;align-items:center;gap:12px;margin-bottom:16px}
.dsu-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--g400),var(--g600));display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:700;color:var(--n900);flex-shrink:0}
.dsu-name{font-size:.88rem;font-weight:700;color:#fff;line-height:1.2}
.dsu-type{font-size:.72rem;color:var(--g400);font-weight:600}
.ds-nav{display:flex;flex-direction:column;gap:2px;padding:0 8px}
.ds-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r8);cursor:pointer;color:var(--s300);font-size:.86rem;font-weight:500;transition:all .18s}
.ds-nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.ds-nav-item.active{background:rgba(201,168,76,.1);color:var(--g300);border:1px solid rgba(201,168,76,.18)}
.ds-nav-icon{width:20px;text-align:center;font-size:.95rem;flex-shrink:0}
.ds-section-lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--s400);padding:14px 20px 6px;font-weight:700}
.ds-bottom{padding:16px;border-top:1px solid var(--gbord);margin-top:auto}
/* Main */
.dash-main{flex:1;margin-left:256px;min-height:100vh;background:var(--surf0)}
.dash-main.full{margin-left:0}
.dash-topbar{height:60px;background:rgba(3,13,22,.9);border-bottom:1px solid var(--gbord);display:flex;align-items:center;padding:0 28px;gap:16px;backdrop-filter:blur(12px);position:sticky;top:0;z-index:50}
.dtb-title{font-weight:700;color:#fff;font-size:.95rem}
.dtb-breadcrumb{font-size:.8rem;color:var(--s400)}
.dtb-spacer{flex:1}
.dtb-actions{display:flex;align-items:center;gap:10px}
.notif-btn{width:36px;height:36px;border-radius:var(--r8);background:var(--surf2);border:1px solid var(--gbord);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;color:var(--s300);transition:all .18s}
.notif-btn:hover{border-color:var(--g400);color:var(--g300)}
.notif-badge{position:absolute;top:-3px;right:-3px;width:16px;height:16px;border-radius:50%;background:var(--err);font-size:.6rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center}
.dash-content{padding:32px 28px}
/* Widgets */
.dash-greeting{margin-bottom:28px}
.dash-greeting h2{font-family:var(--serif);font-size:1.9rem;color:#fff;font-weight:600}
.dash-greeting p{font-size:.88rem;color:var(--s400);margin-top:4px}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:28px}
.kpi-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r16);padding:22px;position:relative;overflow:hidden;transition:all .25s}
.kpi-card:hover{border-color:rgba(201,168,76,.2);transform:translateY(-2px)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--kpi-color,var(--g400)),transparent);opacity:.8}
.kpi-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--s400);margin-bottom:10px;font-weight:600}
.kpi-num{font-family:var(--serif);font-size:2rem;font-weight:700;color:#fff;line-height:1;margin-bottom:4px}
.kpi-change{font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:4px}
.kpi-up{color:var(--suc)}
.kpi-down{color:var(--err)}
.kpi-icon{position:absolute;top:20px;right:20px;font-size:1.6rem;opacity:.35}
/* Dashboard grid */
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px}
.dash-grid.triple{grid-template-columns:1fr 1fr 1fr}
/* Dash card */
.dash-card{background:var(--surf2);border:1px solid var(--gbord);border-radius:var(--r20);overflow:hidden}
.dc-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--gbord)}
.dc-title{font-size:.9rem;font-weight:700;color:#fff}
.dc-action{font-size:.78rem;color:var(--g400);cursor:pointer;font-weight:600}
.dc-action:hover{color:var(--g300)}
.dc-body{padding:18px 22px}
/* Case timeline */
.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:16px;padding-bottom:20px;position:relative}
.tl-item:not(:last-child)::before{content:'';position:absolute;left:15px;top:32px;bottom:0;width:1px;background:var(--gbord)}
.tl-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0;z-index:1;border:2px solid}
.tl-dot.done{background:rgba(34,197,94,.15);border-color:var(--suc);color:var(--suc)}
.tl-dot.active{background:rgba(201,168,76,.15);border-color:var(--g400);color:var(--g400)}
.tl-dot.pending{background:var(--surf3);border-color:var(--gbord);color:var(--s400)}
.tl-content{flex:1;padding-top:4px}
.tl-title{font-size:.85rem;font-weight:600;color:#fff;margin-bottom:3px}
.tl-date{font-size:.75rem;color:var(--s400)}
.tl-note{font-size:.78rem;color:var(--s400);margin-top:4px;line-height:1.5}
/* Doc vault */
.doc-list{display:flex;flex-direction:column;gap:10px}
.doc-row{display:flex;align-items:center;gap:12px;padding:12px;background:var(--surf3);border-radius:var(--r12);border:1px solid var(--gbord);transition:all .18s;cursor:pointer}
.doc-row:hover{border-color:rgba(201,168,76,.2);background:rgba(201,168,76,.04)}
.doc-ico{width:36px;height:36px;border-radius:var(--r8);background:rgba(201,168,76,.1);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.doc-row-name{font-size:.85rem;font-weight:600;color:#fff;margin-bottom:2px}
.doc-row-meta{font-size:.72rem;color:var(--s400)}
.doc-chip{font-size:.68rem;font-weight:700;padding:3px 8px;border-radius:20px;margin-left:auto;white-space:nowrap}
.doc-chip.ok{background:rgba(34,197,94,.12);color:var(--suc);border:1px solid rgba(34,197,94,.25)}
.doc-chip.warn{background:rgba(245,158,11,.12);color:var(--warn);border:1px solid rgba(245,158,11,.25)}
.doc-chip.draft{background:rgba(90,122,149,.12);color:var(--s300);border:1px solid rgba(90,122,149,.25)}
/* Lawyer match */
.match-list{display:flex;flex-direction:column;gap:12px}
.match-card{background:var(--surf3);border:1px solid var(--gbord);border-radius:var(--r16);padding:16px;display:flex;gap:14px;align-items:flex-start;transition:all .2s;cursor:pointer}
.match-card:hover{border-color:rgba(201,168,76,.25);background:rgba(201,168,76,.03)}
.match-av{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff}
.match-name{font-size:.88rem;font-weight:700;color:#fff;margin-bottom:3px}
.match-spec{font-size:.75rem;color:var(--g400);font-weight:600;margin-bottom:4px}
.match-meta{font-size:.75rem;color:var(--s400)}
.match-badge{font-size:.68rem;font-weight:700;padding:4px 9px;border-radius:20px;margin-left:auto;white-space:nowrap;flex-shrink:0}
.match-badge.avail{background:rgba(34,197,94,.12);color:var(--suc);border:1px solid rgba(34,197,94,.2)}
.match-badge.busy{background:rgba(245,158,11,.12);color:var(--warn);border:1px solid rgba(245,158,11,.2)}
/* Quick actions */
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.qa-btn{background:var(--surf3);border:1px solid var(--gbord);border-radius:var(--r12);padding:16px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:all .2s;text-align:left}
.qa-btn:hover{border-color:rgba(201,168,76,.25);transform:translateY(-2px)}
.qa-btn-icon{font-size:1.3rem}
.qa-btn-label{font-size:.82rem;font-weight:600;color:#fff}
.qa-btn-sub{font-size:.72rem;color:var(--s400)}
/* Activity feed */
.activity-feed{display:flex;flex-direction:column;gap:12px}
.af-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--surf3);border-radius:var(--r12);border:1px solid var(--gbord)}
.af-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}
.af-dot.gold{background:var(--g400)}
.af-dot.teal{background:var(--t400)}
.af-dot.green{background:var(--suc)}
.af-dot.red{background:var(--err)}
.af-text{font-size:.82rem;color:var(--s200);line-height:1.5}
.af-time{font-size:.72rem;color:var(--s400);margin-top:2px}
/* Chat widget in dash */
.dash-chat-window{height:420px;display:flex;flex-direction:column}
.dcw-messages{flex:1;padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.dcw-msg{display:flex;gap:10px;align-items:flex-start;max-width:88%}
.dcw-msg.u{flex-direction:row-reverse;align-self:flex-end}
.dcw-bub{background:rgba(255,255,255,.05);border:1px solid var(--gbord);border-radius:14px;padding:10px 14px;font-size:.82rem;color:var(--s200);line-height:1.6}
.dcw-bub.user{background:linear-gradient(135deg,var(--n600),var(--n500));color:#fff;border-top-right-radius:3px}
.dcw-bub.ai{border-top-left-radius:3px}
.dcw-footer{padding:12px 16px;border-top:1px solid var(--gbord);display:flex;gap:8px}
.dcw-input{flex:1;background:var(--surf3);border:1.5px solid var(--gbord);border-radius:var(--r12);padding:10px 14px;color:#fff;font-size:.85rem;outline:none;transition:border-color .2s}
.dcw-input:focus{border-color:var(--g400)}
.dcw-input::placeholder{color:var(--s400)}
/* Dashboard tabs */
.dash-tabs{display:flex;gap:4px;border-bottom:1px solid var(--gbord);margin-bottom:24px;overflow-x:auto;padding-bottom:0}
.dash-tab{padding:10px 18px;font-size:.86rem;font-weight:600;color:var(--s400);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;transition:all .18s;margin-bottom:-1px}
.dash-tab.active{color:var(--g400);border-bottom-color:var(--g400)}
.dash-tab:hover{color:var(--s200)}
/* Panel */
.dash-panel{display:none}
.dash-panel.active{display:block}

/* ═══════════════════════════
   MOBILE / RESPONSIVE
═══════════════════════════ */
@media(max-width:1100px){
  .user-types-grid{grid-template-columns:1fr 1fr}
  .dash-sidebar{transform:translateX(-256px)}
  .dash-sidebar.open{transform:translateX(0)}
  .dash-main{margin-left:0}
  .kpi-row{grid-template-columns:1fr 1fr}
  .bento{grid-template-columns:1fr 1fr}
  .bc.span2{grid-column:span 2}
}
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{display:none}
  .hero{min-height:auto;padding:90px 0 60px}
  .cta-inner{grid-template-columns:1fr;text-align:center}
  .cta-btns{justify-content:center}
  .hiw-steps{flex-direction:column;gap:28px;align-items:center}
  .hiw-conn{display:none}
  .stats-row{grid-template-columns:1fr 1fr}
  .foot-inner{grid-template-columns:1fr 1fr;gap:32px}
  .dash-grid{grid-template-columns:1fr}
  .dash-grid.triple{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links,.nav-actions{display:none}
  .hamburger{display:flex}
  .mobile-nav-open .nav-links{display:flex;flex-direction:column;position:absolute;top:68px;left:0;right:0;background:var(--surf1);border-bottom:1px solid var(--gbord);padding:12px 0;gap:0}
  .mobile-nav-open .nav-links li a{padding:12px 24px;font-size:.95rem}
  .mobile-nav-open .nav-actions{display:flex;flex-direction:column;padding:12px 24px;border-top:1px solid var(--gbord);position:absolute;top:calc(68px + (var(--nav-items,5) * 44px));left:0;right:0;background:var(--surf1)}
  #navbar{position:fixed}
  .bento{grid-template-columns:1fr}
  .bc.span2{grid-column:span 1}
  .user-types-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .utype-grid{grid-template-columns:1fr 1fr}
  .kpi-row{grid-template-columns:1fr 1fr}
  .dash-grid.triple{grid-template-columns:1fr}
  .auth-card{padding:32px 24px}
  .stats-row{grid-template-columns:1fr 1fr}
}
@media(max-width:500px){
  .hero-trust{flex-wrap:wrap;gap:12px}
  .kpi-row{grid-template-columns:1fr}
  .user-types-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr}
}

/* ═══════════════════════════
   REVEAL ANIMATIONS
═══════════════════════════ */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].revealed{opacity:1;transform:none}
[data-reveal][data-delay="100"]{transition-delay:.1s}
[data-reveal][data-delay="200"]{transition-delay:.2s}
[data-reveal][data-delay="300"]{transition-delay:.3s}
/* ═══════════════════════════════════════════════
   HERO LEGAL TIP FLOATING BUTTON
═══════════════════════════════════════════════ */
.hero-tip-btn {
  position: absolute;
  bottom: 14px;
  right: 14px;
  background: linear-gradient(135deg, #c9a84c, #dfc278);
  color: #1a1200;
  border: none;
  border-radius: 22px;
  padding: 8px 16px;
  font-size: .78rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(201,168,76,.45);
  transition: transform .2s, box-shadow .2s;
  z-index: 10;
  font-family: var(--sans);
  white-space: nowrap;
}
.hero-tip-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(201,168,76,.6);
}

/* Hero window position relative for the button */
.hv-win { position: relative; }

/* Auto tip fade in */
@keyframes fadeInMsg {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════════
   HERO TIP MODAL
═══════════════════════════════════════════════ */
.hero-tip-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
.hero-tip-overlay.open {
  opacity: 1;
  pointer-events: all;
}
.hero-tip-modal {
  background: var(--surf2);
  border: 1px solid rgba(201,168,76,.3);
  border-radius: var(--r20);
  padding: 28px;
  max-width: 460px;
  width: 90%;
  box-shadow: 0 24px 64px rgba(0,0,0,.6);
  transform: scale(.94) translateY(16px);
  transition: transform .3s var(--ease);
}
.hero-tip-overlay.open .hero-tip-modal {
  transform: scale(1) translateY(0);
}
.hero-tip-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  font-size: 1.3rem;
}
.hero-tip-head h4 {
  flex: 1;
  font-family: var(--serif);
  font-size: 1.2rem;
  color: var(--g300);
  margin: 0;
}
.hero-tip-body {
  font-size: .9rem;
  color: var(--s200);
  line-height: 1.7;
  padding: 16px;
  background: rgba(201,168,76,.05);
  border: 1px solid rgba(201,168,76,.15);
  border-radius: var(--r12);
  margin-bottom: 18px;
}
.hero-tip-foot {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

/* ═══════════════════════════════════════════════
   SUBSCRIPTION POPUP MODAL
═══════════════════════════════════════════════ */
.sub-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(8px);
  z-index: 10001;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
.sub-overlay.open {
  opacity: 1;
  pointer-events: all;
}
.sub-modal {
  background: var(--surf1);
  border: 1px solid rgba(201,168,76,.25);
  border-radius: var(--r20);
  width: 92%;
  max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 32px 80px rgba(0,0,0,.7);
  transform: scale(.93) translateY(20px);
  transition: transform .35s var(--ease);
  scrollbar-width: thin;
  scrollbar-color: var(--gbord) transparent;
}
.sub-overlay.open .sub-modal {
  transform: scale(1) translateY(0);
}
.sub-modal-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 24px 28px 18px;
  border-bottom: 1px solid var(--gbord);
}
.sub-modal-logo {
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg,var(--g400),var(--g200));
  border-radius: var(--r12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: var(--n900);
  flex-shrink: 0;
}
.sub-modal-head h3 {
  font-family: var(--serif);
  font-size: 1.2rem;
  color: #fff;
  margin: 0 0 3px;
}
.sub-modal-head p {
  font-size: .78rem;
  color: var(--s400);
  margin: 0;
}
.sub-close {
  margin-left: auto;
  background: var(--surf3);
  border: 1px solid var(--gbord);
  border-radius: var(--r8);
  color: var(--s300);
  width: 32px;
  height: 32px;
  cursor: pointer;
  font-size: .9rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
  flex-shrink: 0;
}
.sub-close:hover { background: var(--surf4); color: #fff; }

.sub-modal-body {
  padding: 22px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.sub-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 480px) {
  .sub-form-row { grid-template-columns: 1fr; }
}
.sub-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.sub-label {
  font-size: .75rem;
  font-weight: 700;
  color: var(--s300);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.sub-input {
  background: var(--surf3);
  border: 1px solid var(--gbord);
  border-radius: var(--r8);
  padding: 11px 14px;
  color: #fff;
  font-size: .88rem;
  font-family: var(--sans);
  outline: none;
  transition: border-color .2s;
  width: 100%;
  box-sizing: border-box;
}
.sub-input:focus { border-color: var(--g400); }
.sub-select { cursor: pointer; }
.sub-select option { background: var(--n800); }
.sub-err {
  font-size: .72rem;
  color: #ef4444;
  display: none;
  margin-top: -2px;
}

/* Plan selection cards */
.sub-plans {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 4px;
}
@media (max-width: 480px) {
  .sub-plans { grid-template-columns: 1fr; }
}
.sub-plan-card {
  background: var(--surf3);
  border: 2px solid var(--gbord);
  border-radius: var(--r12);
  padding: 14px 10px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s, transform .15s;
  position: relative;
  overflow: hidden;
}
.sub-plan-card:hover {
  border-color: rgba(201,168,76,.4);
  background: rgba(201,168,76,.05);
  transform: translateY(-2px);
}
.sub-plan-card.selected {
  border-color: var(--g400);
  background: rgba(201,168,76,.08);
}
.sub-plan-card.popular {
  border-color: rgba(201,168,76,.35);
}
.sub-popular-badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(90deg, var(--g400), var(--g200));
  color: var(--n900);
  font-size: .62rem;
  font-weight: 800;
  padding: 2px 10px;
  border-radius: 0 0 8px 8px;
  white-space: nowrap;
  letter-spacing: .05em;
}
.sub-plan-icon { font-size: 1.4rem; margin-bottom: 4px; margin-top: 6px; }
.sub-plan-name { font-size: .82rem; font-weight: 700; color: #fff; margin-bottom: 3px; }
.sub-plan-price { font-family: var(--serif); font-size: 1.1rem; color: var(--g300); font-weight: 700; margin-bottom: 3px; }
.sub-plan-desc { font-size: .7rem; color: var(--s400); }

.sub-modal-foot {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  padding: 16px 28px 22px;
  border-top: 1px solid var(--gbord);
}

/* Dashboard chat footer tips button alignment */
.dcw-footer {
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 12px 16px;
  border-top: 1px solid var(--gbord);
}

/* ═══════════════════════════
   OTP INPUT DIGITS
═══════════════════════════ */
.otp-inputs {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin: 10px 0 4px;
}
.otp-digit {
  width: 52px;
  height: 60px;
  border-radius: var(--r12);
  background: var(--surf3);
  border: 2px solid var(--gbord);
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  text-align: center;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
  font-family: var(--sans);
}
.otp-digit:focus {
  border-color: var(--g400);
  box-shadow: 0 0 0 3px rgba(201,168,76,.18);
}
.otp-digit.filled {
  border-color: rgba(201,168,76,.5);
  background: rgba(201,168,76,.08);
  color: var(--g200);
}

/* ═══════════════════════════
   FORM SELECT STYLING
═══════════════════════════ */
.form-input[type="text"],
.form-input[type="email"],
.form-input[type="tel"],
.form-input[type="password"],
.form-input select,
select.form-input {
  -webkit-appearance: none;
  appearance: none;
}
select.form-input {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235a7a95' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
  cursor: pointer;
}

/* ═══════════════════════════
   NOTIFICATION PANEL
═══════════════════════════ */
.notif-panel{position:absolute;top:52px;right:56px;width:320px;background:var(--surf2);border:1px solid var(--gbord-g);border-radius:var(--r16);z-index:200;box-shadow:0 20px 60px rgba(0,0,0,.6);overflow:hidden;animation:notifIn .2s var(--ease)}
@keyframes notifIn{from{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:none}}
.notif-panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--gbord);background:rgba(201,168,76,.04)}
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-bottom:1px solid var(--gbord);transition:background .15s;cursor:pointer}
.notif-item:hover{background:rgba(201,168,76,.05)}
.notif-item.unread{background:rgba(201,168,76,.04)}
.notif-item:last-child{border-bottom:none}
.notif-ico{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,rgba(201,168,76,.2),rgba(201,168,76,.08));display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.notif-body{flex:1}
.notif-msg{font-size:.82rem;color:var(--s200);line-height:1.45;margin-bottom:3px}
.notif-time{font-size:.72rem;color:var(--s400)}
.notif-panel-view-all{padding:12px 16px;text-align:center;font-size:.8rem;color:var(--g400);font-weight:600;cursor:pointer;border-top:1px solid var(--gbord)}
.notif-panel-view-all:hover{background:rgba(201,168,76,.05)}

/* Bento secure centered */
.bc-secure-centered{grid-column:2}

/* ═══════════════════════════════════════════════
   ADMIN DASHBOARD — Stats Grid
═══════════════════════════════════════════════ */
.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
  margin-bottom: 28px;
}
.admin-stat-card {
  background: var(--surf2);
  border: 1px solid var(--gbord);
  border-radius: var(--r16);
  padding: 20px 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color .2s, transform .2s;
  position: relative;
  overflow: hidden;
}
.admin-stat-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(201,168,76,.04), transparent);
  pointer-events: none;
}
.admin-stat-card:hover {
  border-color: rgba(201,168,76,.3);
  transform: translateY(-2px);
}
.asc-icon {
  font-size: 1.5rem;
  margin-bottom: 4px;
}
.asc-num {
  font-family: var(--serif);
  font-size: 1.8rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}
.asc-label {
  font-size: .78rem;
  font-weight: 700;
  color: var(--s300);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.asc-sub {
  font-size: .74rem;
  color: var(--s400);
}

/* ═══════════════════════════════════════════════
   ADMIN TABLE
═══════════════════════════════════════════════ */
.admin-table {
  width: 100%;
  border-collapse: collapse;
}
.admin-table th {
  text-align: left;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--s400);
  padding: 8px 12px 12px;
  border-bottom: 1px solid var(--gbord);
}
.admin-table td {
  padding: 12px 12px;
  font-size: .84rem;
  color: var(--s300);
  border-bottom: 1px solid rgba(255,255,255,.04);
  vertical-align: middle;
}
.admin-table tr:last-child td {
  border-bottom: none;
}
.admin-table tr:hover td {
  background: rgba(201,168,76,.03);
}

/* ═══════════════════════════════════════════════
   NGO & CORPORATE — Service rows
═══════════════════════════════════════════════ */
.law-svc-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--surf3);
  border: 1px solid var(--gbord);
  border-radius: var(--r10);
  transition: border-color .2s;
}
.law-svc-row:hover { border-color: rgba(201,168,76,.2); }
.law-svc-name {
  font-size: .84rem;
  font-weight: 600;
  color: var(--s200);
}
.law-svc-range {
  font-size: .75rem;
  color: var(--g400);
  font-weight: 600;
  margin-top: 3px;
}

/* ═══════════════════════════════════════════════
   DANGER BUTTON
═══════════════════════════════════════════════ */
.btn-danger {
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.25);
  color: var(--err);
  border-radius: var(--r8);
  padding: 10px 16px;
  font-size: .84rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s;
}
.btn-danger:hover {
  background: rgba(239,68,68,.2);
}

/* ═══════════════════════════════════════════════
   LAWYER OVERVIEW KPI row custom id
═══════════════════════════════════════════════ */
#lawyerKpiRow { /* reuses .kpi-row */ }

/* Ensure overview KPIs show for lawyer */
#panel-overview .kpi-row { display: flex; }

/* ═══════════════════════════════════════════════
   RESPONSIVE — admin grid
═══════════════════════════════════════════════ */
@media (max-width: 768px) {
  .admin-stats-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 480px) {
  .admin-stats-grid {
    grid-template-columns: 1fr;
  }
}

/* ═══════════════════════════════════════════════
   GENERIC MODAL SYSTEM
═══════════════════════════════════════════════ */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(8px);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s var(--ease);
}
.modal-overlay.open {
  opacity: 1;
  pointer-events: all;
}
.modal-box {
  background: var(--surf2);
  border: 1px solid var(--gbord-g);
  border-radius: var(--r20);
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 32px 80px rgba(0,0,0,.7);
  transform: translateY(24px) scale(.97);
  transition: transform .3s var(--ease);
  scrollbar-width: thin;
  scrollbar-color: rgba(201,168,76,.2) transparent;
}
.modal-overlay.open .modal-box {
  transform: translateY(0) scale(1);
}
.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 24px 16px;
  border-bottom: 1px solid var(--gbord);
  position: sticky;
  top: 0;
  background: var(--surf2);
  z-index: 2;
}
.modal-title {
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 700;
  color: #fff;
}
.modal-close {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid var(--gbord);
  background: var(--surf3);
  color: var(--s400);
  cursor: pointer;
  font-size: .9rem;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
  flex-shrink: 0;
}
.modal-close:hover { background: var(--surf4); color: #fff; }
.modal-body {
  padding: 20px 24px 24px;
}

/* ═══════════════════════════════════════════════
   FILE DROP ZONE
═══════════════════════════════════════════════ */
.file-drop-zone {
  border: 2px dashed rgba(201,168,76,.25);
  border-radius: var(--r12);
  padding: 24px 16px;
  text-align: center;
  cursor: pointer;
  transition: border-color .2s, background .2s;
}
.file-drop-zone:hover {
  border-color: rgba(201,168,76,.5);
  background: rgba(201,168,76,.04);
}
.nc-doc-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--surf3);
  border: 1px solid var(--gbord);
  border-radius: var(--r8);
  font-size: .8rem;
  color: var(--s300);
}
.nc-doc-row button {
  margin-left: auto;
  background: none;
  border: none;
  color: var(--s400);
  cursor: pointer;
  font-size: .8rem;
  padding: 2px 6px;
  border-radius: 4px;
  transition: color .2s, background .2s;
}
.nc-doc-row button:hover { color: var(--err); background: rgba(239,68,68,.08); }

/* ═══════════════════════════════════════════════
   CLIENT FILE MODAL CONTENT
═══════════════════════════════════════════════ */
.cf-header-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 0 20px;
  border-bottom: 1px solid var(--gbord);
  margin-bottom: 20px;
}
.cf-av {
  width: 52px; height: 52px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; font-weight: 800; color: #fff;
  flex-shrink: 0;
}
.cf-name { font-size: 1.1rem; font-weight: 700; color: #fff; }
.cf-meta { font-size: .8rem; color: var(--s400); margin-top: 3px; }
.cf-section-title {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--s400);
  margin: 16px 0 8px;
}
.cf-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 8px;
}
.cf-detail-item {
  background: var(--surf3);
  border: 1px solid var(--gbord);
  border-radius: var(--r10);
  padding: 10px 12px;
}
.cf-detail-label {
  font-size: .7rem;
  color: var(--s400);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 4px;
}
.cf-detail-value {
  font-size: .88rem;
  color: var(--s200);
  font-weight: 600;
}
.cf-doc-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--surf3);
  border: 1px solid var(--gbord);
  border-radius: var(--r8);
  margin-bottom: 6px;
  cursor: pointer;
  transition: border-color .2s;
}
.cf-doc-item:hover { border-color: rgba(201,168,76,.3); }
.cf-doc-icon { font-size: 1.2rem; flex-shrink: 0; }
.cf-doc-name { font-size: .84rem; font-weight: 600; color: var(--s200); }
.cf-doc-meta { font-size: .72rem; color: var(--s400); margin-top: 2px; }
.cf-timeline-item {
  display: flex;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.cf-timeline-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--g400);
  flex-shrink: 0;
  margin-top: 6px;
}
.cf-timeline-text {
  font-size: .82rem;
  color: var(--s300);
  line-height: 1.45;
}
.cf-timeline-date {
  font-size: .72rem;
  color: var(--s400);
  margin-top: 2px;
}

/* ═══════════════════════════════════════════════
   HEARING ROW — updated with delete button
═══════════════════════════════════════════════ */
.hearing-actions {
  display: flex;
  gap: 6px;
  align-items: center;
}

/* Responsive modal */
@media (max-width: 600px) {
  .modal-body { padding: 16px; }
  .modal-head { padding: 16px 16px 12px; }
  .cf-detail-grid { grid-template-columns: 1fr; }
}
