/* ============================================================
   AIOD — design system
   void/panel surfaces · green = LOCAL/ALIVE · amber = SEVERED
   ============================================================ */
:root{
  --void:#06080C;
  --panel:#0C111A;
  --panel-2:#101724;
  --line:#1B2433;
  --line-soft:#141C2A;
  --text:#C9D3E0;
  --muted:#6B7890;
  --green:#3FE08C;
  --green-glow:rgba(63,224,140,.14);
  --amber:#F5A83C;
  --amber-glow:rgba(245,168,60,.12);
  --display:'Chakra Petch',sans-serif;
  --body:'IBM Plex Sans',sans-serif;
  --mono:'IBM Plex Mono',monospace;
  --max:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--void);
  color:var(--text);
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;inset:0;
  background-image:
    linear-gradient(var(--line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size:56px 56px;
  opacity:.28;
  pointer-events:none;
  z-index:0;
}
main,header,footer{position:relative;z-index:1}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:2px}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.wrap-n{max-width:820px;margin:0 auto;padding:0 24px}

/* ---------- type ---------- */
.mono{font-family:var(--mono)}
.eyebrow{
  font-family:var(--mono);
  font-size:12px;letter-spacing:.18em;
  color:var(--green);
  text-transform:uppercase;
  display:flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--green);flex:none}
.eyebrow.center{justify-content:center}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.12;letter-spacing:.005em}
h1{font-size:clamp(2.2rem,5vw,3.6rem);color:#E9EEF6}
h2{font-size:clamp(1.7rem,3.4vw,2.5rem);color:#E4EAF3}
h3{font-size:1.12rem;color:#E4EAF3}
.lede{color:var(--muted);font-size:1.06rem;max-width:60ch}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(6,8,12,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;padding:0 24px;
  height:64px;display:flex;align-items:center;gap:28px;
}
.logo{font-family:var(--display);font-weight:700;font-size:1.25rem;color:#fff;letter-spacing:.04em;display:flex;align-items:center;gap:9px}
.logo .block{width:10px;height:10px;background:var(--green);box-shadow:0 0 12px var(--green-glow)}
.nav-links{display:flex;gap:24px;font-size:.92rem;color:var(--muted)}
.nav-links a{transition:color .18s}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--green)}
.nav-status{
  margin-left:auto;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  color:var(--muted);
  border:1px solid var(--line);
  padding:6px 12px;
  display:flex;align-items:center;gap:8px;
  white-space:nowrap;
}
.nav-status .dot{width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber-glow)}
.btn{
  font-family:var(--mono);font-size:13px;letter-spacing:.06em;
  padding:11px 20px;border:1px solid var(--green);
  color:var(--green);background:transparent;
  cursor:pointer;position:relative;
  transition:background .18s,color .18s,box-shadow .18s;
  white-space:nowrap;display:inline-block;
}
.btn:hover{background:var(--green);color:var(--void);box-shadow:0 0 28px var(--green-glow)}
.btn.solid{background:var(--green);color:var(--void)}
.btn.solid:hover{box-shadow:0 0 36px rgba(63,224,140,.3)}
.btn.ghost{border-color:var(--line);color:var(--text)}
.btn.ghost:hover{background:var(--panel-2);color:#fff;box-shadow:none}
.nav .btn{padding:9px 16px}

/* ---------- hero (home) ---------- */
.hero{padding:88px 0 64px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1 span{color:var(--green)}
.hero .lede{margin:22px 0 30px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{
  margin-top:34px;font-family:var(--mono);font-size:12px;
  color:var(--muted);letter-spacing:.04em;line-height:2;
}
.hero-trust b{color:var(--text);font-weight:500}

/* ---------- page hero (subpages) ---------- */
.page-hero{padding:72px 0 56px;border-bottom:1px solid var(--line)}
.page-hero h1{margin-top:18px}
.page-hero .lede{margin-top:20px}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted);margin-bottom:22px}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--green)}
.crumb b{color:var(--text);font-weight:500}

