/* ── RESET & TOKENS ─────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --red:#d41818;--green:#0aaa48;--blue:#1058d0;--purple:#7018cc;
  --yellow:#ffcc00;
  --off:#fffef9;--ink:#141010;--muted:rgba(20,16,16,0.6);--sep:rgba(20,16,16,0.22);
  --mono:'Plus Jakarta Sans',sans-serif;--display:'Space Mono',monospace;
}

/* ── BODY ───────────────────────────────────────────────────── */
body{
  background-color:#b6d8f2;
  color:var(--ink);font-family:var(--mono);overflow-x:hidden;min-height:100vh;
}
body::before{
  content:'';
  position:fixed;
  inset:-15%;
  z-index:-1;
  background-color:#b6d8f2;
  background-image:
    linear-gradient(45deg,rgba(14,40,80,0.1) 25%,transparent 25%),
    linear-gradient(135deg,rgba(14,40,80,0.1) 25%,transparent 25%),
    linear-gradient(45deg,transparent 75%,rgba(14,40,80,0.1) 75%),
    linear-gradient(135deg,transparent 75%,rgba(14,40,80,0.1) 75%);
  background-size:24px 24px;
  background-position:0 0,12px 0,12px -12px,0 12px;
  transform:rotate(7deg);
  animation:bg-drift 9s linear infinite;
}
@keyframes bg-drift{
  from{transform:rotate(7deg) translateX(0);}
  to{transform:rotate(7deg) translateX(24px);}
}

/* ── PAGE ───────────────────────────────────────────────────── */
.page{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:20px;padding:16px 16px 36px;}

