/* ── TOKENS ─────────────────────────────────────────── */
:root {
  --bg:       #F9F9F7;
  --surface:  #FFFFFF;
  --ink:      #0D0D0B;
  --mid:      #3A3731;
  --dim:      #6B6760;
  --rule:     #E4E1D8;
  --g:        #1A5C45;
  --g2:       #22704F;
  --g-light:  rgba(26,92,69,.08);
  --g-mid:    rgba(26,92,69,.22);
  --g-border: rgba(26,92,69,.18);
  --amber:        #A86A10;
  --amber-light:  rgba(168,106,16,.08);
  --amber-border: rgba(168,106,16,.22);
  --blue:         #1B4F91;
  --blue-light:   rgba(27,79,145,.07);
  --blue-border:  rgba(27,79,145,.20);
  --rose:         #8A1F52;
  --rose-light:   rgba(138,31,82,.07);
  --rose-border:  rgba(138,31,82,.20);
  --serif:    'Montserrat', system-ui, sans-serif;
  --sans:     'Montserrat', system-ui, sans-serif;
  --mono:     'DM Mono', monospace;
  --sw:       268px;
  --ease:     cubic-bezier(.4,0,.2,1);
  --lift-shadow: 0 4px 18px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04);
  --lift-shadow-md: 0 8px 32px rgba(0,0,0,.10), 0 2px 8px rgba(0,0,0,.05);
}

/* ── DARK MODE TOKENS ──────────────────────────────── */
[data-theme="dark"] {
  --bg:       #0C0C0A;
  --surface:  #141412;
  --ink:      #ECEAE4;
  --mid:      #C8C4BC;
  --dim:      #928F89;
  --rule:     #222220;
  --g:        #3DB87A;
  --g2:       #4DC98A;
  --g-light:  rgba(61,184,122,.09);
  --g-mid:    rgba(61,184,122,.28);
  --g-border: rgba(61,184,122,.22);
  --amber:        #E8A84A;
  --amber-light:  rgba(232,168,74,.09);
  --amber-border: rgba(232,168,74,.26);
  --blue:         #6BA3D8;
  --blue-light:   rgba(107,163,216,.09);
  --blue-border:  rgba(107,163,216,.26);
  --rose:         #D46894;
  --rose-light:   rgba(212,104,148,.09);
  --rose-border:  rgba(212,104,148,.26);
  --lift-shadow: 0 4px 18px rgba(0,0,0,.28), 0 1px 4px rgba(0,0,0,.18);
  --lift-shadow-md: 0 8px 32px rgba(0,0,0,.38), 0 2px 8px rgba(0,0,0,.22);
}
[data-theme="dark"] body::before{
  background-image: radial-gradient(circle, rgba(255,255,255,.012) 1px, transparent 1px);
}
[data-theme="dark"] .code-block{ background:#080807; border-color:var(--rule); }
[data-theme="dark"] .sec-ghost{ color:rgba(255,255,255,.03); }
[data-theme="dark"] .sidebar{ background:var(--bg); }
[data-theme="dark"] .m-header{ background:var(--bg); }

/* ── RESET ──────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html, body, .sidebar, .m-header, .m-nav, footer, .sec, .proj-body,
.edu-card, .ieee-card, .path-node, .chip, .tl-row, .proj-tag {
  transition-property: background-color, color, border-color;
  transition-duration: .3s;
  transition-timing-function: var(--ease);
}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:inherit}
::selection{background:var(--g);color:var(--bg)}

/* ── SUBTLE PAPER TEXTURE ───────────────────────────── */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    radial-gradient(circle, rgba(0,0,0,.018) 1px, transparent 1px);
  background-size:28px 28px;
}

/* ── SIDEBAR ────────────────────────────────────────── */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;width:var(--sw);
  background:var(--bg);border-right:1px solid var(--rule);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:2.8rem 2.2rem;z-index:200;
}

.sb-wordmark{
  font-family:var(--mono);font-size:.58rem;font-weight:300;
  letter-spacing:.22em;text-transform:uppercase;color:var(--g);
  margin-bottom:3.2rem;
}

.sb-nav{display:flex;flex-direction:column;gap:.2rem}

.sb-link{
  display:flex;align-items:center;gap:.75rem;
  font-family:var(--mono);font-size:12px;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--mid);padding:.45rem 0;
  border-left:2px solid transparent;
  padding-left:.7rem;margin-left:-.7rem;
  transition:color .22s var(--ease), border-color .22s var(--ease);
}
.sb-link:hover{color:var(--ink)}
.sb-link.active{color:var(--g);border-left-color:var(--g)}
.sb-num{color:var(--rule);transition:color .22s}
.sb-link.active .sb-num{color:var(--g-mid)}

