:root{
    --bg:#070A10;--bg2:#0B1018;--panel:#0F151E;--panel2:#151D29;
    --line:rgba(255,255,255,.07);--line-2:rgba(255,255,255,.12);--line-warm:rgba(233,184,74,.22);
    --ink:#F7F3EA;--mut:#94A2B4;--dim:#6E7C94;
    --gold:#E9B84A;--gold-2:#C7902A;--gold-deep:#9A6E1E;--gold-soft:#FBD98C;
    --blue:#5B97FF;--teal:#37D6B2;--red:#FF6B6B;--violet:#B498FF;
    --metal:linear-gradient(135deg,#FBD98C 0%,#E9B84A 38%,#C7902A 70%,#E9B84A 100%);
    --disp:'Fraunces',serif;--ui:'Hanken Grotesk',sans-serif;--mono:'JetBrains Mono',monospace;
    --r:16px;--r-lg:22px;
    --sh:0 28px 70px -38px rgba(0,0,0,.85);--sh-gold:0 24px 60px -28px rgba(233,184,74,.35);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{background:var(--bg);color:var(--ink);font-family:var(--ui);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  section{scroll-margin-top:80px}
  ::selection{background:var(--gold);color:#140d02}
  ::-webkit-scrollbar{width:10px;height:10px}
  ::-webkit-scrollbar-track{background:#05070b}
  ::-webkit-scrollbar-thumb{background:linear-gradient(var(--gold-deep),var(--gold-2));border-radius:10px;border:2px solid #05070b}

  /* atmosphere */
  .atmos{position:fixed;inset:0;z-index:-3;overflow:hidden;pointer-events:none}
  .atmos-base{position:absolute;inset:0;background:
    radial-gradient(120% 80% at 50% -10%,rgba(233,184,74,.10),transparent 55%),
    radial-gradient(100% 70% at 80% 110%,rgba(91,151,255,.08),transparent 55%),
    linear-gradient(180deg,#080B12 0%,#06080D 45%,#070A11 100%)}
  .aurora{position:absolute;inset:0;overflow:hidden}
  .aurora .a{position:absolute;border-radius:50%;filter:blur(110px);opacity:.42;mix-blend-mode:screen;will-change:transform}
  .aurora .a1{width:62vw;height:62vw;background:radial-gradient(circle,rgba(233,184,74,.55),transparent 62%);top:-22vw;right:-12vw;animation:drift1 34s ease-in-out infinite}
  .aurora .a2{width:56vw;height:56vw;background:radial-gradient(circle,rgba(91,151,255,.42),transparent 62%);bottom:-18vw;left:-14vw;animation:drift2 40s ease-in-out infinite}
  .aurora .a3{width:46vw;height:46vw;background:radial-gradient(circle,rgba(55,214,178,.26),transparent 62%);top:42%;left:48%;animation:drift3 46s ease-in-out infinite}
  @keyframes drift1{50%{transform:translate(-5vw,7vw) scale(1.12)}}
  @keyframes drift2{50%{transform:translate(7vw,-5vw) scale(1.16)}}
  @keyframes drift3{50%{transform:translate(-9vw,-4vw) scale(.9)}}
  .drafting{position:absolute;inset:0;opacity:.5;
    background-image:linear-gradient(rgba(255,255,255,.028) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px);
    background-size:64px 64px;
    -webkit-mask:radial-gradient(120% 90% at 50% 30%,#000,transparent 78%);mask:radial-gradient(120% 90% at 50% 30%,#000,transparent 78%)}
  .grain{position:absolute;inset:0;pointer-events:none;opacity:.045;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
  .vignette{position:absolute;inset:0;background:radial-gradient(130% 100% at 50% 42%,transparent 52%,rgba(3,4,8,.7) 100%)}
  .spotlight{position:fixed;width:760px;height:760px;left:0;top:0;z-index:-2;pointer-events:none;border-radius:50%;
    transform:translate(calc(var(--mx,50vw) - 380px),calc(var(--my,40vh) - 380px));
    background:radial-gradient(circle,rgba(233,184,74,.10),transparent 60%);mix-blend-mode:screen;opacity:0;transition:opacity .6s}
  body.has-pointer .spotlight{opacity:1}
  @media(pointer:coarse){.spotlight{display:none}}

  /* scroll progress */
  .progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:200;background:var(--metal);box-shadow:0 0 16px rgba(233,184,74,.6)}

  /* nav */
  nav{position:fixed;top:0;left:0;right:0;z-index:150;display:flex;justify-content:space-between;align-items:center;
    padding:20px 36px;transition:padding .4s,background .4s,border-color .4s}
  nav.scrolled{padding:13px 36px;background:rgba(8,11,18,.66);backdrop-filter:blur(18px) saturate(1.3);-webkit-backdrop-filter:blur(18px) saturate(1.3);border-bottom:1px solid var(--line)}
  nav .logo{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:2px;font-size:.9rem}
  nav .logo .kb{position:relative;width:16px;height:16px}
  nav .logo .kb::before{content:"";position:absolute;inset:0;background:var(--metal);transform:rotate(45deg);box-shadow:0 0 16px rgba(233,184,74,.7);border-radius:2px}
  nav .logo .kb::after{content:"";position:absolute;inset:5px;background:var(--bg);transform:rotate(45deg);border-radius:1px}
  nav .logo b{background:var(--metal);-webkit-background-clip:text;background-clip:text;color:transparent}
  nav .links{display:flex;gap:30px;align-items:center}
  nav .links a{color:var(--mut);text-decoration:none;font-size:.83rem;font-weight:600;letter-spacing:.2px;transition:color .2s;position:relative}
  nav .links a:hover{color:var(--ink)}
  nav .links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .28s}
  nav .links a:not(.btn):hover::after{width:100%}
  .btn{position:relative;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;background:var(--metal);color:#160d01;border:none;font-family:var(--ui);font-weight:800;letter-spacing:.2px;
    font-size:.85rem;padding:12px 22px;border-radius:40px;cursor:pointer;text-decoration:none;overflow:hidden;
    box-shadow:0 1px 0 rgba(255,255,255,.4) inset,0 10px 30px -14px rgba(233,184,74,.7);transition:transform .25s,box-shadow .35s;will-change:transform}
  .btn::after{content:"";position:absolute;top:0;left:-130%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-18deg);transition:left .6s}
  .btn:hover{box-shadow:0 1px 0 rgba(255,255,255,.5) inset,0 18px 44px -16px rgba(233,184,74,.85)}
  .btn:hover::after{left:130%}
  .btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line-2);box-shadow:none}
  .btn.ghost::after{display:none}
  .btn.ghost:hover{border-color:var(--gold);color:var(--gold-soft);box-shadow:0 0 0 1px rgba(233,184,74,.3)}
  @media(max-width:780px){nav .links a:not(.btn){display:none}}

  .wrap{max-width:1140px;margin:0 auto;padding:0 32px}

  /* reveal */
  .reveal{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1);transition-delay:var(--d,0s)}
  .reveal.in{opacity:1;transform:none}
  @media(prefers-reduced-motion:reduce){.reveal{transition:none}}

  /* hero */
  .hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:140px 24px 96px;overflow:hidden}
  .hero-fx{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
  .hero-3d{position:fixed;inset:0;width:100vw;height:100vh;height:100svh;z-index:-1;opacity:1;pointer-events:none}
  body.kai-open .hero-3d{width:calc(100vw - var(--kai-w,440px))}
  @media(max-width:900px){body.kai-open .hero-3d{width:100vw}}
  .hero-arch{position:absolute;left:50%;bottom:-2%;transform:translateX(-50%);width:min(1180px,98vw);z-index:1;pointer-events:none}
  .hero-arch svg{width:100%;height:auto;overflow:visible;display:block}
  .hero-veil{position:absolute;inset:0;z-index:2;pointer-events:none;background:
    radial-gradient(64% 48% at 50% 62%,rgba(5,7,12,.9),rgba(5,7,12,.4) 60%,transparent 80%),
    linear-gradient(180deg,transparent 26%,rgba(5,7,12,.66) 100%)}
  .hero .inner{position:relative;z-index:4;max-width:min(1080px,94vw);will-change:transform}
  .heroeye{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11.5px;letter-spacing:5px;text-transform:uppercase;color:var(--gold-soft);opacity:0;animation:up .9s ease forwards .15s}
  .heroeye .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(233,184,74,.6);animation:pulse 2.4s ease-out infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(233,184,74,.55)}70%{box-shadow:0 0 0 10px rgba(233,184,74,0)}100%{box-shadow:0 0 0 0 rgba(233,184,74,0)}}
  .hero-title{font-family:var(--disp);font-weight:600;font-size:clamp(2.8rem,9vw,6.6rem);line-height:.9;letter-spacing:-.025em;margin:24px 0 0;text-shadow:0 1px 2px rgba(3,5,10,.92),0 3px 14px rgba(3,5,10,.78),0 6px 40px rgba(3,5,10,.55)}
  .hero-title .line{display:block;overflow:visible;padding:.02em .08em .14em}
  .hero-title .word{display:inline-block;margin-right:.26em}
  .hero-title .word:last-child{margin-right:0}
  .hero-title .l2{font-style:italic;font-weight:500;line-height:1.08}
  .hero-title .l2 .word{color:var(--gold-soft);text-shadow:0 1px 0 rgba(255,255,255,.1),0 3px 30px rgba(233,184,74,.32)}
  body.js .hero-title .word{transform:translateY(45%);opacity:0;animation:wordup .95s cubic-bezier(.2,.78,.2,1) forwards;animation-delay:var(--wd,0s)}
  @keyframes wordup{to{transform:none;opacity:1}}
  .herosub{max-width:660px;margin:30px auto 0;color:var(--mut);font-size:clamp(1.02rem,2vw,1.24rem);line-height:1.6;opacity:0;animation:up 1s ease forwards 1.05s}
  .herosub b{color:var(--ink);font-weight:600}
  .herobtns{display:flex;gap:14px;justify-content:center;margin-top:40px;flex-wrap:wrap;opacity:0;animation:up 1s ease forwards 1.25s}
  @keyframes up{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
  .scrollcue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--mono);font-size:9.5px;letter-spacing:3px;text-transform:uppercase;color:var(--dim);opacity:0;animation:up 1s ease forwards 1.7s}
  .scrollcue i{width:1px;height:42px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
  .scrollcue i::after{content:"";position:absolute;left:0;top:0;width:100%;height:40%;background:var(--gold-soft);animation:scrolldown 2s ease-in-out infinite}
  @keyframes scrolldown{0%{transform:translateY(-110%)}60%,100%{transform:translateY(280%)}}
  @media(prefers-reduced-motion:reduce){body.js .hero-title .word{transform:none;opacity:1;animation:none}.scrollcue i::after{animation:none}}

  /* section frame */
  .sec{padding:118px 0;position:relative}
  .kick{display:flex;align-items:center;gap:16px;margin-bottom:26px}
  .kick .num{font-family:var(--mono);font-size:11px;color:var(--gold);letter-spacing:1px;padding:5px 10px;border:1px solid var(--line-warm);border-radius:6px;background:rgba(233,184,74,.05)}
  .kick .ln{flex:1;height:1px;background:linear-gradient(90deg,var(--line-2),transparent)}
  .kick .tag{font-family:var(--mono);font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--mut)}
  .h2{font-family:var(--disp);font-weight:600;font-size:clamp(2.1rem,5.2vw,3.7rem);line-height:1.02;letter-spacing:-.02em;max-width:840px;text-wrap:balance}
  .lead{color:var(--mut);font-size:1.1rem;line-height:1.62;max-width:680px;margin-top:20px;text-wrap:pretty}

  /* thesis from-to */
  .ribbon{overflow:hidden;white-space:nowrap;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 0;margin:46px 0}
  .ribbon .track{display:inline-flex;gap:40px;animation:marq 26s linear infinite;font-family:var(--disp);font-style:italic;font-size:1.5rem;color:var(--dim)}
  .ribbon .track span{display:inline-flex;gap:40px;align-items:center}
  .ribbon .track b{color:var(--gold);font-style:normal;font-family:var(--mono);font-size:.9rem;letter-spacing:3px;text-transform:uppercase}
  @keyframes marq{to{transform:translateX(-50%)}}
  .ft{display:flex;flex-direction:column;gap:12px;margin-top:10px}
  .ftrow{display:grid;grid-template-columns:1fr 50px 1fr;align-items:center;gap:8px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel)}
  .ftrow .from{padding:18px 22px;color:var(--mut)}
  .ftrow .from .l,.ftrow .to .l{display:block;font-family:var(--mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;margin-bottom:5px}
  .ftrow .from .l{color:var(--dim)}
  .ftrow .arr{text-align:center;color:var(--gold);font-size:1.2rem}
  .ftrow .to{padding:18px 22px;font-weight:500;color:var(--ink);background:linear-gradient(90deg,transparent,rgba(233,184,74,.07));border-left:3px solid var(--gold)}
  .ftrow .to .l{color:var(--gold)}
  @media(max-width:640px){.ftrow{grid-template-columns:1fr}.ftrow .arr{transform:rotate(90deg);padding:2px 0}.ftrow .to{border-left:none;border-top:1px solid var(--line)}}

  /* three-sided */
  .inputs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:14px}
  @media(max-width:760px){.inputs{grid-template-columns:1fr}}
  .inp{border:1px solid var(--line);border-radius:18px;padding:26px;background:var(--panel);position:relative;overflow:hidden;transition:transform .3s,border-color .3s}
  .inp::before{content:"";position:absolute;inset:0;border-radius:18px;padding:1px;background:linear-gradient(140deg,var(--ic),transparent 60%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.5}
  .inp:hover{transform:translateY(-6px);border-color:var(--ic)}
  .inp .role{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--ic)}
  .inp h4{font-family:var(--disp);font-size:1.5rem;font-weight:600;margin:4px 0 16px}
  .inp ul{list-style:none;display:flex;flex-direction:column;gap:10px}
  .inp li{display:flex;gap:10px;font-size:.92rem}.inp li::before{content:"";flex-shrink:0;width:7px;height:7px;background:var(--ic);transform:rotate(45deg);margin-top:6px}
  .flowdown{display:flex;justify-content:center;margin:18px 0}
  .flowdown .pulse{width:2px;height:54px;background:linear-gradient(var(--gold),transparent);position:relative}
  .flowdown .pulse::after{content:"";position:absolute;left:-3px;top:0;width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 12px var(--gold);animation:fall 2s ease-in-out infinite}
  @keyframes fall{0%{top:0;opacity:0}30%{opacity:1}100%{top:48px;opacity:0}}
  .labbar{border:1px solid rgba(233,184,74,.4);border-radius:18px;padding:30px;text-align:center;background:linear-gradient(155deg,rgba(233,184,74,.1),rgba(10,14,20,.4));position:relative;overflow:hidden}
  .labbar .lg{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
  .labbar h3{font-family:var(--disp);font-size:clamp(1.2rem,3vw,1.8rem);font-weight:600;margin-top:8px}
  .labbar p{color:var(--mut);font-size:.94rem;margin-top:8px;max-width:580px;margin-left:auto;margin-right:auto}
  .outbar{border:1px solid rgba(55,214,178,.4);border-radius:18px;padding:22px;text-align:center;background:rgba(55,214,178,.06);margin-top:18px}
  .outbar .l{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--teal)}
  .outbar h3{font-family:var(--disp);font-size:clamp(1.1rem,3vw,1.5rem);font-weight:600;margin-top:6px}

  /* zones */
  .zone{display:grid;grid-template-columns:90px 1fr;gap:24px;align-items:center;padding:30px 0;border-top:1px solid var(--line)}
  .zone .zi{width:78px;height:78px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:var(--bg2);border:1px solid var(--zc);font-family:var(--disp);font-weight:700;font-size:2rem;color:var(--zc);box-shadow:0 0 30px -10px var(--zc);transition:transform .4s}
  .zone:hover .zi{transform:scale(1.06) rotate(-3deg)}
  .zone .zn{font-family:var(--disp);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:600}
  .zone .zr{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--zc);margin:4px 0 8px}
  .zone p{color:var(--mut);font-size:.96rem;max-width:680px}
  @media(max-width:560px){.zone{grid-template-columns:1fr}.zone .zi{width:60px;height:60px;font-size:1.5rem}}

  /* partners */
  .marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;margin:36px 0}
  .marquee .t{display:inline-flex;gap:56px;white-space:nowrap;animation:marq 24s linear infinite;font-family:var(--disp);font-size:1.7rem;color:var(--dim);font-weight:500}
  .marquee:hover .t{animation-play-state:paused}
  .marquee .t b{color:var(--ink);font-weight:600}
  .pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  @media(max-width:820px){.pgrid{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.pgrid{grid-template-columns:1fr}}
  .pc{border:1px solid var(--line);border-radius:14px;padding:22px;background:var(--panel);transition:.3s}
  .pc:hover{transform:translateY(-4px);border-color:var(--violet)}
  .pc .pn{font-family:var(--disp);font-size:1.15rem;font-weight:600}
  .pc p{color:var(--mut);font-size:.86rem;margin-top:7px}
  .coinv{margin-top:20px;border:1px solid rgba(180,152,255,.3);background:rgba(180,152,255,.06);border-radius:18px;padding:28px}
  .coinv .l{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--violet)}
  .coinv h4{font-family:var(--disp);font-size:1.4rem;font-weight:600;margin:8px 0 10px}
  .coinv p{color:var(--mut);max-width:760px}.coinv p b{color:var(--ink)}

  /* members */
  .anchor{border:1px solid var(--line);border-radius:18px;padding:26px 30px;background:linear-gradient(150deg,var(--panel),var(--bg2));margin-bottom:26px}
  .anchor .l{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--blue)}
  .anchor p{margin-top:8px;font-size:1.02rem;color:var(--mut)}.anchor p b{color:var(--ink)}
  .tiers{display:flex;flex-direction:column;gap:12px}
  .tier{display:grid;grid-template-columns:46px 1fr auto;gap:18px;align-items:center;border:1px solid var(--line);border-radius:16px;padding:20px 24px;background:var(--panel);border-left:4px solid var(--tc);transition:.3s}
  .tier:hover{transform:translateX(6px);border-left-width:7px}
  .tier .tnum{font-family:var(--disp);font-weight:700;font-size:1.7rem;color:transparent;-webkit-text-stroke:1.4px var(--tc)}
  .tier .tn{font-family:var(--disp);font-size:1.3rem;font-weight:600}
  .tier .td{font-size:.9rem;color:var(--mut);margin-top:3px}
  .tier .tm{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--tc);text-align:right;white-space:nowrap}
  @media(max-width:600px){.tier{grid-template-columns:46px 1fr}.tier .tm{grid-column:2;text-align:left;margin-top:5px}}
  .subwheel{margin-top:20px;border:1px solid rgba(233,184,74,.3);background:rgba(233,184,74,.06);border-radius:18px;padding:26px}
  .subwheel .l{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
  .subwheel p{color:var(--mut);margin-top:8px;max-width:780px}.subwheel p b{color:var(--ink)}

  /* products */
  .pipe{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}
  .pst{flex:1;min-width:150px;border:1px solid var(--line);border-radius:14px;padding:20px;background:var(--panel);position:relative;transition:.3s}
  .pst:hover{border-color:var(--gold);transform:translateY(-4px)}
  .pst .s{font-family:var(--mono);font-size:10px;color:var(--gold);letter-spacing:1px}
  .pst b{display:block;font-family:var(--disp);font-size:1.1rem;font-weight:600;margin:5px 0}
  .pst span{font-size:.82rem;color:var(--mut)}
  .gradbox{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
  @media(max-width:720px){.gradbox{grid-template-columns:1fr}}
  .gb{border:1px solid var(--line);border-radius:16px;padding:24px;background:var(--bg2)}
  .gb .l{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--teal);margin-bottom:12px}
  .gb ul{list-style:none;display:flex;flex-direction:column;gap:10px}.gb li{display:flex;gap:10px;font-size:.92rem}.gb li::before{content:"✓";color:var(--teal);font-weight:700}
  .chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
  .chipgrp{margin-top:22px;width:100%}
  .chl{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
  .chrow{display:flex;flex-wrap:wrap;gap:10px}
  .chip{font-family:var(--mono);font-size:11px;padding:9px 15px;border-radius:30px;background:var(--panel2);border:1px solid var(--line);color:var(--ink);transition:.25s}
  .chip:hover{border-color:var(--gold);color:var(--gold)}
  .chip.bank{border-color:rgba(91,151,255,.4);color:var(--blue)}
  .chip.sys{border-color:rgba(233,184,74,.45);color:var(--gold-soft);background:rgba(233,184,74,.06)}

  /* flywheel scrollytelling */
  .fwsec{position:relative}
  .fwgrid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
  @media(max-width:880px){.fwgrid{grid-template-columns:1fr;gap:0}}
  .fwviz{position:sticky;top:14vh;height:70vh;display:flex;align-items:center;justify-content:center}
  @media(max-width:880px){.fwviz{height:44vh;top:64px;background:linear-gradient(180deg,var(--bg) 80%,transparent)}}
  .fwviz svg{width:min(420px,86vw);height:auto;overflow:visible}
  #ring{transition:transform .7s cubic-bezier(.5,0,.2,1);transform-origin:180px 180px}
  .fnode{fill:var(--bg2);stroke:var(--line);stroke-width:2;transition:.5s}
  .fnode.active{fill:var(--gold);stroke:var(--gold);filter:drop-shadow(0 0 14px var(--gold))}
  .fwcenter .n{font-family:var(--disp);font-weight:700;font-size:54px;fill:var(--gold)}
  .fwsteps{display:flex;flex-direction:column}
  .fwstep{min-height:62vh;display:flex;flex-direction:column;justify-content:center}
  @media(max-width:880px){.fwstep{min-height:52vh}}
  .fwstep .si{font-family:var(--mono);font-size:11px;letter-spacing:2px;color:var(--gold)}
  .fwstep h3{font-family:var(--disp);font-size:clamp(1.4rem,3.2vw,2.1rem);font-weight:600;margin:8px 0 10px;transition:.4s;line-height:1.1}
  .fwstep p{color:var(--mut);max-width:440px}
  .fwstep.dim h3{color:var(--dim)}

  /* counters */
  .nums{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
  @media(max-width:820px){.nums{grid-template-columns:1fr 1fr}}
  .nc{border:1px solid var(--line);border-radius:18px;padding:28px 22px;background:var(--panel);text-align:center}
  .nc .v{font-family:var(--disp);font-weight:700;font-size:clamp(2rem,5vw,3rem);color:var(--gold-soft);line-height:1;letter-spacing:-1px}
  .nc .c{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--mut);margin-top:12px;line-height:1.5}

  /* cta */
  .cta{text-align:center;padding:120px 24px}
  .cta h2{font-family:var(--disp);font-weight:600;font-size:clamp(2rem,6vw,4rem);line-height:1.06;letter-spacing:-1.5px;max-width:880px;margin:0 auto}
  .cta h2 em{font-style:italic;color:var(--gold-soft)}
  .cta .sig{margin-top:26px;font-family:var(--mono);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold)}
  .cta .btn{margin-top:34px;font-size:1rem;padding:16px 30px}
  footer{border-top:1px solid var(--line);text-align:center;padding:34px 20px;color:var(--dim);font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase}

  /* conversion layer */
  .whynow{border:1px solid var(--line);border-radius:18px;padding:30px;background:linear-gradient(150deg,var(--panel),var(--bg2))}
  .whynow p{color:var(--mut);font-size:1.04rem;max-width:840px}.whynow p b{color:var(--ink)}
  .whynow .have{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
  .haveitem{font-family:var(--mono);font-size:11px;padding:8px 14px;border-radius:30px;background:rgba(233,184,74,.08);border:1px solid rgba(233,184,74,.3);color:var(--gold-soft)}
  .matrix{display:flex;flex-direction:column;gap:10px}
  .mrow{display:grid;grid-template-columns:1fr 1.3fr;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel)}
  .mrow .risk{padding:16px 20px;color:var(--ink);font-weight:600;border-left:4px solid var(--red);font-size:.92rem;display:flex;align-items:center}
  .mrow .ctrl{padding:16px 20px;color:var(--mut);font-size:.89rem;border-left:1px solid var(--line);background:linear-gradient(90deg,transparent,rgba(55,214,178,.05));display:flex;align-items:center}
  @media(max-width:640px){.mrow{grid-template-columns:1fr}.mrow .ctrl{border-left:none;border-top:1px solid var(--line)}}
  .ladder{display:flex;flex-direction:column;gap:10px}
  .whyg{display:grid;grid-template-columns:1.05fr .95fr;gap:20px;align-items:start}
  @media(max-width:780px){.whyg{grid-template-columns:1fr}}
  .creds{list-style:none;display:flex;flex-direction:column;gap:13px}
  .creds li{display:flex;gap:12px;font-size:.98rem;color:var(--ink)}.creds li::before{content:"\25C6";color:var(--gold);font-size:.65rem;margin-top:6px}
  .rolecard{border:1px solid rgba(233,184,74,.4);border-radius:18px;padding:28px;background:linear-gradient(155deg,rgba(233,184,74,.09),var(--bg2))}
  .rolecard .l{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
  .rolecard dl{margin-top:16px;display:flex;flex-direction:column;gap:14px}
  .rolecard dt{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--mut)}
  .rolecard dd{font-size:.98rem;color:var(--ink);font-weight:500;margin-top:3px;line-height:1.4}
  .lh{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  @media(max-width:820px){.lh{grid-template-columns:1fr}}
  .lhc{border:1px solid var(--line);border-radius:16px;padding:22px;background:var(--panel);border-top:3px solid var(--blue);transition:.3s}
  .lhc:hover{transform:translateY(-5px);border-color:var(--blue)}
  .lhc h4{font-family:var(--disp);font-size:1.12rem;font-weight:600;line-height:1.15}
  .lhc .who{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--blue);margin:6px 0 14px}
  .lhc .m{margin-bottom:11px}
  .lhc .m .k{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--dim);display:block;margin-bottom:2px}
  .lhc .m .vv{font-size:.86rem;color:var(--mut)}
  .lhc .m .vv.val{color:var(--teal);font-weight:600}
  .memo{border:1px solid rgba(233,184,74,.35);border-radius:20px;padding:34px;background:linear-gradient(155deg,rgba(233,184,74,.07),var(--bg2))}
  .memo .l{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-soft)}
  .memo h3{font-family:var(--disp);font-size:clamp(1.5rem,3.6vw,2.2rem);font-weight:600;margin:10px 0 16px}
  .memo ul{list-style:none;display:flex;flex-direction:column;gap:12px}
  .memo li{display:flex;gap:12px;font-size:1.02rem}.memo li::before{content:"\2192";color:var(--gold);font-weight:700}
  .memo .kill{margin-top:18px;font-size:.92rem;color:#ADB9CB;font-style:italic}

  .anchor3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:6px}
  @media(max-width:680px){.anchor3{grid-template-columns:1fr}}
  .a3{border:1px solid rgba(233,184,74,.3);border-radius:16px;padding:22px;background:linear-gradient(155deg,rgba(233,184,74,.08),var(--bg2));text-align:center}
  .a3 .v{font-family:var(--disp);font-weight:700;font-size:clamp(1.7rem,4.5vw,2.6rem);color:var(--gold-soft);line-height:1}
  .a3 .c{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--mut);margin-top:8px}
  .prow{display:grid;grid-template-columns:1.3fr .8fr .8fr 1.8fr;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel);transition:.3s}
  .prow:hover{border-color:var(--gold)}
  .prow>div{padding:16px 18px;border-left:1px solid var(--line);display:flex;flex-direction:column;justify-content:center}
  .prow>div:first-child{border-left:4px solid var(--lc)}
  .prow .pph{font-family:var(--disp);font-weight:600;font-size:1.02rem}
  .prow .pdur{font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:.5px;margin-top:3px}
  .prow .pl{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--dim)}
  .prow .ppur{color:var(--mut);font-size:.84rem}
  .prow .pv2{font-family:var(--mono);font-weight:700;color:var(--teal);font-size:.9rem;margin-top:4px;display:block}
  @media(max-width:720px){.prow{grid-template-columns:1fr 1fr}.prow .ppur{grid-column:1/3}.prow>div{border-left:none;border-top:1px solid var(--line)}.prow>div:first-child{border-top:none;border-left:4px solid var(--lc)}}
  .memodl{display:flex;flex-direction:column;gap:14px;margin:10px 0 4px}
  .memodl dt{font-family:var(--mono);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--gold-soft)}
  .memodl dd{font-size:1.02rem;color:var(--ink);font-weight:500;margin-top:2px}
  .kill b{color:var(--ink)}

  .vs{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:stretch}
  @media(max-width:760px){.vs{grid-template-columns:1fr}.vsarrow{transform:rotate(90deg);justify-self:center}}
  .vscard{border:1px solid var(--line);border-radius:18px;padding:26px;background:var(--panel)}
  .vscard.out{opacity:.72}
  .vscard.in{border-color:rgba(233,184,74,.4);background:linear-gradient(155deg,rgba(233,184,74,.08),var(--bg2))}
  .vscard .vl{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--dim)}
  .vscard h4{font-family:var(--disp);font-size:1.5rem;font-weight:600;margin:6px 0 10px}
  .vscard.in h4{color:var(--gold-soft)}
  .vscard p{color:var(--mut);font-size:.92rem;line-height:1.55}
  .vsarrow{display:flex;align-items:center;font-size:1.6rem;color:var(--gold);font-family:var(--disp)}
  .principle{border:1px solid rgba(233,184,74,.3);border-left:4px solid var(--gold);border-radius:14px;padding:24px 26px;background:rgba(233,184,74,.05);margin-top:24px}
  .principle .pl{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
  .principle p{color:var(--mut);font-size:1.02rem;margin-top:8px;max-width:860px}.principle p b{color:var(--ink)}
  .nolose{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  @media(max-width:900px){.nolose{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:520px){.nolose{grid-template-columns:1fr}}
  .nl{border:1px solid var(--line);border-radius:16px;padding:20px;background:var(--panel);border-top:3px solid var(--nc)}
  .nl .nh{font-family:var(--disp);font-size:1.2rem;font-weight:600;margin-bottom:8px}
  .nl p{color:var(--mut);font-size:.85rem;line-height:1.5}

  .loop{display:flex;flex-wrap:wrap;align-items:stretch;gap:8px}
  .lnode{flex:1 1 130px;min-width:130px;border:1px solid var(--line);border-radius:12px;padding:14px 12px;background:var(--panel);text-align:center;transition:.3s}
  .lnode:hover{border-color:var(--gold);transform:translateY(-3px)}
  .lnode .ln2{font-family:var(--mono);font-size:9px;color:var(--dim);letter-spacing:1px}
  .lnode .lt{font-family:var(--disp);font-weight:600;font-size:1rem;margin-top:4px;color:var(--ink)}
  .lnode .ld{font-size:.74rem;color:var(--mut);margin-top:5px;line-height:1.4}
  .taf{display:flex;flex-direction:column;gap:10px}
  .tafrow{display:grid;grid-template-columns:1fr auto 1fr;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel)}
  .tafrow .b{padding:15px 18px;color:var(--mut);font-size:.9rem;display:flex;align-items:center}
  .tafrow .ar{display:flex;align-items:center;padding:0 8px;color:var(--gold);font-family:var(--disp);font-size:1.1rem}
  .tafrow .a{padding:15px 18px;color:var(--ink);font-weight:600;font-size:.9rem;display:flex;align-items:center;border-left:1px solid var(--line);background:linear-gradient(90deg,transparent,rgba(233,184,74,.06))}
  @media(max-width:620px){.tafrow{grid-template-columns:1fr}.tafrow .ar{transform:rotate(90deg);justify-content:center;padding:4px 0}.tafrow .a{border-left:none;border-top:1px solid var(--line)}}

  .peers{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
  @media(max-width:820px){.peers{grid-template-columns:1fr}}
  .peer{border:1px solid var(--line);border-radius:16px;padding:22px;background:var(--panel);border-top:3px solid var(--pc)}
  .peer .pf{font-family:var(--disp);font-size:1.15rem;font-weight:600}
  .peer .pb{font-size:.86rem;color:var(--mut);margin:8px 0 12px;line-height:1.5}
  .peer .pgap{font-family:var(--mono);font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--dim);border-top:1px solid var(--line);padding-top:10px;line-height:1.6}
  .peer .pgap b{color:var(--gold-soft);font-weight:700}

  @media(prefers-reduced-motion:reduce){
    .reveal{opacity:1!important;transform:none!important}
    .aurora .a,.ribbon .track,.marquee .t,.scrollcue i::after,.flowdown .pulse::after{animation:none!important}
    .heroeye,.herosub,.herobtns,.scrollcue{opacity:1!important;animation:none!important}
    #ring{transition:none}
  }

  /* ============ POLISH LAYER ============ */
  /* shared elevated glass surface on neutral cards (keeps tinted cards intact) */
  .inp,.pc,.tier,.pst,.gb,.nc,.lhc,.nl,.lnode,.peer,.ftrow,.mrow,.prow,.tafrow,.vscard{
    background-image:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,0) 42%);
    box-shadow:var(--sh);
    transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s,box-shadow .35s}
  .inp:hover,.pc:hover,.lhc:hover,.lnode:hover,.pst:hover{box-shadow:var(--sh),0 0 0 1px var(--line-2)}
  /* tinted feature cards get depth too */
  .labbar,.outbar,.coinv,.memo,.principle,.anchor,.subwheel,.rolecard,.whynow,.a3,.vscard.in{box-shadow:var(--sh)}

  /* marquee / ribbon edge fade */
  .ribbon,.marquee{-webkit-mask:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}

  /* counters as struck metal */
  .nc .v,.a3 .v{background:var(--metal);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1.12;padding-bottom:.1em;filter:drop-shadow(0 2px 14px rgba(233,184,74,.25))}

  /* h2 gets a faint architectural accent */
  .h2{position:relative}

  /* flywheel ring + nodes refined */
  .fnode{filter:drop-shadow(0 0 0 transparent);transition:fill .5s,stroke .5s,filter .5s}
  .fnode.active{filter:drop-shadow(0 0 16px var(--gold))}
  .fwcenter .n{filter:drop-shadow(0 0 18px rgba(233,184,74,.6))}

  /* zone tile icon = metallic keystone */
  .zone .zi{background:linear-gradient(160deg,rgba(255,255,255,.05),transparent),var(--bg2)}

  /* section keystone divider */
  .keydiv{display:flex;align-items:center;justify-content:center;gap:18px;padding:10px 0 2px;opacity:.0;transition:opacity 1s}
  .keydiv.in{opacity:1}
  .keydiv .kr{width:min(220px,34vw);height:1px;background:linear-gradient(90deg,transparent,var(--line-warm))}
  .keydiv .kr.r{background:linear-gradient(270deg,transparent,var(--line-warm))}
  .keydiv .ks{width:14px;height:14px;position:relative}
  .keydiv .ks::before{content:"";position:absolute;inset:0;background:var(--metal);transform:rotate(45deg);border-radius:2px;box-shadow:0 0 18px rgba(233,184,74,.55)}
  .keydiv .ks::after{content:"";position:absolute;inset:4px;background:var(--bg);transform:rotate(45deg);border-radius:1px}

  /* nicer focus ring for a11y */
  a:focus-visible,button:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

  /* ===== hero architecture ===== */
  .hero-arch .ring{fill:none;stroke:url(#archgrad);stroke-width:1.3;stroke-linecap:round;stroke-dasharray:1;stroke-dashoffset:1;animation:archdraw 2.4s cubic-bezier(.45,0,.12,1) forwards}
  .hero-arch line.ring{stroke:rgba(233,184,74,.4)}
  @keyframes archdraw{to{stroke-dashoffset:0}}
  .hero-arch .tick{stroke:rgba(251,217,140,.55);stroke-width:1;opacity:0;animation:tickin .7s ease forwards}
  @keyframes tickin{to{opacity:.7}}
  .hero-arch .key{fill:#EBBB52;opacity:0;transform-box:fill-box;transform-origin:center;transform:translateY(8px) scale(.6);animation:keyset 1s cubic-bezier(.2,.8,.2,1) forwards 2.1s;filter:drop-shadow(0 0 16px rgba(233,184,74,.85))}
  @keyframes keyset{to{opacity:1;transform:none}}
  .hero-arch .aglow{opacity:0;animation:glowin 1.4s ease forwards 2.3s}
  @keyframes glowin{to{opacity:1}}
  @media(prefers-reduced-motion:reduce){
    .hero-arch .ring{animation:none;stroke-dashoffset:0}
    .hero-arch .tick{animation:none;opacity:.7}
    .hero-arch .key{animation:none;opacity:1;transform:none}
    .hero-arch .aglow{animation:none;opacity:1}
  }

  /* ===== when the real 3D keystone is live ===== */
  body.has-3d .hero-arch{opacity:.5}
  body.has-3d .hero-arch .key,body.has-3d .hero-arch .aglow{display:none}
  body.has-3d .hero .inner{margin-top:clamp(120px,22vh,250px)}
  body.has-3d .hero-title{font-size:clamp(2.6rem,8vw,6rem)}
  body.has-3d .heroeye{background:rgba(8,11,18,.4);padding:7px 14px;border-radius:30px;border:1px solid var(--line-warm);backdrop-filter:blur(6px)}
  @media(max-width:720px){body.has-3d .hero .inner{margin-top:clamp(110px,20vh,200px)}}
  @media(max-height:680px){body.has-3d .hero .inner{margin-top:108px}}

  /* ===== no-anim fallback: if the document timeline never advances
     (throttled / background tab), force every entrance state to its
     visible end-state so nothing is ever stuck invisible ===== */
  body.no-anim .reveal{opacity:1!important;transform:none!important;transition:none!important}
  body.no-anim .heroeye,body.no-anim .herosub,body.no-anim .herobtns,body.no-anim .scrollcue{opacity:1!important;animation:none!important}
  body.no-anim .hero-title .word{opacity:1!important;transform:none!important;animation:none!important}
  body.no-anim .hero-arch .ring{stroke-dashoffset:0!important;animation:none!important}
  body.no-anim .hero-arch .tick{opacity:.7!important;animation:none!important}
  body.no-anim .hero-arch .key{opacity:1!important;transform:none!important;animation:none!important}
  body.no-anim .hero-arch .aglow{opacity:1!important;animation:none!important}
  body.no-anim .keydiv{opacity:1!important}

  /* ===== micro-interactions ===== */
  /* card 3D tilt + glare */
  .tiltable{transition:transform .16s ease-out,box-shadow .35s,border-color .35s!important;transform-style:preserve-3d}
  .tiltable:hover{will-change:transform}
  .tilt-glare{position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .35s;z-index:3;
    background:radial-gradient(220px circle at var(--gx,50%) var(--gy,50%),rgba(255,238,196,.16),transparent 62%)}

  /* trailing cursor halo (sits alongside the native cursor) */
  .cursor-ring{position:fixed;left:0;top:0;width:30px;height:30px;border:1.5px solid rgba(233,184,74,.6);border-radius:50%;
    pointer-events:none;z-index:9999;opacity:0;mix-blend-mode:screen;
    transition:opacity .35s,width .28s cubic-bezier(.2,.8,.2,1),height .28s cubic-bezier(.2,.8,.2,1),background .28s,border-color .28s}
  .cursor-ring.hot{width:52px;height:52px;background:radial-gradient(circle,rgba(233,184,74,.12),transparent 70%);border-color:rgba(251,217,140,.85)}
  .cursor-ring.down{width:22px;height:22px;border-color:rgba(251,217,140,1)}
  @media(pointer:coarse){.cursor-ring{display:none}}

  /* the gold headline accent — solid gold so descenders can never be clipped */
  body.js .hero-title .l2 .word{animation:wordup .95s cubic-bezier(.2,.78,.2,1) forwards var(--wd)}

  /* ============ UTILITY CLASSES (promoted from inline styles) ============ */
  .mt-2{margin-top:2px}.mt-10{margin-top:10px}.mt-14{margin-top:14px}.mt-16{margin-top:16px}
  .mt-18{margin-top:18px}.mt-20{margin-top:20px}.mt-22{margin-top:22px}.mt-24{margin-top:24px}
  .mt-26{margin-top:26px}.mt-28{margin-top:28px}.mt-30{margin-top:30px}.mt-32{margin-top:32px}
  .mb-40{margin-bottom:40px}
  .d1{--d:.1s}.d2{--d:.2s}.d3{--d:.3s}.d12{--d:.12s}.d24{--d:.24s}
  .col2{grid-column:span 2}
  .ic-gold{--ic:var(--gold)}.ic-violet{--ic:var(--violet)}.ic-blue{--ic:var(--blue)}
  .pc-teal{--pc:var(--teal)}.pc-violet{--pc:var(--violet)}.pc-blue{--pc:var(--blue)}
  .lc-gold{--lc:var(--gold)}.lc-blue{--lc:var(--blue)}.lc-teal{--lc:var(--teal)}.lc-violet{--lc:var(--violet)}
  .nl-gold{--nc:var(--gold)}.nl-violet{--nc:var(--violet)}.nl-blue{--nc:var(--blue)}.nl-teal{--nc:var(--teal)}
  .subhead{font-family:var(--disp);font-weight:600;font-size:1.4rem;margin:38px 0 4px;color:var(--ink)}
  .lead-sm{font-size:.96rem}
  .memo-quote{font-family:var(--disp);font-size:clamp(1.15rem,2.6vw,1.55rem);line-height:1.42;margin-top:12px;color:var(--ink)}

  /* ============ WHY JOHN ============ */
  .wj-head{margin-top:38px}
  .wj-step-label{font-family:var(--mono);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold)}
  .wj-h3{font-family:var(--disp);font-size:clamp(1.5rem,3.2vw,2.1rem);font-weight:600;line-height:1.08;margin-top:7px;letter-spacing:-.01em;text-wrap:balance}

  /* convergence diagram */
  .wj-converge{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:26px;
    padding:46px 14px;border:1px solid var(--line);border-radius:24px;
    background:radial-gradient(120% 120% at 50% 50%,rgba(233,184,74,.05),var(--bg2) 70%);box-shadow:var(--sh);overflow:hidden}
  .wj-side{display:flex;flex-direction:column;gap:26px}
  .wj-domain{display:flex;align-items:center;gap:0}
  .wj-left .wj-domain{justify-content:flex-end}
  .wj-dl{font-family:var(--disp);font-size:clamp(.92rem,1.5vw,1.12rem);font-weight:600;color:var(--ink);white-space:nowrap;line-height:1.1}
  .wj-left .wj-dl{text-align:right;padding-right:14px}
  .wj-right .wj-dl{text-align:left;padding-left:14px}
  .wj-wire{flex:1;min-width:46px;height:1px;position:relative;align-self:center}
  .wj-left .wj-wire{background:linear-gradient(90deg,transparent,var(--line-warm) 30%,var(--gold))}
  .wj-right .wj-wire{background:linear-gradient(270deg,transparent,var(--line-warm) 30%,var(--gold))}
  .wj-left .wj-wire::after,.wj-right .wj-wire::after{content:"";position:absolute;top:50%;width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px rgba(233,184,74,.9);transform:translateY(-50%)}
  .wj-left .wj-wire::after{right:-2px}
  .wj-right .wj-wire::after{left:-2px}
  /* travelling signal pulse toward the core */
  .wj-wire::before{content:"";position:absolute;top:50%;width:5px;height:5px;border-radius:50%;background:var(--gold-soft);box-shadow:0 0 9px rgba(251,217,140,.95);transform:translateY(-50%);opacity:0}
  .wj-left .wj-wire::before{animation:wjpulseL 2.6s linear infinite var(--pd,0s)}
  .wj-right .wj-wire::before{animation:wjpulseR 2.6s linear infinite var(--pd,0s)}
  @keyframes wjpulseL{0%{left:0;opacity:0}12%{opacity:1}88%{opacity:1}100%{left:100%;opacity:0}}
  @keyframes wjpulseR{0%{left:100%;opacity:0}12%{opacity:1}88%{opacity:1}100%{left:0;opacity:0}}
  .wj-side .wj-domain:nth-child(1) .wj-wire::before{--pd:0s}
  .wj-side .wj-domain:nth-child(2) .wj-wire::before{--pd:.5s}
  .wj-side .wj-domain:nth-child(3) .wj-wire::before{--pd:1s}
  .wj-side .wj-domain:nth-child(4) .wj-wire::before{--pd:1.5s}

  .wj-core{position:relative;display:flex;flex-direction:column;align-items:center;gap:9px;
    padding:32px 40px;border-radius:20px;border:1px solid var(--line-warm);
    background:radial-gradient(circle at 50% 26%,rgba(233,184,74,.14),var(--bg2));
    box-shadow:0 0 70px -22px rgba(233,184,74,.6),var(--sh)}
  .wj-ring{position:absolute;inset:-1px;border-radius:20px;border:1px solid rgba(233,184,74,.34);animation:wjring 3.4s ease-out infinite}
  @keyframes wjring{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.14);opacity:0}}
  .wj-key{width:58px;height:58px;background:var(--metal);clip-path:polygon(0 0,100% 0,82% 100%,18% 100%);
    box-shadow:0 0 28px rgba(233,184,74,.6);position:relative}
  .wj-key::after{content:"";position:absolute;inset:7px 9px;background:var(--bg2);clip-path:polygon(0 0,100% 0,80% 100%,20% 100%)}
  .wj-core-name{font-family:var(--disp);font-size:1.55rem;font-weight:600;line-height:1;margin-top:4px}
  .wj-core-role{font-family:var(--mono);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold)}

  @media(max-width:820px){
    .wj-converge{grid-template-columns:1fr;gap:22px;padding:26px 16px}
    .wj-core{order:-1}
    .wj-side{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:9px}
    .wj-wire{display:none}
    .wj-dl{padding:9px 14px!important;text-align:center!important;border:1px solid var(--line-warm);border-radius:30px;background:rgba(233,184,74,.05);font-size:.86rem}
  }

  /* career arc */
  .wj-arc{display:flex;align-items:stretch;gap:0;margin-top:20px;flex-wrap:wrap}
  .wj-stage{flex:1 1 190px;min-width:190px;border:1px solid var(--line);border-radius:16px;padding:22px;background:var(--panel);transition:transform .35s,border-color .35s,box-shadow .35s}
  .wj-stage:hover{transform:translateY(-5px);border-color:var(--line-2);box-shadow:var(--sh)}
  .wj-now{border-color:var(--line-warm);background:linear-gradient(155deg,rgba(233,184,74,.09),var(--bg2))}
  .wj-sn{font-family:var(--mono);font-size:11px;color:var(--gold);letter-spacing:1px}
  .wj-st{font-family:var(--disp);font-size:1.1rem;font-weight:600;margin:7px 0 9px;line-height:1.15}
  .wj-stage p{font-size:.86rem;color:var(--mut);line-height:1.5}
  .wj-link{display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.3rem;padding:0 7px;flex:0 0 auto}
  @media(max-width:860px){
    .wj-arc{flex-direction:column}
    .wj-link{transform:rotate(90deg);padding:7px 0}
  }

  /* mandate */
  .wj-mandate{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:20px}
  .wj-panel{border:1px solid var(--line);border-radius:18px;padding:24px;background:var(--bg2)}
  .wj-seat{grid-column:1/-1;border-color:var(--line-warm);background:linear-gradient(150deg,rgba(233,184,74,.1),var(--bg2))}
  .wj-pl{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:13px}
  .wj-seat p{font-size:1.05rem;color:var(--mut);max-width:820px;line-height:1.55}.wj-seat b{color:var(--ink)}
  .wj-nots{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
  .wj-nots span{font-family:var(--mono);font-size:10px;letter-spacing:.4px;text-transform:uppercase;color:var(--mut);border:1px solid var(--line);border-radius:30px;padding:7px 13px}
  .wj-nots span::before{content:"✕";color:var(--red);margin-right:7px;font-size:11px}
  .wj-chips{display:flex;flex-wrap:wrap;gap:8px}
  .wj-chip{font-family:var(--mono);font-size:11px;padding:8px 13px;border-radius:8px;background:var(--panel2);border:1px solid var(--line);color:var(--ink)}
  .wj-chip.is-gold{border-color:var(--line-warm);background:rgba(233,184,74,.08);color:var(--gold-soft)}
  .wj-chips.is-small .wj-chip{font-size:10px;padding:6px 11px}
  .wj-pp{font-size:.9rem;color:var(--mut);margin-bottom:13px}
  .wj-acc{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:9px 18px}
  .wj-wide{grid-column:1/-1}
  .wj-wide .wj-acc{grid-template-columns:repeat(3,1fr)}
  .wj-acc li{font-size:.9rem;color:var(--ink);display:flex;gap:9px;line-height:1.35}
  .wj-acc li::before{content:"✓";color:var(--teal);font-weight:700;flex-shrink:0}
  @media(max-width:760px){.wj-mandate{grid-template-columns:1fr}.wj-acc,.wj-wide .wj-acc{grid-template-columns:1fr}}

  /* closing */
  .wj-close{margin-top:36px;text-align:center;padding:42px 24px 8px;border-top:1px solid var(--line)}
  .wj-close .wj-pl{margin-bottom:10px}
  .wj-close-q{font-family:var(--disp);font-weight:500;font-size:clamp(1.5rem,3.6vw,2.5rem);line-height:1.24;max-width:920px;margin:0 auto;color:var(--mut);text-wrap:balance}
  .wj-close-q b{color:var(--ink);font-weight:600}
  .wj-close-q em{font-style:italic;color:var(--gold-soft)}

  @media(prefers-reduced-motion:reduce){.wj-wire::before,.wj-ring{animation:none}.wj-wire::before{display:none}}

  /* ============ KEYSTONE OS ============ */
  .kos-claim{display:flex;align-items:center;gap:20px;border:1px solid var(--line-warm);border-radius:16px;padding:22px 28px;
    background:linear-gradient(120deg,rgba(233,184,74,.09),var(--bg2) 70%);box-shadow:var(--sh)}
  .kos-claim-l{font-family:var(--mono);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);white-space:nowrap;border-right:1px solid var(--line-warm);padding-right:20px}
  .kos-claim p{font-family:var(--disp);font-size:clamp(1.1rem,2.2vw,1.45rem);font-weight:500;color:var(--mut);line-height:1.3}
  .kos-claim p b{color:var(--ink);font-weight:600}
  @media(max-width:620px){.kos-claim{flex-direction:column;align-items:flex-start;gap:12px}.kos-claim-l{border-right:none;padding-right:0}}

  /* stack */
  .kos-stack{display:flex;flex-direction:column;gap:7px;margin-top:20px;position:relative}
  .kos-layer{display:grid;grid-template-columns:42px 200px 1fr auto;gap:20px;align-items:center;
    padding:18px 22px;border:1px solid var(--line);border-radius:13px;background:var(--panel);position:relative;transition:transform .3s,border-color .3s,box-shadow .3s}
  .kos-layer:hover{transform:translateX(5px);border-color:var(--line-2);box-shadow:var(--sh)}
  .kos-layer::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:2px;border-radius:2px;background:linear-gradient(var(--gold),transparent);opacity:.5}
  .kos-key{border-color:var(--line-warm);background:linear-gradient(120deg,rgba(233,184,74,.08),var(--panel) 60%)}
  .kos-ln{font-family:var(--mono);font-size:12px;color:var(--gold);letter-spacing:1px}
  .kos-lt{font-family:var(--disp);font-size:1.12rem;font-weight:600;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
  .kos-flag{font-family:var(--mono);font-size:8.5px;letter-spacing:1.5px;text-transform:uppercase;color:#160d01;background:var(--metal);padding:3px 7px;border-radius:5px}
  .kos-ld{font-size:.9rem;color:var(--mut);line-height:1.5}
  .kos-tag{font-family:var(--mono);font-size:10px;color:var(--gold-soft);background:rgba(233,184,74,.07);border:1px solid var(--line-warm);border-radius:6px;padding:6px 11px;white-space:nowrap}
  @media(max-width:780px){
    .kos-layer{grid-template-columns:34px 1fr;gap:6px 14px}
    .kos-ld{grid-column:2}.kos-tag{grid-column:2;justify-self:start;margin-top:4px}
  }

  /* compiler */
  .kos-compiler{display:grid;grid-template-columns:1fr auto 1.15fr auto 1fr;gap:14px;align-items:stretch;margin-top:20px}
  .kos-col{border:1px solid var(--line);border-radius:16px;padding:22px;background:var(--bg2)}
  .kos-col-l{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
  .kos-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
  .kos-col li{font-size:.9rem;color:var(--ink);display:flex;gap:9px;line-height:1.3}
  .kos-col li::before{content:"";width:6px;height:6px;margin-top:6px;flex-shrink:0;background:var(--gold);transform:rotate(45deg);opacity:.7}
  .kos-mid{border-color:var(--line-warm);background:linear-gradient(160deg,rgba(233,184,74,.1),var(--bg2));box-shadow:0 0 50px -24px rgba(233,184,74,.6)}
  .kos-verbs{display:flex;flex-wrap:wrap;gap:7px}
  .kos-verbs span{font-family:var(--mono);font-size:10.5px;color:var(--gold-soft);background:rgba(233,184,74,.08);border:1px solid var(--line-warm);border-radius:6px;padding:7px 11px}
  .kos-arrow{display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1.3rem}
  @media(max-width:860px){
    .kos-compiler{grid-template-columns:1fr}
    .kos-arrow{transform:rotate(90deg);padding:4px 0}
  }

  /* simulation */
  .kos-sim{margin-top:20px;border:1px solid var(--line-2);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,var(--panel),var(--bg2));box-shadow:var(--sh)}
  .kos-sim-head{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--mut);padding:16px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;background:rgba(0,0,0,.2)}
  .kos-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 10px var(--teal);animation:pulse 2s ease-out infinite}
  .kos-sim-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
  .kos-stat{background:var(--bg2);padding:22px 18px;text-align:center}
  .kos-sv{font-family:var(--disp);font-weight:700;font-size:clamp(1.7rem,3.5vw,2.4rem);color:var(--gold-soft);line-height:1;letter-spacing:-.01em}
  .kos-sc{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--mut);margin-top:9px;line-height:1.4}
  @media(max-width:680px){.kos-sim-stats{grid-template-columns:repeat(2,1fr)}}
  .kos-console{font-family:var(--mono);font-size:12.5px;line-height:1.85;padding:20px 24px;background:#06080d;color:var(--mut);border-top:1px solid var(--line)}
  .kos-log{opacity:0;transform:translateY(5px)}
  .kos-sim.kos-live .kos-log{animation:koslog .45s ease forwards}
  .kos-sim.kos-live .kos-log:nth-child(1){animation-delay:.1s}
  .kos-sim.kos-live .kos-log:nth-child(2){animation-delay:.42s}
  .kos-sim.kos-live .kos-log:nth-child(3){animation-delay:.74s}
  .kos-sim.kos-live .kos-log:nth-child(4){animation-delay:1.06s}
  .kos-sim.kos-live .kos-log:nth-child(5){animation-delay:1.38s}
  .kos-sim.kos-live .kos-log:nth-child(6){animation-delay:1.7s}
  .kos-sim.kos-live .kos-log:nth-child(7){animation-delay:2.02s}
  @keyframes koslog{to{opacity:1;transform:none}}
  .kos-t{color:var(--gold-soft)}
  .kos-console .ok{color:var(--teal)}
  .kos-console .warn{color:var(--gold)}
  .kos-console .block{color:var(--red);font-weight:700}
  .kos-caret{color:var(--gold);animation:koscaret 1s steps(1) infinite}
  @keyframes koscaret{50%{opacity:0}}
  .kos-certbar{position:relative;height:52px;display:flex;align-items:center;justify-content:center;border-top:1px solid var(--line);background:rgba(0,0,0,.25);overflow:hidden}
  .kos-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(233,184,74,.18),rgba(55,214,178,.16));border-right:1px solid var(--gold)}
  .kos-sim.kos-live .kos-fill{animation:kosfill 2.3s cubic-bezier(.4,0,.2,1) forwards .2s}
  @keyframes kosfill{to{width:100%}}
  .kos-cert{position:relative;font-family:var(--mono);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--teal);opacity:0}
  .kos-sim.kos-live .kos-cert{animation:koscert .6s ease forwards 2.3s}
  @keyframes koscert{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}

  /* playbook labs */
  .kos-labs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px}
  @media(max-width:760px){.kos-labs{grid-template-columns:repeat(2,1fr)}}
  .kos-lab{border:1px solid var(--line);border-radius:14px;padding:20px;background:var(--panel);border-top:2px solid var(--line-warm);transition:transform .3s,box-shadow .3s,border-color .3s}
  .kos-lab:hover{transform:translateY(-5px);box-shadow:var(--sh-gold);border-top-color:var(--gold)}
  .kos-lab-n{font-family:var(--disp);font-size:1.2rem;font-weight:600}
  .kos-lab-s{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-top:6px}
  .kos-compound{margin-top:16px;border:1px solid var(--line-warm);border-left:4px solid var(--gold);border-radius:14px;padding:22px 26px;background:rgba(233,184,74,.05)}
  .kos-compound .kos-pl{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
  .kos-compound p{color:var(--mut);font-size:1.02rem;margin-top:8px;max-width:840px}.kos-compound p b{color:var(--ink)}

  /* throughline */
  .kos-through{margin-top:36px;text-align:center;padding:42px 24px 6px;border-top:1px solid var(--line)}
  .kos-through-q{font-family:var(--disp);font-weight:500;font-size:clamp(1.5rem,3.4vw,2.4rem);line-height:1.22;max-width:900px;margin:0 auto;color:var(--ink);text-wrap:balance}
  .kos-through-q em{font-style:italic;color:var(--gold-soft)}
  .kos-one{font-size:1.05rem;color:var(--mut);max-width:760px;margin:22px auto 0;line-height:1.55}.kos-one b{color:var(--gold-soft);font-weight:600}

  body.no-anim .kos-log{opacity:1;transform:none}
  body.no-anim .kos-fill{width:100%}
  body.no-anim .kos-cert{opacity:1}
  @media(prefers-reduced-motion:reduce){
    .kos-log{opacity:1!important;transform:none!important;animation:none!important}
    .kos-fill{width:100%!important;animation:none!important}.kos-cert{opacity:1!important;animation:none!important}
    .kos-caret,.kos-dot{animation:none}
  }
  .gate{border:1px solid rgba(233,184,74,.34);border-radius:22px;padding:30px;
    background:linear-gradient(160deg,rgba(233,184,74,.07),var(--bg2) 62%);position:relative;overflow:hidden;box-shadow:var(--sh)}
  .gate-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:34px}
  .gate-l{font-family:var(--mono);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:9px}
  .gate-l::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(233,184,74,.6);animation:pulse 2.4s ease-out infinite}
  .gate-pick{display:flex;align-items:center;gap:10px;margin-left:auto}
  .gate-pick label{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--mut)}
  .gate-pick select{font-family:var(--ui);font-size:.86rem;font-weight:600;color:var(--ink);background:var(--panel);border:1px solid var(--line-2);
    border-radius:30px;padding:9px 16px;cursor:pointer;max-width:260px}
  .gate-pick select:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
  #gateRun[disabled]{opacity:.6;cursor:default}

  .gate-rail{overflow-x:auto;overflow-y:hidden;padding:6px 2px 4px;-webkit-overflow-scrolling:touch}
  .rail-inner{position:relative;min-width:680px}
  .rail-line{position:absolute;left:8.33%;right:8.33%;top:21px;height:2px;background:var(--line-2);border-radius:2px;overflow:hidden}
  .rail-fill{position:absolute;left:0;top:0;height:100%;width:0;background:var(--metal);box-shadow:0 0 14px rgba(233,184,74,.6);transition:width .6s cubic-bezier(.4,0,.2,1)}
  .stations{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;position:relative;z-index:2}
  .station{text-align:center;padding:0 6px}
  .st-dot{width:44px;height:44px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;position:relative;
    background:var(--panel);border:1.5px solid var(--line-2);transition:border-color .4s,background .4s,box-shadow .4s,transform .4s}
  .st-g{font-family:var(--mono);font-size:12px;color:var(--mut);transition:opacity .3s}
  .st-check{position:absolute;font-size:18px;color:#160d01;font-weight:800;opacity:0;transform:scale(.4);transition:opacity .3s,transform .3s}
  .station.active .st-dot{border-color:var(--gold);box-shadow:0 0 0 5px rgba(233,184,74,.12),0 0 22px rgba(233,184,74,.5);transform:scale(1.08)}
  .station.active .st-dot::after{content:"";position:absolute;inset:-1.5px;border-radius:50%;border:1.5px solid transparent;border-top-color:var(--gold);animation:spin360 .7s linear infinite}
  @keyframes spin360{to{transform:rotate(360deg)}}
  .station.pass .st-dot{background:var(--metal);border-color:transparent;box-shadow:0 6px 20px -8px rgba(233,184,74,.8)}
  .station.pass .st-g{opacity:0}
  .station.pass .st-check{opacity:1;transform:scale(1)}
  .st-name{font-family:var(--disp);font-size:1.02rem;font-weight:600;line-height:1.1}
  .st-sub{font-size:.74rem;color:var(--dim);margin-top:4px;line-height:1.35;min-height:2.4em}
  .st-stat{font-family:var(--mono);font-size:9.5px;letter-spacing:.3px;text-transform:uppercase;color:var(--dim);margin-top:8px;transition:color .3s;min-height:1.4em}
  .station.active .st-stat{color:var(--gold-soft)}
  .station.pass .st-stat{color:var(--teal)}
  .agent-token{position:absolute;top:21px;left:8.33%;width:26px;height:26px;transform:translate(-50%,-50%);z-index:3;
    transition:left .6s cubic-bezier(.4,0,.2,1);pointer-events:none}
  .agent-token span{position:absolute;inset:0;background:var(--metal);border-radius:4px;transform:rotate(45deg);
    box-shadow:0 0 18px rgba(233,184,74,.9);animation:tokfloat 2.4s ease-in-out infinite}
  .agent-token.done span{animation:none;opacity:.0}
  @keyframes tokfloat{50%{transform:rotate(45deg) scale(1.12)}}

  .gate-stage{min-height:8px;margin-top:30px;display:flex;justify-content:center}
  .gate-stage.show{min-height:auto}

  /* the minted passport */
  .passport{width:100%;max-width:580px;border-radius:20px;padding:28px;position:relative;overflow:hidden;
    background:linear-gradient(158deg,#17120a 0%,#0c0e13 58%,#0a0c11 100%);
    border:1px solid rgba(233,184,74,.5);
    box-shadow:0 36px 90px -42px rgba(233,184,74,.55),inset 0 1px 0 rgba(255,255,255,.07);
    opacity:0;transform:translateY(26px) scale(.96);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
  .gate-stage.show .passport{opacity:1;transform:none}
  .passport::before{content:"";position:absolute;inset:8px;border:1px solid rgba(233,184,74,.18);border-radius:13px;pointer-events:none}
  .pp-sheen{position:absolute;top:-60%;left:-30%;width:50%;height:220%;transform:rotate(18deg);pointer-events:none;
    background:linear-gradient(90deg,transparent,rgba(255,240,200,.16),transparent);animation:ppsheen 4.5s ease-in-out infinite 1s}
  @keyframes ppsheen{0%{left:-40%}55%,100%{left:130%}}
  .pp-top{display:flex;align-items:center;gap:16px;position:relative;z-index:2}
  .pp-seal{width:52px;height:52px;position:relative;flex-shrink:0}
  .pp-seal .pp-key{position:absolute;inset:0;background:var(--metal);transform:rotate(45deg);border-radius:7px;box-shadow:0 0 22px rgba(233,184,74,.6)}
  .pp-seal::after{content:"";position:absolute;inset:13px;background:#0c0e13;transform:rotate(45deg);border-radius:4px}
  .pp-kicker{font-family:var(--mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}
  .pp-name{font-family:var(--disp);font-size:1.5rem;font-weight:600;line-height:1;margin-top:3px}
  .pp-badge{margin-left:auto;font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);
    border:1px solid rgba(55,214,178,.45);background:rgba(55,214,178,.08);padding:7px 13px;border-radius:30px;white-space:nowrap}
  .pp-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 22px;margin:22px 0 18px;position:relative;z-index:2}
  .pp-grid dt{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--dim)}
  .pp-grid dd{font-size:.92rem;color:var(--ink);font-weight:500;margin-top:3px}
  .pp-grid dd.mono{font-family:var(--mono);color:var(--gold-soft);letter-spacing:.5px}
  .pp-stamps{display:flex;flex-wrap:wrap;gap:7px;position:relative;z-index:2}
  .pp-stamp{font-family:var(--mono);font-size:9.5px;letter-spacing:.5px;color:var(--gold-soft);
    border:1px solid rgba(233,184,74,.3);background:rgba(233,184,74,.06);border-radius:6px;padding:5px 9px;display:inline-flex;align-items:center;gap:5px}
  .pp-stamp i{font-style:normal;color:var(--teal);font-size:10px}
  .pp-hash{display:flex;gap:3px;margin-top:16px;position:relative;z-index:2}
  .pp-hash i{width:7px;height:14px;border-radius:1px;background:rgba(255,255,255,.06)}
  .pp-hash i.on{background:var(--gold);box-shadow:0 0 6px rgba(233,184,74,.5)}
  .pp-foot{font-family:var(--mono);font-size:9px;letter-spacing:.5px;color:var(--dim);margin-top:16px;position:relative;z-index:2}
  .gate-again{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:22px;width:100%}
  .gate-note{font-size:.86rem;color:var(--mut);font-style:italic}

  @media(max-width:560px){
    .pp-grid{grid-template-columns:1fr}
    .gate{padding:22px}
  }
  @media(prefers-reduced-motion:reduce){
    .pp-sheen,.agent-token span,.station.active .st-dot::after,.gate-l::before{animation:none}
    .passport,.rail-fill,.agent-token,.st-dot,.st-check{transition:none}
  }

  /* ============ KEYSTONE AI AGENT ============ */
  #kai{position:fixed;right:22px;bottom:22px;z-index:170;font-family:var(--ui)}

  /* shared keystone mark */
  .kai-mark{position:relative;display:inline-block;width:18px;height:18px;flex-shrink:0}
  .kai-mark::before{content:"";position:absolute;inset:0;background:var(--metal);clip-path:polygon(0 0,100% 0,78% 100%,22% 100%);box-shadow:0 0 14px rgba(233,184,74,.55)}
  .kai-mark::after{content:"";position:absolute;inset:4px 5px;background:#0B1018;clip-path:polygon(0 0,100% 0,74% 100%,26% 100%)}

  /* launcher */
  .kai-fab{position:relative;display:inline-flex;align-items:center;gap:11px;background:linear-gradient(180deg,#131B27,#0C121B);color:var(--ink);
    border:1px solid var(--line-warm);font-family:var(--ui);font-weight:700;letter-spacing:.2px;font-size:.88rem;
    padding:13px 21px 13px 17px;border-radius:40px;cursor:pointer;
    box-shadow:0 1px 0 rgba(255,255,255,.06) inset,0 18px 44px -18px rgba(0,0,0,.9),0 0 0 0 rgba(233,184,74,.0);
    transition:transform .25s,border-color .3s,box-shadow .35s,opacity .25s}
  .kai-fab:hover{transform:translateY(-2px);border-color:var(--gold);box-shadow:0 1px 0 rgba(255,255,255,.08) inset,0 22px 52px -18px rgba(0,0,0,.95),0 0 28px -6px rgba(233,184,74,.45)}
  .kai-fab.hide{opacity:0;transform:translateY(12px) scale(.92);pointer-events:none}
  @media(max-width:520px){.kai-fab-t{display:none}.kai-fab{padding:14px}}

  /* panel */
  .kai-panel{position:fixed;top:0;right:0;bottom:0;width:var(--kai-w,440px);max-width:calc(100vw - 12px);
    display:flex;flex-direction:column;
    background:linear-gradient(180deg,rgba(13,18,27,.97),rgba(8,12,18,.985));
    backdrop-filter:blur(22px) saturate(1.25);-webkit-backdrop-filter:blur(22px) saturate(1.25);
    border-left:1px solid rgba(255,255,255,.1);border-radius:0;overflow:hidden;
    box-shadow:-30px 0 80px -30px rgba(0,0,0,.85),-1px 0 0 rgba(233,184,74,.12);
    transform:translateX(103%);pointer-events:none;
    transition:transform .45s cubic-bezier(.2,.8,.2,1)}
  .kai-panel.open{transform:none;pointer-events:auto}
  body.no-anim .kai-panel{transition:none}
  body.kai-noanim .kai-panel,body.kai-noanim{transition:none!important}
  body.no-anim,body.no-anim .kai-panel{transition:none!important}
  /* the page yields to the drawer */
  body{transition:margin-right .45s cubic-bezier(.2,.8,.2,1)}
  body.kai-open{margin-right:var(--kai-w,440px)}
  body.kai-open nav{right:var(--kai-w,440px)}
  @media(max-width:900px){
    body.kai-open{margin-right:0}
    body.kai-open nav{right:0}
  }
  /* drag-to-resize edge */
  .kai-rs{position:absolute;left:-4px;top:0;bottom:0;width:9px;cursor:col-resize;z-index:8;touch-action:none}
  .kai-rs::after{content:"";position:absolute;left:4px;top:50%;height:64px;width:3px;transform:translateY(-50%);border-radius:3px;background:rgba(255,255,255,.16);transition:background .2s,height .2s}
  .kai-rs:hover::after{background:var(--gold);height:90px}
  @media(max-width:900px){.kai-rs{display:none}}

  /* header */
  .kai-head{display:flex;align-items:center;gap:12px;padding:16px 16px 14px 18px}
  .kai-id{display:flex;flex-direction:column;gap:2px;min-width:0;margin-right:auto}
  .kai-id b{font-family:var(--disp);font-weight:600;font-size:1.08rem;line-height:1}
  .kai-sub{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:8.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--dim);white-space:nowrap}
  .kai-live{width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px var(--teal);animation:pulse 2.4s ease-out infinite}
  .kai-hbtn{width:30px;height:30px;display:grid;place-items:center;background:none;border:1px solid transparent;border-radius:9px;
    color:var(--dim);font-size:1.05rem;line-height:1;cursor:pointer;transition:color .2s,border-color .2s,background .2s}
  .kai-hbtn:hover{color:var(--ink);border-color:var(--line);background:rgba(255,255,255,.04)}

  /* context strip */
  .kai-ctxbar{display:flex;align-items:center;gap:10px;margin:0 16px;padding:9px 2px 11px;border-top:1px solid rgba(255,255,255,.06)}
  .kai-ctx-l{font-family:var(--mono);font-size:8.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--dim)}
  .kai-ctx{font-family:var(--mono);font-size:10px;letter-spacing:.6px;color:var(--gold-soft);border:1px solid var(--line-warm);
    background:rgba(233,184,74,.06);border-radius:30px;padding:4px 11px;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .kai-ctx.tick{animation:kaiTick .5s cubic-bezier(.2,.8,.2,1)}
  @keyframes kaiTick{0%{transform:translateY(6px);opacity:0}100%{transform:none;opacity:1}}

  /* log */
  .kai-log{flex:1;overflow-y:auto;padding:8px 18px 18px;display:flex;flex-direction:column;gap:15px;scrollbar-width:thin}
  .kai-log::-webkit-scrollbar{width:5px}
  .kai-log::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px;border:none}

  .kai-msg{display:flex;gap:9px;max-width:94%}
  .kai-user{align-self:flex-end;flex-direction:row-reverse;max-width:86%}
  .kai-bot{align-self:flex-start}
  .kai-msg.kai-wide{max-width:100%;width:100%}
  .kai-av{width:24px;height:24px;flex-shrink:0;display:grid;place-items:center;margin-top:2px;border-radius:8px;
    background:rgba(233,184,74,.07);border:1px solid var(--line-warm)}
  .kai-av .kai-mark{width:11px;height:11px}
  .kai-av .kai-mark::before{box-shadow:none}
  .kai-msg.kai-grp .kai-av{visibility:hidden}
  .kai-body{display:flex;flex-direction:column;gap:7px;min-width:0;flex:1}
  .kai-user .kai-body{align-items:flex-end}

  .kai-bubble{font-size:.92rem;line-height:1.62;padding:12px 15px;border-radius:15px;white-space:pre-wrap;overflow-wrap:break-word;text-wrap:pretty;max-width:100%;width:fit-content}
  .kai-bot .kai-bubble{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.07);color:var(--ink);border-top-left-radius:5px}
  .kai-user .kai-bubble{background:rgba(233,184,74,.12);border:1px solid rgba(233,184,74,.3);color:var(--gold-soft);font-weight:500;border-top-right-radius:5px}
  .kai-err .kai-bubble{border-color:var(--line-warm);color:var(--mut);font-style:italic}

  /* thinking */
  .kai-stage{font-family:var(--mono);font-size:9.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--gold);margin-right:9px;
    background:linear-gradient(90deg,var(--gold-2),var(--gold-soft),var(--gold-2));background-size:200% 100%;
    -webkit-background-clip:text;background-clip:text;color:transparent;animation:kaiShimmer 1.8s linear infinite}
  @keyframes kaiShimmer{to{background-position:-200% 0}}
  body.no-anim .kai-stage{color:var(--gold);background:none;-webkit-background-clip:initial;background-clip:initial}
  .kai-typ{display:inline-flex;gap:4px}
  .kai-typ i{width:5px;height:5px;border-radius:50%;background:var(--gold);opacity:.5;animation:kaityp 1s infinite}
  .kai-typ i:nth-child(2){animation-delay:.16s}.kai-typ i:nth-child(3){animation-delay:.32s}
  @keyframes kaityp{0%,60%,100%{opacity:.35;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}

  /* streaming */
  .kai-word{display:inline-block;white-space:pre;opacity:0;transform:translateY(.26em)}
  .kai-word.in{animation:kaiWord .3s cubic-bezier(.2,.8,.2,1) forwards}
  @keyframes kaiWord{to{opacity:1;transform:none}}
  .kai-caret2{display:inline-block;width:.46em;height:1em;vertical-align:-.14em;margin-left:1px;border-radius:1px;
    background:linear-gradient(var(--gold-soft),var(--gold-2));box-shadow:0 0 8px rgba(233,184,74,.6);animation:kaiBlink 1s steps(1) infinite}
  @keyframes kaiBlink{50%{opacity:0}}

  /* meta row under replies */
  .kai-meta{display:flex;align-items:center;gap:9px;padding-left:3px;opacity:0;animation:kaiMeta .5s ease forwards .1s}
  @keyframes kaiMeta{to{opacity:1}}
  body.no-anim .kai-meta{opacity:1}
  .kai-conf{width:34px;height:3px;border-radius:3px;background:rgba(255,255,255,.1);overflow:hidden;cursor:help}
  .kai-conf i{display:block;height:100%;width:var(--p,50%);border-radius:3px;background:linear-gradient(90deg,var(--gold-2),var(--gold-soft))}
  .kai-meta-t{font-family:var(--mono);font-size:8.5px;letter-spacing:1px;text-transform:uppercase;color:var(--dim)}
  .kai-meta-dim{opacity:.7}
  .kai-jump,.kai-copy{font-family:var(--mono);font-size:8.5px;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;
    background:none;border:none;padding:2px 4px;border-radius:5px;transition:color .2s,background .2s}
  .kai-jump{color:var(--gold-soft)}
  .kai-jump:hover{background:rgba(233,184,74,.1)}
  .kai-copy{color:var(--dim);margin-left:auto}
  .kai-copy:hover{color:var(--ink)}
  .kai-copy.did{color:var(--teal)}

  /* clarify card */
  .kai-clar{width:100%;display:flex;flex-direction:column;gap:11px;padding:14px 15px;border:1px solid var(--line-warm);
    border-radius:14px;background:linear-gradient(160deg,rgba(233,184,74,.06),rgba(233,184,74,.02))}
  .kai-msg.kai-done .kai-clar{opacity:.55}
  .kai-clar-guess{font-size:.84rem;color:var(--mut);font-style:italic;line-height:1.45;padding-bottom:2px;border-bottom:1px dashed rgba(233,184,74,.18)}
  .kai-clar-q{font-family:var(--mono);font-size:9px;letter-spacing:1.3px;text-transform:uppercase;color:var(--gold);margin-top:2px}
  .kai-opts{display:flex;flex-wrap:wrap;gap:7px}
  .kai-opt{font-size:.8rem;color:var(--ink);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
    border-radius:10px;padding:8px 13px;cursor:pointer;text-align:left;line-height:1.25;transition:border-color .2s,background .2s,transform .2s}
  .kai-opt:hover{border-color:var(--gold);background:rgba(233,184,74,.1);transform:translateY(-1px)}
  .kai-opt:disabled{opacity:.45;cursor:default;transform:none}
  .kai-clar-hint{font-family:var(--mono);font-size:8.5px;letter-spacing:1px;text-transform:uppercase;color:var(--dim)}

  /* welcome */
  .kai-hello{display:flex;flex-direction:column;align-items:center;text-align:center;gap:13px;padding:34px 14px 10px;margin:auto 0}
  .kai-hello .kai-mark{width:34px;height:34px}
  .kai-hello-t{font-family:var(--disp);font-weight:600;font-size:1.35rem;letter-spacing:-.01em}
  .kai-hello-s{font-size:.88rem;color:var(--mut);line-height:1.55;max-width:300px;text-wrap:pretty}
  .kai-starters{display:flex;flex-direction:column;gap:7px;width:100%;margin-top:10px}
  .kai-starter{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;text-align:left;
    font-size:.86rem;color:var(--ink);background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);
    border-radius:12px;padding:12px 15px;cursor:pointer;line-height:1.3;transition:border-color .22s,background .22s,transform .22s}
  .kai-starter i{font-style:normal;color:var(--dim);transition:transform .22s,color .22s}
  .kai-starter:hover{border-color:var(--line-warm);background:rgba(233,184,74,.07);transform:translateX(3px)}
  .kai-starter:hover i{color:var(--gold);transform:translateX(3px)}

  /* jump-to-latest */
  .kai-down{position:absolute;right:16px;bottom:84px;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
    background:rgba(15,21,30,.95);border:1px solid var(--line-warm);color:var(--gold-soft);font-size:.95rem;cursor:pointer;
    opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .25s,transform .25s;box-shadow:0 10px 26px -10px rgba(0,0,0,.8)}
  .kai-down.show{opacity:1;transform:none;pointer-events:auto}
  .kai-down:hover{border-color:var(--gold)}

  /* input */
  .kai-input{display:flex;gap:9px;padding:13px 16px 16px;border-top:1px solid rgba(255,255,255,.06);background:rgba(0,0,0,.18)}
  .kai-input input{flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:13px;
    padding:12px 16px;color:var(--ink);font-family:var(--ui);font-size:.92rem;outline:none;transition:border-color .25s,background .25s,box-shadow .25s}
  .kai-input input::placeholder{color:var(--dim)}
  .kai-input input:focus{border-color:var(--gold);background:rgba(233,184,74,.05);box-shadow:0 0 0 3px rgba(233,184,74,.12)}
  .kai-input button{width:44px;flex-shrink:0;background:var(--metal);color:#160d01;border:none;border-radius:13px;
    font-size:1.1rem;font-weight:800;cursor:pointer;display:grid;place-items:center;
    box-shadow:0 1px 0 rgba(255,255,255,.4) inset;transition:transform .2s,opacity .2s,box-shadow .25s}
  .kai-input button:hover{transform:translateY(-1px);box-shadow:0 1px 0 rgba(255,255,255,.5) inset,0 10px 24px -10px rgba(233,184,74,.7)}
  .kai-input button:disabled{opacity:.45;cursor:default;transform:none;box-shadow:none}

  @media(max-width:520px){
    .kai-panel{width:100vw;max-width:100vw}
  }
  @media(prefers-reduced-motion:reduce){
    .kai-panel,.kai-fab,.kai-starter,.kai-opt{transition:none}
    .kai-live,.kai-typ i,.kai-word,.kai-caret2,.kai-stage{animation:none}
    .kai-word{opacity:1;transform:none}
    .kai-stage{color:var(--gold);background:none;-webkit-background-clip:initial;background-clip:initial}
    .kai-meta{opacity:1;animation:none}
  }

  /* ===== agent pipeline trace ===== */
  .kai-trace{display:flex;flex-wrap:wrap;gap:5px 14px;padding:10px 13px;border:1px solid rgba(255,255,255,.07);
    border-radius:12px;background:rgba(0,0,0,.22);width:100%}
  .kai-tstep{display:inline-flex;align-items:center;gap:6px;min-height:16px}
  .kai-tstep i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.14);flex-shrink:0;transition:background .25s,box-shadow .25s}
  .kai-tstep .kai-tl{font-family:var(--mono);font-size:8.5px;letter-spacing:1.1px;text-transform:uppercase;color:var(--dim);transition:color .25s}
  .kai-tstep em{font-family:var(--mono);font-style:normal;font-size:8.5px;letter-spacing:.3px;color:var(--dim);opacity:.85;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .kai-tstep.active i{background:var(--gold);box-shadow:0 0 9px rgba(233,184,74,.8);animation:pulse 1.4s ease-out infinite}
  .kai-tstep.active .kai-tl{color:var(--gold-soft)}
  .kai-tstep.done i{background:var(--teal);box-shadow:0 0 7px rgba(55,214,178,.55)}
  .kai-tstep.done .kai-tl{color:var(--mut)}
  .kai-tstep.done em{color:var(--gold-soft);opacity:.95}

  /* certification stamp */
  .kai-cert{font-family:var(--mono);font-size:8.5px;letter-spacing:1px;text-transform:uppercase;color:var(--teal);
    border:1px solid rgba(55,214,178,.3);background:rgba(55,214,178,.06);border-radius:30px;padding:3px 9px;cursor:help}

  /* follow-up suggestions */
  .kai-fus{display:flex;flex-direction:column;gap:6px;width:100%}
  .kai-fu{display:block;width:fit-content;max-width:100%;text-align:left;font-size:.8rem;color:var(--gold-soft);
    background:rgba(233,184,74,.05);border:1px dashed rgba(233,184,74,.3);border-radius:10px;padding:8px 12px;
    cursor:pointer;line-height:1.3;transition:border-color .2s,background .2s,transform .2s}
  .kai-fu:hover{border-style:solid;border-color:var(--gold);background:rgba(233,184,74,.1);transform:translateX(2px)}

  @media(prefers-reduced-motion:reduce){.kai-tstep i{animation:none}}

  /* ===== rich replies ===== */
  .kai-bubble.kai-rich{width:100%;display:block}
  .kai-rich p{margin:0 0 9px}
  .kai-rich p:last-child,.kai-rich ul:last-child,.kai-rich ol:last-child,.kai-rich .kai-chart:last-child{margin-bottom:0}
  .kai-rich b,.kai-word.kb{font-weight:700;color:var(--gold-soft)}
  .kai-rich em,.kai-word.ke{font-style:italic}
  .kai-rich code,.kai-word.kc{font-family:var(--mono);font-size:.8em;background:rgba(233,184,74,.08);border:1px solid var(--line-warm);border-radius:5px;padding:1px 5px;color:var(--gold-soft)}
  .kai-rich ul,.kai-rich ol{margin:2px 0 10px;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}
  .kai-rich li{position:relative;padding-left:17px;line-height:1.5}
  .kai-rich ul li::before{content:"";position:absolute;left:2px;top:.52em;width:6px;height:6px;background:var(--gold);transform:rotate(45deg);opacity:.7}
  .kai-rich ol{counter-reset:kai}
  .kai-rich ol li{counter-increment:kai;padding-left:24px}
  .kai-rich ol li::before{content:counter(kai,decimal-leading-zero);position:absolute;left:0;top:.2em;font-family:var(--mono);font-size:9px;color:var(--gold)}
  .kai-lab{font-family:var(--mono);font-size:9px;letter-spacing:1.6px;text-transform:uppercase;color:var(--gold);margin:3px 0 7px}

  /* ===== in-chat charts ===== */
  .kai-chart{margin:7px 0 11px;padding:13px 14px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(0,0,0,.22)}
  .kai-ch-t{font-family:var(--mono);font-size:9px;letter-spacing:1.4px;text-transform:uppercase;color:var(--mut);margin-bottom:11px}
  .kai-ch-row{display:grid;grid-template-columns:minmax(96px,42%) 1fr auto;gap:10px;align-items:center;margin-bottom:9px}
  .kai-ch-row:last-child{margin-bottom:0}
  .kai-ch-l{font-size:.73rem;color:var(--mut);line-height:1.3;white-space:normal;overflow-wrap:break-word}
  .kai-ch-track{height:8px;border-radius:5px;background:rgba(255,255,255,.07);overflow:hidden}
  .kai-ch-track i{display:block;height:100%;width:0;border-radius:5px;background:linear-gradient(90deg,var(--gold-2),var(--gold-soft));box-shadow:0 0 10px rgba(233,184,74,.35);transition:width .9s cubic-bezier(.2,.8,.2,1)}
  .kai-ch-v{font-family:var(--mono);font-size:10px;color:var(--gold-soft);white-space:nowrap}
  .kai-ch-stats{display:flex;gap:8px;flex-wrap:wrap}
  .kai-ch-stat{flex:1 1 72px;text-align:center;padding:11px 8px;border:1px solid rgba(255,255,255,.07);border-radius:10px;background:rgba(255,255,255,.025)}
  .kai-ch-stat b{display:block;font-family:var(--disp);font-size:1.3rem;font-weight:700;color:var(--gold-soft);line-height:1.05}
  .kai-ch-stat span{display:block;font-family:var(--mono);font-size:8px;letter-spacing:.8px;text-transform:uppercase;color:var(--dim);margin-top:5px;line-height:1.35}
  .kai-ch-donut{display:flex;align-items:center;gap:15px}
  .kai-ch-donut>i{width:88px;height:88px;border-radius:50%;flex-shrink:0;-webkit-mask:radial-gradient(circle,transparent 27px,#000 28px);mask:radial-gradient(circle,transparent 27px,#000 28px)}
  .kai-ch-leg{display:flex;flex-direction:column;gap:6px;min-width:0}
  .kai-ch-leg span{display:flex;align-items:center;gap:7px;font-size:.74rem;color:var(--mut)}
  .kai-ch-leg i{width:8px;height:8px;border-radius:2px;flex-shrink:0}

  /* ===== Gate policy hold ===== */
  .kai-tstep.hold i{background:rgba(255,107,107,.85);box-shadow:0 0 8px rgba(255,107,107,.45)}
  .kai-tstep.hold .kai-tl{color:var(--mut)}
  .kai-tstep.hold em{color:var(--red);opacity:.9}
  .kai-policy{width:100%;display:flex;flex-direction:column;gap:10px;padding:14px 15px;border:1px solid rgba(255,107,107,.3);border-radius:14px;background:linear-gradient(160deg,rgba(255,107,107,.06),rgba(0,0,0,.12))}
  .kai-pol-l{font-family:var(--mono);font-size:9px;letter-spacing:1.4px;text-transform:uppercase;color:var(--red)}
  .kai-pol-r{font-size:.88rem;color:var(--ink);line-height:1.5}
  .kai-pol-s{font-size:.78rem;color:var(--mut);line-height:1.45;border-top:1px dashed rgba(255,255,255,.12);padding-top:9px}

  /* ===== Truth Layer section ===== */
  .tl-legend{display:flex;flex-wrap:wrap;gap:9px}
  .tl-b{font-family:var(--mono);font-size:9.5px;letter-spacing:1px;text-transform:uppercase;padding:7px 13px;border-radius:30px;border:1px solid var(--line)}
  .tl-ey{color:var(--teal);border-color:rgba(55,214,178,.35);background:rgba(55,214,178,.06)}
  .tl-pt{color:var(--blue);border-color:rgba(91,151,255,.35);background:rgba(91,151,255,.06)}
  .tl-ks{color:var(--gold-soft);border-color:var(--line-warm);background:rgba(233,184,74,.07)}
  .tl-inf{color:var(--violet);border-color:rgba(180,152,255,.35);background:rgba(180,152,255,.06)}
  .tl-cf{color:var(--red);border-color:rgba(255,107,107,.35);background:rgba(255,107,107,.06)}
  .tl-st{color:var(--dim);border-color:var(--line);background:rgba(255,255,255,.03)}
  .tl-loop{font-family:var(--mono);font-size:11px;letter-spacing:1.2px;color:var(--mut);padding:14px 18px;border:1px dashed var(--line-warm);border-radius:12px;background:rgba(233,184,74,.03);overflow-x:auto;white-space:nowrap}

  /* ===== chat: claim citation chips ===== */
  .kai-claim{display:inline-block;font-family:var(--mono);font-size:8.5px;letter-spacing:.5px;padding:2px 7px;border-radius:6px;cursor:help;vertical-align:.12em;margin:0 1px;border:1px solid}
  .kai-claim-ey{color:var(--teal);border-color:rgba(55,214,178,.4);background:rgba(55,214,178,.08)}
  .kai-claim-pt{color:var(--blue);border-color:rgba(91,151,255,.4);background:rgba(91,151,255,.08)}
  .kai-claim-ks{color:var(--gold-soft);border-color:var(--line-warm);background:rgba(233,184,74,.09)}
  .kai-claim-mk{color:var(--mut);border-color:var(--line-2);background:rgba(255,255,255,.05)}

  /* ===== chat: evidence-basis badges ===== */
  .kai-basis{display:flex;flex-wrap:wrap;gap:6px;padding-left:3px}
  .kai-b{font-family:var(--mono);font-size:8.5px;letter-spacing:.8px;text-transform:uppercase;padding:4px 10px;border-radius:30px;border:1px solid;cursor:help}
  .kai-b-ey{color:var(--teal);border-color:rgba(55,214,178,.35);background:rgba(55,214,178,.06)}
  .kai-b-pt{color:var(--blue);border-color:rgba(91,151,255,.35);background:rgba(91,151,255,.06)}
  .kai-b-ks{color:var(--gold-soft);border-color:var(--line-warm);background:rgba(233,184,74,.07)}
  .kai-b-mk{color:var(--mut);border-color:var(--line-2);background:rgba(255,255,255,.04)}
  .kai-b-inf{color:var(--violet);border-color:rgba(180,152,255,.35);background:rgba(180,152,255,.06)}

  /* ============ CHAT POLISH PASS ============ */
  /* drawer ambiance: gold edge light + top aura */
  .kai-panel::before{content:"";position:absolute;inset:0 auto 0 0;width:1px;background:linear-gradient(180deg,rgba(233,184,74,.5),rgba(233,184,74,.08) 30%,rgba(233,184,74,.08) 70%,rgba(233,184,74,.4));pointer-events:none;z-index:9}
  .kai-panel::after{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:130%;height:240px;background:radial-gradient(50% 100% at 50% 0%,rgba(233,184,74,.09),transparent 70%);pointer-events:none}

  /* header refined */
  .kai-head{padding:18px 18px 14px 20px;gap:13px}
  .kai-head .kai-mark{width:22px;height:22px;filter:drop-shadow(0 0 10px rgba(233,184,74,.5))}
  .kai-id b{font-size:1.16rem;letter-spacing:.2px}
  .kai-ctxbar{margin:0 18px;border-top:1px solid transparent;border-image:linear-gradient(90deg,rgba(233,184,74,.3),rgba(255,255,255,.07) 60%,transparent) 1}

  /* welcome: editorial moment */
  .kai-hello{gap:0;padding:40px 18px 14px}
  .kai-hello-mark .kai-mark{width:40px;height:40px;filter:drop-shadow(0 0 22px rgba(233,184,74,.55))}
  .kai-hello-eyebrow{font-family:var(--mono);font-size:8.5px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-top:18px}
  .kai-hello-t{font-family:var(--disp);font-weight:600;font-size:1.62rem;line-height:1.16;letter-spacing:-.01em;margin-top:12px;text-wrap:balance}
  .kai-hello-t em{font-style:italic;font-weight:500;color:var(--gold-soft)}
  .kai-hello-s{font-size:.9rem;color:var(--mut);line-height:1.6;max-width:320px;margin-top:12px}
  .kai-rule{display:flex;justify-content:center;width:100%;padding:20px 0 18px}
  .kai-rule i{width:54px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
  .kai-starters{gap:8px;margin-top:0}
  .kai-starter{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:13px;padding:13px 16px;border-radius:13px;
    background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.08)}
  .kai-st-n{font-family:var(--mono);font-size:9px;letter-spacing:1px;color:var(--dim);transition:color .22s}
  .kai-st-q{font-size:.87rem;color:var(--ink);line-height:1.35}
  .kai-starter:hover{border-color:var(--line-warm);background:linear-gradient(180deg,rgba(233,184,74,.09),rgba(233,184,74,.03));transform:translateX(3px)}
  .kai-starter:hover .kai-st-n{color:var(--gold)}

  /* bubbles refined */
  .kai-bot .kai-bubble{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.028));border:1px solid rgba(255,255,255,.08);box-shadow:0 1px 0 rgba(255,255,255,.05) inset,0 8px 24px -16px rgba(0,0,0,.7)}
  .kai-user .kai-bubble{background:linear-gradient(180deg,rgba(233,184,74,.16),rgba(233,184,74,.08));border:1px solid rgba(233,184,74,.34);box-shadow:0 1px 0 rgba(255,238,196,.12) inset}
  .kai-av{border-radius:9px;background:linear-gradient(180deg,rgba(233,184,74,.12),rgba(233,184,74,.04));box-shadow:0 1px 0 rgba(255,255,255,.06) inset}

  /* trace: jewel rail */
  .kai-trace{background:linear-gradient(180deg,rgba(0,0,0,.3),rgba(0,0,0,.18));border-color:rgba(255,255,255,.08);box-shadow:0 1px 0 rgba(255,255,255,.04) inset}

  /* input: floating */
  .kai-input{padding:14px 18px 18px;background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.32))}
  .kai-input input{border-radius:14px;padding:13px 17px;background:rgba(255,255,255,.055);border-color:rgba(255,255,255,.12)}
  .kai-input input:focus{border-color:var(--gold);background:rgba(233,184,74,.06);box-shadow:0 0 0 3px rgba(233,184,74,.13),0 0 24px -6px rgba(233,184,74,.35)}
  .kai-input button{border-radius:14px;position:relative;overflow:hidden}
  .kai-input button::after{content:"";position:absolute;top:0;left:-130%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-18deg);transition:left .5s}
  .kai-input button:hover::after{left:130%}

  /* ============ BREATHING ROOM + PROGRESSIVE DISCLOSURE ============ */
  /* spacing pass */
  .sec{padding:clamp(122px,13vh,170px) 0}
  .kick{margin-bottom:30px}
  .lead{margin-top:22px}
  .wj-head{margin-top:58px}
  .kos-stack{margin-top:24px;gap:9px}
  .kos-compiler,.kos-sim,.kos-labs{margin-top:24px}
  .subhead{margin:50px 0 8px}

  /* OS stack: collapsed layers — hover to peek, click to pin */
  .kos-stack .kos-layer{grid-template-columns:42px 1fr auto auto;cursor:pointer;row-gap:0}
  .kos-stack .kos-layer .kos-ln{grid-row:1;grid-column:1}
  .kos-stack .kos-layer .kos-lt{grid-row:1;grid-column:2}
  .kos-stack .kos-layer .kos-tag{grid-row:1;grid-column:3;justify-self:end;margin-top:0}
  .kos-stack .kos-layer::after{content:"+";grid-row:1;grid-column:4;font-family:var(--mono);font-size:15px;color:var(--gold);opacity:.7;transition:opacity .25s}
  .kos-stack .kos-layer:hover::after{opacity:1}
  .kos-stack .kos-layer.open::after{content:"\2212"}
  .kos-stack .kos-ld{grid-row:2;grid-column:2/-1;max-height:0;opacity:0;overflow:hidden;margin-top:0;
    transition:max-height .45s cubic-bezier(.2,.8,.2,1),opacity .35s,margin-top .35s}
  .kos-stack .kos-layer:hover .kos-ld,.kos-stack .kos-layer.open .kos-ld{max-height:150px;opacity:1;margin-top:9px}
  @media(max-width:780px){
    .kos-stack .kos-layer{grid-template-columns:34px 1fr auto}
    .kos-stack .kos-layer .kos-tag{display:none}
    .kos-stack .kos-layer::after{grid-column:3}
    .kos-stack .kos-ld{grid-column:2/-1}
  }

  /* risk matrix: risk visible, control reveals on hover / pins on click */
  .matrix .mrow{grid-template-columns:1fr;cursor:pointer;transition:border-color .3s}
  .matrix .mrow:hover{border-color:var(--line-2)}
  .mrow .risk{position:relative;padding-right:50px}
  .mrow .risk::after{content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:15px;color:var(--gold);opacity:.7;transition:opacity .25s}
  .mrow:hover .risk::after{opacity:1}
  .mrow.open .risk::after{content:"\2212"}
  .mrow .ctrl{max-height:0;opacity:0;overflow:hidden;padding-top:0;padding-bottom:0;border-left:none;border-top:0;
    transition:max-height .45s cubic-bezier(.2,.8,.2,1),opacity .35s,padding .35s}
  .mrow .ctrl::before{content:"control \00b7\00a0";font-family:var(--mono);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);white-space:pre}
  .mrow:hover .ctrl,.mrow.open .ctrl{max-height:160px;opacity:1;padding-top:13px;padding-bottom:16px;border-top:1px solid var(--line)}
  @media(max-width:640px){.mrow .ctrl{border-top:0}}

  /* never trap content: frozen tabs, reduced motion, print */
  body.no-anim .kos-ld,body.no-anim .mrow .ctrl{transition:none}
  @media(prefers-reduced-motion:reduce){.kos-ld,.mrow .ctrl{transition:none}}
  @media print{
    .kos-stack .kos-ld,.mrow .ctrl{max-height:none!important;opacity:1!important;margin-top:9px!important;padding-top:13px!important;padding-bottom:16px!important}
    .kos-stack .kos-layer::after,.mrow .risk::after{display:none}
  }

  /* ===== claim source links + evidence panel ===== */
  a.kai-claim{text-decoration:none;transition:filter .2s,transform .2s}
  a.kai-claim:hover{filter:brightness(1.3);transform:translateY(-1px)}
  .kai-b{cursor:pointer;transition:filter .2s}
  .kai-b:hover{filter:brightness(1.25)}
  .kai-evid{display:none;flex-direction:column;gap:8px;padding:11px 13px;border:1px solid rgba(255,255,255,.08);border-radius:11px;background:rgba(0,0,0,.25)}
  .kai-evid.show{display:flex}
  .kai-ev-row{display:flex;align-items:baseline;gap:8px;font-size:.78rem;color:var(--mut);line-height:1.45}
  .kai-ev-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;align-self:center;background:currentColor;border:none!important;padding:0!important}
  .kai-ev-row a{font-family:var(--mono);font-size:9px;letter-spacing:.6px;text-transform:uppercase;color:var(--gold-soft);text-decoration:none;white-space:nowrap;border-bottom:1px dotted rgba(233,184,74,.4)}
  .kai-ev-row a:hover{color:var(--gold);border-bottom-style:solid}
  /* ===== AI OS force/property/output cards ===== */
  .kf-grid{display:grid;gap:12px;margin-top:24px}
  .kf-5{grid-template-columns:repeat(5,1fr)}
  .kf-3{grid-template-columns:repeat(3,1fr)}
  @media(max-width:980px){.kf-5{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:640px){.kf-5,.kf-3{grid-template-columns:1fr}}
  .kf{border:1px solid var(--line);border-radius:15px;padding:19px 18px;background:var(--panel);transition:transform .3s,border-color .3s,box-shadow .3s}
  .kf:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:var(--sh)}
  .kf-gold{border-color:var(--line-warm);background:linear-gradient(155deg,rgba(233,184,74,.09),var(--panel) 65%)}
  .kf-n{font-family:var(--mono);font-size:10px;color:var(--gold);letter-spacing:1px;margin-bottom:8px}
  .kf-t{font-family:var(--disp);font-size:1.05rem;font-weight:600;line-height:1.2;margin-bottom:8px}
  .kf p{font-size:.83rem;color:var(--mut);line-height:1.5}
  .kf-nots{justify-content:center;margin-bottom:26px}

  /* ============ EXECUTIVE LAYER (decision-first restructure) ============ */
  /* hero concept disclaimer — visible above the fold */
  .hero-disc{display:inline-flex;align-items:center;gap:9px;margin-top:34px;font-family:var(--mono);font-size:9.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--dim);
    border:1px solid var(--line);border-radius:30px;padding:8px 16px;background:rgba(8,11,18,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
    opacity:0;animation:up 1s ease forwards 1.5s}
  body.no-anim .hero-disc{opacity:1!important;animation:none!important}
  @media(prefers-reduced-motion:reduce){.hero-disc{opacity:1;animation:none}}

  /* demoted headline for supporting-detail sections */
  .h2.h2-sm{font-size:clamp(1.8rem,4vw,2.7rem)}

  /* the four-pillar executive grid */
  .kf-4{grid-template-columns:repeat(4,1fr)}
  @media(max-width:980px){.kf-4{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:640px){.kf-4{grid-template-columns:1fr}}
  a.kf{display:block;color:inherit;text-decoration:none}
  .kf-4 .kf-t{font-size:1.35rem}
  .kf-go{font-family:var(--mono);font-size:9.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--dim);margin-top:14px;transition:color .25s}
  a.kf:hover .kf-go{color:var(--gold)}

  /* executive skip affordance */
  .skipline{font-family:var(--mono);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--dim)}
  .skipline a{color:var(--gold-soft);text-decoration:none;border-bottom:1px solid var(--line-warm);padding-bottom:1px;transition:color .25s,border-color .25s}
  .skipline a:hover{color:var(--gold);border-color:var(--gold)}

  /* footnote citations */
  sup.fn{line-height:0}
  sup.fn a{font-family:var(--mono);font-size:.62em;color:var(--gold);text-decoration:none;padding:0 2px}
  sup.fn a:hover{color:var(--gold-soft)}

  /* sources & evidence list */
  .srcs{list-style:none;counter-reset:src;display:flex;flex-direction:column;gap:10px}
  .srcs li{counter-increment:src;display:grid;grid-template-columns:34px 1fr auto;gap:14px;align-items:baseline;
    border:1px solid var(--line);border-radius:12px;padding:14px 18px;background:var(--panel);font-size:.88rem;color:var(--mut);scroll-margin-top:90px}
  .srcs li::before{content:counter(src,decimal-leading-zero);font-family:var(--mono);font-size:11px;color:var(--gold)}
  .srcs li a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line-2);transition:color .25s,border-color .25s}
  .srcs li a:hover{color:var(--gold-soft);border-color:var(--gold)}
  .srcs .st{font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;white-space:nowrap}
  .srcs .st.ey{color:var(--teal)}
  .srcs .st.mk{color:var(--violet)}
  @media(max-width:640px){.srcs li{grid-template-columns:34px 1fr}.srcs .st{grid-column:2}}