/* ── WINDOW ─────────────────────────────────────────────────── */
.window{background:var(--off);border:2px solid var(--ink);border-radius:12px;overflow:hidden;box-shadow:5px 5px 0 #000;}
.window-titlebar{display:flex;align-items:center;padding:0 10px;height:30px;gap:8px;border-bottom:2px solid var(--ink);}
.window-num{color:rgba(255,255,255,0.5);font-size:8px;letter-spacing:0.15em;font-family:var(--mono);}
.window-title{color:#fff;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;margin-left:auto;font-family:var(--mono);opacity:0.9;}
.window-controls{display:flex;gap:5px;align-items:center;order:-1;margin-right:8px;}
.win-btn{width:12px;height:12px;border-radius:50%;flex-shrink:0;border:1px solid #000;}
.window-controls .win-btn:nth-child(1){background:#ff5f57;}
.window-controls .win-btn:nth-child(2){background:#febc2e;}
.window-controls .win-btn:nth-child(3){background:#28c840;}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:10px;font-weight:700;
  letter-spacing:0.15em;text-transform:uppercase;text-decoration:none;
  padding:8px 18px;border:2px solid var(--ink);border-radius:6px;
  background:var(--yellow);color:var(--ink);cursor:pointer;
  box-shadow:4px 4px 0 var(--ink);
  transition:box-shadow 0.08s,transform 0.08s;
  user-select:none;
}
.btn:hover{box-shadow:1px 1px 0 var(--ink);transform:translate(3px,3px);background:#fff3a0;}
.btn:active{box-shadow:0 0 0 var(--ink);transform:translate(4px,4px);}

/* ── CARD HOVER (subtle depress) ────────────────────────────── */
.pipeline-card,.reading-card,.stat-cell,.target-card,.stack-card{
  transition:box-shadow 0.08s,transform 0.08s;
}
.pipeline-card:hover,.reading-card:hover,.stat-cell:hover,.target-card:hover,.stack-card:hover{
  box-shadow:1px 1px 0 #000;transform:translate(2px,2px);
}

/* ── HERO ───────────────────────────────────────────────────── */
.hero{display:grid;grid-template-columns:1fr 270px;}
.hero-left{padding:20px 16px 16px;}
.hero-right{padding:16px;display:flex;flex-direction:column;gap:14px;background:var(--ink);color:var(--off);margin:12px 12px 12px 0;border-radius:8px;}
.profile-card-label{font-size:8px;letter-spacing:0.12em;text-transform:uppercase;opacity:0.45;font-weight:700;margin-bottom:4px;}
.profile-card-role{font-size:15px;font-weight:700;line-height:1.25;color:var(--off);}
.profile-card-sub{font-size:11px;color:rgba(255,255,255,0.5);margin-top:3px;}
.profile-stat-row{display:flex;gap:24px;padding-top:12px;border-top:1px dashed rgba(255,255,255,0.12);}
.profile-stat-num{font-family:'Syne',sans-serif;font-size:38px;font-weight:800;line-height:1;color:var(--yellow);}
.profile-stat-lbl{font-size:8px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-top:4px;}
.profile-open-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(255,255,255,0.18);border-radius:999px;padding:5px 12px;font-size:10px;font-weight:600;color:var(--off);margin-top:auto;align-self:flex-start;}
.open-dot{width:7px;height:7px;border-radius:50%;background:#28c840;flex-shrink:0;}
.window-status{font-family:var(--mono);font-size:8px;color:rgba(255,255,255,0.45);letter-spacing:0.06em;margin-left:auto;white-space:nowrap;}

.name-lg{font-family:'Syne',sans-serif;font-size:52px;font-weight:800;line-height:0.95;letter-spacing:-0.03em;text-transform:uppercase;display:block;}
.name-lg.accent{color:var(--red);}
.name-wrap{margin-bottom:14px;}

.cursor{display:inline-block;width:0.07em;height:0.75em;background:var(--red);margin-left:0.03em;vertical-align:baseline;animation:cursor-blink 1s step-end infinite;}
@keyframes cursor-blink{0%,100%{opacity:1}50%{opacity:0}}

.hero-bio{font-size:11px;line-height:1.75;font-weight:500;opacity:0.85;margin-bottom:16px;}

.hero-tags{display:flex;flex-wrap:wrap;gap:5px;margin:12px 0 0;}

/* ── CHIPS ──────────────────────────────────────────────────── */
.chip{font-size:8px;letter-spacing:0.05em;padding:3px 11px;border:1.5px solid var(--ink);border-radius:5px;text-transform:uppercase;font-family:var(--mono);font-weight:600;}
.chip.inv{background:var(--ink);color:var(--off);}
.chip.red{background:var(--red);border-color:var(--red);color:#fff;}
.chip.purple{background:var(--purple);border-color:var(--purple);color:#fff;}

/* ── TARGET CARD (profile) ──────────────────────────────────── */
.target-card{border:1.5px solid var(--ink);border-radius:10px;padding:12px 14px;box-shadow:3px 3px 0 #000;margin-top:auto;}
.target-card-eyebrow{font-size:8px;letter-spacing:0.12em;text-transform:uppercase;opacity:0.45;font-weight:700;margin-bottom:6px;}
.target-card-title{font-size:13px;font-weight:700;line-height:1.4;letter-spacing:0.01em;}
.target-card-sub{font-size:9px;opacity:0.55;margin-top:6px;font-weight:500;}

/* ── BODY GRID ──────────────────────────────────────────────── */
.body-grid{display:grid;grid-template-columns:1fr 1fr;}
.body-grid.divider{border-bottom:1px dashed var(--sep);}
.lbl-section{padding:16px;}
.body-grid > .lbl-section:first-child{border-right:1px dashed var(--sep);}
.lbl-sec-header{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;opacity:0.5;font-weight:700;margin-bottom:14px;display:flex;justify-content:space-between;border-bottom:1px dashed var(--sep);padding-bottom:8px;}
.sec-code{opacity:0.4;font-weight:500;}

/* ── ENTRY ──────────────────────────────────────────────────── */
.entry{margin-bottom:10px;}
.entry-key{font-size:8px;letter-spacing:0.09em;text-transform:uppercase;opacity:0.45;display:block;margin-bottom:3px;font-weight:700;}
.entry-val{font-size:11px;font-weight:700;letter-spacing:0.01em;display:block;line-height:1.3;}
.entry-val.sm{font-size:10px;font-weight:500;opacity:0.88;}
.entry-val.red{color:var(--red);}
.entry-val.green{color:var(--green);}
.entry-val.blue{color:var(--blue);}
.entry-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.entry-divider{border-top:1px dashed var(--sep);margin:10px 0 8px;padding-top:8px;}

/* ── MINI BADGES ────────────────────────────────────────────── */
.mini-badge{border:1.5px solid var(--ink);padding:2px 10px;font-size:8px;letter-spacing:0.03em;text-transform:uppercase;display:inline-block;margin-bottom:4px;margin-right:3px;border-radius:4px;font-weight:600;}
.mini-badge.green{border-color:var(--green);color:var(--green);}
.mini-badge.blue{border-color:var(--blue);color:var(--blue);}
.mini-badge.red{border-color:var(--red);color:var(--red);}
.mini-badge.purple{border-color:var(--purple);color:var(--purple);}
.mini-badge.inv{background:var(--ink);color:var(--off);}

.badge-group{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px;}

/* ── PROJECT ────────────────────────────────────────────────── */
.project-inner{display:grid;grid-template-columns:1fr 1fr;}
.proj-left{padding:16px;display:flex;flex-direction:column;}
.proj-right{padding:16px 14px;}
.proj-title{font-family:'Syne',sans-serif;font-size:32px;font-weight:800;text-transform:uppercase;letter-spacing:-0.02em;line-height:1;margin-bottom:6px;}
.proj-title .sub{color:var(--green);}
.proj-title .dim{color:var(--green);}
.proj-desc{font-size:10px;line-height:1.65;opacity:0.78;margin-top:8px;font-weight:500;}
.proj-spec{margin-top:10px;border-top:1px dashed var(--sep);padding-top:8px;display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.proj-actions{margin-top:auto;padding-top:12px;}

/* ── HEATMAP ────────────────────────────────────────────────── */
.heatmap-wrap{margin-top:14px;width:100%;border:2px solid var(--ink);border-radius:4px;box-shadow:4px 4px 0 var(--ink);overflow:hidden;}
.heatmap-titlebar{background:var(--ink);padding:5px 10px;display:flex;justify-content:space-between;align-items:center;}
.heatmap-title{font-family:var(--display);font-size:8px;color:var(--off);letter-spacing:0.15em;font-weight:700;}
.heatmap-spec{font-size:7px;color:rgba(255,255,255,0.45);letter-spacing:0.06em;}
.heatmap-inner{background:var(--off);padding:8px 10px 10px;}
.heatmap-axes{display:flex;justify-content:space-between;font-family:var(--display);font-size:7px;color:rgba(20,16,16,0.4);letter-spacing:0.08em;margin-top:5px;text-transform:uppercase;}
.colorbar-wrap{display:flex;align-items:center;gap:6px;margin-top:8px;}
.colorbar-label{font-size:6px;color:rgba(20,16,16,0.45);letter-spacing:0.06em;text-transform:uppercase;white-space:nowrap;}
.colorbar{flex:1;display:flex;gap:1px;border-radius:2px;overflow:hidden;}
.colorbar-cell{flex:1;height:6px;}

/* ── ACADEMIA ───────────────────────────────────────────────── */
.academia-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:8px;padding:12px 12px 0;}
.academia-grid .span-rows{grid-row:1/3;}
.academia-uni{font-family:'Syne',sans-serif;font-size:48px;font-weight:800;line-height:0.95;letter-spacing:-0.03em;text-transform:uppercase;}
.academia-uni .accent{color:var(--red);}
.academia-sub{font-size:10px;opacity:0.6;margin-top:6px;line-height:1.5;font-weight:500;}
.academia-quote{border-left:3px solid var(--red);padding:6px 12px;font-size:11px;line-height:1.65;opacity:0.75;margin:0;font-style:normal;font-weight:500;}
.gpa-num{font-family:'Syne',sans-serif;font-size:72px;line-height:1;color:var(--red);letter-spacing:-0.03em;font-weight:800;}
.gpa-denom{font-size:28px;opacity:0.4;font-weight:700;color:var(--ink);}
.gpa-honors{font-size:9px;opacity:0.5;margin-top:6px;letter-spacing:0.04em;font-weight:600;}
.grad-awards{display:flex;flex-direction:column;gap:6px;}
.award-row{font-size:10px;padding:7px 0;display:flex;justify-content:space-between;align-items:center;gap:12px;font-weight:500;border-bottom:1px dashed var(--sep);}
.award-row:last-child{border-bottom:none;}
.award-tag{font-size:8px;letter-spacing:0.04em;text-transform:uppercase;padding:2px 10px;border:1.5px solid rgba(20,16,16,0.25);color:var(--muted);white-space:nowrap;border-radius:4px;font-weight:600;}
.coursework-block{padding:14px 16px;margin-top:16px;}
.coursework-eyebrow{font-size:10px;letter-spacing:0.14em;text-transform:uppercase;font-weight:700;margin-bottom:14px;padding-bottom:8px;border-bottom:1px dashed var(--sep);display:flex;justify-content:space-between;}
.coursework-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}

/* ── WORK ───────────────────────────────────────────────────── */
.work-hero{padding:16px;display:flex;flex-direction:column;gap:12px;}

/* ── STATS ──────────────────────────────────────────────────── */
.stat-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px;}
.stat-cell{padding:14px 16px;border:1.5px solid var(--ink);border-radius:10px;box-shadow:3px 3px 0 #000;}
.stat-num{font-family:var(--display);font-size:36px;line-height:1;letter-spacing:-0.01em;font-weight:700;}
.stat-num .unit{font-size:14px;opacity:0.65;}
.stat-num .accent{color:var(--red);}
.stat-num .blue{color:var(--blue);}
.stat-num .purple{color:var(--purple);}
.stat-desc{font-size:9px;opacity:0.72;letter-spacing:0.03em;text-transform:uppercase;margin-top:4px;line-height:1.6;font-weight:600;}

/* ── PIPELINE CARDS ─────────────────────────────────────────── */
.pipelines-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:12px;}
.pipeline-card{padding:20px;border:1.5px solid var(--ink);border-radius:10px;box-shadow:3px 3px 0 #000;position:relative;overflow:hidden;display:flex;flex-direction:column;}
.pipeline-card.dark{background:var(--ink);}
.pc-tag{font-size:8px;letter-spacing:0.1em;text-transform:uppercase;opacity:0.45;margin-bottom:8px;font-weight:700;}
.pc-tag.blue{opacity:1;color:var(--blue);}
.pc-tag.purple{opacity:1;color:var(--purple);}
.pipeline-card.dark .pc-tag{color:rgba(255,255,255,0.4);}
.pc-title{font-family:var(--display);font-size:20px;line-height:1.05;margin-bottom:8px;color:var(--ink);font-weight:700;}
.pipeline-card.dark .pc-title{color:var(--off);}
.pc-desc{font-size:10px;line-height:1.65;opacity:0.75;max-width:300px;font-weight:500;flex:1;margin-bottom:4px;}
.pipeline-card.dark .pc-desc{color:rgba(255,255,255,0.5);}
.pc-badge{display:inline-block;margin-top:10px;margin-right:3px;font-size:7px;letter-spacing:0.1em;text-transform:uppercase;padding:2px 9px;border:1.5px solid currentColor;border-radius:4px;}
.pc-badge.inv{background:var(--red);border-color:var(--red);color:#fff;}
.pc-badge.red{color:var(--red);}
.pc-badge.purple{color:var(--purple);}
.pc-badge.inv-purple{background:var(--purple);border-color:var(--purple);color:#fff;}
.pc-badge.def{color:var(--muted);}
.pipeline-card.dark .pc-badge.def{color:rgba(255,255,255,0.35);border-color:rgba(255,255,255,0.2);}
.pc-num{font-family:var(--display);font-size:60px;line-height:1;position:absolute;right:8px;bottom:14px;opacity:0.10;font-weight:700;color:var(--ink);pointer-events:none;}

/* course cards (reuse pipeline-card) */
.pipeline-card.cc-blue{border-left:4px solid var(--blue);}
.pipeline-card.cc-red{border-left:4px solid var(--red);}
.pipeline-card.cc-purple{border-left:4px solid var(--purple);}
.course-name{font-size:9px;font-weight:700;letter-spacing:0.02em;display:block;}
.course-sub{font-size:8px;opacity:0.65;margin-top:2px;display:block;font-weight:500;}

/* ── STACK GRID ─────────────────────────────────────────────── */
.stack-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:8px;padding:12px 12px 0;}
.stack-card{padding:14px 16px;border:2px solid var(--ink);border-radius:10px;display:flex;flex-direction:column;gap:10px;box-shadow:3px 3px 0 #000;}
.stack-card.span-rows{grid-row:1/3;}
.stack-card.dark{background:var(--ink);color:var(--off);}
.stack-card.purple-card{background:var(--purple);color:#fff;}
.stack-card.blue-card{background:var(--blue);color:#fff;}
.stack-card-eyebrow{font-size:8px;letter-spacing:0.12em;text-transform:uppercase;font-weight:700;opacity:0.5;}
.stack-card-title{font-family:'Syne',sans-serif;font-size:30px;font-weight:800;line-height:0.92;letter-spacing:-0.02em;text-transform:uppercase;}
.stack-card-desc{font-size:11px;line-height:1.6;opacity:0.72;flex:1;}
.stack-card-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto;}
.stack-card.dark .mini-badge,.stack-card.purple-card .mini-badge,.stack-card.blue-card .mini-badge{background:transparent;border-color:rgba(255,255,255,0.35);color:inherit;}
.reads-list{display:flex;flex-direction:column;gap:0;width:100%;}
.read-row{display:flex;align-items:baseline;gap:8px;padding:7px 0;border-bottom:1px dashed var(--sep);}
.read-row:last-child{border-bottom:none;}
.read-title{font-size:12px;font-weight:700;flex:1;}
.read-author{font-size:11px;opacity:0.5;white-space:nowrap;}
.stack-tooling{display:flex;align-items:center;gap:6px;padding:10px 12px;border-top:1px dashed var(--sep);flex-wrap:wrap;margin-top:8px;}
.stack-tooling-label{font-size:8px;letter-spacing:0.12em;text-transform:uppercase;opacity:0.45;font-weight:700;margin-right:6px;white-space:nowrap;}

/* ── TECH SLASH ─────────────────────────────────────────────── */
.tech-slash-block{padding:14px 16px;border-top:1px dashed var(--sep);}
.prev-exp-block{padding:14px 16px;border-top:1px dashed var(--sep);}
.prev-exp-row{display:grid;grid-template-columns:160px 1fr auto;align-items:baseline;gap:8px;padding:5px 0;border-bottom:1px dashed var(--sep);}
.prev-exp-row:last-child{border-bottom:none;}
.prev-exp-role{font-size:12px;font-weight:700;letter-spacing:0.01em;}
.prev-exp-org{font-size:11px;opacity:0.6;font-weight:500;}
.prev-exp-date{font-family:var(--display);font-size:9px;opacity:0.45;letter-spacing:0.06em;white-space:nowrap;}
@media(max-width:760px){
  .prev-exp-row{grid-template-columns:1fr auto;row-gap:1px;}
  .prev-exp-org{grid-column:1;font-size:10px;}
  .prev-exp-date{grid-row:1;grid-column:2;}
}
.slash-eyebrow{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;opacity:0.45;margin-bottom:8px;font-weight:700;}
.slash-text{font-family:var(--display);font-size:14px;line-height:1.5;letter-spacing:0.01em;font-weight:700;}
.slash-text .sep{color:var(--blue);margin:0 4px;}
.slash-text .sub{font-family:var(--mono);font-size:9px;opacity:0.5;font-weight:500;}

/* ── OUTSIDE WORK BENTO ─────────────────────────────────────── */
.outside-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:8px;padding:12px;}
.span-cols{grid-column:2/4;}
.bento-label{font-size:8px;letter-spacing:0.1em;text-transform:uppercase;opacity:0.45;font-weight:700;margin-bottom:2px;margin-top:8px;}
.bento-val{font-size:11px;font-weight:500;line-height:1.5;}

/* ── CONTACT ────────────────────────────────────────────────── */
.contact-bar{padding:12px 16px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:12px;}
.contact-item{display:flex;flex-direction:column;gap:2px;}
.contact-key{font-size:9px;letter-spacing:0.09em;text-transform:uppercase;opacity:0.45;font-weight:700;margin-bottom:5px;}

/* ── FROG ───────────────────────────────────────────────────── */
.frog-block{overflow:hidden;display:flex;justify-content:center;padding:28px 0;}

/* ── FOOTER ─────────────────────────────────────────────────── */
footer{display:flex;justify-content:space-between;align-items:center;padding:6px 4px;font-size:7px;opacity:0.5;letter-spacing:0.1em;text-transform:uppercase;}

/* ── DIALOG ─────────────────────────────────────────────────── */
.dialog-overlay{position:fixed;inset:0;background:rgba(30,14,6,0.45);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px;}
.dialog-overlay.hidden{display:none;}
.dialog{background:var(--off);border:2px solid var(--ink);border-radius:10px;overflow:hidden;min-width:220px;max-width:360px;width:100%;font-family:var(--mono);box-shadow:5px 5px 0 #000;}
.dialog-titlebar{background:var(--ink);color:var(--off);display:flex;align-items:center;justify-content:space-between;padding:6px 10px;font-size:8px;letter-spacing:0.18em;text-transform:uppercase;user-select:none;}
.dialog-title{opacity:0.85;}
.dialog-close{background:rgba(255,255,255,0.15);border:none;color:var(--off);font-family:var(--mono);font-size:9px;padding:2px 7px;cursor:pointer;opacity:0.7;border-radius:999px;}
.dialog-close:hover{opacity:1;background:rgba(255,255,255,0.25);}
.dialog-body{padding:20px 16px 12px;font-size:10px;line-height:1.6;text-align:center;border-bottom:1px dashed var(--sep);}
.dialog-footer{padding:10px 12px;display:flex;justify-content:center;gap:8px;}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:760px){
  .hero{grid-template-columns:1fr;}
  .hero-right{border-top:none;margin:0 12px 12px;}
  .body-grid{grid-template-columns:1fr;}
  .project-inner{grid-template-columns:1fr;}
  .proj-left{border-bottom:1px dashed var(--sep);}
  .stat-strip{grid-template-columns:1fr;}
  .stack-grid{grid-template-columns:1fr;}
  .stack-card.span-rows{grid-row:auto;}
  .academia-grid{grid-template-columns:1fr;}
  .academia-grid .span-rows{grid-row:auto;}
  .outside-grid{grid-template-columns:1fr;}
  .span-cols{grid-column:auto;}
  .pipelines-grid{grid-template-columns:1fr;}
  .coursework-grid{grid-template-columns:1fr 1fr;}
  .reading-card{flex-direction:column;align-items:flex-start;}
  .name-lg{font-size:36px;}
  .window-title{font-size:8px;letter-spacing:0.1em;}
  .page{gap:16px;padding:12px 12px 28px;}
}
