/* ════════════════════════════════════════════════════════════════
   candy-styles.css · "Sugar Pop" — bakery-poster portfolio
   Cream paper, chunky rounded display type, color-block cards,
   pine-green stickers. Set in Fredoka + Nunito.
   ════════════════════════════════════════════════════════════════ */

:root{
  --c1:#F2BE45;            /* butter   */
  --c2:#A9CFE8;            /* sky      */
  --c3:#EE8B4F;            /* tangerine*/
  --c4:#C4D89B;            /* pistachio*/
  --pine:#2C5E3F;
  --paper:#F5F0E2;
  --card:#FFFDF4;
  --ink:#241F15;
  --ink-soft:rgba(36,31,21,.64);
  --r:30px;
  --disp:"Fredoka";
  --body:"Nunito";
  --pine-ink:color-mix(in oklab, var(--pine) 78%, #000);
  --c1-soft:color-mix(in oklab, var(--c1) 30%, var(--card));
  --c2-soft:color-mix(in oklab, var(--c2) 32%, var(--card));
  --c3-soft:color-mix(in oklab, var(--c3) 26%, var(--card));
  --c4-soft:color-mix(in oklab, var(--c4) 34%, var(--card));
  --shadow:0 14px 34px rgba(36,31,21,.09);
  --border:1.5px solid rgba(36,31,21,.10);
}

*{ box-sizing:border-box }
html{ scroll-behavior:smooth }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body), system-ui, sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-wrap:pretty;
}
a{ color:inherit; text-decoration:none }
p a, .linklike{ text-decoration:underline; text-decoration-color:var(--c3); text-underline-offset:3px; text-decoration-thickness:2px }
p a:hover, .linklike:hover{ color:var(--pine) }
::selection{ background:var(--c1); color:var(--ink) }
section{ scroll-margin-top:110px }

h1,h2,h3,h4,h5,h6{
  font-family:var(--disp), var(--body), sans-serif;
  font-weight:600;
  letter-spacing:.01em;
  margin:0;
}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--disp), sans-serif;
  font-weight:600; font-size:15px; letter-spacing:.03em;
  padding:10px 20px; border-radius:999px;
  border:1.5px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 8px 18px rgba(36,31,21,.16) }
