/* thegateroom - SGC console aesthetic. dark slate, pale-cyan + amber, Coolvetica display. */
/* Shared palette tokens live in design-tokens.css (imported by index.html).
   This file extends them with layout and motion tokens specific to the SPA. */
@font-face{
  font-family:'Coolvetica';
  src:url('/coolvetica.otf') format('opentype');
  font-display:swap;
}
:root{
  --bg:#0a0f12;
  --panel:#121a1f;
  --panel-2:#18242b;
  --edge:#23353e;
  --cyan:rgb(209,238,238);
  --cyan-hot:#7fe0ff;
  --cyan-dim:#6f9aaa;
  --amber:rgb(255,200,120);
  --amber-bracket:#ffb24a;
  --amber-dim:#b8893f;
  --text:#cfe2e6;
  --muted:#7d949b;
  --good:#6fcf8e;
  --bad:#e07a6f;
  /* panel chrome */
  --panel-border:1px solid var(--edge);
  --panel-glow:0 0 26px rgba(90,190,220,.22);
  /* layout */
  --radius:10px;
  --radius-lg:14px;
  --shadow-card:0 10px 30px rgba(0,0,0,.35);
  --shadow-card-hover:0 16px 46px rgba(0,0,0,.5),0 0 26px rgba(209,238,238,.07);
  --shadow-panel:0 12px 36px rgba(0,0,0,.34);
  --transition-fast:.14s ease;
  --transition-std:.2s ease;
  /* typography */
  --font-display:'Coolvetica','Inter',sans-serif;
  --font-body:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-mono:'Courier New',monospace;
}
*{box-sizing:border-box}
body{
  margin:0;color:var(--text);
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  font-size:15px;line-height:1.55;min-height:100vh;
  background:
    radial-gradient(1100px 620px at 80% -12%, rgba(255,200,120,.10), transparent 58%),
    radial-gradient(950px 700px at -10% 8%, rgba(209,238,238,.07), transparent 60%),
    linear-gradient(180deg, rgba(10,15,18,.68) 0%, rgba(10,15,18,.90) 46%, var(--bg) 80%),
    url('/img/space-gate.jpg') center 12%/min(1500px,135%) no-repeat fixed,
    var(--bg);
}
body::before{ /* starfield */
  content:'';position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(1.6px 1.6px at 18% 28%, #ffffffaa 0, transparent 60%),
    radial-gradient(1.4px 1.4px at 82% 18%, #ffffff88 0, transparent 60%),
    radial-gradient(1px 1px at 62% 66%, #ffffff99 0, transparent 60%),
    radial-gradient(2px 2px at 40% 82%, #cfe5ff66 0, transparent 60%),
    radial-gradient(1px 1px at 12% 74%, #ffffff77 0, transparent 60%),
    radial-gradient(1px 1px at 91% 56%, #ffffff88 0, transparent 60%),
    radial-gradient(1.5px 1.5px at 50% 38%, #ffffff55 0, transparent 60%),
    radial-gradient(1px 1px at 30% 52%, #ffffff66 0, transparent 60%),
    radial-gradient(1.3px 1.3px at 72% 44%, #ffffff77 0, transparent 60%);
}
body::after{ /* faint console scanlines */
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.55;
  background:repeating-linear-gradient(0deg, transparent 0 3px, rgba(120,196,225,.02) 3px 4px);
}
h1,h2,h3,.display{font-family:'Coolvetica','Inter',sans-serif;letter-spacing:.02em;font-weight:400}
main>h1{font-size:2.5rem;text-shadow:0 0 32px rgba(209,238,238,.18);margin:0 0 6px}
a{color:var(--cyan);text-decoration:none}
a:hover{color:#fff}
.mono{font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:.82em;color:var(--muted)}

header.top{
  display:flex;align-items:center;gap:18px;padding:12px 26px;
  border-bottom:1px solid var(--edge);background:rgba(10,15,18,.85);
  position:sticky;top:0;backdrop-filter:blur(10px);z-index:10;
  box-shadow:0 10px 34px rgba(0,0,0,.5);min-height:52px;
}
.brand{display:flex;align-items:center;gap:11px;font-family:'Coolvetica';font-size:22px;color:var(--cyan);flex-shrink:0}
.brand .glyph{width:26px;height:26px;border:2px solid var(--amber);border-radius:50%;
  display:grid;place-items:center;color:var(--amber);font-size:13px;box-shadow:0 0 14px rgba(255,200,120,.35)}
nav.tabs{display:flex;gap:4px;margin-left:8px;flex-wrap:wrap}
nav.tabs button{background:none;border:none;color:var(--muted);font:inherit;padding:8px 16px;
  border-radius:8px;cursor:pointer;letter-spacing:.03em;white-space:nowrap;line-height:1.4}
nav.tabs button.active{color:var(--cyan);background:var(--panel-2)}
nav.tabs button:hover{color:var(--text);background:rgba(18,26,31,.6)}
nav.tabs button:active{transform:scale(.97)}
nav.tabs button:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}
.spacer{flex:1}
.who{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;flex-shrink:0}
/* Gate avatar mini-preview in the logged-in #who header area */
.who-gate-mini{position:relative;width:44px;height:44px;flex-shrink:0;cursor:pointer}
.who-gate-mini a{display:block;width:100%;height:100%}
.who-gate-eh{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:90%;height:90%;border-radius:50%;z-index:1}
.who-gate-ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:158%;height:158%;background-size:contain;background-repeat:no-repeat;background-position:center;z-index:2;pointer-events:none;filter:drop-shadow(0 1px 3px rgba(0,0,0,.7))}

main{max-width:920px;margin:0 auto;padding:32px 24px 80px}
.lede{color:var(--muted);margin:0 0 24px;max-width:62ch}

.btn{background:var(--panel-2);color:var(--cyan);border:1px solid var(--edge);
  padding:9px 18px;border-radius:8px;font:inherit;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),background var(--transition-fast);white-space:nowrap;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;line-height:1.4}
.btn:hover{border-color:var(--cyan);color:#fff;box-shadow:0 0 12px rgba(209,238,238,.1)}
.btn:active{transform:scale(.97)}
.btn:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}
.btn.amber{color:var(--amber);border-color:var(--amber-dim)}
.btn.amber:hover{border-color:var(--amber);box-shadow:0 0 14px rgba(255,200,120,.25);color:#fff}
.btn.amber:focus-visible{outline-color:var(--amber)}
.btn.ghost{background:none}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.card{position:relative;border:1px solid var(--edge);border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(18,26,31,.97), rgba(13,19,26,.97));
  padding:18px 20px 18px 24px;margin-bottom:14px;transition:border-color var(--transition-std),box-shadow var(--transition-std),transform var(--transition-std);
  box-shadow:var(--shadow-card);overflow-wrap:break-word;word-break:break-word}
.card:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}
.card::before{content:'';position:absolute;left:0;top:10px;bottom:10px;width:2px;border-radius:2px;
  background:linear-gradient(180deg,var(--cyan),transparent);opacity:.45;transition:opacity var(--transition-std),box-shadow var(--transition-std)}
.card:hover{border-color:var(--cyan);transform:translateY(-2px);
  box-shadow:var(--shadow-card-hover)}
.card:hover::before{opacity:1;box-shadow:0 0 14px rgba(209,238,238,.55)}
.card[style*="cursor:pointer"]:active{transform:translateY(0) scale(.99)}
.card h3{margin:0 0 6px;font-size:19px;line-height:1.3;overflow-wrap:break-word;word-break:break-word}
.card .meta{color:var(--muted);font-size:13px;display:flex;gap:12px;flex-wrap:wrap;margin-top:8px;align-items:center}

.chip{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;border:1px solid;font-family:ui-monospace,monospace}
.chip.proposal{color:var(--cyan);border-color:#2f5563}
.chip.open{color:var(--amber);border-color:var(--amber-dim)}
.chip.decided{color:var(--good);border-color:#2f6b46}
.chip.rejected{color:var(--bad);border-color:#73403a}
.chip.withdrawn{color:var(--muted);border-color:var(--edge)}

.tally{display:flex;height:8px;border-radius:4px;overflow:hidden;background:var(--panel-2);margin-top:12px;border:1px solid var(--edge);transition:opacity var(--transition-std)}
.tally .for{background:var(--good)}.tally .against{background:var(--bad)}.tally .abstain{background:#46606a}
.tally-legend{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-top:6px;flex-wrap:wrap}
/* decision card inline tally row */
.card-tally-row{display:flex;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap}
.card-tally-row .tally{flex:1;min-width:80px;margin-top:0}
.card-vote-counts{display:flex;gap:10px;font-family:ui-monospace,monospace;font-size:11px;flex-shrink:0}
.card-vote-counts .vfor{color:var(--good)}.card-vote-counts .vagainst{color:var(--bad)}.card-vote-counts .vabstain{color:var(--muted)}

input,textarea,select{width:100%;background:var(--panel-2);border:1px solid var(--edge);color:var(--text);
  border-radius:8px;padding:10px 14px;font:inherit;margin:4px 0 16px}
input:focus,textarea:focus{border-color:var(--cyan)}
input:focus:not(:focus-visible),textarea:focus:not(:focus-visible){outline:none}
label{font-size:13px;color:var(--muted);letter-spacing:.03em;display:block;margin-top:4px}
textarea{min-height:110px;resize:vertical}

.outcome{background:rgba(111,207,142,.07);border:1px solid #2f6b46;border-left:3px solid var(--good);
  border-radius:8px;padding:14px 16px;margin:16px 0}
.outcome .label{color:var(--good);font-size:12px;letter-spacing:.1em;text-transform:uppercase}

.log{border-left:2px solid var(--edge);margin:18px 0;padding-left:16px}
.log .entry{font-size:13px;color:var(--muted);margin-bottom:8px}
.log .entry b{color:var(--text);font-weight:600}

.comment{border-top:1px solid var(--edge);padding:12px 0}
.comment .who{color:var(--cyan);font-size:13px;margin-bottom:3px}

.empty{color:var(--muted);text-align:center;padding:48px 24px;border:1px dashed var(--edge);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(18,26,31,.6),rgba(10,15,18,.3));position:relative;overflow:hidden}
.empty .empty-icon{font-size:36px;opacity:.35;margin-bottom:14px;display:block}
.empty .empty-title{font-family:'Coolvetica','Inter',sans-serif;font-size:1.1rem;color:var(--text);margin:0 0 8px}
.empty .empty-sub{font-size:13px;line-height:1.6;margin:0 0 16px}
.empty .empty-retry{margin-top:4px}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:grid;place-items:center;z-index:50}
.modal{background:var(--panel);border:1px solid var(--edge);border-radius:14px;padding:28px 30px;width:min(520px,92vw)}
.banner{background:var(--panel-2);border:1px solid var(--amber-dim);border-radius:8px;padding:10px 14px;
  font-size:13px;color:var(--amber);margin-bottom:22px}
.soon{opacity:.6}

/* ── supergate dial loader - chevrons lock in sequence, kawoosh on ready ── */
.gate-loader{position:relative;width:136px;height:136px;margin:78px auto 56px}
.gate-loader .ring{position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 50% 44%, #16222b, #0c1117 72%);
  border:1px solid #243640;
  box-shadow:inset 0 0 28px rgba(0,0,0,.72), 0 0 32px rgba(209,238,238,.10);}
.gate-loader .eh{position:absolute;inset:21px;border-radius:50%;
  background:radial-gradient(circle, rgba(120,196,225,0), transparent 70%);
  animation:gl-eh 2.7s ease-in-out infinite;}
.gate-loader i{position:absolute;top:50%;left:50%;width:13px;height:8px;margin:-4px 0 0 -6.5px;
  border-radius:2px;background:#23323c;
  transform:rotate(var(--a)) translateY(-55px);
  animation:gl-chev 2.7s ease-in-out infinite;animation-delay:var(--d);}
.gate-loader .lbl{position:absolute;left:50%;transform:translateX(-50%);top:150px;white-space:nowrap;
  font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
@keyframes gl-chev{0%,38%{background:#23323c;box-shadow:none}
  48%,66%{background:var(--amber);box-shadow:0 0 12px rgba(255,200,120,.85)}
  84%,100%{background:#23323c;box-shadow:none}}
@keyframes gl-eh{0%,60%{opacity:0}
  82%,100%{opacity:1;
    background:radial-gradient(circle,rgba(120,196,225,.42),rgba(43,108,255,.22) 55%,transparent 74%);
    box-shadow:0 0 48px rgba(120,196,225,.42)}}

/* ===== atmosphere + theming pass 2 ===== */
body::before{inset:-60px;animation:starDrift 150s ease-in-out infinite alternate}
@keyframes starDrift{from{transform:translate3d(0,0,0)}to{transform:translate3d(-34px,-22px,0)}}

.vignette{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(130% 100% at 50% 26%, transparent 50%, rgba(0,0,0,.55) 100%)}

/* brand glyph → a slowly dialing gate ring */
.brand .glyph{font-size:0;position:relative;border:2px solid #2c3e48;
  background:radial-gradient(circle at 50% 50%, #11202a, #0a0f12);overflow:visible;
  box-shadow:0 0 16px rgba(255,200,120,.22)}
.brand .glyph::before{content:'';position:absolute;inset:-3px;border-radius:50%;
  background:conic-gradient(from 0deg, transparent 0 66%, rgba(255,200,120,.95) 82%, transparent 92%);
  -webkit-mask:radial-gradient(circle, transparent 10px, #000 11px);
          mask:radial-gradient(circle, transparent 10px, #000 11px);
  animation:dialSpin 7s linear infinite}
.brand .glyph::after{content:'';position:absolute;inset:8px;border-radius:50%;
  background:radial-gradient(circle, rgba(120,196,225,.7), rgba(43,108,255,.22) 60%, transparent);
  box-shadow:0 0 12px rgba(120,196,225,.4)}
@keyframes dialSpin{to{transform:rotate(360deg)}}

/* nav + page titles */
nav.tabs button.active{box-shadow:inset 0 -2px 0 var(--cyan);color:#fff}
main>h1::after{content:'';display:block;width:56px;height:2px;margin-top:10px;border-radius:2px;
  background:linear-gradient(90deg,var(--amber),transparent);box-shadow:0 0 12px rgba(255,200,120,.45)}

/* component glow */
.chip.open{box-shadow:0 0 12px rgba(255,200,120,.16)}
.chip.decided{box-shadow:0 0 12px rgba(111,207,142,.16)}
.chip.proposal{box-shadow:0 0 12px rgba(209,238,238,.12)}
.tally .for{box-shadow:0 0 9px rgba(111,207,142,.55)}
.tally .against{box-shadow:0 0 9px rgba(224,122,111,.5)}
.outcome{box-shadow:0 0 30px rgba(111,207,142,.08)}
.modal{box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 40px rgba(209,238,238,.05)}

/* footer seal */
.seal{max-width:920px;margin:30px auto 0;padding:22px 22px 60px;border-top:1px solid var(--edge);
  display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
  font-family:ui-monospace,monospace;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:#8faab3}
.seal .chev{color:var(--amber)}

/* ── featured pullquote (homepage) ─────────────────────── */
.quote-hero{position:relative;margin:0 0 30px;padding:28px 30px 24px;border-radius:14px;
  background:linear-gradient(180deg, rgba(18,26,31,.92), rgba(13,19,26,.92));
  border:1px solid var(--edge);border-left:3px solid var(--amber);
  box-shadow:0 16px 50px rgba(0,0,0,.45), 0 0 44px rgba(255,200,120,.05)}
.quote-hero .qmark{position:absolute;top:2px;left:16px;font-family:'Coolvetica',serif;font-size:62px;
  color:var(--amber);opacity:.32;line-height:1;pointer-events:none}
.quote-hero blockquote{margin:0 0 14px;padding-left:36px;
  font-family:'Coolvetica','Inter',sans-serif;font-size:1.45rem;line-height:1.44;
  color:#eaf4fb;letter-spacing:.01em;text-shadow:0 0 26px rgba(209,238,238,.12)}
.quote-hero .qby{padding-left:36px;font-family:ui-monospace,monospace;font-size:11.5px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;flex-wrap:wrap;gap:4px 12px}
.quote-hero .qby b{color:var(--cyan)}
.quote-hero .qby a{color:var(--amber);border-bottom:1px solid rgba(255,200,120,.3);white-space:nowrap}
@media(max-width:640px){.quote-hero blockquote{font-size:1.2rem;padding-left:28px}.quote-hero .qby{padding-left:28px}}

/* ===== codex design vocabulary (ported, in-palette) ===== */
.term-bar{position:sticky;top:0;z-index:20;height:34px;display:flex;align-items:center;gap:14px;
  padding:0 22px;background:linear-gradient(180deg,rgba(6,10,17,.96),rgba(10,15,18,.72));
  border-bottom:1px solid var(--edge);backdrop-filter:blur(9px);
  font-family:ui-monospace,monospace;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.term-bar .id{display:flex;align-items:center;gap:9px;font-family:'Coolvetica',sans-serif;letter-spacing:.12em;color:var(--text);font-size:12px}
.term-bar .id b{color:var(--amber)}
.term-bar .sep{width:1px;height:16px;background:var(--edge)}
.term-bar .status{display:flex;align-items:center;gap:7px;color:var(--cyan)}
header.top{top:34px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.glyphs{display:flex;gap:5px;margin-left:auto}
.glyphs span{width:15px;height:20px;border:1px solid var(--edge);background:rgba(9,18,33,.5);
  clip-path:polygon(50% 0,100% 28%,100% 100%,0 100%,0 28%)}
.glyphs span.lock{background:var(--amber);border-color:var(--amber);box-shadow:0 0 12px rgba(255,200,120,.6)}

.kicker{display:flex;align-items:center;gap:13px;margin:0 0 20px;
  font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--cyan)}
.kicker .ln{height:1px;width:46px;background:var(--cyan);opacity:.6}

.manifest{position:relative;margin:0 0 30px;border:1px solid var(--edge);border-radius:12px;
  background:linear-gradient(180deg,rgba(18,26,31,.7),rgba(10,15,18,.4));
  display:grid;grid-template-columns:repeat(5,1fr);box-shadow:0 12px 36px rgba(0,0,0,.34)}
.manifest .cell{padding:20px 12px;text-align:center;border-right:1px solid var(--edge);
  display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:88px}
.manifest .cell:last-child{border-right:0}
.manifest .n{font-family:'Coolvetica',sans-serif;font-size:2rem;color:var(--cyan);line-height:1;
  text-shadow:0 0 20px rgba(209,238,238,.28)}
.manifest .k{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:8px;font-family:ui-monospace,monospace}
.manifest .bracket{position:absolute;width:13px;height:13px;border:1px solid var(--amber);opacity:.45}
.manifest .bracket.tl{top:7px;left:7px;border-right:0;border-bottom:0}
.manifest .bracket.tr{top:7px;right:7px;border-left:0;border-bottom:0}
.manifest .bracket.bl{bottom:7px;left:7px;border-right:0;border-top:0}
.manifest .bracket.br{bottom:7px;right:7px;border-left:0;border-top:0}
@media(max-width:640px){.manifest{grid-template-columns:repeat(3,1fr)}.manifest .cell:nth-child(3n){border-right:0}
  .manifest .cell:nth-child(n+4){border-top:1px solid var(--edge)}}

.sec-head{display:flex;align-items:center;gap:14px;margin:4px 0 18px;flex-wrap:wrap}
.sec-head .tag{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--amber);white-space:nowrap}
.sec-head h1{margin:0;font-size:2rem;line-height:1.1}
.sec-head .meta{margin-left:auto;font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);white-space:nowrap}

/* ===== codex pass 3: SG-1 glyphs, file-cards, quote brackets ===== */
@font-face{font-family:'StargateSG1';src:url('/fonts/stargate_sg1.ttf') format('truetype');font-display:swap}
.glyphs span{display:grid;place-items:center;font-family:'StargateSG1',monospace;font-size:11px;color:var(--cyan);opacity:.72}
.glyphs span.lock{color:#0a1320;opacity:1}

.quote-hero .bracket{position:absolute;width:14px;height:14px;border:1px solid var(--amber);opacity:.5}
.quote-hero .bracket.tl{top:9px;left:9px;border-right:0;border-bottom:0}
.quote-hero .bracket.tr{top:9px;right:9px;border-left:0;border-bottom:0}
.quote-hero .bracket.bl{bottom:9px;left:9px;border-right:0;border-top:0}
.quote-hero .bracket.br{bottom:9px;right:9px;border-left:0;border-top:0}

.files{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;align-items:start}
@media(max-width:680px){.files{grid-template-columns:1fr}}
.file{position:relative;border:1px solid var(--edge);border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(180deg,rgba(18,26,31,.97),rgba(13,19,26,.97));transition:.2s ease;box-shadow:0 10px 30px rgba(0,0,0,.35);
  display:flex;flex-direction:column}
.file:hover{border-color:var(--amber);transform:translateY(-4px);box-shadow:0 20px 52px rgba(0,0,0,.5),0 0 34px rgba(255,200,120,.08)}
.file .thumb{height:130px;background-size:cover;background-position:center;position:relative;filter:saturate(.92) brightness(.82);flex-shrink:0}
.file .thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,19,26,0) 28%,rgba(18,26,31,.98) 100%)}
.file-body{padding:12px 18px 18px;flex:1;display:flex;flex-direction:column}
.file-top{display:flex;justify-content:space-between;align-items:center;margin-top:-24px;position:relative;z-index:1}
.file .arc{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.12em;color:var(--amber);text-shadow:0 1px 6px rgba(0,0,0,.8)}
.file .cls{font-family:ui-monospace,monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan)}
.file h3{margin:8px 0 6px;font-size:1.2rem;line-height:1.3;overflow-wrap:break-word;word-break:break-word}
.file .purpose{color:var(--text);font-size:14px;opacity:.86;flex:1;line-height:1.5}
.file .meta{color:var(--muted);font-size:12px;margin-top:12px;display:flex;gap:10px;flex-wrap:wrap;font-family:ui-monospace,monospace;letter-spacing:.04em;align-items:center}

/* ===== theme the rest: detail view, modals, log ===== */
.kicker a{color:var(--cyan);border-bottom:1px solid transparent;transition:.15s}
.kicker a:hover{border-bottom-color:var(--cyan);color:#fff}
.kicker a:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:2px}
.dsec{display:flex;align-items:center;gap:10px;margin:28px 0 14px;
  font-family:'Coolvetica','Inter',sans-serif;font-size:1.15rem;color:var(--text);letter-spacing:.02em}
.dsec::before{content:'';width:3px;height:16px;border-radius:2px;background:var(--amber);box-shadow:0 0 10px rgba(255,200,120,.5);flex-shrink:0}
.dsec .dsec-n{font-family:ui-monospace,monospace;font-size:11px;color:var(--muted);letter-spacing:.1em;margin-left:4px}
.outcome{position:relative}
.outcome .bracket{position:absolute;width:13px;height:13px;border:1px solid var(--good);opacity:.55}
.outcome .bracket.tl{top:8px;left:8px;border-right:0;border-bottom:0}
.outcome .bracket.tr{top:8px;right:8px;border-left:0;border-bottom:0}
.outcome .bracket.bl{bottom:8px;left:8px;border-right:0;border-top:0}
.outcome .bracket.br{bottom:8px;right:8px;border-left:0;border-top:0}
.outcome .label{display:flex;align-items:center;gap:6px}
.log{background:linear-gradient(180deg,rgba(13,19,26,.6),rgba(10,15,18,.3));border:1px solid var(--edge);
  border-left:2px solid var(--cyan);border-radius:8px;padding:14px 16px;font-family:ui-monospace,monospace}
.log .entry{font-size:12px;color:var(--muted)}
.comment .who{font-family:ui-monospace,monospace;letter-spacing:.04em}
/* modal polish */
.modal{position:relative;border-top:2px solid var(--amber);box-shadow:0 30px 80px rgba(0,0,0,.62),0 0 40px rgba(255,200,120,.06)}
.modal h2{font-family:'Coolvetica','Inter',sans-serif;margin:0 0 18px;font-size:1.55rem;
  padding-bottom:12px;border-bottom:1px solid var(--edge);letter-spacing:.02em}

/* ===== auth + modal theming ===== */
.modal-bg{background:rgba(5,8,11,.74);backdrop-filter:blur(6px)}
.modal::before,.modal::after{content:'';position:absolute;width:14px;height:14px;border:1px solid var(--amber);opacity:.5;pointer-events:none}
.modal::before{top:10px;left:10px;border-right:0;border-bottom:0}
.modal::after{bottom:10px;right:10px;border-left:0;border-top:0}

.modal-auth{text-align:center}
.modal-auth h2{border:0;padding:0}
.modal-auth .lede{max-width:none;margin:0 auto 18px}
.modal-auth .kicker{justify-content:center;margin:0 0 6px}
.auth-glyph{width:62px;height:62px;margin:4px auto 14px;position:relative;border-radius:50%;
  border:2px solid #2c3e48;background:radial-gradient(circle,#11202a,#0a0f12);box-shadow:0 0 22px rgba(255,200,120,.25)}
.auth-glyph::before{content:'';position:absolute;inset:-3px;border-radius:50%;
  background:conic-gradient(from 0deg,transparent 0 66%,rgba(255,200,120,.95) 82%,transparent 92%);
  -webkit-mask:radial-gradient(circle,transparent 24px,#000 25px);mask:radial-gradient(circle,transparent 24px,#000 25px);
  animation:dialSpin 7s linear infinite}
.auth-glyph::after{content:'';position:absolute;inset:18px;border-radius:50%;
  background:radial-gradient(circle,rgba(120,196,225,.7),rgba(43,108,255,.22) 60%,transparent);box-shadow:0 0 14px rgba(120,196,225,.4)}

.btn.discord{width:100%;margin-bottom:10px;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:#5865F2;border-color:#5865F2;color:#fff;font-weight:500}
.btn.discord:hover{background:#6b78ff;border-color:#6b78ff;color:#fff;box-shadow:0 0 18px rgba(88,101,242,.45)}

/* Ancient (Anquietas) page headers */
@font-face{font-family:'Anquietas';src:url('/fonts/anquietas.ttf') format('truetype');font-display:swap}
.sec-head h1, main>h1{font-family:'Anquietas','Coolvetica',sans-serif !important;letter-spacing:.06em;font-weight:400}

/* tiny readable English under the Ancient header */
.en-sub{display:block;font-family:'Inter',system-ui,sans-serif;font-size:9.5px;letter-spacing:.26em;
  text-transform:uppercase;color:var(--muted);opacity:.85;font-weight:400;margin-top:2px;line-height:1}

/* ── accessibility: focus-visible global outline ── */
:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:4px;}

/* ── accessibility: skip-navigation link ── */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:static;width:auto;height:auto;padding:8px 16px;
  background:var(--amber);color:#0a0f12;font-weight:600;z-index:999;border-radius:4px}

/* ── accessibility: screen-reader only utility ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── mobile header breakpoint ── */
@media(max-width:640px){
  header.top{flex-wrap:wrap;gap:8px;padding:10px 16px}
  nav.tabs{margin-left:0;order:3;width:100%;gap:2px;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none}
  nav.tabs::-webkit-scrollbar{display:none}
  nav.tabs button{padding:7px 10px;font-size:13px;flex-shrink:0}
  .spacer{display:none}
  .who{margin-left:auto}
  main{padding:24px 16px 60px}
}
/* ── extra-narrow viewports (360px) ── */
@media(max-width:400px){
  .home-hero{padding:20px 16px 18px}
  .sec-head{gap:8px}
  .sec-head h1{font-size:1.6rem}
  .manifest{grid-template-columns:repeat(3,1fr)}
  .manifest .cell:nth-child(3n){border-right:0}
  .manifest .cell:nth-child(n+4){border-top:1px solid var(--edge)}
}

/* ── iOS Safari: disable background-attachment:fixed on touch devices ── */
@media(hover:none){
  body{background:
    radial-gradient(1100px 620px at 80% -12%, rgba(255,200,120,.10), transparent 58%),
    radial-gradient(950px 700px at -10% 8%, rgba(209,238,238,.07), transparent 60%),
    linear-gradient(180deg, rgba(10,15,18,.68) 0%, rgba(10,15,18,.90) 46%, var(--bg) 80%),
    url('/img/space-gate.jpg') center 12%/min(1500px,135%) no-repeat scroll,
    var(--bg);}
}

/* ── prefers-reduced-motion: disable all infinite animations ── */
@media(prefers-reduced-motion:reduce){
  body::before{animation:none;}
  .brand .glyph::before{animation:none;}
  .dot{animation:none;opacity:1;}
  .gate-loader i,.gate-loader .eh{animation:none;}
}

/* ---------- Home / landing ---------- */
.home-hero{position:relative;margin:4px 0 28px;padding:32px 32px 28px;border-radius:14px;
  background:radial-gradient(120% 140% at 50% -10%,rgba(95,170,210,.10),transparent 60%),linear-gradient(180deg,#0c161c,#0a1014);
  border:1px solid var(--edge);box-shadow:0 14px 40px rgba(0,0,0,.4)}
.home-hero .bracket{position:absolute;width:15px;height:15px;border:1px solid var(--amber);opacity:.5}
.home-hero .bracket.tl{top:9px;left:9px;border-right:0;border-bottom:0}
.home-hero .bracket.tr{top:9px;right:9px;border-left:0;border-bottom:0}
.home-hero .bracket.bl{bottom:9px;left:9px;border-right:0;border-top:0}
.home-hero .bracket.br{bottom:9px;right:9px;border-left:0;border-top:0}
.home-title{margin:0 0 14px;font-size:clamp(32px,5vw,50px);line-height:1.04;color:#eaf4fb;
  letter-spacing:.01em;text-shadow:0 0 28px rgba(209,238,238,.16);overflow-wrap:break-word;word-break:break-word}
.home-title .en-sub{display:block;font-size:13px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--cyan-dim);margin-top:10px;font-weight:400}
.home-lede{max-width:62ch;color:var(--text);font-size:15.5px;line-height:1.62;margin:0 0 22px;opacity:.9}
.home-cta{display:flex;flex-wrap:wrap;gap:10px;align-items:center}

.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin:0 0 30px;
  align-items:stretch}
.feature-card{position:relative;display:flex;flex-direction:column;text-decoration:none;color:var(--text);
  border:1px solid var(--edge);border-radius:var(--radius);padding:22px 20px 20px;
  background:linear-gradient(180deg,var(--panel),#0c1318);overflow:hidden;
  transition:transform .14s,border-color .14s,box-shadow .14s}
.feature-card:hover{transform:translateY(-3px);border-color:var(--cyan);box-shadow:0 14px 32px rgba(0,0,0,.4),0 0 22px rgba(209,238,238,.12)}
.feature-card:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}
.feature-card .bracket{position:absolute;width:13px;height:13px;border:1px solid var(--amber);opacity:.4}
.feature-card .bracket.tl{top:8px;left:8px;border-right:0;border-bottom:0}
.feature-card .bracket.br{bottom:8px;right:8px;border-left:0;border-top:0}
.feature-card .fc-icon{font-size:28px;line-height:1;color:var(--cyan);margin-bottom:12px;text-shadow:0 0 16px rgba(209,238,238,.4)}
.feature-card h3{margin:0 0 8px;font-size:18px;color:#eaf4fb;line-height:1.3}
.feature-card p{margin:0 0 14px;font-size:13.5px;line-height:1.55;color:var(--muted);flex:1}
.feature-card .fc-go{font-family:ui-monospace,monospace;font-size:11.5px;letter-spacing:.08em;color:var(--amber);opacity:.85;margin-top:auto}
.feature-card:hover .fc-go{opacity:1;color:var(--amber)}
.fc-starmap .fc-icon{color:#9b7dff;text-shadow:0 0 16px rgba(155,125,255,.5)}
.fc-decisions .fc-icon{color:var(--good)}
.fc-groups .fc-icon{color:var(--amber)}
.fc-forum .fc-icon{color:var(--cyan)}
@media(max-width:560px){.home-hero{padding:24px 20px 20px}.home-cta .btn{flex:1 1 100%;text-align:center;justify-content:center}}

/* ===== view transitions ===== */
#app{position:relative}
#app.view-leaving{animation:viewLeave .16s ease forwards}
#app.view-entering{animation:viewEnter .22s ease forwards}
@keyframes viewLeave{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}
@keyframes viewEnter{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ===== shimmer skeleton loader ===== */
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.skel{
  background:linear-gradient(90deg,var(--panel-2) 30%,rgba(35,53,62,.55) 50%,var(--panel-2) 70%);
  background-size:200% 100%;
  border-radius:6px;
  animation:shimmer 1.8s ease-in-out infinite;
}
.skel-card{border:1px solid var(--edge);border-radius:var(--radius);padding:20px 20px 20px 24px;margin-bottom:14px;
  position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(18,26,31,.97),rgba(13,19,26,.97));
  box-shadow:var(--shadow-card)}
.skel-card::before{content:'';position:absolute;left:0;top:10px;bottom:10px;width:2px;border-radius:2px;
  background:var(--edge);opacity:.45}
.skel-line{height:14px;margin-bottom:10px}
.skel-line.wide{width:72%}
.skel-line.medium{width:48%}
.skel-line.narrow{width:32%}
.skel-line.chip{width:70px;height:22px;border-radius:999px}
.skel-tally{height:8px;border-radius:4px;width:100%;margin-top:14px}
.skel-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}
.skel-row .skel-line{margin-bottom:0}
/* file/group card skeleton */
.skel-file{border:1px solid var(--edge);border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(180deg,rgba(18,26,31,.97),rgba(13,19,26,.97));box-shadow:var(--shadow-card)}
.skel-thumb{height:130px;width:100%}
.skel-file-body{padding:14px 18px 18px}

/* ===== improved decision card ===== */
.card .card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.card .card-header h3{margin:0;flex:1;min-width:0}
.card .card-proposer{font-family:ui-monospace,monospace;font-size:11.5px;color:var(--cyan-dim);
  letter-spacing:.04em;margin-top:4px}
.card .card-comment-count{display:inline-flex;align-items:center;gap:4px;font-family:ui-monospace,monospace;font-size:11px;color:var(--muted)}

/* ===== detail view section ===== */
.detail-meta-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:8px 0 20px;font-size:13px;color:var(--muted);font-family:ui-monospace,monospace;letter-spacing:.03em}
.detail-meta-row .chip{margin-right:4px}

/* ===== vote button row ===== */
.vote-row .btn.voted{border-color:var(--cyan);background:rgba(209,238,238,.08);color:var(--cyan)}
.vote-row .btn[data-v="for"].voted{border-color:var(--good);background:rgba(111,207,142,.08);color:var(--good)}
.vote-row .btn[data-v="against"].voted{border-color:var(--bad);background:rgba(224,122,111,.08);color:var(--bad)}

/* ===== branded empty / error states ===== */
.empty-branded{text-align:center;padding:52px 24px;border:1px dashed var(--edge);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(18,26,31,.7),rgba(10,15,18,.4));position:relative}
.empty-branded .eb-icon{font-size:2.4rem;opacity:.38;line-height:1;margin-bottom:16px;display:block}
.empty-branded .eb-title{font-family:'Coolvetica','Inter',sans-serif;font-size:1.15rem;color:var(--text);margin:0 0 8px}
.empty-branded .eb-sub{font-size:13.5px;color:var(--muted);line-height:1.6;margin:0 0 20px;max-width:44ch;margin-left:auto;margin-right:auto}
.error-branded{text-align:center;padding:52px 24px;border:1px solid rgba(224,122,111,.28);border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(30,16,14,.7),rgba(10,15,18,.4));position:relative}
.error-branded .eb-icon{font-size:2.4rem;opacity:.5;line-height:1;margin-bottom:16px;display:block;color:var(--bad)}
.error-branded .eb-title{font-family:'Coolvetica','Inter',sans-serif;font-size:1.15rem;color:var(--bad);margin:0 0 8px}
.error-branded .eb-sub{font-size:13.5px;color:var(--muted);line-height:1.6;margin:0 0 20px;max-width:44ch;margin-left:auto;margin-right:auto}

/* ===== group card enhancements ===== */
.file{transition:border-color var(--transition-std),transform var(--transition-std),box-shadow var(--transition-std)}
.file:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:var(--radius)}
.file .group-stats{display:flex;gap:14px;margin-top:10px;padding-top:10px;border-top:1px solid var(--edge)}
.file .group-stat{display:flex;flex-direction:column;align-items:center;flex:1;gap:2px}
.file .group-stat .gs-n{font-family:'Coolvetica','Inter',sans-serif;font-size:1.2rem;color:var(--cyan);line-height:1;text-shadow:0 0 14px rgba(209,238,238,.2)}
.file .group-stat .gs-k{font-family:ui-monospace,monospace;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.file .file-badge{display:inline-flex;align-items:center;gap:5px;font-family:ui-monospace,monospace;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);background:rgba(209,238,238,.06);border:1px solid rgba(209,238,238,.12);border-radius:4px;padding:2px 7px}

/* ===== manifest stat animation ===== */
.manifest .n{transition:color .3s,text-shadow .3s}
.manifest .cell:hover .n{color:#fff;text-shadow:0 0 24px rgba(209,238,238,.5)}

/* ===== prefers-reduced-motion guard ===== */
@media(prefers-reduced-motion:reduce){
  #app.view-leaving,#app.view-entering{animation:none;opacity:1;transform:none}
  .skel{animation:none}
  .feature-card,.file,.card,.btn{transition:none}
  nav.tabs button{transition:none}
}

/* ===== v10: Signature counter + campaign treatment ===== */
.sig-counter{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:linear-gradient(90deg,rgba(255,200,120,.07),rgba(18,26,31,.6));
  border:1px solid var(--amber-dim);border-radius:10px;padding:12px 18px;margin:0 0 20px}
.sig-label{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--amber)}
.sig-num{font-family:'Coolvetica','Inter',sans-serif;font-size:1.8rem;color:var(--amber);line-height:1;min-width:48px}
.sig-num.sig-loaded{text-shadow:0 0 18px rgba(255,200,120,.5)}
.sig-unit{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.sig-link{margin-left:auto;font-size:12px;color:var(--amber);padding:6px 12px}
.sig-link:hover{color:#fff}

/* Campaign cards: amber border treatment */
.card.card-campaign{border-color:rgba(255,200,120,.28)}
.card.card-campaign::before{background:linear-gradient(180deg,var(--amber),transparent)}
.card.card-campaign:hover{border-color:var(--amber-dim);box-shadow:0 14px 36px rgba(0,0,0,.4),0 0 20px rgba(255,200,120,.08)}
.campaign-badge{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--amber);margin-bottom:6px}

/* Campaign filter row */
.dec-filter-row{display:flex;gap:6px;flex-wrap:wrap}
.dec-filter-row .btn.active{border-color:var(--cyan);color:var(--cyan)}
.dec-filter-row .campaign-filter-btn.active{border-color:var(--amber);color:var(--amber)}

/* Permalink anchor in decision cards */
.card-permalink{color:var(--muted);font-size:14px;opacity:.6;text-decoration:none;margin-left:auto;transition:opacity .15s}
.card-permalink:hover{opacity:1;color:var(--cyan)}

/* Audit permalink in detail view */
.audit-permalink{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.1em;color:var(--amber-dim);
  margin-left:auto;text-decoration:none;transition:color .15s}
.audit-permalink:hover{color:var(--amber)}

/* ===== Codex view ===== */
.codex-search-bar{margin-bottom:18px}
.codex-search-bar input{margin-bottom:10px}
.codex-filter-row{display:flex;gap:6px;flex-wrap:wrap}
.codex-filter-row .btn.active{border-color:var(--cyan);color:var(--cyan)}
.codex-filter-row .btn.ghost:hover{border-color:var(--cyan-dim)}
.codex-meta{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px}
.codex-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-top:4px}
.codex-card{position:relative;border:1px solid var(--edge);border-radius:var(--radius);
  padding:14px 16px 12px;background:linear-gradient(180deg,rgba(18,26,31,.96),rgba(13,19,26,.96));
  cursor:pointer;transition:border-color .16s,transform .16s,box-shadow .16s}
.codex-card:hover{border-color:var(--cyan);transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.35),0 0 14px rgba(209,238,238,.06)}
.codex-card:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}
.codex-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}
.codex-name{margin:0;font-size:1rem;line-height:1.3;color:#eaf4fb;overflow-wrap:break-word}
.codex-desig{font-family:ui-monospace,monospace;font-size:9px;letter-spacing:.12em;color:var(--amber-dim);
  white-space:nowrap;flex-shrink:0;padding-top:2px}
.codex-shows{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:4px}
.codex-show-tag{font-family:ui-monospace,monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;
  border-radius:3px;padding:1px 5px;border:1px solid}
.cx-sg1{color:var(--cyan);border-color:#2f5563}
.cx-sga{color:var(--amber);border-color:var(--amber-dim)}
.cx-sgu{color:#9b7dff;border-color:rgba(155,125,255,.4)}
.cx-movies{color:var(--good);border-color:#2f6b46}
.codex-ep-count{font-family:ui-monospace,monospace;font-size:10px;color:var(--muted)}
.codex-uncertain{color:var(--amber-dim);margin-left:4px;font-size:.8em}
/* World detail page */
.codex-desig-detail{font-family:ui-monospace,monospace;font-size:12px;letter-spacing:.12em;color:var(--amber-dim);margin:4px 0 14px}
.codex-desig-detail .label{text-transform:uppercase;letter-spacing:.22em;font-size:10px;margin-right:6px}
.codex-sample{border-left:3px solid var(--amber-dim);margin:16px 0;padding:8px 14px;
  color:var(--muted);font-style:italic;font-size:14px;line-height:1.6;background:rgba(255,200,120,.04);border-radius:0 6px 6px 0}
.codex-ep-group{margin-bottom:16px}
.codex-ep-show{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--amber-dim);margin-bottom:6px}
.codex-ep-list{margin:0;padding:0 0 0 16px;list-style:disc}
.codex-ep-list li{font-size:13px;color:var(--muted);line-height:1.55;padding:1px 0}
.codex-ep-more{color:var(--muted);opacity:.6;font-style:italic}

/* ===== Campaign hub ===== */
.campaign-sig-block{position:relative;margin:0 0 22px;padding:24px 28px;border-radius:12px;
  background:linear-gradient(180deg,rgba(30,22,10,.92),rgba(18,14,8,.92));
  border:1px solid var(--amber-dim);box-shadow:0 0 36px rgba(255,200,120,.08)}
.csig-label{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--amber-dim);margin-bottom:6px}
.csig-num{font-family:'Coolvetica','Inter',sans-serif;font-size:3.2rem;color:var(--amber);line-height:1;
  text-shadow:0 0 24px rgba(255,200,120,.5);margin-bottom:4px}
.csig-sub{font-family:ui-monospace,monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.campaign-links{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 22px}

/* fc-codex feature card */
.fc-codex .fc-icon{color:#9b7dff;text-shadow:0 0 16px rgba(155,125,255,.5)}
@media(max-width:500px){.codex-grid{grid-template-columns:1fr 1fr}}

/* ---------- email/password auth modal ---------- */
.auth-tabs{display:flex;gap:6px;margin:14px 0 12px;border-bottom:1px solid var(--edge)}
.auth-tab{flex:1;background:none;border:0;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--font-display,'Coolvetica'),sans-serif;font-size:15px;letter-spacing:1px;padding:8px 0;cursor:pointer;transition:color .15s,border-color .15s}
.auth-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}
.auth-tab:hover{color:#fff}
.auth-form label{display:block;margin:8px 0 4px;font-size:11px;letter-spacing:1px;color:var(--muted);text-transform:uppercase}
.auth-form input{width:100%;background:#0a1620;border:1px solid var(--edge);border-radius:6px;color:var(--text);padding:9px 11px;font-size:14px;box-sizing:border-box}
.auth-form input:focus{border-color:var(--cyan);outline:none;box-shadow:0 0 0 1px rgba(209,238,238,.25)}
.auth-msg{font-size:12.5px;line-height:1.45;margin:0;color:var(--muted);min-height:1.2em}
.auth-msg.err{color:var(--bad)}
.auth-msg.ok{color:var(--good)}
.auth-or{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin:14px 0 10px}
.auth-or::before,.auth-or::after{content:'';flex:1;height:1px;background:var(--edge)}
.auth-or span{padding:0 12px}
.who-link-dc{font-size:11px;color:var(--cyan-dim,#6f9aaa);text-decoration:none;border:1px solid var(--edge);border-radius:5px;padding:4px 8px;white-space:nowrap}
.who-link-dc:hover{color:var(--cyan);border-color:var(--cyan)}