/* ---------- terminal ---------- */
.term{
  background:var(--panel);
  border:1px solid var(--line);
  box-shadow:0 24px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(63,224,140,.04);
  font-family:var(--mono);font-size:13px;line-height:1.75;
  position:relative;
}
.term-bar{
  display:flex;align-items:center;gap:8px;
  padding:11px 16px;border-bottom:1px solid var(--line);
  background:var(--panel-2);
}
.term-bar .d{width:9px;height:9px;border-radius:50%;background:#222C3D}
.term-bar .title{margin-left:8px;font-size:11px;letter-spacing:.08em;color:var(--muted)}
.term-body{padding:20px 20px 16px;height:352px;overflow:hidden;color:#A8B4C6;white-space:pre-wrap;word-break:break-word}
.term-body .p{color:var(--green)}
.term-body .sev{color:var(--amber)}
.term-body .ok{color:var(--green)}
.term-body .ans{color:#DDE5F0}
.term-body .dim{color:#54607A}
.caret{display:inline-block;width:8px;height:14px;background:var(--green);vertical-align:-2px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.term-status{
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--line);
  padding:10px 16px;font-size:11px;letter-spacing:.12em;
  color:var(--muted);background:var(--panel-2);
}
.term-status .net{color:var(--amber)}
.term-status .inf{color:var(--green)}
.term::before,.term::after{
  content:"";position:absolute;width:18px;height:18px;
  border:1px solid var(--green);opacity:.6;
}
.term::before{top:-7px;left:-7px;border-right:0;border-bottom:0}
.term::after{bottom:-7px;right:-7px;border-left:0;border-top:0}

/* ---------- fingerprint strip ---------- */
.strip{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--panel);
  overflow:hidden;white-space:nowrap;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--muted);
  padding:12px 0;
}
.strip .inner{display:inline-block;animation:scroll 46s linear infinite;padding-left:100%}
.strip b{color:var(--green);font-weight:500}
@keyframes scroll{to{transform:translateX(-100%)}}

/* ---------- sections ---------- */
section{padding:96px 0}
.sec-head{margin-bottom:52px;max-width:680px}
.sec-head h2{margin:14px 0 14px}
.sever{
  max-width:var(--max);margin:0 auto;padding:0 24px;
  display:flex;align-items:center;gap:14px;
}
.sever .l{flex:1;border-top:1px dashed var(--line)}
.sever .x{font-family:var(--mono);color:var(--amber);font-size:12px}

/* ---------- cards / tiers ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{
  background:var(--panel);border:1px solid var(--line);
  padding:30px 26px;position:relative;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.card:hover{border-color:rgba(63,224,140,.4);transform:translateY(-3px);box-shadow:0 18px 48px rgba(0,0,0,.4)}
.card .unit{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  color:var(--green);margin-bottom:14px;display:block;
}
.card h3{margin-bottom:10px;font-size:1.3rem}
.card p{color:var(--muted);font-size:.94rem;margin-bottom:20px}
.spec{font-family:var(--mono);font-size:12px;border-top:1px solid var(--line)}
.spec div{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--line-soft);color:var(--muted)}
.spec div span:last-child{color:var(--text);text-align:right}
.card .for{margin-top:18px;font-size:.86rem;color:var(--muted)}
.card .for b{color:var(--text);font-weight:500}

/* ---------- protocol ---------- */
.proto{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.step{border-left:1px solid var(--line);padding:6px 0 6px 22px;position:relative}
.step::before{
  content:"";position:absolute;left:-4px;top:10px;
  width:7px;height:7px;background:var(--green);
  box-shadow:0 0 10px var(--green-glow);
}
.step .n{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--green)}
.step h3{margin:10px 0 8px;font-size:1.05rem}
.step p{color:var(--muted);font-size:.9rem}

/* ---------- industries grid ---------- */
.grid-ind{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.ind{background:var(--panel);padding:26px 22px;transition:background .18s}
.ind:hover{background:var(--panel-2)}
.ind .tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--green);display:block;margin-bottom:10px}
.ind h3{font-size:1rem;margin-bottom:6px}
.ind p{font-size:.85rem;color:var(--muted)}

/* ---------- threat table ---------- */
.threat{border:1px solid var(--line);background:var(--panel)}
.t-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;border-bottom:1px solid var(--line-soft)}
.t-row:last-child{border-bottom:0}
.t-row > div{padding:16px 22px;font-size:.92rem}
.t-row.head > div{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  color:var(--muted);text-transform:uppercase;
  background:var(--panel-2);
}
.t-row .q{color:var(--text)}
.t-row .cloud{color:var(--amber)}
.t-row .local{color:var(--green)}
.t-row .cloud,.t-row .local{font-family:var(--mono);font-size:.84rem}