.sb-divider{height:1px;background:var(--rule);margin:2rem 0}

.sb-meta{
  font-family:var(--mono);font-size:10px;font-weight:300;
  color:var(--dim);letter-spacing:.09em;line-height:2;
}
.sb-meta a{transition:color .18s}
.sb-meta a:hover{color:var(--g)}

/* Theme toggle button */
.theme-toggle{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--dim);background:none;
  border:1px solid var(--rule);padding:.28rem .6rem;
  margin-top:1rem;cursor:pointer;
  transition:color .2s,border-color .2s,background .2s;
}
.theme-toggle:hover{color:var(--g);border-color:var(--g-border);background:var(--g-light)}
.theme-toggle-icon{font-size:.7rem;line-height:1}

/* Mobile header theme toggle */
.mh-theme{
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  letter-spacing:.12em;text-transform:uppercase;color:var(--dim);
  background:none;border:1px solid var(--rule);
  padding:.3rem .55rem;transition:all .18s;cursor:pointer;
}
.mh-theme:hover{border-color:var(--g-border);color:var(--g)}

/* ── MAIN ────────────────────────────────────────────── */
.main{margin-left:var(--sw);position:relative;z-index:1}

/* ── SECTIONS ────────────────────────────────────────── */
.sec{
  padding:5.5rem 5rem;
  border-bottom:1px solid var(--rule);
  position:relative;overflow:hidden;
}
.sec:last-of-type{border-bottom:none}

.sec-ghost{
  position:absolute;right:-1rem;top:50%;transform:translateY(-55%);
  font-family:var(--serif);font-weight:600;
  font-size:clamp(9rem,18vw,18rem);
  color:rgba(0,0,0,.028);letter-spacing:-.04em;
  line-height:1;pointer-events:none;user-select:none;
  transition:color .3s;
}

.sec-header{
  display:flex;align-items:center;gap:1.2rem;
  margin-bottom:3.5rem;
}
.sec-num{
  font-family:var(--mono);font-size:.58rem;font-weight:400;
  color:var(--g);letter-spacing:.22em;
}
.sec-rule{width:36px;height:1px;background:var(--rule);flex-shrink:0}
.sec-name{
  font-family:var(--mono);font-size:.58rem;font-weight:300;
  color:var(--dim);letter-spacing:.18em;text-transform:uppercase;
}

/* ── INTRO ───────────────────────────────────────────── */
#intro{padding:6rem 5rem 5.5rem;min-height:92vh;display:flex;flex-direction:column;justify-content:center}

.intro-status{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--mono);font-size:.55rem;font-weight:400;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--g);padding:.3rem .8rem;
  border:1px solid var(--g-border);background:var(--g-light);
  margin-bottom:2.8rem;
  opacity:0;animation:fadeUp .7s var(--ease) .1s forwards;
}
.status-pulse{
  width:5px;height:5px;border-radius:50%;background:var(--g);
  animation:pulse 2.6s ease infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

.intro-eyebrow{
  font-family:var(--mono);font-size:.6rem;font-weight:300;
  letter-spacing:.2em;text-transform:uppercase;color:var(--mid);
  margin-bottom:1.2rem;
  opacity:0;animation:fadeUp .7s var(--ease) .2s forwards;
}

.intro-h{
  font-family:var(--serif);font-weight:600;
  font-size: 40px;
  line-height:1.1;letter-spacing:-.03em;color:var(--ink);
  margin-bottom:2rem;
  opacity:0;animation:fadeUp .8s var(--ease) .3s forwards;
}
.intro-h em{font-style:italic;color:var(--g)}

.intro-body{
  font-size:1.05rem;color:var(--mid);line-height:1.78;
  max-width:520px;margin-bottom:3rem;
  opacity:0;animation:fadeUp .7s var(--ease) .45s forwards;
}

/* Career path nodes */
.path-track{
  display:flex;align-items:center;gap:0;
  flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
  margin-bottom:2.5rem;
  opacity:0;animation:fadeUp .7s var(--ease) .55s forwards;
}
.path-node{
  display:flex;flex-direction:column;gap:.15rem;
  padding:.6rem .75rem;border:1px solid var(--rule);
  background:var(--bg);position:relative;flex-shrink:0;
  transition:border-color .22s,background .22s,transform .22s var(--ease),box-shadow .22s;
}
.path-node:hover{
  border-color:var(--g-border);background:var(--g-light);
  transform:translateY(-3px);box-shadow:var(--lift-shadow);
}
.path-node.current{border-color:var(--g-border);background:var(--g-light)}
.pn-label{
  font-family:var(--mono);font-size:.48rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;color:var(--dim);
}
.pn-role{
  font-family:var(--sans);font-size:.82rem;font-weight:500;color:var(--ink);
}
.pn-year{
  font-family:var(--mono);font-size:.48rem;font-weight:300;
  letter-spacing:.1em;color:var(--dim);
}
.path-arrow{
  font-size:1rem;color:var(--rule);padding:0 .55rem;
  align-self:center;flex-shrink:0;
}

.chips{
  display:flex;flex-wrap:wrap;gap:.45rem;
  opacity:0;animation:fadeUp .7s var(--ease) .65s forwards;
}
.chip{
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.25rem .6rem;border:1px solid var(--rule);color:var(--dim);
  transition:all .18s var(--ease);cursor:default;
}
.chip:hover,.chip.hi{
  border-color:var(--g-border);color:var(--g);background:var(--g-light);
  transform:translateY(-1px);
}

/* ── PROFILE ─────────────────────────────────────────── */
#profile .profile-cols{
  display:grid;grid-template-columns:1.25fr 1fr;gap:4rem;align-items:start;
}
.profile-body p{
  font-size:1.08rem;color:var(--mid);line-height:1.82;margin-bottom:1.1rem;
}
.profile-body p:last-child{margin-bottom:0}
.profile-body strong{color:var(--ink);font-weight:500}
.profile-body em{color:var(--g);font-style:italic}

