/* ═══════════════════════════════════════════════════════════
   SCP LEGION // scplegion.ovh
   Single source of truth — terminal/operator aesthetic
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Bebas+Neue&family=DM+Sans:wght@300;400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#09090B;
  --bg1:#0D0D10;
  --bg2:#111114;
  --bg3:#18181C;
  --line:#222226;
  --line2:#2A2A2F;

  --text:#E4E4E7;
  --text-bright:#FAFAFA;
  --muted:#52525B;
  --sub:#71717A;
  --dim:#A1A1AA;

  --accent:#4ADE80;
  --accent-dim:#22C55E;
  --accent-bg:#0A1F14;
  --accent-border:#1A3D28;

  --amber:#FACC15;
  --amber-bg:#1C1600;
  --amber-bd:#3A2E00;

  --red:#EF4444;
  --red-bg:#1C0606;
  --red-bd:#3B0D0D;

  --cyan:#38BDF8;
  --cyan-bg:#061721;
  --cyan-bd:#0B2C42;

  --mono:'JetBrains Mono', ui-monospace, "Courier New", monospace;
  --display:'Bebas Neue', sans-serif;
  --body:'DM Sans', sans-serif;

  --maxw:1080px;
  --pad:2.5rem;
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--body);font-size:14.5px;line-height:1.7;overflow-x:hidden;min-height:100vh}

/* CRT scanlines */
body::before{content:'';position:fixed;inset:0;background:repeating-linear-gradient(to bottom,rgba(255,255,255,0.012) 0 1px,transparent 1px 3px);pointer-events:none;z-index:9999;mix-blend-mode:overlay}

/* ─── LAYOUT ─── */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
main{animation:fadeIn .35s ease;padding-top:52px;min-height:calc(100vh - 52px - 100px)}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ─── NAV ─── */
nav{position:fixed;top:0;left:0;right:0;height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--pad);background:rgba(9,9,11,0.92);border-bottom:1px solid var(--line);backdrop-filter:blur(14px);z-index:500}
.nav-logo{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--text-bright);text-decoration:none;text-transform:uppercase}
.nav-logo .br{color:var(--accent)}
.nav-logo .sl{color:var(--muted);margin:0 4px}
.nav-links{display:flex;gap:2px;list-style:none}
.nav-links a{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:8px 14px;text-decoration:none;transition:color .12s,background .12s;position:relative;display:block}
.nav-links a:hover{color:var(--text)}
.nav-links a.active{color:var(--accent);background:var(--accent-bg)}
.nav-links a.active::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--accent-dim)}
.nav-right{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;font-weight:600;color:var(--accent-dim);letter-spacing:.12em;padding:3px 8px;border:1px solid var(--accent-border);background:var(--accent-bg)}
.pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);animation:blink 2s ease infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ─── HERO (home only) ─── */
.hero{min-height:calc(100vh - 52px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 2rem 5rem;position:relative;overflow:hidden}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:56px 56px;opacity:.5;mask-image:radial-gradient(ellipse 75% 70% at 50% 50%,black 30%,transparent 100%)}
.hero-eyebrow{font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.25em;color:var(--accent-dim);text-transform:uppercase;display:flex;align-items:center;gap:14px;margin-bottom:1.8rem;position:relative;z-index:1}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:36px;height:1px;background:var(--accent-border)}
.hero-h1{font-family:var(--display);font-size:clamp(5rem,14vw,11rem);letter-spacing:.07em;line-height:.88;color:var(--text-bright);margin-bottom:.3rem;position:relative;z-index:1}
.hero-h1 em{color:var(--accent);font-style:normal}
.hero-domain{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.18em;color:var(--muted);margin-bottom:2.2rem;position:relative;z-index:1}
.hero-desc{max-width:520px;font-weight:300;color:var(--dim);font-size:14.5px;line-height:1.85;margin-bottom:2.4rem;position:relative;z-index:1}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;position:relative;z-index:1}

/* ─── PAGE HERO (interior pages) ─── */
.page-hero{padding:5rem var(--pad) 2.4rem;max-width:var(--maxw);margin:0 auto;border-bottom:1px solid var(--line);position:relative}
.page-hero::after{content:'';position:absolute;left:var(--pad);right:var(--pad);bottom:-1px;height:1px;background:linear-gradient(to right,var(--accent-border),transparent 70%)}
.s-tag{font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.2em;color:var(--accent-dim);text-transform:uppercase;margin-bottom:.7rem}
.s-title{font-family:var(--display);font-size:clamp(2.4rem,5vw,4rem);letter-spacing:.06em;color:var(--text-bright);line-height:1;margin-bottom:1.1rem}
.s-lead{font-size:14px;color:var(--dim);max-width:520px;line-height:1.85}
.s-lead strong{color:var(--text);font-weight:500}