/* ---------- proof / cta ---------- */
.proof{text-align:center;padding:120px 0}
.proof h2{font-size:clamp(2.2rem,5.5vw,3.6rem)}
.proof h2 span{color:var(--amber)}
.proof p{color:var(--muted);max-width:54ch;margin:22px auto 0;font-size:1.05rem}
.cta{
  border:1px solid var(--line);background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  padding:64px 48px;text-align:center;position:relative;
}
.cta::before,.cta::after{
  content:"";position:absolute;width:18px;height:18px;border:1px solid var(--green);opacity:.5;
}
.cta::before{top:-7px;left:-7px;border-right:0;border-bottom:0}
.cta::after{bottom:-7px;right:-7px;border-left:0;border-top:0}
.cta h2{margin-bottom:14px}
.cta p{color:var(--muted);margin-bottom:30px}
.cta .mono-note{margin-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted)}

/* ---------- knowledge cards ---------- */
.kb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.kb-card{
  background:var(--panel);border:1px solid var(--line);
  padding:28px 24px;display:flex;flex-direction:column;gap:12px;
  transition:border-color .2s,transform .2s;
}
.kb-card:hover{border-color:rgba(63,224,140,.4);transform:translateY(-3px)}
.kb-card .tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--green)}
.kb-card h3{font-size:1.08rem;line-height:1.35}
.kb-card p{color:var(--muted);font-size:.9rem;flex:1}
.kb-card .read{font-family:var(--mono);font-size:12px;color:var(--green);letter-spacing:.06em}

/* ---------- article / prose ---------- */
.article{padding:72px 0}
.article-head{max-width:820px;margin:0 auto 48px;padding:0 24px}
.article-head h1{font-size:clamp(2rem,4.2vw,3rem);margin-top:18px}
.article-meta{
  margin-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  color:var(--muted);display:flex;gap:18px;flex-wrap:wrap;
}
.article-meta span b{color:var(--green);font-weight:500}
.prose{max-width:820px;margin:0 auto;padding:0 24px}
.prose p{margin:0 0 22px;color:var(--text);font-size:1.02rem;line-height:1.75}
.prose p.lead{font-size:1.12rem;color:#DDE5F0}
.prose h2{font-size:1.5rem;margin:52px 0 18px}
.prose h3{font-size:1.15rem;margin:36px 0 14px}
.prose ul,.prose ol{margin:0 0 22px 22px;color:var(--text)}
.prose li{margin-bottom:10px;line-height:1.7}
.prose li::marker{color:var(--green)}
.prose a{color:var(--green);border-bottom:1px solid rgba(63,224,140,.3)}
.prose a:hover{border-bottom-color:var(--green)}
.prose strong{color:#E9EEF6;font-weight:600}
.prose code{font-family:var(--mono);font-size:.88em;background:var(--panel-2);border:1px solid var(--line);padding:2px 6px;color:var(--green)}
.prose blockquote{
  border-left:2px solid var(--green);background:var(--panel);
  padding:18px 24px;margin:0 0 22px;color:var(--muted);font-style:italic;
}
.callout{
  border:1px solid var(--line);border-left:2px solid var(--green);
  background:var(--panel);padding:20px 24px;margin:0 0 22px;
}
.callout .c-tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--green);display:block;margin-bottom:8px;text-transform:uppercase}
.callout p{margin:0;font-size:.95rem;color:var(--muted)}
.tbl{width:100%;border-collapse:collapse;margin:0 0 26px;font-size:.92rem;border:1px solid var(--line)}
.tbl th{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);text-align:left;padding:12px 16px;
  background:var(--panel-2);border-bottom:1px solid var(--line);
}
.tbl td{padding:12px 16px;border-bottom:1px solid var(--line-soft);color:var(--text);background:var(--panel)}
.tbl tr:last-child td{border-bottom:0}
.tbl td.g{color:var(--green);font-family:var(--mono);font-size:.85rem}
.tbl td.a{color:var(--amber);font-family:var(--mono);font-size:.85rem}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto;padding:0 24px}
.faq details{border:1px solid var(--line);background:var(--panel);margin-bottom:10px}
.faq summary{
  cursor:pointer;list-style:none;padding:18px 22px;
  font-family:var(--display);font-weight:600;color:#E4EAF3;font-size:1rem;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--green);font-size:1.1rem;flex:none}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 22px 20px;color:var(--muted);font-size:.95rem;line-height:1.7}

/* ---------- founder ---------- */
.founder-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:start}
.f-photo{position:relative;border:1px solid var(--line);background:var(--panel);padding:10px}
.f-photo img{width:100%;height:auto}
.f-photo::before,.f-photo::after{
  content:"";position:absolute;width:18px;height:18px;border:1px solid var(--green);opacity:.6;
}
.f-photo::before{top:-7px;left:-7px;border-right:0;border-bottom:0}
.f-photo::after{bottom:-7px;right:-7px;border-left:0;border-top:0}
.f-photo .f-cap{
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--muted);
  padding:12px 4px 4px;text-transform:uppercase;
}
.badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.badge{
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  border:1px solid var(--line);color:var(--muted);
  padding:6px 12px;background:var(--panel);
}
.founder-strip{
  display:flex;align-items:center;gap:28px;
  border:1px solid var(--line);background:var(--panel);padding:28px 32px;
}
.founder-strip img{width:84px;height:84px;object-fit:cover;border:1px solid var(--line)}
.founder-strip .fs-text{flex:1}
.founder-strip .fs-text h3{margin-bottom:6px}
.founder-strip .fs-text p{color:var(--muted);font-size:.92rem}