/* Keystone private access gate + JP metrics portal */
body.ks-locked{overflow:hidden;}
body.ks-locked > :not(.ks-access):not(.atmos):not(.spotlight):not(.progress){filter:blur(10px) saturate(.7);pointer-events:none;user-select:none;}
.ks-access{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:28px;background:radial-gradient(70% 62% at 50% 20%,rgba(233,184,74,.13),transparent 58%),rgba(4,6,10,.84);backdrop-filter:blur(20px) saturate(1.15);-webkit-backdrop-filter:blur(20px) saturate(1.15);transition:opacity .45s ease,visibility .45s ease;}
.ks-access.cleared{opacity:0;visibility:hidden;pointer-events:none;}
.ks-access-orbit{position:absolute;width:min(72vw,760px);aspect-ratio:1;border:1px solid rgba(233,184,74,.18);border-radius:50%;box-shadow:inset 0 0 90px rgba(233,184,74,.05),0 0 100px rgba(0,0,0,.65);animation:ksOrbit 18s linear infinite;}
.ks-access-orbit::before,.ks-access-orbit::after{content:"";position:absolute;inset:12%;border:1px solid rgba(255,255,255,.08);border-radius:50%;transform:rotate(24deg) scaleX(.72);}
.ks-access-orbit::after{inset:26%;border-color:rgba(233,184,74,.16);transform:rotate(-31deg) scaleX(.86);}
@keyframes ksOrbit{to{transform:rotate(360deg)}}
.ks-access-card{position:relative;width:min(560px,94vw);padding:36px;border:1px solid rgba(233,184,74,.25);border-radius:28px;background:linear-gradient(180deg,rgba(17,22,32,.94),rgba(8,11,18,.96));box-shadow:0 35px 90px -32px rgba(0,0,0,.95),0 0 0 1px rgba(255,255,255,.04) inset;}
.ks-access-card::before{content:"";position:absolute;inset:1px;border-radius:27px;pointer-events:none;background:linear-gradient(135deg,rgba(251,217,140,.18),transparent 32%,rgba(91,151,255,.08) 78%,transparent);}
.ks-access-mark{position:relative;display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:2.5px;font-size:.78rem;color:var(--gold-soft);}
.ks-access-mark .kb{position:relative;width:16px;height:16px;display:inline-block;}
.ks-access-mark .kb::before{content:"";position:absolute;inset:0;background:var(--metal);transform:rotate(45deg);box-shadow:0 0 16px rgba(233,184,74,.65);border-radius:2px;}
.ks-access-mark .kb::after{content:"";position:absolute;inset:5px;background:var(--bg);transform:rotate(45deg);border-radius:1px;}
.ks-access-kicker{position:relative;margin-top:28px;font-family:var(--mono);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);}
.ks-access h2{position:relative;margin-top:12px;font-family:var(--disp);font-weight:600;font-size:clamp(2rem,5vw,3.15rem);line-height:.98;letter-spacing:-.03em;}
.ks-access p{position:relative;margin-top:18px;color:var(--mut);max-width:48ch;}
.ks-access label{position:relative;display:block;margin-top:26px;margin-bottom:9px;font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--dim);}
.ks-access-row{position:relative;display:flex;gap:12px;align-items:center;}
.ks-access input{flex:1;min-width:0;border:1px solid rgba(255,255,255,.13);border-radius:999px;background:rgba(0,0,0,.34);color:var(--ink);font:700 15px var(--ui);padding:14px 18px;outline:none;box-shadow:0 1px 0 rgba(255,255,255,.04) inset;}
.ks-access input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(233,184,74,.14),0 1px 0 rgba(255,255,255,.04) inset;}
.ks-access-error{position:relative;min-height:22px;margin-top:12px;color:#ffb0a9;font-weight:700;}
.ks-access-foot{position:relative;margin-top:16px;color:var(--dim);font-size:.82rem;border-top:1px solid var(--line);padding-top:16px;}
.ks-access.shake .ks-access-card{animation:ksShake .36s ease;}
@keyframes ksShake{20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}
.ks-welcome{position:fixed;z-index:170;top:82px;left:30px;padding:8px 12px;border:1px solid rgba(233,184,74,.28);border-radius:999px;background:rgba(8,11,18,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);color:var(--gold-soft);font:800 11px var(--mono);letter-spacing:1.2px;text-transform:uppercase;box-shadow:0 18px 46px -30px rgba(233,184,74,.45);}
.ks-admin-nav{border-radius:999px;font-size:.8rem;padding:10px 16px;}
.ks-admin{position:fixed;inset:0;z-index:980;padding:92px 28px 28px;background:rgba(3,5,10,.72);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);overflow:auto;}
.ks-admin[hidden]{display:none;}
.ks-admin-shell{position:relative;max-width:1180px;margin:0 auto;padding:30px;border:1px solid rgba(233,184,74,.22);border-radius:28px;background:linear-gradient(180deg,rgba(17,22,32,.96),rgba(7,10,16,.98));box-shadow:0 35px 100px -40px rgba(0,0,0,.95);}
.ks-admin-close{position:absolute;top:18px;right:20px;width:38px;height:38px;border:1px solid var(--line-2);border-radius:50%;background:rgba(255,255,255,.04);color:var(--ink);font-size:24px;line-height:1;cursor:pointer;}
.ks-admin-head{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;padding-right:46px;}
.ks-admin-kicker{font-family:var(--mono);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);}
.ks-admin h2{margin-top:8px;font-family:var(--disp);font-size:clamp(2rem,4vw,3.4rem);line-height:1;letter-spacing:-.03em;}
.ks-admin p{margin-top:10px;color:var(--mut);max-width:690px;}
.ks-admin-cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:26px;}
.ks-admin-card{padding:18px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.035);}
.ks-admin-card b{display:block;font-size:clamp(1.55rem,3vw,2.55rem);line-height:1;color:var(--gold-soft);}
.ks-admin-card span{display:block;margin-top:8px;color:var(--mut);font-size:.88rem;}
.ks-admin-grid{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:18px;margin-top:18px;}
.ks-admin-pane{min-width:0;border:1px solid var(--line);border-radius:20px;background:rgba(0,0,0,.18);overflow:hidden;}
.ks-admin-pane h3{padding:16px 18px;border-bottom:1px solid var(--line);font-size:1rem;letter-spacing:.2px;}
.ks-admin-table{max-height:430px;overflow:auto;}
.ks-admin-table table{width:100%;border-collapse:collapse;font-size:.9rem;}
.ks-admin-table th,.ks-admin-table td{padding:12px 14px;text-align:left;border-bottom:1px solid rgba(255,255,255,.07);vertical-align:top;}
.ks-admin-table th{position:sticky;top:0;background:#101722;color:var(--gold-soft);font:800 11px var(--mono);letter-spacing:1.4px;text-transform:uppercase;z-index:1;}
.ks-admin-empty{padding:18px;color:var(--mut);}
.ks-chat-row{padding:15px 16px;border-bottom:1px solid rgba(255,255,255,.07);}
.ks-chat-meta{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);}
.ks-chat-q{margin-top:8px;color:var(--ink);font-weight:800;}
.ks-chat-a{margin-top:8px;color:var(--mut);font-size:.9rem;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;}
@media(max-width:900px){.ks-welcome{left:16px;top:72px}.ks-access-card{padding:28px 22px}.ks-access-row{flex-direction:column;align-items:stretch}.ks-admin{padding:80px 14px 16px}.ks-admin-shell{padding:22px 16px}.ks-admin-head{flex-direction:column;padding-right:38px}.ks-admin-cards{grid-template-columns:repeat(2,minmax(0,1fr))}.ks-admin-grid{grid-template-columns:1fr}}
@media(max-width:560px){.ks-admin-cards{grid-template-columns:1fr}.ks-admin-table th,.ks-admin-table td{padding:10px 9px;font-size:.82rem}.ks-access{padding:18px}.ks-access h2{font-size:2.1rem}}
@media(prefers-reduced-motion:reduce){.ks-access-orbit,.ks-access.shake .ks-access-card{animation:none}}