/* ─── PANEL BAR (numbered section header) ─── */
.panel-bar{display:flex;align-items:center;gap:10px;padding:0 var(--pad);height:38px;border-bottom:1px solid var(--line);background:var(--bg1);max-width:var(--maxw);margin:0 auto}
.panel-bar .num{font-family:var(--mono);font-size:9px;font-weight:700;color:var(--line2);letter-spacing:.1em;font-variant-numeric:tabular-nums}
.panel-bar .panel-header{font-family:var(--mono);font-size:9.5px;font-weight:700;color:var(--muted);letter-spacing:.18em;text-transform:uppercase}
.panel-bar .grow{flex:1}

/* ─── BUTTONS ─── */
.btn{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:11px 22px;border:1px solid var(--line2);color:var(--muted);cursor:pointer;background:transparent;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:color .12s,border-color .12s,background .12s}
.btn:hover{color:var(--text);border-color:var(--text)}
.btn-green{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent-dim)}
.btn-green:hover{color:var(--accent);border-color:var(--accent)}
.btn-ghost{border-color:var(--line2);color:var(--muted)}
.btn-ghost:hover{border-color:var(--text);color:var(--text)}

/* ─── PILLS ─── */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border:1px solid var(--line2);background:var(--bg3);font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.08em;color:var(--dim);text-transform:uppercase;height:22px;line-height:1}
.pill.green{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent-dim)}
.pill.amber{background:var(--amber-bg);border-color:var(--amber-bd);color:var(--amber)}
.pill.red{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}
.pill.cyan{background:var(--cyan-bg);border-color:var(--cyan-bd);color:var(--cyan)}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent)}
.pill.amber .dot{background:var(--amber);box-shadow:0 0 6px var(--amber)}
.pill.red .dot{background:var(--red);box-shadow:0 0 6px var(--red)}
.pill.cyan .dot{background:var(--cyan);box-shadow:0 0 6px var(--cyan)}

/* ─── BADGES (legacy, kept for compat) ─── */
.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.08em;padding:3px 8px;border:1px solid var(--line2);background:var(--bg3);color:var(--dim);text-transform:uppercase;height:20px}
.badge-live{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent-dim)}
.badge-wip{background:var(--amber-bg);border-color:var(--amber-bd);color:var(--amber)}
.badge-done{background:var(--bg3);border-color:var(--line2);color:var(--sub)}
.badge-paused{background:var(--bg3);border-color:var(--line2);color:var(--muted)}

/* ─── STATS STRIP ─── */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-bottom:1px solid var(--line)}
@media(max-width:680px){.stats-strip{grid-template-columns:repeat(2,1fr)}}
.stat-cell{background:var(--bg1);padding:1.1rem 1.4rem}
.stat-cell .stat-label{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.stat-cell .stat-val{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--text-bright);font-variant-numeric:tabular-nums;line-height:1}
.stat-cell .stat-val.green{color:var(--accent)}
.stat-cell .stat-val.amber{color:var(--amber)}
.stat-cell .stat-delta{font-family:var(--mono);font-size:9.5px;color:var(--accent-dim);margin-top:6px;letter-spacing:.06em}

/* ─── STATUS STRIP (pills row) ─── */
.status-strip{padding:1rem var(--pad);display:flex;gap:10px;flex-wrap:wrap;background:var(--bg1);border-bottom:1px solid var(--line)}

/* ─── TERMINAL ─── */
.terminal{background:var(--bg1);border:1px solid var(--line);padding:1.6rem 1.8rem;font-family:var(--mono);font-size:11.5px;line-height:1.95;color:var(--sub);position:relative;margin:2.4rem auto;max-width:var(--maxw)}
.terminal::before{content:attr(data-label);position:absolute;top:-1px;left:1.5rem;background:var(--bg);font-size:9px;font-weight:600;letter-spacing:.2em;color:var(--accent-dim);padding:0 8px;border:1px solid var(--line);border-top:none}
.t-r{color:var(--accent-dim);user-select:none}
.t-g{color:var(--accent)}
.t-a{color:var(--amber)}
.t-b{color:var(--text-bright)}
.t-d{color:var(--muted)}
.t-c{color:var(--cyan)}