/* ---------- glossary ---------- */
.gloss dl{max-width:820px;margin:0 auto;padding:0 24px}
.gloss dt{
  font-family:var(--display);font-weight:600;color:#E4EAF3;font-size:1.1rem;
  margin-top:34px;padding-top:24px;border-top:1px solid var(--line-soft);
  display:flex;align-items:baseline;gap:12px;
}
.gloss dt .g-id{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--green)}
.gloss dd{color:var(--muted);margin-top:8px;line-height:1.7}
.gloss dd b{color:var(--text);font-weight:500}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);background:var(--panel);padding:64px 0 36px;margin-top:96px}
.f-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr 1fr;gap:36px}
.f-col h4{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  color:var(--green);text-transform:uppercase;margin-bottom:16px;
}
.f-col a{display:block;color:var(--muted);font-size:.9rem;padding:4px 0;transition:color .15s}
.f-col a:hover{color:var(--text)}
.f-brand p{color:var(--muted);font-size:.88rem;margin-top:14px;max-width:30ch}
.f-bottom{
  margin-top:52px;padding-top:22px;border-top:1px solid var(--line-soft);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muted);
}

/* ---------- reveal ---------- */
.rv{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.rv.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-grid,.founder-grid{grid-template-columns:1fr;gap:44px}
  .tiers,.kb-grid{grid-template-columns:1fr}
  .proto{grid-template-columns:1fr 1fr;gap:32px}
  .grid-ind{grid-template-columns:1fr 1fr}
  .t-row{grid-template-columns:1.2fr 1fr 1fr}
  .f-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
}
@media(max-width:600px){
  section{padding:72px 0}
  .proto{grid-template-columns:1fr}
  .grid-ind{grid-template-columns:1fr}
  .t-row{grid-template-columns:1fr}
  .t-row > div{padding:12px 18px;border-bottom:1px solid var(--line-soft)}
  .t-row.head{display:none}
  .t-row .q{color:#E4EAF3;font-weight:600}
  .t-row .cloud::before{content:"CLOUD — ";color:var(--muted)}
  .t-row .local::before{content:"AIOD — ";color:var(--muted)}
  .nav-status{display:none}
  .cta{padding:48px 24px}
  .founder-strip{flex-direction:column;align-items:flex-start}
  .tbl{display:block;overflow-x:auto}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .strip .inner{animation:none;padding-left:0}
  html{scroll-behavior:auto}
}

/* ---------- corporate attribution (MAXFR LTD) ---------- */
.f-corp{
  margin-top:52px;padding-top:22px;border-top:1px solid var(--line-soft);
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
}
.f-corp img{height:20px;width:auto;opacity:.9}
.f-corp p{
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;
  color:var(--muted);margin:0;line-height:1.8;
}
.f-corp a{color:var(--text);transition:color .15s}
.f-corp a:hover{color:var(--green)}
.f-corp + .f-bottom{margin-top:16px;border-top:0;padding-top:0}

/* ---------- tools: forms, options, readouts ---------- */
.tool-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:start}
.tool-panel{background:var(--panel);border:1px solid var(--line);padding:30px 28px}
.tool-panel h3{font-size:1rem;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.tool-panel h3 .q-id{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--green)}
.field{margin-bottom:24px}
.f-label{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;margin-bottom:10px}
.f-label output{color:var(--green);font-size:12px}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt input{position:absolute;opacity:0;pointer-events:none}
.opt label{
  display:inline-block;cursor:pointer;
  font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  border:1px solid var(--line);background:var(--panel-2);color:var(--muted);
  padding:9px 14px;transition:all .15s;
}
.opt label:hover{color:var(--text);border-color:#2A3548}
.opt input:checked + label{border-color:var(--green);color:var(--green);background:rgba(63,224,140,.07)}
.opt input:focus-visible + label{outline:2px solid var(--green);outline-offset:2px}
select,input[type=number]{
  width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--text);
  font-family:var(--mono);font-size:13px;padding:11px 12px;
}
select:focus,input[type=number]:focus{outline:2px solid var(--green);outline-offset:1px;border-color:var(--green)}
input[type=range]{width:100%;accent-color:var(--green);background:transparent}
.q-block{border-top:1px solid var(--line-soft);padding:22px 0}
.q-block:first-of-type{border-top:0;padding-top:0}
.q-block p.q{color:var(--text);font-size:.98rem;margin-bottom:12px}
.q-block p.q b{font-family:var(--mono);font-size:11px;color:var(--green);letter-spacing:.12em;margin-right:10px}
/* result readout */
.readout{background:var(--panel);border:1px solid var(--line);position:relative}
.readout::before,.readout::after{content:"";position:absolute;width:18px;height:18px;border:1px solid var(--green);opacity:.6}
.readout::before{top:-7px;left:-7px;border-right:0;border-bottom:0}
.readout::after{bottom:-7px;right:-7px;border-left:0;border-top:0}
.readout .r-bar{display:flex;align-items:center;gap:8px;padding:11px 16px;border-bottom:1px solid var(--line);background:var(--panel-2);font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted)}
.readout .r-body{padding:24px 24px 20px}
.res-row{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--line-soft);font-family:var(--mono);font-size:13px;color:var(--muted)}
.res-row:last-child{border-bottom:0}
.res-row span:last-child{color:var(--text);text-align:right}
.res-row .g{color:var(--green)}
.res-row .a{color:var(--amber)}
.grade{font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,4vw,2.6rem);line-height:1.1;margin:6px 0 4px}
.grade.g{color:var(--green)}
.grade.a{color:var(--amber)}
.score-track{height:10px;background:var(--panel-2);border:1px solid var(--line);margin:14px 0 6px;position:relative}
.score-fill{height:100%;background:var(--green);transition:width .5s ease}
.score-fill.a{background:var(--amber)}
.score-cap{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:var(--muted);display:flex;justify-content:space-between}
.flag-list{margin:16px 0 0;list-style:none}
.flag-list li{font-size:.92rem;color:var(--muted);padding:8px 0 8px 22px;position:relative;border-bottom:1px solid var(--line-soft)}
.flag-list li::before{content:"✕";position:absolute;left:0;color:var(--amber);font-family:var(--mono);font-size:12px}
.flag-list li.ok::before{content:"●";color:var(--green)}
.flag-list li:last-child{border-bottom:0}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.bars{display:grid;gap:14px;margin:18px 0 6px}
.bar-line .b-label{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted);margin-bottom:6px}
.bar-line .b-track{height:14px;background:var(--panel-2);border:1px solid var(--line)}
.bar-line .b-fill{height:100%;transition:width .5s ease}
.bar-line .b-fill.cloud{background:var(--amber)}
.bar-line .b-fill.local{background:var(--green)}
.tool-note{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muted);margin-top:18px;line-height:1.8}
.audience-tag{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--void);background:var(--green);padding:5px 10px;margin-bottom:18px}
@media(max-width:980px){.tool-grid{grid-template-columns:1fr}.readout{position:sticky;bottom:0}}