.btn .arr{ font-family:var(--body); font-weight:800 }
.btn-dark{ background:var(--pine); color:#FFFDF4 }
.btn-paper{ background:var(--card); color:var(--ink); border-color:rgba(36,31,21,.16) }
.btn.big{ font-size:17px; padding:14px 28px }
.btn.small{ font-size:13px; padding:7px 16px }

/* ── Stickers ────────────────────────────────────────────────── */
.sticker{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--disp), sans-serif;
  font-weight:600; font-size:13px;
  letter-spacing:.08em; text-transform:uppercase;
  padding:7px 16px; border-radius:999px;
  transform:rotate(-2deg);
  transition:transform .2s ease;
}
.sticker:hover{ transform:rotate(1.5deg) scale(1.04) }
.sticker-green{ background:var(--pine); color:#FBF2D8 }
.sticker-paper{ background:var(--card); color:var(--ink); border:var(--border) }
.sticker-butter{ background:var(--c1); color:var(--ink) }
.sticker .dot{
  width:8px; height:8px; border-radius:50%;
  background:#9FE08A; flex:none;
  animation:pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{ 0%,100%{ opacity:1; transform:scale(1)} 50%{ opacity:.4; transform:scale(.7)} }
body.flat-stickers .sticker{ transform:none }
body.flat-stickers .chip{ transform:none !important }

/* ── Topbar ──────────────────────────────────────────────────── */
.topbar{
  position:fixed; top:14px; left:0; right:0; z-index:50;
  display:flex; justify-content:center;
  padding:0 16px;
  pointer-events:none;
}
.topbar-inner{
  pointer-events:auto;
  display:flex; align-items:center; gap:22px;
  background:var(--card);
  border:var(--border);
  border-radius:999px;
  padding:8px 10px 8px 18px;
  width:min(1180px,100%);
  box-shadow:0 6px 22px rgba(36,31,21,.07);
  transition:box-shadow .25s ease;
}
.topbar.scrolled .topbar-inner{ box-shadow:0 12px 32px rgba(36,31,21,.14) }
.mark{
  display:flex; align-items:center; gap:10px;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:16px;
}
.mark .av{
  width:32px; height:32px; border-radius:50%; flex:none;
  background:var(--c1);
  display:grid; place-items:center;
  font-size:15px; color:var(--ink);
}
.nav{ display:flex; gap:4px; margin:0 auto }
.nav a{
  font-family:var(--disp), sans-serif;
  font-weight:500; font-size:14px;
  padding:7px 13px; border-radius:999px;
  color:var(--ink-soft);
  transition:background .15s ease, color .15s ease;
}
.nav a:hover{ background:var(--paper); color:var(--ink) }
.nav a.active{ background:var(--pine); color:#FBF2D8 }
.topbar-right{ display:flex; align-items:center; gap:10px }
.lang{
  display:flex; gap:2px;
  background:var(--paper); border-radius:999px; padding:3px;
}
.lang button{
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12px;
  letter-spacing:.05em;
  border:0; background:transparent; color:var(--ink-soft);
  padding:5px 11px; border-radius:999px; cursor:pointer;
}
.lang button.active{ background:var(--ink); color:var(--card) }

/* ── Hero ────────────────────────────────────────────────────── */
.hero{
  max-width:1180px; margin:0 auto;
  padding:104px 16px 0;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.55fr 1fr;
  grid-template-rows:auto auto;
  gap:18px;
}
.hcard{
  border-radius:calc(var(--r) + 10px);
  padding:34px;
  position:relative;
  overflow:hidden;
}
.hcard-main{
  grid-row:1 / 3;
  background:var(--c1);
  display:flex; flex-direction:column; align-items:flex-start;
  padding:38px 42px 42px;
}
.hero-toprow{
  display:flex; flex-wrap:wrap; gap:12px;
  margin-bottom:26px;
}
.mega{
  font-size:clamp(58px, 8.2vw, 128px);
  line-height:.96;
  text-transform:uppercase;
  font-weight:600;
  letter-spacing:0;
  display:flex; flex-direction:column;
}
.mega .l1{ display:inline-flex; align-items:center }
.mega .l2{ color:var(--pine) }
.mega .bang{ color:var(--c3) }
.mega .face{
  display:inline-flex;
  width:.82em; height:.82em;
  margin:0 .06em;
  flex:none;
  transform:rotate(4deg);
}
.mega .face image-slot{
  width:100%; height:100%; display:block;
  border-radius:50%;
  box-shadow:0 6px 16px rgba(36,31,21,.18);
}
.hero-sub{
  font-family:var(--disp), sans-serif;
  font-weight:600; font-size:clamp(18px,2vw,24px);
  margin:22px 0 0;
}
.hero-intro{
  max-width:560px;
  margin:14px 0 0;
  font-size:16.5px;
  color:var(--ink); opacity:.85;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:30px }

.hcard-lab{ background:var(--c2); display:flex; flex-direction:column; gap:10px; align-items:flex-start }
.hcard-hire{ background:var(--c3); display:flex; flex-direction:column; gap:10px; align-items:flex-start }
.hcard .hk{
  font-family:var(--disp), sans-serif;
  font-weight:600; font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--pine-ink);
}
.hcard h3{
  font-size:clamp(26px,2.6vw,36px);
  text-transform:uppercase; line-height:1.02;
}
.hcard p{ margin:0; font-size:14.5px; color:var(--ink); opacity:.8; max-width:32ch }
.hcard .btn{ margin-top:auto }
.hcard-lab .corner-tag,
.hcard-hire .corner-tag{
  position:absolute; top:20px; right:20px;
  width:64px; height:64px; border-radius:50%;
  background:var(--pine); color:#FBF2D8;
  display:grid; place-items:center;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:13px;
  text-align:center; line-height:1.1;
  transform:rotate(8deg);
  padding:6px;
}
a.hcard{ transition:transform .2s ease, box-shadow .2s ease }
a.hcard:hover{ transform:translateY(-4px); box-shadow:var(--shadow) }

/* ── Now playing panel ───────────────────────────────────────── */
.now-panel{
  margin-top:18px;
  background:var(--card);
  border:var(--border);
  border-radius:calc(var(--r) + 10px);
  padding:26px 30px;
  box-shadow:var(--shadow);
}
.now-head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:14px;
}
.now-title{
  font-size:clamp(22px,2.2vw,30px);
  text-transform:uppercase;
}
.live-pill{
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12px;
  letter-spacing:.1em;
  background:var(--c3); color:var(--ink);
  border-radius:999px; padding:6px 14px;
}
.live-pill .dot{ width:8px; height:8px; border-radius:50%; background:var(--pine); animation:pulse 1.6s ease-in-out infinite }
.now-list{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column;
}
.now-list li{
  display:grid;
  grid-template-columns:44px 1fr auto;
  align-items:center; gap:16px;
  padding:13px 4px;
}
.now-list li + li{ border-top:1.5px dashed rgba(36,31,21,.14) }
.now-list .n{
  width:40px; height:40px; border-radius:50%;
  background:var(--c4);
  display:grid; place-items:center;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:14px;
}
.now-list li:nth-child(2) .n{ background:var(--c2) }
.now-list li:nth-child(3) .n{ background:var(--c1) }
.now-list .ttl{ display:block; font-family:var(--disp), sans-serif; font-weight:600; font-size:17px }
.now-list .ttl a:hover{ color:var(--pine) }
.now-list .sub{ display:block; font-size:13.5px; color:var(--ink-soft) }
.now-list .go{
  width:34px; height:34px; border-radius:50%;
  background:var(--pine); color:#FBF2D8;
  display:grid; place-items:center; font-size:15px;
}

/* ── Marquee ribbon ──────────────────────────────────────────── */
.marquee{
  margin:54px 0;
  background:var(--pine);
  transform:rotate(-1.2deg) scale(1.02);
  overflow:hidden;
  padding:13px 0;
}
.marquee-track{
  display:flex; gap:0; width:max-content;
  animation:slide 36s linear infinite;
}
.marquee-track span{
  font-family:var(--disp), sans-serif; font-weight:600;
  font-size:16px; letter-spacing:.14em; text-transform:uppercase;
  color:#FBF2D8; white-space:nowrap;
  padding:0 18px;
}
.marquee-track .sep{ color:var(--c1); padding:0 }
@keyframes slide{ from{ transform:translateX(0)} to{ transform:translateX(-50%)} }
@media (prefers-reduced-motion: reduce){
  .marquee-track{ animation:none }
  .sticker .dot, .live-pill .dot{ animation:none }
}

/* ── Sections ────────────────────────────────────────────────── */
.sec{
  max-width:1180px;
  margin:0 auto;
  padding:38px 16px;
}
.sec-head{ margin-bottom:34px }
.sec-head .sticker{ margin-bottom:18px }
.sec-head h2{
  font-size:clamp(40px,5vw,72px);
  line-height:1;
  text-transform:uppercase;
}
.sec-head h2 .hl{ color:var(--pine) }
.sec-meta{
  margin:12px 0 0;
  font-family:var(--disp), sans-serif; font-weight:500;
  font-size:15px; color:var(--ink-soft);
}

/* ── Work / experience ───────────────────────────────────────── */
.xp-list{ display:flex; flex-direction:column; gap:16px }
.xp-row{
  background:var(--card);
  border:var(--border);
  border-radius:var(--r);
  padding:28px 30px;
  display:grid;
  grid-template-columns:56px 1.1fr 1.6fr auto;
  gap:24px;
  align-items:start;
  position:relative;
  transition:transform .2s ease, box-shadow .2s ease;
}
.xp-row:hover{ transform:translateY(-3px); box-shadow:var(--shadow) }
.xp-row:nth-child(1){ background:var(--c1-soft) }
.xp-row:nth-child(2){ background:var(--c2-soft) }
.xp-row:nth-child(3){ background:var(--c3-soft) }
.xp-row:nth-child(4){ background:var(--c4-soft) }
.xp-row .num{
  width:52px; height:52px; border-radius:50%;
  background:var(--pine); color:#FBF2D8;
  display:grid; place-items:center;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:16px;
  transform:rotate(-6deg);
}
.xp-row h3{ font-size:24px; text-transform:uppercase; line-height:1.1 }
.xp-row h3 a:hover{ color:var(--pine) }
.xp-row .role{
  display:block; margin-top:6px;
  font-family:var(--disp), sans-serif; font-weight:500;
  font-size:14px; color:var(--ink-soft);
}
.xp-row .desc{ font-size:15px; color:var(--ink); opacity:.85 }
.xp-row .when{
  font-family:var(--disp), sans-serif; font-weight:600; font-size:13px;
  text-transform:uppercase; letter-spacing:.05em;
  text-align:right; white-space:nowrap;
}
.xp-row .loc{
  display:block; margin-top:6px;
  font-weight:500; color:var(--ink-soft); letter-spacing:.08em;
}
.xp-row.current::after{
  content:"★ now";
  position:absolute; top:-12px; right:26px;
  background:var(--c3); color:var(--ink);
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12px;
  letter-spacing:.1em; text-transform:uppercase;
  padding:6px 14px; border-radius:999px;
  transform:rotate(3deg);
}

/* ── Ventures ────────────────────────────────────────────────── */
.vent-list{ display:grid; grid-template-columns:1fr 1fr; gap:18px }
.venture{
  border-radius:calc(var(--r) + 8px);
  padding:32px;
  min-height:240px;
  display:flex; flex-direction:column; gap:18px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.venture:hover{ transform:translateY(-4px); box-shadow:var(--shadow) }
.venture:nth-child(1){ background:var(--c2) }
.venture:nth-child(2){ background:var(--c4) }
.venture .vtop{
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12px;
  letter-spacing:.12em; text-transform:uppercase;
}
.venture .vnum{
  background:var(--pine); color:#FBF2D8;
  padding:6px 14px; border-radius:999px;
  transform:rotate(-2deg);
}
.venture .vurl{ color:var(--pine-ink) }
.venture .vname{
  font-size:clamp(32px,3.4vw,46px);
  text-transform:uppercase; line-height:1;
}
.venture .vname .it{ color:var(--c3) }
.venture .vmeta{ margin:10px 0 0; font-size:15px; opacity:.85; max-width:46ch }

/* ── Projects ────────────────────────────────────────────────── */
.proj-list{ display:grid; grid-template-columns:1fr 1fr; gap:18px }
.proj{
  background:var(--card);
  border:var(--border);
  border-radius:var(--r);
  padding:28px 30px 26px;
  position:relative;
  display:flex; flex-direction:column; gap:8px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.proj:hover{ transform:translateY(-4px); box-shadow:var(--shadow) }
.proj:nth-child(1){ background:var(--c1-soft) }
.proj:nth-child(2){ background:var(--c2-soft) }
.proj:nth-child(3){ background:var(--c3-soft) }
.proj:nth-child(4){ background:var(--c4-soft) }
.proj .h{
  display:flex; justify-content:space-between; align-items:flex-start;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12px;
  letter-spacing:.1em; color:var(--ink-soft);
}
.proj .yr{
  width:58px; height:58px; border-radius:50%;
  background:var(--pine); color:#FBF2D8;
  display:grid; place-items:center;
  font-size:14px; letter-spacing:.02em;
  transform:rotate(8deg);
  margin:-6px -6px 0 0;
}
.proj .tag{
  font-family:var(--disp), sans-serif; font-weight:500; font-size:13px;
  color:var(--pine-ink); text-transform:uppercase; letter-spacing:.06em;
}
.proj h4{ font-size:26px; text-transform:uppercase; line-height:1.05 }
.proj p{ margin:0; font-size:15px; opacity:.85 }
.proj .more{
  margin-top:auto; padding-top:14px;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:13.5px;
  letter-spacing:.04em; color:var(--pine);
}
.proj .more .arr{ display:inline-block; transition:transform .15s ease }
.proj:hover .more .arr{ transform:translate(2px,-2px) }

/* ── AI Lab (pine panel) ─────────────────────────────────────── */
.lab-panel{
  background:var(--pine);
  border-radius:calc(var(--r) + 14px);
  padding:46px clamp(24px,4vw,52px) 50px;
  color:#FBF2D8;
}
.lab-panel .sec-head{ margin-bottom:24px }
.lab-panel .sec-head h2{ color:#FBF2D8 }
.lab-panel .sec-head h2 .hl{ color:var(--c1) }
.lab-panel .sec-meta{ color:rgba(251,242,216,.65) }
.lab-panel .sticker-green{ background:var(--c1); color:var(--ink) }
.lab-lede{
  max-width:64ch; margin:0 0 32px;
  font-size:17px; color:rgba(251,242,216,.88);
}
.lab-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px }
.lab-card{
  background:var(--card);
  color:var(--ink);
  border-radius:var(--r);
  padding:26px;
  display:flex; flex-direction:column; gap:10px;
  transition:transform .2s ease;
}
.lab-card:hover{ transform:translateY(-4px) rotate(-.5deg) }
.lab-card .num{
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12px;
  letter-spacing:.12em; color:var(--ink-soft);
}
.lab-card h4{ font-size:21px; text-transform:uppercase; line-height:1.1 }
.lab-card .role{
  font-family:var(--disp), sans-serif; font-weight:500; font-size:13px;
  color:var(--pine);
}
.lab-card p{ margin:0; font-size:14.5px; opacity:.85; flex:1 }
.lab-card .stack{ display:flex; flex-wrap:wrap; gap:7px; padding-top:6px }
.chip{
  font-family:var(--disp), sans-serif; font-weight:500; font-size:12.5px;
  background:var(--c1-soft);
  border:1.5px solid rgba(36,31,21,.12);
  padding:4px 12px; border-radius:999px;
}
.chip:nth-child(odd){ transform:rotate(-2deg) }
.chip:nth-child(even){ transform:rotate(1.5deg) }

/* ── Sample (deck) ───────────────────────────────────────────── */
.sample-panel{
  background:var(--c1);
  border-radius:calc(var(--r) + 14px);
  padding:46px clamp(24px,4vw,52px);
  display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(24px,4vw,56px);
  align-items:center;
  position:relative;
}
.sample-panel .sec-head{ margin-bottom:20px }
.sample-lede{ max-width:54ch; margin:0 0 26px; font-size:16.5px; opacity:.88 }
.smp-rows{ display:flex; flex-direction:column; gap:0; margin-bottom:30px }
.smp-row{
  display:grid; grid-template-columns:34px 1fr; gap:14px;
  padding:11px 0; align-items:baseline;
}
.smp-row + .smp-row{ border-top:1.5px dashed rgba(36,31,21,.22) }
.smp-row .ic{
  width:30px; height:30px; border-radius:50%;
  background:var(--pine); color:#FBF2D8;
  display:grid; place-items:center;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:13px;
  transform:rotate(-5deg);
}
.smp-row h5{ font-size:16px; text-transform:uppercase; display:inline }
.smp-row p{ margin:2px 0 0; font-size:14px; opacity:.8 }
.smp-cta{ display:flex; flex-wrap:wrap; gap:12px }
.deck-mock{
  background:var(--card);
  border-radius:var(--r);
  aspect-ratio:4/3;
  position:relative;
  box-shadow:0 24px 50px rgba(36,31,21,.18);
  transform:rotate(2deg);
  display:flex; flex-direction:column;
  justify-content:center; align-items:center; gap:8px;
  padding:30px; text-align:center;
}
.deck-mock .pages-tag{
  position:absolute; top:-20px; right:-14px;
  width:76px; height:76px; border-radius:50%;
  background:var(--c3); color:var(--ink);
  display:grid; place-items:center;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:13px;
  line-height:1.05; text-align:center;
  transform:rotate(10deg);
  padding:8px;
}
.deck-mock .dk-title{ font-size:26px; text-transform:uppercase; line-height:1.05 }
.deck-mock .dk-sub{ font-size:13px; color:var(--ink-soft); margin:0 }
.deck-mock .dk-bar{
  width:64%; height:10px; border-radius:999px; background:var(--c2);
}
.deck-mock .dk-bar.b2{ width:46%; background:var(--c4) }
.deck-mock .dk-bar.b3{ width:54%; background:var(--c1) }

/* ── Studies ─────────────────────────────────────────────────── */
.edu-list{ display:grid; grid-template-columns:1fr 1fr; gap:18px }
.deg{
  background:var(--card);
  border:var(--border);
  border-radius:var(--r);
  padding:30px;
  display:grid; grid-template-columns:auto 1fr; gap:22px;
  transition:transform .2s ease, box-shadow .2s ease;
}
.deg:hover{ transform:translateY(-3px); box-shadow:var(--shadow) }
.deg:nth-child(1){ background:var(--c2-soft) }
.deg:nth-child(2){ background:var(--c4-soft) }
.deg .yr{
  font-family:var(--disp), sans-serif; font-weight:600; font-size:18px;
  line-height:1.25; color:var(--pine);
  text-align:center;
  border-right:1.5px dashed rgba(36,31,21,.18);
  padding-right:20px;
}
.deg h4{ font-size:22px; text-transform:uppercase; line-height:1.1 }
.deg .school{
  display:block; margin-top:6px;
  font-family:var(--disp), sans-serif; font-weight:500; font-size:14px;
  color:var(--ink-soft);
}
.deg .school a:hover{ color:var(--pine) }
.deg p{ margin:10px 0 0; font-size:14.5px; opacity:.85 }
.deg .gpa{
  display:inline-block; margin-top:14px;
  background:var(--pine); color:#FBF2D8;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12.5px;
  letter-spacing:.08em; text-transform:uppercase;
  padding:5px 14px; border-radius:999px;
  transform:rotate(-2deg);
}

/* ── After hours / events ────────────────────────────────────── */
.events-panel{
  background:var(--c3);
  border-radius:calc(var(--r) + 14px);
  padding:44px clamp(24px,4vw,52px);
}
.events-panel .sticker-green{ background:var(--pine); color:#FBF2D8 }
.events-lede{ max-width:56ch; margin:0 0 26px; font-size:16.5px; opacity:.9 }
.events-lede .it{ font-style:italic; font-weight:800 }
.ev-list{
  background:var(--card);
  border-radius:var(--r);
  padding:10px 26px;
}
.ev{
  display:grid; grid-template-columns:40px 1fr auto;
  gap:16px; align-items:center;
  padding:16px 0;
}
.ev + .ev{ border-top:1.5px dashed rgba(36,31,21,.14) }
.ev .n{
  width:36px; height:36px; border-radius:50%;
  background:var(--c1);
  display:grid; place-items:center;
  font-family:var(--disp), sans-serif; font-weight:600; font-size:13px;
}
.ev:nth-child(2) .n{ background:var(--c2) }
.ev:nth-child(3) .n{ background:var(--c4) }
.ev h5{ font-size:17px; text-transform:uppercase }
.ev h5 a:hover{ color:var(--pine) }
.ev .sub{ display:block; font-size:13.5px; color:var(--ink-soft) }
.ev .yr{
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12px;
  letter-spacing:.08em; text-transform:uppercase;
  background:var(--paper); border:var(--border);
  padding:6px 13px; border-radius:999px;
  white-space:nowrap;
}

/* ── Skills ──────────────────────────────────────────────────── */
.sk-list{
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.skill-col{
  background:var(--card);
  border:var(--border);
  border-radius:var(--r);
  padding:24px 26px;
}
.skill-col h6{
  font-size:13px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--pine);
  margin-bottom:14px;
}
.skill-col ul{
  list-style:none; margin:0; padding:0;
  display:flex; flex-wrap:wrap; gap:8px;
}
.skill-col li{
  font-family:var(--disp), sans-serif; font-weight:500; font-size:13.5px;
  background:var(--paper);
  border:1.5px solid rgba(36,31,21,.12);
  padding:6px 14px; border-radius:999px;
}
.skill-col:nth-child(1) li{ background:var(--c1-soft) }
.skill-col:nth-child(2) li{ background:var(--c2-soft) }
.skill-col:nth-child(3) li{ background:var(--c3-soft) }
.skill-col:nth-child(4) li{ background:var(--c4-soft) }
.skill-col:nth-child(5) li{ background:var(--c1-soft) }
.skill-col li .meta{
  font-size:11px; font-weight:600; color:var(--pine);
  letter-spacing:.06em; text-transform:uppercase;
  margin-left:4px;
}

/* ── Contact ─────────────────────────────────────────────────── */
.contact-panel{
  background:var(--pine);
  border-radius:calc(var(--r) + 14px);
  color:#FBF2D8;
  padding:clamp(40px,6vw,72px) clamp(24px,5vw,64px);
  display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(28px,5vw,64px);
}
.contact-mega{
  font-size:clamp(40px,5.4vw,76px);
  line-height:.98; text-transform:uppercase;
}
.contact-mega .hl{ color:var(--c1) }
.contact-ask{ max-width:48ch; margin:20px 0 30px; font-size:16.5px; color:rgba(251,242,216,.85) }
.cta-row{ display:flex; flex-wrap:wrap; gap:14px; align-items:center }
.cta-row .btn-butter{ background:var(--c1); color:var(--ink) }
.cta-ghost{
  font-family:var(--disp), sans-serif; font-weight:500; font-size:14.5px;
  color:rgba(251,242,216,.8);
  text-decoration:underline; text-underline-offset:4px;
  text-decoration-color:var(--c3);
}
.cta-ghost:hover{ color:#FBF2D8 }
.contact-lines{
  display:flex; flex-direction:column; justify-content:center;
}
.line{
  display:flex; justify-content:space-between; gap:16px;
  padding:12px 0;
  font-size:14.5px;
}
.line + .line{ border-top:1.5px dashed rgba(251,242,216,.22) }
.line .k{
  font-family:var(--disp), sans-serif; font-weight:600; font-size:12px;
  letter-spacing:.1em; text-transform:uppercase;
  color:rgba(251,242,216,.6);
}
.line .v{ text-align:right }
.line .v a{ text-decoration:underline; text-decoration-color:var(--c1); text-underline-offset:3px }
.line .v a:hover{ color:var(--c1) }

/* ── Footer ──────────────────────────────────────────────────── */
.footer{
  max-width:1180px; margin:0 auto;
  padding:28px 16px 40px;
  display:flex; justify-content:space-between; gap:16px;
  font-family:var(--disp), sans-serif; font-weight:500;
  font-size:13px; color:var(--ink-soft);
}

/* ── Reveal ──────────────────────────────────────────────────── */
[data-reveal]{
  opacity:0; transform:translateY(16px);
  transition:opacity .55s ease, transform .55s ease;
}
[data-reveal].in{ opacity:1; transform:none }
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1; transform:none; transition:none }
}

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 1020px){
  .hero-grid{ grid-template-columns:1fr 1fr }
  .hcard-main{ grid-column:1 / 3; grid-row:auto }
  .lab-list{ grid-template-columns:1fr 1fr }
  .sk-list{ grid-template-columns:1fr 1fr }
  .xp-row{ grid-template-columns:56px 1fr; }
  .xp-row .desc{ grid-column:2 }
  .xp-row .when{ grid-column:2; text-align:left }
  .xp-row .loc{ display:inline; margin-left:10px }
  .sample-panel{ grid-template-columns:1fr }
  .deck-mock{ max-width:440px }
}
@media (max-width: 760px){
  html, body { overflow-x: hidden; }
  #naive-doodles svg {
    transform: scale(0.6) !important;
  }
  .nav{ display:none }
  .mark-name{ display:none }
  .topbar-inner{ gap:8px; justify-content: space-between; padding: 6px 12px; width: 100%; }
  .topbar{ padding: 10px 12px; }
  .hero{ padding-top:90px }
  .hero-grid{ grid-template-columns:1fr }
  .hcard-main{ grid-column:auto; padding:28px 24px 32px }
  .hcard{ padding:26px 24px }
  .vent-list, .proj-list, .edu-list, .lab-list, .sk-list{ grid-template-columns:1fr }
  .contact-panel{ grid-template-columns:1fr }
  .xp-row{ padding:24px 22px }
  .deg{ grid-template-columns:1fr }
  .deg .yr{ border-right:0; border-bottom:1.5px dashed rgba(36,31,21,.18); padding:0 0 12px; text-align:left }
  .deg .yr br{ display:none }
  .footer{ flex-direction:column; gap:6px; text-align:center }
}