/* Education block */
.edu-stack{display:flex;flex-direction:column;gap:1rem}
.edu-card{
  padding:1.3rem;border:1px solid var(--rule);background:var(--bg);
  transition:border-color .22s,transform .22s var(--ease),box-shadow .22s;
}
.edu-card:hover{
  border-color:var(--g-border);
  transform:translateY(-2px);box-shadow:var(--lift-shadow);
}
.edu-badge{
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--g);margin-bottom:.45rem;
}
.edu-degree{
  font-family:var(--serif);font-size:1.08rem;font-weight:400;
  color:var(--ink);line-height:1.25;margin-bottom:.3rem;
}
.edu-detail{
  font-size:.85rem;color:var(--mid);font-style:italic;line-height:1.5;
}
.edu-meta{
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.1em;color:var(--dim);margin-top:.4rem;
}

.ieee-card{
  padding:1.3rem;border:1px solid var(--g-border);
  background:var(--g-light);margin-top:.4rem;
  transition:transform .22s var(--ease),box-shadow .22s,border-color .22s;
}
.ieee-card:hover{
  transform:translateY(-2px);box-shadow:var(--lift-shadow);
  border-color:var(--g);
}
.ieee-tag{
  font-family:var(--mono);font-size:.5rem;font-weight:400;
  letter-spacing:.2em;text-transform:uppercase;color:var(--g);margin-bottom:.5rem;
}
.ieee-title{
  font-family:var(--serif);font-size:1rem;font-weight:400;
  color:var(--ink);line-height:1.45;margin-bottom:.35rem;
}
.ieee-meta{
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.09em;color:var(--mid);line-height:1.7;
}

/* ── RECORD (Timeline) ──────────────────────────────── */
.timeline{border-top:1px solid var(--rule)}
.tl-row{
  display:grid;grid-template-columns:160px 1fr;gap:2.5rem;
  padding:2rem 0;border-bottom:1px solid var(--rule);
  border-left:2px solid transparent;padding-left:1rem;margin-left:-1rem;
  opacity:0;transform:translateY(14px);
  transition:opacity .55s var(--ease),transform .55s var(--ease),
             border-left-color .25s,background .25s;
}
.tl-row.in{opacity:1;transform:translateY(0)}
.tl-row:hover{border-left-color:var(--g);background:var(--g-light)}
.tl-row:last-child{border-bottom:none}

.tl-meta{padding-top:.15rem}
.tl-period{
  font-family:var(--mono);font-size:.55rem;font-weight:300;
  letter-spacing:.12em;color:var(--g);margin-bottom:.25rem;
}
.tl-org{
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  letter-spacing:.09em;color:var(--dim);
}