/* ---------- skip link ---------- */
.skip{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--green);color:var(--void);
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;
  padding:12px 18px;text-transform:uppercase;
}
.skip:focus{left:0}

/* ---------- consent-gated external embed (origins page) ---------- */
.embed-gate{min-height:440px;display:flex;align-items:center;justify-content:center;text-align:center;padding:56px 28px}
.embed-gate .eg-inner{max-width:50ch}
.embed-gate .eg-inner p{color:var(--muted);font-size:.95rem;margin:14px 0 24px}
.ig-wrap{padding:28px 16px;display:flex;justify-content:center}
.ig-frame{width:100%;max-width:540px;height:780px;border:1px solid var(--line);background:#FFF}

/* ---------- instagram gallery (origins) ---------- */
.ig-gallery{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:22px;padding:26px 18px;align-items:start}
.ig-cell{display:flex;flex-direction:column;gap:10px}
.ig-tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--green)}
@media(max-width:600px){.ig-gallery{padding:16px 10px}}

/* ---------- grid variants (inline styles defeated media queries on mobile) ---------- */
.kb-grid.four{grid-template-columns:repeat(4,1fr)}
.tiers.two{grid-template-columns:repeat(2,1fr)}
@media(max-width:1080px){.kb-grid.four{grid-template-columns:repeat(2,1fr)}}
@media(max-width:980px){.tiers.two{grid-template-columns:1fr}}
@media(max-width:640px){.kb-grid.four{grid-template-columns:1fr}}