/* ─── KV PAIR ─── */
.kv{display:grid;grid-template-columns:auto 1fr;gap:14px;font-family:var(--mono);font-size:10.5px;padding:6px 0;border-bottom:1px dashed var(--line)}
.kv .k{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600;min-width:90px}
.kv .v{color:var(--text);font-variant-numeric:tabular-nums;text-align:right}
.kv .v.green{color:var(--accent-dim)}
.kv .v.amber{color:var(--amber)}

/* ─── CONN ROW ─── */
.conn{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--bg2);border:1px solid var(--line);font-family:var(--mono);font-size:10.5px;color:var(--sub);text-decoration:none;transition:border-color .12s,color .12s}
.conn:hover{border-color:var(--text);color:var(--text)}
.conn.ok{border-color:var(--accent-border);background:var(--accent-bg);color:var(--accent-dim)}
.conn.ok:hover{border-color:var(--accent);color:var(--accent)}
.conn .dot{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 6px currentColor}

/* ─── SERVICES GRID ─── */
.services-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1px;background:var(--line)}
.svc{background:var(--bg1);padding:1.8rem;position:relative;overflow:hidden;transition:background .15s}
.svc::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent-border);transition:width .15s,background .15s}
.svc:hover{background:var(--bg2)}
.svc:hover::before{width:3px;background:var(--accent)}
.svc-id{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.2em;color:var(--accent-dim);margin-bottom:.9rem;text-transform:uppercase}
.svc-name{font-family:var(--display);font-size:1.8rem;letter-spacing:.05em;color:var(--text-bright);margin-bottom:.6rem;line-height:1.1}
.svc-desc{font-size:12.5px;color:var(--dim);line-height:1.7;margin-bottom:1.3rem}
.svc-meta{display:flex;flex-direction:column}
.svc-meta .kv{grid-template-columns:80px 1fr}
.svc-meta .kv .v{font-size:10px;text-align:right}

/* ─── PROJECTS LIST ─── */
.projects-list{max-width:var(--maxw);margin:0 auto}
.proj{border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr auto;align-items:start;gap:2rem;padding:1.6rem var(--pad);transition:background .12s;position:relative}
.proj::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:transparent;transition:background .12s}
.proj:hover{background:var(--bg1)}
.proj:hover::before{background:var(--accent-border)}
.proj-header{display:flex;align-items:center;gap:14px;margin-bottom:.5rem}
.proj-num{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--accent-dim);letter-spacing:.12em;min-width:28px;font-variant-numeric:tabular-nums;cursor:help}
.proj-title{font-family:var(--display);font-size:1.55rem;letter-spacing:.05em;color:var(--text-bright)}
.proj-desc{font-size:13px;color:var(--dim);line-height:1.7;max-width:600px}
.proj-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:.9rem}
.proj-tag{font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.06em;padding:3px 8px;border:1px solid var(--line2);background:var(--bg3);color:var(--sub);text-transform:uppercase}
.proj-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px;padding-top:4px}

/* ─── STACK CHIPS ─── */
.stack-sections{max-width:var(--maxw);margin:0 auto;padding:2.4rem var(--pad) 3rem;display:grid;grid-template-columns:1fr 1fr;gap:2.4rem 3rem}
@media(max-width:680px){.stack-sections{grid-template-columns:1fr}}
.stack-section-label{font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.2em;color:var(--accent-dim);text-transform:uppercase;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--line)}
.stack-chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.05em;padding:6px 12px;border:1px solid var(--line2);color:var(--sub);background:var(--bg1);transition:color .12s,border-color .12s,background .12s;cursor:default}
.chip:hover{border-color:var(--text);color:var(--text);background:var(--bg2)}
.chip.hi{border-color:var(--accent-border);background:var(--accent-bg);color:var(--accent-dim)}
.chip.hi:hover{border-color:var(--accent);color:var(--accent)}