/* ===== enhanced review analytics portal ===== */
.ks-admin-grid-wide{grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr)}
.ks-admin-grid-compact{grid-template-columns:repeat(3,minmax(0,1fr))}
.ks-admin-stack{display:grid;grid-template-columns:1fr;gap:0}
.ks-admin-table-small{max-height:214px;border-bottom:1px solid rgba(255,255,255,.07)}
.ks-admin-table-small:last-child{border-bottom:0}
.ks-admin-table td:last-child{color:var(--mut)}
.ks-journey-row .ks-chat-a{font-family:var(--mono);font-size:.76rem;line-height:1.55;color:var(--gold-soft)}
.kai-rate{display:flex;gap:7px;margin-top:8px;align-items:center}
.kai-rate span{font-family:var(--mono);font-size:8.5px;letter-spacing:1.1px;text-transform:uppercase;color:var(--dim)}
.kai-rate button{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.045);color:var(--mut);border-radius:999px;padding:5px 9px;font:800 10px var(--mono);letter-spacing:.8px;text-transform:uppercase;cursor:pointer;transition:border-color .2s,background .2s,color .2s}
.kai-rate button:hover,.kai-rate button.did{border-color:var(--gold);background:rgba(233,184,74,.1);color:var(--gold-soft)}
.kai-rate button:disabled{cursor:default;opacity:.58}
@media(max-width:1100px){.ks-admin-grid-compact{grid-template-columns:1fr}.ks-admin-grid-wide{grid-template-columns:1fr}}
