/* Portfolio layout — composes design tokens from tokens.css */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;min-height:100vh;}
body{font-family:var(--font-sans);-webkit-font-smoothing:antialiased;}

/* Light/print mode override */
body.lite { background: #fafaf7 !important; color: #0a0a0a !important; }
body.lite .pc-gridbg, body.lite .pc-radial { display: none !important; }

/* Accessibility modes */
body.a11y-dyslexia { font-family: 'OpenDyslexic', 'Inter', sans-serif !important; }
body.a11y-contrast { filter: contrast(1.3) brightness(1.05); }
body.a11y-reduced * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }

/* App shell */
.pc{position:relative;min-height:100vh;}
.pc-gridbg{position:fixed;inset:0;background-image:var(--grid-bg);background-size:var(--grid-size);mask-image:linear-gradient(to bottom,black,transparent 88%);-webkit-mask-image:linear-gradient(to bottom,black,transparent 88%);pointer-events:none;z-index:0;}
.pc-main{position:relative;z-index:1;}

/* ───── A2 SELF-SELECT GATE ───── */
.gate{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:48px 32px;max-width:1280px;margin:0 auto;}
.gate-top{font-family:ui-monospace,monospace;font-size:12px;letter-spacing:.24em;color:var(--violet-soft);text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.gate-top::before{content:"";width:8px;height:8px;border-radius:999px;background:var(--violet);box-shadow:0 0 12px var(--violet);}
.gate-q{font-family:var(--font-display);font-weight:700;font-size:clamp(48px,7vw,96px);line-height:.97;letter-spacing:-.05em;color:#fff;margin:0 0 16px;max-width:1080px;}
.gate-q em{font-style:normal;background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;color:transparent;}
.gate-sub{font-size:18px;color:var(--fg2);line-height:1.65;max-width:680px;margin:0 0 48px;}
.gate-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:1080px;}
.gate-card{position:relative;border:1px solid var(--rule);border-radius:20px;padding:24px;background:rgba(15,8,30,.4);display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;transition:all 280ms var(--ease-out);min-height:200px;}
.gate-card:hover{transform:translateY(-4px) rotate(-.3deg);}
.gate-card.violet:hover{border-color:var(--violet);background:rgba(167,139,250,.08);box-shadow:var(--glow-violet);}
.gate-card.cyan:hover{border-color:var(--cyan);background:rgba(34,211,238,.08);box-shadow:var(--glow-cyan);transform:translateY(-4px) rotate(.3deg);}
.gate-card.emerald:hover{border-color:var(--emerald);background:rgba(52,211,153,.08);box-shadow:var(--glow-emerald);}
.gate-card.amber:hover{border-color:var(--amber);background:rgba(251,191,36,.08);box-shadow:var(--glow-amber);transform:translateY(-4px) rotate(.3deg);}
.gate-card .id{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;}
.gate-card.violet .id{color:var(--violet-soft);}
.gate-card.cyan .id{color:var(--cyan-soft);}
.gate-card.emerald .id{color:var(--emerald-soft);}
.gate-card.amber .id{color:var(--amber-soft);}
.gate-card .t{font-family:var(--font-display);font-weight:700;font-size:22px;color:#fff;letter-spacing:-.02em;line-height:1.15;margin:10px 0;}
.gate-card .b{font-size:14px;color:var(--fg2);line-height:1.6;}
.gate-card .arr{margin-top:16px;font-family:ui-monospace,monospace;font-size:10px;color:var(--fg4);letter-spacing:.14em;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px dashed rgba(148,163,184,.18);}
.gate-card .arr code{font-size:10px;padding:2px 8px;border-radius:4px;background:rgba(255,255,255,.04);color:var(--fg2);border:1px solid var(--rule-strong);font-family:ui-monospace,monospace;}
.gate-card.violet:hover .arr code{color:var(--violet-soft);border-color:var(--violet);}
.gate-card.cyan:hover .arr code{color:var(--cyan-soft);border-color:var(--cyan);}
.gate-card.emerald:hover .arr code{color:var(--emerald-soft);border-color:var(--emerald);}
.gate-card.amber:hover .arr code{color:var(--amber-soft);border-color:var(--amber);}
.gate-foot{margin-top:36px;display:flex;justify-content:space-between;align-items:center;font-family:ui-monospace,monospace;font-size:11px;color:var(--fg4);letter-spacing:.16em;text-transform:uppercase;}
.gate-foot kbd{padding:3px 8px;border:1px solid var(--rule-strong);border-radius:4px;color:#fff;background:rgba(255,255,255,.04);font-size:10px;}

/* ───── ROUTE SHELL ───── */
.route{position:relative;min-height:100vh;}
.route-switcher{position:fixed;top:18px;right:18px;z-index:60;display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid rgba(167,139,250,.3);background:rgba(10,4,24,.85);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.14em;color:var(--fg3);text-transform:uppercase;}
.route-switcher .who{color:var(--violet-soft);font-weight:600;}
.route-switcher button{background:transparent;border:none;color:var(--fg3);font-family:inherit;font-size:11px;cursor:pointer;text-transform:uppercase;letter-spacing:.14em;padding:0;}
.route-switcher button:hover{color:#fff;}

/* ───── TERMINAL BOOT (A3) ───── */
.boot{min-height:100vh;background:#000;font-family:ui-monospace,monospace;padding:48px 32px;display:flex;flex-direction:column;}
.boot-term{font-size:14px;line-height:1.75;flex:1;max-width:880px;margin:0 auto;width:100%;}
.boot-term .line{white-space:pre-wrap;word-break:break-word;}
.boot-term .violet{color:var(--violet-soft);}
.boot-term .primary{color:#fff;font-weight:700;}
.boot-term .emerald{color:var(--emerald-soft);}
.boot-term .cyan{color:var(--cyan-soft);}
.boot-term .fg1{color:#fff;}
.boot-term .fg2{color:var(--fg2);}
.boot-cursor{display:inline-block;width:8px;height:14px;background:var(--violet);vertical-align:-2px;animation:bootblink 1.05s infinite;}
@keyframes bootblink{0%,49%{opacity:1;}50%,100%{opacity:0;}}
.boot-skip{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);padding:8px 18px;border-radius:999px;border:1px solid var(--rule-strong);background:rgba(15,8,30,.7);backdrop-filter:blur(8px);color:var(--fg2);font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.16em;cursor:pointer;text-transform:uppercase;}
.boot-skip:hover{color:var(--violet-soft);border-color:var(--violet);}

/* ───── MISSION CONSOLE HERO (A1) ───── */
.console{min-height:100vh;padding:80px 32px;max-width:1280px;margin:0 auto;font-family:var(--font-sans);}
.console-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border:1px solid rgba(167,139,250,.28);border-radius:10px;background:rgba(2,6,23,.5);font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.14em;color:var(--fg3);text-transform:uppercase;margin-bottom:32px;}
.console-bar .live{color:var(--emerald-soft);display:inline-flex;align-items:center;gap:8px;}
.console-bar .live::before{content:"";width:7px;height:7px;border-radius:999px;background:var(--emerald);box-shadow:0 0 10px var(--emerald);animation:bootblink 1.4s infinite;}
.console-id{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.22em;color:var(--violet-soft);text-transform:uppercase;}
.console-name{font-family:var(--font-display);font-weight:700;font-size:clamp(56px,8vw,112px);line-height:.92;letter-spacing:-.05em;color:#fff;margin:8px 0 8px;}
.console-name em{font-style:normal;background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;color:transparent;}
.console-cursor{display:inline-block;width:8px;height:14px;background:var(--violet);vertical-align:-2px;animation:bootblink 1.1s infinite;margin-left:6px;}
.console-roles{font-size:16px;color:var(--fg2);font-weight:500;margin-bottom:32px;}
.console-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.console-col{border:1px solid var(--rule);border-radius:14px;padding:18px;background:rgba(15,8,30,.5);}
.console-col .h{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;}
.console-col.ai .h{color:var(--violet-soft);}
.console-col.bd .h{color:var(--cyan-soft);}
.console-col.sv .h{color:var(--emerald-soft);}
.console-col .t{font-family:var(--font-display);font-weight:700;font-size:18px;color:#fff;line-height:1.2;letter-spacing:-.02em;margin:8px 0 6px;}
.console-col .b{font-size:13px;color:var(--fg3);line-height:1.55;}
.console-col .p{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;}
.console-col .p span{font-family:ui-monospace,monospace;font-size:10px;padding:3px 8px;border-radius:999px;border:1px solid var(--rule-strong);color:var(--fg2);letter-spacing:.06em;}
.console-foot{margin-top:32px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.16em;color:var(--fg4);text-transform:uppercase;}
.console-foot kbd{background:rgba(167,139,250,.15);border:1px solid rgba(167,139,250,.4);padding:2px 6px;border-radius:4px;color:#fff;font-size:10px;}

/* ───── TIMELINE RAIL (B2) ───── */
.rail{display:grid;grid-template-columns:240px 1fr;min-height:100vh;}
.rail-side{position:sticky;top:0;height:100vh;overflow-y:auto;padding:24px 18px;background:rgba(2,6,23,.7);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-right:1px solid rgba(167,139,250,.18);display:flex;flex-direction:column;}
.rail-brand{font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-.02em;color:#fff;margin-bottom:6px;}
.rail-brand em{font-style:normal;background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;color:transparent;}
.rail-role{font-size:11px;color:var(--fg3);margin-bottom:24px;}
.rail-head{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg4);margin-bottom:14px;}
.rail-spine{flex:1;position:relative;padding-left:24px;}
.rail-spine::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;background:linear-gradient(180deg,var(--violet) 0%,var(--cyan) 50%,var(--emerald) 100%);opacity:.5;}
.rail-yr{position:relative;display:flex;flex-direction:column;gap:2px;padding:7px 0;cursor:pointer;transition:color 150ms;}
.rail-yr::before{content:"";position:absolute;left:-22px;top:11px;width:11px;height:11px;border-radius:999px;background:var(--night-2);border:2px solid var(--ink);}
.rail-yr.violet::before{background:var(--violet);} .rail-yr.cyan::before{background:var(--cyan);} .rail-yr.emerald::before{background:var(--emerald);} .rail-yr.amber::before{background:var(--amber);}
.rail-yr:hover .y, .rail-yr:hover .r{color:#fff;}
.rail-yr.active::before{box-shadow:0 0 0 4px rgba(167,139,250,.3);}
.rail-yr.active .y{color:var(--violet-soft);}
.rail-yr.active .r{color:#fff;}
.rail-yr .y{font-family:ui-monospace,monospace;font-size:11px;color:var(--fg2);font-weight:600;letter-spacing:.04em;}
.rail-yr .r{font-size:12px;color:var(--fg3);line-height:1.3;}
.rail-foot{margin-top:18px;padding-top:14px;border-top:1px solid rgba(167,139,250,.15);font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.16em;color:var(--fg4);text-transform:uppercase;display:flex;flex-direction:column;gap:6px;}
.rail-foot kbd{padding:2px 6px;border:1px solid var(--rule-strong);border-radius:4px;color:#fff;background:rgba(255,255,255,.04);font-size:9px;}

.rail-main{padding:48px;max-width:none;}

/* ───── SECTIONS ───── */
.sec{padding:48px 0;max-width:980px;}
.sec-eyebrow{font-family:ui-monospace,monospace;font-size:12px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--violet-soft);display:inline-flex;align-items:center;gap:8px;}
.sec-eyebrow::before{content:"▸";}
.sec-eyebrow.cyan{color:var(--cyan-soft);} .sec-eyebrow.emerald{color:var(--emerald-soft);} .sec-eyebrow.amber{color:var(--amber-soft);}
.sec-title{font-family:var(--font-display);font-weight:700;font-size:clamp(36px,5vw,56px);line-height:1.0;letter-spacing:-.04em;color:#fff;margin:14px 0 0;}
.sec-sub{font-size:17px;color:var(--fg2);line-height:1.65;margin:18px 0 0;max-width:680px;}

.card-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:32px;}
@media (max-width: 880px){.card-grid{grid-template-columns:1fr;}}
.card{background:linear-gradient(180deg,rgba(15,8,30,.78),rgba(15,8,30,.5));border:1px solid rgba(167,139,250,.18);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-radius:20px;padding:24px;transition:transform 240ms,border-color 240ms;}
.card:hover{transform:translateY(-3px);border-color:rgba(167,139,250,.4);}
.card-title{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.02em;line-height:1.15;margin:0;}
.card-title.violet{color:var(--violet-soft);} .card-title.cyan{color:var(--cyan-soft);} .card-title.emerald{color:var(--emerald-soft);} .card-title.amber{color:var(--amber-soft);}
.card-body{font-size:14px;color:var(--fg2);line-height:1.65;margin:12px 0 0;}
.card-chips{display:flex;flex-wrap:wrap;gap:6px;margin:16px 0 0;}
.card-chip{font-family:var(--font-sans);font-size:11px;font-weight:500;padding:4px 10px;border-radius:999px;border:1px solid var(--rule-strong);background:rgba(15,8,30,.6);color:var(--fg2);}

/* ───── CASE STUDY (Mission Brief) ───── */
.case{background:linear-gradient(180deg,rgba(15,8,30,.85),rgba(15,8,30,.55));border:1px solid rgba(167,139,250,.22);backdrop-filter:blur(18px);border-radius:24px;overflow:hidden;margin-top:32px;}
.case-stamp{padding:10px 22px;background:rgba(167,139,250,.1);border-bottom:1px solid rgba(167,139,250,.25);display:flex;justify-content:space-between;align-items:center;font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.18em;color:var(--violet-soft);text-transform:uppercase;gap:14px;flex-wrap:wrap;}
.case-stamp .cls{padding:3px 10px;border:1px solid rgba(52,211,153,.4);border-radius:4px;background:rgba(52,211,153,.1);color:var(--emerald-soft);}
.case-body{padding:24px 28px;}
.case-id{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.18em;color:var(--violet-soft);text-transform:uppercase;}
.case-t{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,3.5vw,40px);line-height:1.05;letter-spacing:-.03em;color:#fff;margin:8px 0 18px;}
.case-lede{padding:14px 18px;border-left:2px solid var(--amber);background:rgba(251,191,36,.04);margin:0 0 24px;}
.case-lede .q{font-family:var(--font-display);font-style:italic;font-size:20px;line-height:1.35;color:#fff;margin:0 0 6px;letter-spacing:-.005em;}
.case-lede .a{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.18em;color:var(--amber-soft);text-transform:uppercase;}
.case-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;padding:14px 0;border-top:1px dashed rgba(148,163,184,.16);border-bottom:1px dashed rgba(148,163,184,.16);margin-bottom:24px;}
.case-row{display:grid;grid-template-columns:104px 1fr;gap:12px;font-size:13px;}
.case-row .k{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.16em;color:var(--fg4);text-transform:uppercase;align-self:center;}
.case-row .v{color:#fff;line-height:1.5;}
.case-tags{display:flex;flex-wrap:wrap;gap:5px;}
.case-tags span{font-size:10px;padding:3px 8px;border-radius:999px;border:1px solid var(--rule-strong);color:var(--fg2);font-family:ui-monospace,monospace;letter-spacing:.06em;text-transform:uppercase;}
.case-redact{display:inline-block;background:#1a1430;color:transparent;padding:0 5px;margin:0 3px;border-radius:2px;user-select:none;cursor:help;transition:all .3s;font-family:ui-monospace,monospace;}
.case-redact:hover{background:var(--amber);color:#0a0418;}
.case-section{margin:18px 0;}
.case-section h4{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.22em;color:var(--violet-soft);text-transform:uppercase;margin:0 0 6px;font-weight:600;display:flex;align-items:center;gap:6px;}
.case-section h4::before{content:"▸";color:var(--violet);}
.case-section p{font-size:14px;color:var(--fg1);line-height:1.7;margin:0;}
.case-figure{margin:18px 0;height:88px;background:linear-gradient(135deg,rgba(167,139,250,.12),rgba(34,211,238,.08));border:1px dashed rgba(167,139,250,.3);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:ui-monospace,monospace;font-size:11px;color:var(--violet-soft);letter-spacing:.18em;text-transform:uppercase;text-align:center;padding:8px;}
.case-pq{margin:14px 0;padding:10px 14px;border-left:2px solid var(--cyan);background:rgba(34,211,238,.04);font-family:var(--font-display);font-style:italic;}
.case-pq .q{font-size:14px;color:#fff;line-height:1.45;margin:0;}
.case-pq .a{font-family:ui-monospace,monospace;font-style:normal;font-size:10px;letter-spacing:.16em;color:var(--cyan-soft);text-transform:uppercase;display:block;margin-top:4px;}
.case-find{margin:14px 0;padding:12px 16px;border-left:2px solid var(--violet);background:rgba(167,139,250,.06);}
.case-find .l{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.22em;color:var(--violet-soft);text-transform:uppercase;margin-bottom:6px;display:flex;align-items:center;gap:6px;}
.case-find .l::before{content:"◉";color:var(--violet);}
.case-find .b{font-size:14px;color:#fff;line-height:1.6;margin:0;}
.case-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px;}
@media (max-width: 720px){.case-metrics{grid-template-columns:1fr;}}
.case-mc{border:1px solid var(--rule);border-radius:10px;padding:10px 14px;background:rgba(15,8,30,.5);}
.case-mc .h{font-family:ui-monospace,monospace;font-size:9px;letter-spacing:.16em;color:var(--fg3);text-transform:uppercase;}
.case-mc .row{display:flex;justify-content:space-between;margin-top:6px;font-size:13px;align-items:baseline;}
.case-mc .b{color:var(--fg4);text-decoration:line-through;font-family:ui-monospace,monospace;font-size:12px;}
.case-mc .a{color:var(--emerald-soft);font-weight:700;font-family:ui-monospace,monospace;}
.case-mc .arr{color:var(--violet-soft);font-family:ui-monospace,monospace;font-size:11px;}
.case-reflect{margin:18px 0 0;padding:12px 16px;border:1px dashed var(--rule-strong);border-radius:10px;background:rgba(15,8,30,.4);}
.case-reflect .l{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.22em;color:var(--fg3);text-transform:uppercase;margin-bottom:6px;}
.case-reflect .b{font-family:var(--font-display);font-style:italic;font-size:15px;color:#fff;line-height:1.55;margin:0;}

/* ───── CASE LIST (collapsed cards before expanding to full mission brief) ───── */
.case-list{display:flex;flex-direction:column;gap:12px;margin-top:24px;}
.case-summary{background:rgba(15,8,30,.55);border:1px solid var(--rule);border-radius:14px;padding:18px 22px;cursor:pointer;transition:all 240ms;display:grid;grid-template-columns:48px 1fr auto;gap:18px;align-items:center;}
.case-summary:hover{border-color:rgba(167,139,250,.4);transform:translateX(4px);}
.case-summary .n{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.18em;color:var(--violet-soft);}
.case-summary .t{font-family:var(--font-display);font-weight:700;font-size:18px;color:#fff;letter-spacing:-.02em;line-height:1.2;}
.case-summary .m{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.12em;color:var(--fg3);text-transform:uppercase;margin-top:4px;}
.case-summary .arr{font-family:var(--font-display);font-size:24px;color:var(--fg3);}

/* ───── COMMAND PALETTE (B3) ───── */
.cmdk{position:fixed;inset:0;z-index:200;background:rgba(2,6,23,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding-top:14vh;opacity:0;pointer-events:none;transition:opacity 200ms;}
.cmdk.open{opacity:1;pointer-events:auto;}
.cmdk-box{width:min(620px,92%);background:linear-gradient(180deg,rgba(15,8,30,.96),rgba(15,8,30,.88));border:1px solid rgba(167,139,250,.4);border-radius:18px;box-shadow:0 24px 80px rgba(0,0,0,.7),var(--glow-violet);overflow:hidden;transform:translateY(-12px);transition:transform 200ms var(--ease-out);}
.cmdk.open .cmdk-box{transform:translateY(0);}
.cmdk-head{padding:14px 18px;border-bottom:1px solid rgba(167,139,250,.2);display:flex;align-items:center;gap:12px;}
.cmdk-head .sigil{font-family:ui-monospace,monospace;font-size:12px;color:var(--violet-soft);letter-spacing:.14em;font-weight:700;}
.cmdk-head input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-family:var(--font-sans);font-size:15px;}
.cmdk-head input::placeholder{color:var(--fg4);}
.cmdk-head .esc{font-family:ui-monospace,monospace;font-size:10px;color:var(--fg4);letter-spacing:.14em;padding:2px 6px;border:1px solid var(--rule-strong);border-radius:4px;}
.cmdk-list{max-height:50vh;overflow-y:auto;}
.cmdk-sec{padding:10px 18px 4px;font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.22em;color:var(--fg4);text-transform:uppercase;}
.cmdk-item{display:flex;justify-content:space-between;align-items:center;padding:9px 18px;font-size:14px;color:var(--fg1);cursor:pointer;border:none;background:transparent;width:100%;text-align:left;font-family:var(--font-sans);}
.cmdk-item:hover, .cmdk-item.sel{background:rgba(167,139,250,.12);color:#fff;}
.cmdk-item .l{display:flex;align-items:center;gap:10px;}
.cmdk-item .l .i{color:var(--violet-soft);font-family:ui-monospace,monospace;font-size:12px;}
.cmdk-item .h{font-family:ui-monospace,monospace;font-size:11px;color:var(--fg3);padding:2px 7px;border-radius:4px;background:rgba(255,255,255,.03);border:1px solid var(--rule);}
.cmdk-foot{padding:10px 18px;border-top:1px solid rgba(167,139,250,.15);font-family:ui-monospace,monospace;font-size:10px;color:var(--fg4);letter-spacing:.14em;text-transform:uppercase;display:flex;justify-content:space-between;}

.cmdk-prompt{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.18em;color:var(--fg3);text-transform:uppercase;display:flex;align-items:center;gap:8px;padding:7px 14px;border:1px solid var(--rule-strong);background:rgba(15,8,30,.85);backdrop-filter:blur(8px);border-radius:999px;z-index:50;cursor:pointer;}
.cmdk-prompt:hover{color:var(--violet-soft);border-color:var(--violet);}
.cmdk-prompt kbd{background:rgba(167,139,250,.18);border:1px solid rgba(167,139,250,.4);padding:2px 6px;border-radius:4px;color:var(--violet-soft);font-size:10px;}

/* ───── SIDE PROJECTS PANEL ───── */
.sp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px;}
@media (max-width: 880px){.sp-grid{grid-template-columns:1fr;}}
.sp-card{background:linear-gradient(180deg,rgba(15,8,30,.85),rgba(15,8,30,.55));border:1px solid rgba(167,139,250,.2);border-radius:20px;padding:24px;backdrop-filter:blur(18px);transition:all 280ms;display:flex;flex-direction:column;}
.sp-card:hover{transform:translateY(-3px);border-color:rgba(167,139,250,.45);}
.sp-card .tag{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;}
.sp-card.violet .tag{color:var(--violet-soft);} .sp-card.cyan .tag{color:var(--cyan-soft);} .sp-card.emerald .tag{color:var(--emerald-soft);}
.sp-card .name{font-family:var(--font-display);font-weight:700;font-size:28px;color:#fff;letter-spacing:-.03em;margin:8px 0 4px;}
.sp-card .one{font-size:14px;color:var(--fg2);font-weight:500;line-height:1.45;margin-bottom:12px;}
.sp-card .body{font-size:13px;color:var(--fg3);line-height:1.6;}
.sp-card .chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:14px;}
.sp-card .chips span{font-size:10px;padding:3px 8px;border-radius:999px;border:1px solid var(--rule-strong);color:var(--fg2);font-family:ui-monospace,monospace;}
.sp-platforms{margin-top:14px;display:grid;gap:8px;}
.sp-plat{padding:10px 12px;background:rgba(2,6,23,.5);border:1px solid var(--rule);border-radius:10px;}
.sp-plat .ptag{font-family:ui-monospace,monospace;font-size:9px;letter-spacing:.18em;color:var(--violet-soft);text-transform:uppercase;}
.sp-plat .ptit{font-family:var(--font-display);font-weight:700;font-size:14px;color:#fff;margin-top:3px;}
.sp-plat .pbody{font-size:11px;color:var(--fg3);margin-top:3px;line-height:1.45;}
.sp-plat .prepo{font-family:ui-monospace,monospace;font-size:10px;color:var(--fg4);margin-top:6px;}
.sp-bullets{list-style:none;padding:0;margin:14px 0 0;}
.sp-bullets li{padding:6px 0 6px 18px;position:relative;font-size:13px;color:var(--fg2);line-height:1.5;}
.sp-bullets li::before{content:"▸";position:absolute;left:0;color:var(--violet);font-weight:700;}
.sp-risk{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px;}
.sp-risk-cell{background:rgba(2,6,23,.5);border:1px solid var(--rule);border-radius:10px;padding:10px 12px;}
.sp-risk-cell .rt{font-family:var(--font-sans);font-weight:700;font-size:12px;margin:0 0 4px;}
.sp-risk-cell .rt.violet{color:var(--violet-soft);} .sp-risk-cell .rt.cyan{color:var(--cyan-soft);} .sp-risk-cell .rt.emerald{color:var(--emerald-soft);} .sp-risk-cell .rt.amber{color:var(--amber-soft);}
.sp-risk-cell .rb{font-size:11px;color:var(--fg3);line-height:1.45;}

/* ───── BUSINESSES PANEL ───── */
.biz-section{margin-top:32px;}
.biz-card{background:linear-gradient(180deg,rgba(15,8,30,.78),rgba(15,8,30,.5));border:1px solid rgba(167,139,250,.2);border-radius:24px;padding:28px;margin-bottom:18px;backdrop-filter:blur(18px);}
.biz-card .biz-role{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.22em;color:var(--violet-soft);text-transform:uppercase;font-weight:600;}
.biz-card .biz-name{font-family:var(--font-display);font-weight:700;font-size:32px;letter-spacing:-.03em;color:#fff;margin:6px 0 4px;}
.biz-card .biz-name em{font-style:normal;background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;color:transparent;}
.biz-card .biz-domain{font-family:ui-monospace,monospace;font-size:12px;color:var(--fg3);margin-bottom:14px;}
.biz-card .biz-domain a{color:var(--violet-soft);text-decoration:none;}
.biz-card .biz-domain a:hover{color:var(--violet);}
.biz-card .biz-body{font-size:15px;color:var(--fg2);line-height:1.65;margin:0;}
.biz-hire{margin-top:18px;padding:16px 18px;border-radius:14px;background:linear-gradient(135deg,rgba(167,139,250,.15),rgba(34,211,238,.1));border:1px solid rgba(167,139,250,.35);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;}
.biz-hire .he{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--violet-soft);font-weight:700;}
.biz-hire .ht{font-family:var(--font-display);font-weight:700;font-size:18px;color:#fff;margin-top:3px;letter-spacing:-.02em;}
.biz-hire .hcta{padding:10px 18px;border-radius:10px;background:var(--violet);color:#0a0418;font-weight:700;font-size:13px;text-decoration:none;transition:all 200ms;font-family:var(--font-sans);}
.biz-hire .hcta:hover{background:var(--violet-soft);transform:translateY(-1px);box-shadow:var(--glow-violet);}
.biz-services{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;}
.biz-services span{font-size:12px;padding:5px 10px;border-radius:999px;border:1px solid var(--rule-strong);color:var(--fg2);background:rgba(15,8,30,.6);}
.biz-outcomes{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:18px;}
@media (max-width: 720px){.biz-outcomes{grid-template-columns:repeat(2,1fr);}}
.biz-out{background:rgba(2,6,23,.5);border:1px solid var(--rule);border-radius:10px;padding:12px;}
.biz-out .n{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--violet-soft);letter-spacing:-.02em;line-height:1;}
.biz-out .l{font-size:11px;color:var(--fg3);margin-top:6px;line-height:1.4;}

.subs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px;}
@media (max-width: 880px){.subs-grid{grid-template-columns:1fr;}}
.sub-card{background:rgba(2,6,23,.4);border:1px solid var(--rule);border-radius:14px;padding:18px;transition:all 240ms;}
.sub-card:hover{transform:translateY(-2px);border-color:rgba(167,139,250,.4);}
.sub-card .stag{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;}
.sub-card.violet .stag{color:var(--violet-soft);} .sub-card.cyan .stag{color:var(--cyan-soft);} .sub-card.emerald .stag{color:var(--emerald-soft);}
.sub-card .sname{font-family:var(--font-display);font-weight:700;font-size:18px;color:#fff;letter-spacing:-.02em;margin:6px 0 4px;}
.sub-card .sbody{font-size:12px;color:var(--fg3);line-height:1.55;}

/* ───── MILITARY + TOGGLE ───── */
.mil-summary{font-family:ui-monospace,monospace;font-size:12px;color:var(--amber-soft);margin-top:14px;letter-spacing:.04em;line-height:1.7;}
.mil-bullets{list-style:none;padding:0;margin:18px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media (max-width: 720px){.mil-bullets{grid-template-columns:1fr;}}
.mil-bullets li{padding:0 0 0 22px;position:relative;font-size:13px;color:var(--fg2);line-height:1.55;}
.mil-bullets li::before{content:"▸";position:absolute;left:0;color:var(--amber);}
.mil-medals{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}
.mil-medal{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;border:1px solid rgba(251,191,36,.3);background:rgba(251,191,36,.08);color:var(--amber-soft);font-size:12px;font-weight:600;}
.mil-medal::before{content:"★";color:var(--amber);}

/* ───── TIMELINE ───── */
.tl{position:relative;margin-top:32px;padding-left:24px;}
.tl::before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--violet),var(--cyan),var(--emerald));opacity:.5;border-radius:2px;}
.tl-item{position:relative;padding:8px 0 18px 22px;}
.tl-item::before{content:"";position:absolute;left:-22px;top:14px;width:14px;height:14px;border-radius:999px;background:var(--night-2);border:2px solid #0a0418;}
.tl-item.violet::before{background:var(--violet);} .tl-item.cyan::before{background:var(--cyan);} .tl-item.emerald::before{background:var(--emerald);} .tl-item.amber::before{background:var(--amber);}
.tl-years{font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.16em;color:var(--fg3);text-transform:uppercase;}
.tl-role{font-family:var(--font-display);font-weight:700;font-size:18px;color:#fff;letter-spacing:-.02em;margin:4px 0 2px;}
.tl-org{font-size:12px;color:var(--violet-soft);font-family:ui-monospace,monospace;letter-spacing:.04em;}
.tl-short{font-size:13px;color:var(--fg2);margin-top:6px;line-height:1.55;}

/* ───── ACHIEVEMENTS ───── */
.ach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:32px;}
@media (max-width: 880px){.ach-grid{grid-template-columns:1fr 1fr;}}
.ach{background:rgba(15,8,30,.5);border:1px solid var(--rule);border-radius:14px;padding:18px;}
.ach .n{font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:-.03em;line-height:1;}
.ach.violet .n{color:var(--violet-soft);} .ach.cyan .n{color:var(--cyan-soft);} .ach.emerald .n{color:var(--emerald-soft);} .ach.amber .n{color:var(--amber-soft);}
.ach .p{font-size:12px;color:var(--fg2);margin-top:8px;line-height:1.5;}

/* ───── CONTACT ───── */
.contact{margin-top:48px;padding:48px;border-radius:28px;background:linear-gradient(180deg,rgba(15,8,30,.85),rgba(15,8,30,.55));border:1px solid rgba(167,139,250,.3);text-align:center;position:relative;overflow:hidden;}
.contact::before{content:"";position:absolute;inset:-1px;background:linear-gradient(135deg,rgba(167,139,250,.12),rgba(34,211,238,.08),rgba(52,211,153,.08));pointer-events:none;}
.contact > *{position:relative;}
.contact-eyebrow{font-family:ui-monospace,monospace;font-size:12px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--violet-soft);}
.contact-title{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,4vw,52px);letter-spacing:-.04em;color:#fff;line-height:1;margin:14px 0 14px;}
.contact-sub{font-size:17px;color:var(--fg2);margin:0 auto 28px;max-width:520px;line-height:1.65;}
.contact-email{display:inline-block;font-family:var(--font-display);font-size:28px;font-weight:700;letter-spacing:-.02em;color:#fff;text-decoration:none;border-bottom:3px solid var(--violet);padding-bottom:4px;}
.contact-email:hover{color:var(--violet-soft);}

/* ───── FOOTER ───── */
.foot{margin-top:64px;padding:32px;border-top:1px solid rgba(167,139,250,.15);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:ui-monospace,monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg3);}
.foot a{color:var(--fg2);text-decoration:none;}
.foot a:hover{color:var(--violet-soft);}

/* ───── RESPONSIVE RAIL COLLAPSE ───── */
@media (max-width: 880px){
  .rail{grid-template-columns:1fr;}
  .rail-side{position:relative;height:auto;border-right:none;border-bottom:1px solid rgba(167,139,250,.18);}
  .rail-main{padding:24px;}
}