.tl-body{}
.tl-role{
  font-family:var(--serif);font-size:1.35rem;font-weight:400;
  color:var(--ink);line-height:1.15;margin-bottom:.5rem;
}
.tl-desc{
  font-size:.9rem;color:var(--mid);line-height:1.68;
}
.tl-desc li{
  padding-left:1rem;position:relative;margin-bottom:.2rem;
}
.tl-desc li::before{
  content:'—';position:absolute;left:0;
  color:var(--rule);font-size:.8rem;
}

/* ── WORK (Projects) ────────────────────────────────── */
.proj-list{display:flex;flex-direction:column;gap:1.2rem}

/* Grid layout (replaces list in §03) */
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}

/* Graphic header inside each card */
.pc-visual{
  height:152px;
  border-bottom:1px solid var(--rule);
  background:var(--surface);
  display:flex;align-items:center;justify-content:center;
  padding:1rem 2rem;overflow:hidden;position:relative;
  transition:background .28s var(--ease);
}
.proj:hover .pc-visual,.proj.open .pc-visual{background:var(--g-light)}
.pc-visual svg{width:100%;max-width:300px;height:auto;display:block}

/* Card text area */
.pc-content{padding:1.4rem 2rem .5rem}

/* Inline metric below hook */
.pc-stat{
  display:flex;align-items:baseline;gap:.6rem;
  margin-top:.85rem;padding-top:.7rem;
  border-top:1px solid var(--rule);
}

/* Live badge for deployed projects */
.proj-live{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--g);text-decoration:none;
  transition:opacity .18s;
}
.proj-live:hover{opacity:.62}
.proj-live .live-dot{
  width:5px;height:5px;border-radius:50%;background:var(--g);
  animation:pulse 2.4s ease infinite;flex-shrink:0;
}

.proj{
  border:1px solid var(--rule);
  transition:border-color .22s,transform .22s var(--ease),box-shadow .22s;
  position:relative;overflow:hidden;
}
.proj:hover{
  border-color:var(--g-border);
  transform:translateY(-2px);box-shadow:var(--lift-shadow-md);
}
.proj.open{border-color:var(--g-border);transform:none;box-shadow:none}

/* Left accent strip */
.proj::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:2px;background:transparent;
  transition:background .22s;
}
.proj:hover::before,.proj.open::before{background:var(--g)}

.proj-top{
  padding:1.8rem 2rem;cursor:pointer;
  display:grid;grid-template-columns:1fr auto;gap:1.5rem;align-items:start;
}
.proj-tl{}
.proj-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.7rem}
.proj-tag{
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.18rem .48rem;border:1px solid var(--rule);color:var(--dim);
}
.proj-tag.hot{border-color:var(--g-border);color:var(--g);background:var(--g-light)}

.proj-title{
  font-family:var(--serif);font-size:1.5rem;font-weight:400;
  color:var(--ink);line-height:1.15;margin-bottom:.4rem;
}
.proj-hook{
  font-size:.9rem;color:var(--mid);font-style:italic;line-height:1.55;
}

.proj-stat{text-align:right;flex-shrink:0}
.ps-val{
  font-family:var(--serif);font-size:2rem;font-weight:400;
  color:var(--g);line-height:1;
}
.ps-label{
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.1em;text-transform:uppercase;color:var(--dim);
  margin-top:.15rem;
}

.proj-toggle{
  display:flex;align-items:center;gap:.5rem;padding:0 2rem 1.3rem;
  font-family:var(--mono);font-size:.56rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;color:var(--dim);
  background:none;border:none;transition:color .18s;
}
.proj-toggle:hover{color:var(--g)}
.toggle-arrow{transition:transform .28s var(--ease);font-size:.9rem}
.proj.open .toggle-arrow{transform:rotate(90deg)}

.proj-body{
  display:none;
  border-top:1px solid var(--rule);
  padding:1.8rem 2rem;
  background:var(--surface);
}
.proj.open .proj-body{display:block}

.pbd-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.pbd-col{}
.pbd-label{
  font-family:var(--mono);font-size:.52rem;font-weight:400;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--g);margin-bottom:.55rem;
}
.pbd-text{font-size:.9rem;color:var(--mid);line-height:1.68}
.pbd-text strong{color:var(--ink);font-weight:500}

.proj-metrics-row{
  display:flex;gap:2rem;flex-wrap:wrap;
  margin-top:1.5rem;padding-top:1.3rem;
  border-top:1px solid var(--rule);
}
.prm-stat{display:flex;flex-direction:column;gap:.1rem}
.prm-val{
  font-family:var(--serif);font-size:1.5rem;font-weight:400;
  color:var(--g);line-height:1;
}
.prm-key{
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.1em;text-transform:uppercase;color:var(--dim);
}