/* ─── ABOUT ─── */
.about-grid{max-width:var(--maxw);margin:0 auto;padding:2.4rem var(--pad) 3rem;display:grid;grid-template-columns:1fr 1fr;gap:3rem}
@media(max-width:700px){.about-grid{grid-template-columns:1fr;gap:2rem}}
.about-block-label{font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.2em;color:var(--accent-dim);text-transform:uppercase;margin-bottom:1rem;padding-bottom:.6rem;border-bottom:1px solid var(--line)}
.about-block p{font-size:13.5px;color:var(--dim);line-height:1.8;margin-bottom:.8rem}
.about-block p strong{color:var(--text);font-weight:500}
.info-table{width:100%;border-collapse:collapse}
.info-table tr{border-bottom:1px dashed var(--line)}
.info-table td{padding:9px 0;font-family:var(--mono);font-size:11px;vertical-align:top}
.info-table td:first-child{color:var(--muted);letter-spacing:.08em;padding-right:1.5rem;white-space:nowrap;text-transform:uppercase;font-size:9.5px;font-weight:600}
.info-table td:last-child{color:var(--text-bright);font-variant-numeric:tabular-nums}
.conn-grid{max-width:var(--maxw);margin:0 auto;padding:1.4rem var(--pad) 0;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(max-width:680px){.conn-grid{grid-template-columns:1fr}}

/* ─── AVAIL BANNER (about page) ─── */
.avail-banner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.avail-inner{border:1px solid var(--accent-border);background:var(--accent-bg);padding:1.2rem 1.8rem;display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.1em;color:var(--dim)}
.avail-inner .dot-g{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);flex-shrink:0;animation:blink 2s ease infinite}
.avail-inner strong{color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.15em}

/* ─── FOOTER ─── */
footer{border-top:1px solid var(--line);padding:1.4rem var(--pad);display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;background:var(--bg1)}
.footer-logo{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--text-bright);text-transform:uppercase}
.footer-copy{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--muted);text-align:right;line-height:1.7}

/* ─── WATERMARK (fragment puzzle) ─── */
.watermark{display:inline-block;color:var(--line2);font-size:9px;letter-spacing:.18em;opacity:.5;transition:opacity .2s,color .2s;cursor:help;user-select:all}
.watermark:hover{opacity:1;color:var(--sub)}
.watermark b{color:var(--accent-dim);font-weight:600}
body.cleared .watermark{color:var(--accent-dim);opacity:.9}

/* ─── BREACH MODE ─── */
body.breach{animation:shake .4s ease}
body.breach::after{content:'';position:fixed;inset:0;background:repeating-linear-gradient(90deg,rgba(239,68,68,.04) 0 2px,transparent 2px 6px);pointer-events:none;z-index:9998;mix-blend-mode:overlay}
body.breach .pill.green,body.breach .badge-live{background:var(--red-bg)!important;border-color:var(--red-bd)!important;color:var(--red)!important}
body.breach .pill.green .dot{background:var(--red)!important;box-shadow:0 0 6px var(--red)!important}
body.breach .hero-h1 em{color:var(--red)!important;animation:glitch .25s infinite}
body.breach .hero-eyebrow,body.breach .nav-right{color:var(--red)!important}
body.breach .nav-right{border-color:var(--red-bd)!important;background:var(--red-bg)!important}
body.breach .pulse{background:var(--red)!important;box-shadow:0 0 6px var(--red)!important}
@keyframes shake{0%,100%{transform:translate(0,0)}25%{transform:translate(-2px,1px)}75%{transform:translate(2px,-1px)}}
@keyframes glitch{0%,100%{transform:translate(0,0);text-shadow:none}33%{transform:translate(-1px,0);text-shadow:2px 0 var(--cyan),-2px 0 var(--red)}66%{transform:translate(1px,0);text-shadow:-2px 0 var(--cyan),2px 0 var(--red)}}

/* glow pulse from typing "scp" */
.hero-h1.glow em{text-shadow:0 0 24px var(--accent),0 0 48px var(--accent-dim);transition:text-shadow .3s}

/* console toast */
#scp-toast{position:fixed;bottom:24px;right:24px;background:var(--bg1);border:1px solid var(--accent-border);color:var(--accent);font-family:var(--mono);font-size:10.5px;padding:10px 14px;letter-spacing:.1em;text-transform:uppercase;z-index:10000;opacity:0;transform:translateY(8px);transition:opacity .25s,transform .25s;pointer-events:none}
#scp-toast.on{opacity:1;transform:translateY(0)}
#scp-toast.red{border-color:var(--red-bd);color:var(--red)}

/* ─── SELECTION ─── */
::selection{background:rgba(74,222,128,.25);color:var(--text-bright)}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--bg1)}
::-webkit-scrollbar-thumb{background:var(--line2);border:1px solid var(--bg1)}
::-webkit-scrollbar-thumb:hover{background:var(--sub)}
