*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

/* ---------- THEME (light/dark) x MODE (product/hacker) ---------- */
body{
  font-family:'Hanken Grotesk',sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;
  /* light + product (default) */
  --bg:#f6f2ea;--fg:#5c5347;--emph:#211d18;--mut:#6b6356;--accent:#1f5f8b;--rule:#e5ddcf;--surface:#efe7d8;--hl:#e3eef5;
  transition:background .45s ease,color .45s ease;
}
@media(prefers-color-scheme:dark){body:not(.light){--bg:#11131f;--fg:#a6aac6;--emph:#edeef7;--mut:#9095b6;--accent:#5b9dd9;--rule:#23263b;--surface:#181b2b;--hl:#1c2740}}
body.dark{--bg:#11131f;--fg:#a6aac6;--emph:#edeef7;--mut:#9095b6;--accent:#5b9dd9;--rule:#23263b;--surface:#181b2b;--hl:#1c2740}
body.light{--bg:#f6f2ea;--fg:#5c5347;--emph:#211d18;--mut:#6b6356;--accent:#1f5f8b;--rule:#e5ddcf;--surface:#efe7d8;--hl:#e3eef5}

/* HACKER mode overrides — terminal register, green accent, always darker surface feel */
body.hacker{--accent:#2faf6a;--hl:#12351f}
body.hacker.light{--bg:#0e1016;--fg:#9fb4a6;--emph:#e9f3ec;--mut:#8aa193;--rule:#1d2630;--surface:#141821;--hl:#13321f;--accent:#37c97c}
body.hacker:not(.light){--bg:#0a0c12;--fg:#8fa89a;--emph:#e9f3ec;--mut:#86a092;--rule:#1a222b;--surface:#10141c;--hl:#0f2a19;--accent:#37c97c}

.page{background:var(--bg);color:var(--fg);min-height:100vh;transition:background .45s,color .45s}
.wrap{max-width:760px;margin:0 auto;padding:0 28px}

/* ---------- NAV ---------- */
nav{display:flex;justify-content:space-between;align-items:center;padding:26px 0;font-family:'JetBrains Mono',monospace;font-size:12px;flex-wrap:wrap;gap:14px}
nav .mk{color:var(--emph);font-weight:600;text-decoration:none;letter-spacing:.02em}
nav .mk:hover{color:var(--accent)}
nav .right{display:flex;align-items:center;gap:6px}
nav a.lnk{color:var(--mut);text-decoration:none;margin-left:16px;transition:color .15s}
nav a.lnk:hover{color:var(--accent)}
nav .links{display:inline}
@media(max-width:520px){nav a.lnk{margin-left:0;margin-right:14px}nav .links{display:block;width:100%;order:3;margin-top:4px}}

/* MODE SWITCH — the star */
.switch{display:inline-flex;align-items:center;border:1px solid var(--rule);border-radius:999px;padding:3px;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;cursor:pointer;user-select:none;background:var(--surface);transition:.2s}
.switch:hover{border-color:var(--accent)}
.switch span{padding:6px 12px;border-radius:999px;color:var(--mut);transition:.25s;letter-spacing:.05em;text-transform:uppercase}
.switch .on{background:var(--accent);color:#fff}
body.hacker .switch .on{color:#06140c}
.toggle{background:none;border:1px solid var(--rule);color:var(--mut);font:inherit;font-size:13px;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-left:10px;transition:.15s}
.toggle:hover{color:var(--accent);border-color:var(--accent)}

/* ---------- HERO ---------- */
header{padding:60px 0 64px}
.tag{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent);letter-spacing:.16em;text-transform:uppercase;margin-bottom:22px;min-height:14px}
h1{font-size:clamp(40px,8.5vw,76px);line-height:.98;letter-spacing:-.03em;color:var(--emph);min-height:1.96em}
h1 .dot{color:var(--accent)}
body.hacker h1{font-family:'JetBrains Mono',monospace;font-weight:600;letter-spacing:-.04em;font-size:clamp(30px,6.5vw,56px)}
.cursor{display:inline-block;width:.6ch;background:var(--accent);animation:blink 1.1s steps(1) infinite;margin-left:2px}
@keyframes blink{50%{opacity:0}}
.lede{font-size:clamp(17px,2.3vw,21px);max-width:33em;margin-top:26px}
.lede b{color:var(--emph);font-weight:600}
body.hacker .lede{font-family:'JetBrains Mono',monospace;font-size:clamp(14px,1.9vw,16px);line-height:1.7}

.flip-cta{display:inline-flex;align-items:center;gap:8px;margin-top:30px;font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--accent);text-decoration:none;cursor:pointer;border-bottom:1px dashed var(--accent);padding-bottom:2px;transition:.15s}
.flip-cta:hover{gap:12px}
.cvbtn{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-family:'JetBrains Mono',monospace;font-size:12.5px;font-weight:600;color:#fff;background:var(--accent);text-decoration:none;padding:11px 18px;border-radius:8px;transition:.18s}
body.hacker .cvbtn{color:#06140c}
.cvbtn:hover{gap:12px;filter:brightness(1.08)}

/* ---------- SECTIONS ---------- */
section{padding:44px 0;border-top:1px solid var(--rule)}
.lbl{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px}
h2{font-size:clamp(23px,4vw,30px);margin-bottom:14px;letter-spacing:-.015em;color:var(--emph)}
body.hacker h2{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:clamp(20px,3.4vw,26px)}
p.body{max-width:44em;margin-bottom:12px}
p.body:last-child{margin-bottom:0}
.lk{color:var(--accent);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px;padding:0 1px;transition:background .15s}
.lk:hover{background:var(--hl)}

/* mode-swap content */
.m{display:none}
body:not(.hacker) .m.product{display:block}
body.hacker .m.hacker{display:block}
.fade{animation:fadein .5s ease}
@keyframes fadein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* career ladder (product) */
.ladder{list-style:none;margin-top:6px}
.ladder li{position:relative;padding:0 0 24px 26px;border-left:2px solid var(--rule)}
.ladder li:last-child{padding-bottom:0}
.ladder li::before{content:"";position:absolute;left:-7px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--accent)}
.ladder li:first-child::before{background:var(--accent)}
.ladder .co{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.04em;text-transform:uppercase;margin-bottom:5px}
.ladder .ro{color:var(--fg);max-width:44em}
.ladder .ro b{color:var(--emph);font-weight:700}

/* project cards (hacker) */
.grid{display:grid;gap:12px;grid-template-columns:1fr;margin-top:6px}
@media(min-width:560px){.grid{grid-template-columns:1fr 1fr}}
.card{border:1px solid var(--rule);padding:18px;text-decoration:none;display:block;transition:.2s;background:var(--surface);border-radius:8px;font-family:'JetBrains Mono',monospace}
.card:hover{border-color:var(--accent);transform:translateY(-2px)}
.card h3{font-size:14px;color:var(--emph);font-weight:600;margin-bottom:6px;display:flex;justify-content:space-between}
.card h3 .s{color:var(--accent);font-size:11px}
.card p{color:var(--mut);font-size:13px;line-height:1.5}

/* find me */
.out{display:grid;grid-template-columns:1fr;gap:2px;margin-top:6px;font-family:'JetBrains Mono',monospace;font-size:14px}
@media(min-width:560px){.out{grid-template-columns:1fr 1fr}}
.out a{display:flex;justify-content:space-between;color:var(--emph);text-decoration:none;padding:12px 4px;border-bottom:1px solid var(--rule);transition:.15s}
.out a:hover{color:var(--accent);padding-left:10px}
.out a .h{color:var(--mut)}

footer{padding:46px 0 56px;border-top:1px solid var(--rule);font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mut);display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

nav a.lnk.active{color:var(--emph)}

/* ---------- SUBPAGE STUB ---------- */
.sub-hero{padding:64px 0 28px}
.sub-hero .tag{margin-bottom:18px}
.sub-hero h1{font-size:clamp(34px,7vw,58px);min-height:auto;margin-bottom:18px}
.soon{font-size:clamp(16px,2.2vw,19px);color:var(--mut);max-width:34em}
.soon a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.back{display:inline-block;margin-top:32px;font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--accent);text-decoration:none;border-bottom:1px dashed var(--accent);padding-bottom:2px}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .cursor{display:none}
}