/* ── CONNECT ─────────────────────────────────────────── */
#connect{
  text-align:center;padding:7rem 5rem;
  background:var(--surface);
}
.ct-h{
  font-family:var(--serif);font-weight:400;
  font-size:40px;
  line-height:1.05;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:1rem;
}
.ct-h em{font-style:italic;color:var(--g)}
.ct-sub{
  font-size:1rem;color:var(--mid);font-style:italic;
  margin-bottom:2.5rem;max-width:400px;margin-left:auto;margin-right:auto;
  line-height:1.6;
}
.ct-btns{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}
.btn-p{
  font-family:var(--mono);font-size:.6rem;font-weight:400;
  letter-spacing:.16em;text-transform:uppercase;
  padding:.85rem 2rem;background:var(--ink);color:var(--bg);
  border:1px solid var(--ink);display:inline-block;cursor:pointer;
  transition:background .2s,color .2s,transform .2s var(--ease),box-shadow .2s;
}
.btn-p:hover{
  background:var(--g);border-color:var(--g);
  transform:translateY(-2px);box-shadow:var(--lift-shadow);
}
.btn-s{
  font-family:var(--mono);font-size:.6rem;font-weight:300;
  letter-spacing:.16em;text-transform:uppercase;
  padding:.85rem 2rem;background:transparent;color:var(--ink);
  border:1px solid var(--rule);display:inline-block;
  transition:border-color .2s,color .2s,transform .2s var(--ease),box-shadow .2s;
}
.btn-s:hover{
  border-color:var(--g-border);color:var(--g);
  transform:translateY(-2px);box-shadow:var(--lift-shadow);
}
.ct-note{
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  letter-spacing:.1em;color:var(--dim);margin-top:1.8rem;
  line-height:1.9;
}

/* ── FOOTER ──────────────────────────────────────────── */
footer{
  margin-left:0;padding:1.4rem 5rem;
  border-top:1px solid var(--rule);
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  color:var(--dim);letter-spacing:.1em;background:var(--bg);
}

/* ── FADE ANIMATION ──────────────────────────────────── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}
.fade{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.fade.in{opacity:1;transform:translateY(0)}

/* ── MOBILE HEADER ───────────────────────────────────── */
.m-header{
  display:none;position:fixed;top:0;left:0;right:0;z-index:300;
  padding:.9rem 1.5rem;background:var(--bg);
  border-bottom:1px solid var(--rule);
  align-items:center;justify-content:space-between;
}
.mh-mark{
  font-family:var(--mono);font-size:.6rem;font-weight:400;
  letter-spacing:.22em;text-transform:uppercase;color:var(--g);
}
.mh-menu{
  font-family:var(--mono);font-size:.56rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;color:var(--mid);
  background:none;border:1px solid var(--rule);
  padding:.3rem .7rem;transition:all .18s;
}
.mh-menu:hover{border-color:var(--g-border);color:var(--g)}

/* Mobile dropdown nav */
.m-nav{
  display:none;position:fixed;top:44px;left:0;right:0;z-index:299;
  background:var(--bg);border-bottom:1px solid var(--rule);
  padding:1rem 1.5rem;
}
.m-nav.open{display:block}
.m-nav a{
  display:block;font-family:var(--mono);font-size:.62rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;color:var(--mid);
  padding:.6rem 0;border-bottom:1px solid var(--rule);transition:color .18s;
}
.m-nav a:last-child{border-bottom:none}
.m-nav a:hover{color:var(--g)}

/* ── RESPONSIVE ──────────────────────────────────────── */
@media(max-width:960px){
  :root{--sw:0px}
  .sidebar{display:none}
  .main{margin-left:0}
  .sec{padding:4rem 1.5rem}
  #intro{padding:6rem 1.5rem 4rem;min-height:auto}
  #connect{padding:5rem 1.5rem}
  footer{padding:1.2rem 1.5rem}
  .m-header{display:flex}
  .main{padding-top:44px}
  .pbd-grid{grid-template-columns:1fr}
  .tl-row{grid-template-columns:1fr;gap:.8rem}
  #profile .profile-cols{grid-template-columns:1fr}
  .proj-top{grid-template-columns:1fr}
  .proj-stat{text-align:left}
  .path-track{gap:.3rem}
  .proj-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .intro-h{font-size:2.5rem}
}

/* ── CASE STUDY ──────────────────────────────────────── */
.cs-back{
  font-family:var(--mono);font-size:.56rem;font-weight:300;
  letter-spacing:.16em;text-transform:uppercase;color:var(--dim);
  display:inline-flex;align-items:center;gap:.5rem;
  transition:color .18s;margin-bottom:2rem;
}
.cs-back:hover{color:var(--g)}

.cs-meta-bar{
  display:flex;align-items:center;gap:1.5rem;
  flex-wrap:wrap;margin-bottom:1rem;
}
.cs-badge{
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.16em;text-transform:uppercase;
  padding:.22rem .6rem;border:1px solid var(--g-border);
  color:var(--g);background:var(--g-light);
}
.cs-badge.grey{border-color:var(--rule);color:var(--dim);background:transparent}

.cs-title{
  font-family:var(--serif);font-size:clamp(2rem,4.5vw,3.6rem);
  font-weight:600;line-height:1.1;color:var(--ink);
  margin-bottom:1rem;letter-spacing:-.02em;
}
.cs-title em{font-style:italic;color:var(--g)}

.cs-subtitle{
  font-size:1.05rem;color:var(--mid);line-height:1.72;
  max-width:580px;margin-bottom:2.5rem;
}

.kpi-row{
  display:flex;gap:0;flex-wrap:wrap;
  border:1px solid var(--rule);margin-bottom:3rem;
}
.kpi{flex:1;min-width:120px;padding:1.2rem 1.4rem;border-right:1px solid var(--rule)}
.kpi:last-child{border-right:none}
.kpi-val{
  font-family:var(--serif);font-size:1.8rem;font-weight:400;
  color:var(--g);line-height:1;
}
.kpi-key{
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-top:.25rem;
}

.step-intro{
  font-size:1.05rem;color:var(--mid);line-height:1.78;
  max-width:660px;margin-bottom:2rem;
}
.step-intro strong{color:var(--ink);font-weight:500}
.step-intro em{color:var(--g);font-style:italic}

.chart-wrap{
  background:var(--surface);border:1px solid var(--rule);
  padding:1.6rem;margin-bottom:1.5rem;position:relative;
}
.chart-title{
  font-family:var(--mono);font-size:.56rem;font-weight:300;
  letter-spacing:.18em;text-transform:uppercase;color:var(--dim);
  margin-bottom:1rem;
}
.chart-note{
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  letter-spacing:.09em;color:var(--dim);margin-top:.8rem;
  font-style:italic;line-height:1.6;
}
.chart-grid-2{
  display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:1.5rem;
}

.callout{
  padding:1.2rem 1.5rem;border-left:3px solid var(--g);
  background:var(--g-light);margin:1.5rem 0;
}
.callout-label{
  font-family:var(--mono);font-size:.52rem;font-weight:400;
  letter-spacing:.2em;text-transform:uppercase;color:var(--g);margin-bottom:.4rem;
}
.callout-text{font-size:.97rem;color:var(--ink);line-height:1.65}
.callout-text strong{color:var(--g)}

.dag-wrap{
  background:var(--surface);border:1px solid var(--rule);
  padding:2rem;overflow-x:auto;
}
.dag-wrap svg{display:block;margin:0 auto}

.code-block{
  background:#0E0D0B;border:1px solid var(--rule);
  padding:1.4rem 1.6rem;margin:1.2rem 0;overflow-x:auto;
}
.code-block pre{
  font-family:var(--mono);font-size:.7rem;font-weight:300;
  color:#A8A49C;line-height:1.75;margin:0;
}
.code-block .kw{color:#1A4D3A}
.code-block .fn{color:#8DB4A8}
.code-block .st{color:#C4A882}
.code-block .cm{color:#4A4740}
.code-block .num{color:#D4943A}

details.code-toggle{margin:1.2rem 0}
details.code-toggle summary{
  font-family:var(--mono);font-size:.56rem;font-weight:300;
  letter-spacing:.14em;text-transform:uppercase;color:var(--dim);
  cursor:pointer;padding:.6rem 0;transition:color .18s;
  list-style:none;display:flex;align-items:center;gap:.5rem;
}
details.code-toggle summary:hover{color:var(--g)}
details.code-toggle summary::before{content:'›';transition:transform .2s}
details.code-toggle[open] summary::before{transform:rotate(90deg)}

.insight-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.5rem;
}
.insight-card{
  padding:1.4rem;border:1px solid var(--rule);background:var(--bg);
  transition:border-color .22s,transform .22s var(--ease),box-shadow .22s;
}
.insight-card:hover{
  border-color:var(--g-border);
  transform:translateY(-3px);box-shadow:var(--lift-shadow);
}
.ic-num{
  font-family:var(--mono);font-size:.52rem;color:var(--g);
  letter-spacing:.2em;margin-bottom:.5rem;
}
.ic-title{
  font-family:var(--serif);font-size:1.1rem;font-weight:400;
  color:var(--ink);margin-bottom:.5rem;line-height:1.2;
}
.ic-body{font-size:.88rem;color:var(--mid);line-height:1.65}
.ic-body strong{color:var(--ink);font-weight:500}
.ic-metric{
  font-family:var(--serif);font-size:1.5rem;color:var(--g);margin-top:.7rem;
}
.ic-metric-label{
  font-family:var(--mono);font-size:.5rem;color:var(--dim);
  letter-spacing:.1em;text-transform:uppercase;
}

/* ── CASE STUDY SHARED COMPONENTS ───────────────────── */
.cs-kpi-row{
  display:flex;gap:0;flex-wrap:wrap;
  border:1px solid var(--rule);margin-bottom:2.5rem;
}
.cs-kpi{flex:1;min-width:120px;padding:1.2rem 1.4rem;border-right:1px solid var(--rule)}
.cs-kpi:last-child{border-right:none}
.cs-kv{
  font-family:var(--serif);font-size:1.8rem;font-weight:400;
  color:var(--g);line-height:1;
}
.cs-kl{
  font-family:var(--mono);font-size:.5rem;font-weight:300;
  letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-top:.25rem;
}

.cs-twoUp{
  display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;
  margin-bottom:1.8rem;
}
.cs-twoUp p{font-size:.92rem;color:var(--mid);line-height:1.72;margin-bottom:.8rem}
.cs-twoUp p:last-child{margin-bottom:0}

.cs-block-label{
  font-family:var(--mono);font-size:.52rem;font-weight:300;
  letter-spacing:.16em;text-transform:uppercase;color:var(--g);
  margin-bottom:.6rem;
}

.cs-list{
  padding-left:1.1rem;font-size:.9rem;color:var(--mid);
  line-height:1.78;margin:0;
}
.cs-list li{margin-bottom:.3rem}
.cs-list strong{color:var(--ink);font-weight:500}

.cs-code{
  font-family:var(--mono);font-size:.75rem;
  background:var(--surface);border:1px solid var(--rule);
  border-left:3px solid var(--g);
  padding:.7rem 1rem;color:var(--ink);
  line-height:1.6;word-break:break-all;
  margin:.4rem 0;
}
.cs-code code{font-family:inherit}

.cs-mini-card{
  background:var(--surface);border:1px solid var(--rule);
  border-top:2px solid var(--rule);
  padding:1.1rem 1.2rem;
}
.cs-mini-card:hover{border-top-color:var(--g);transition:border-top-color .18s}
.cs-mc-title{
  font-family:var(--mono);font-size:.6rem;font-weight:400;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);margin-bottom:.5rem;
}
.cs-mc-body{font-size:.84rem;color:var(--mid);line-height:1.65}

.cs-pull{
  border-left:3px solid var(--g);
  padding:.9rem 1.4rem;margin:2rem 0;
  font-family:var(--serif);font-size:1.2rem;font-weight:300;
  font-style:italic;color:var(--ink);line-height:1.5;
  background:var(--g-light);
}

@media(max-width:960px){
  .cs-twoUp{grid-template-columns:1fr}
  .chart-grid-2{grid-template-columns:1fr}
  .insight-grid{grid-template-columns:1fr}
  .kpi{min-width:90px}
}

/* ── COLOR ACCENTS & HOVER ENHANCEMENTS ─────────────────── */

/* Intro heading — warm amber on the italic em */
.intro-h em { color: var(--amber); }

/* Sidebar nav — tinted bg + colored left bar on hover */
.sb-link { border-radius: 3px; }
.sb-link:hover {
  color: var(--g); border-left-color: var(--g-border);
  background: var(--g-light); padding-left: calc(.6rem + 2px);
}

/* Chips — hi chips get distinct accent colors */
.chips .chip { transition: all .2s var(--ease); }
.chips .chip.hi:nth-child(1){ color:var(--g);    border-color:var(--g-border);    background:var(--g-light); }
.chips .chip.hi:nth-child(2){ color:var(--amber); border-color:var(--amber-border); background:var(--amber-light); }
.chips .chip.hi:nth-child(3){ color:var(--blue);  border-color:var(--blue-border);  background:var(--blue-light); }
.chips .chip:not(.hi):hover  { transform:translateY(-2px); box-shadow:var(--lift-shadow); }
.chips .chip:nth-child(4):hover { color:var(--rose);  border-color:var(--rose-border);  background:var(--rose-light); }
.chips .chip:nth-child(5):hover { color:var(--amber); border-color:var(--amber-border); background:var(--amber-light); }
.chips .chip:nth-child(6):hover { color:var(--blue);  border-color:var(--blue-border);  background:var(--blue-light); }
.chips .chip:nth-child(7):hover { color:var(--g);     border-color:var(--g-border);     background:var(--g-light); }
.chips .chip:nth-child(8):hover { color:var(--rose);  border-color:var(--rose-border);  background:var(--rose-light); }
.chips .chip:nth-child(9):hover { color:var(--amber); border-color:var(--amber-border); background:var(--amber-light); }
.chips .chip:nth-child(10):hover{ color:var(--blue);  border-color:var(--blue-border);  background:var(--blue-light); }

/* Path nodes — each node in the career track gets its own color */
.path-node:nth-child(1):hover  { border-color:var(--rose-border);  background:var(--rose-light); }
.path-node:nth-child(3):hover  { border-color:var(--amber-border); background:var(--amber-light); }
.path-node:nth-child(5):hover  { border-color:var(--blue-border);  background:var(--blue-light); }
.path-node:nth-child(7):hover  { border-color:var(--amber-border); background:var(--amber-light); }
.path-node:nth-child(9):hover  { border-color:var(--g-border);     background:var(--g-light); }

/* Timeline rows — each job gets a distinct accent on hover */
.tl-row:nth-child(1):hover { border-left-color:var(--g);     background:var(--g-light); }
.tl-row:nth-child(2):hover { border-left-color:var(--blue);  background:var(--blue-light); }
.tl-row:nth-child(3):hover { border-left-color:var(--amber); background:var(--amber-light); }
.tl-row:nth-child(4):hover { border-left-color:var(--rose);  background:var(--rose-light); }

/* Project cards — each card has its own accent color */
/* p1: WhatsApp → amber */
#p1:hover::before { background:var(--amber); }
#p1:hover         { border-color:var(--amber-border); box-shadow:0 8px 32px rgba(168,106,16,.12),0 2px 8px rgba(168,106,16,.07); }
#p1:hover .pc-visual { background:var(--amber-light); }
#p1 .ps-val       { color:var(--amber); }
#p1 .proj-tag.hot { color:var(--amber); border-color:var(--amber-border); background:var(--amber-light); }

/* p2: Clinical Trials → blue */
#p2:hover::before { background:var(--blue); }
#p2:hover         { border-color:var(--blue-border); box-shadow:0 8px 32px rgba(27,79,145,.12),0 2px 8px rgba(27,79,145,.07); }
#p2:hover .pc-visual { background:var(--blue-light); }
#p2 .ps-val       { color:var(--blue); }
#p2 .proj-tag.hot { color:var(--blue); border-color:var(--blue-border); background:var(--blue-light); }

/* p3: Genomics / IEEE → rose */
#p3:hover::before { background:var(--rose); }
#p3:hover         { border-color:var(--rose-border); box-shadow:0 8px 32px rgba(138,31,82,.12),0 2px 8px rgba(138,31,82,.07); }
#p3:hover .pc-visual { background:var(--rose-light); }
#p3 .ps-val       { color:var(--rose); }
#p3 .proj-tag.hot { color:var(--rose); border-color:var(--rose-border); background:var(--rose-light); }

/* p4: Finance FP&A → keep green (default) */

/* Buttons — bottom-up fill sweep on hover */
.btn-p, .btn-s { position:relative; overflow:hidden; z-index:0; }
.btn-p::after, .btn-s::after {
  content:''; position:absolute; inset:0; z-index:-1;
  transform:translateY(102%);
  transition:transform .3s var(--ease);
}
.btn-p::after { background:var(--g); }
.btn-p:hover::after { transform:translateY(0); }
.btn-p:hover { background:var(--g); border-color:var(--g); }

.btn-s::after { background:var(--g-light); }
.btn-s:hover::after  { transform:translateY(0); }
.btn-s:hover { border-color:var(--g-border); color:var(--g); }

/* Edu / IEEE cards — colored accent on hover */
.edu-card:hover  { border-left:2px solid var(--amber); padding-left:calc(1.3rem - 2px); }
.ieee-card:hover { border-color:var(--blue-border); box-shadow:0 6px 24px rgba(27,79,145,.1); }
