:root {
  --nav-bg: rgba(250,248,251,0.9);
  --accent-dim: rgba(177,4,200,0.10);
  --accent-light: #d635ef;
  --surface: #f3f0f6;
  --serif: 'Playfair Display', Georgia, serif;
}
body { background: var(--paper); color: var(--ink); font-family: var(--sans); font-size: 16px; line-height: 1.6; overflow-x: hidden; }

/* ── Hero ── */
.resume-hero {
  background: var(--ink);
  padding: 10rem 4rem 6rem;
  position: relative;
  overflow: hidden;
}
.hero-grid-bg {
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:60px 60px;pointer-events:none;
}
.hero-orb {
  position:absolute;width:640px;height:640px;
  background:radial-gradient(circle,rgba(177,4,200,.12) 0%,transparent 65%);
  top:-100px;right:-100px;pointer-events:none;
}
.hero-inner {
  position:relative;z-index:2;max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:1fr auto;align-items:end;gap:4rem;
}
.hero-text-col {}

.hero-eyebrow {
  font-family:var(--mono);font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.25rem;
  display:flex;align-items:center;gap:.75rem;
  opacity:0;animation:fadeUp .8s ease .1s forwards;
}
.hero-eyebrow::before { content:'';width:28px;height:1px;background:var(--accent);display:block; }

.hero-name {
  font-family:var(--serif);
  font-size:clamp(3rem,5vw,5.5rem);
  font-weight:900;line-height:.95;letter-spacing:-.04em;
  color:white;margin-bottom:1.25rem;
  opacity:0;animation:fadeUp .8s ease .25s forwards;
}
.hero-name em { font-style:italic;color:var(--accent); }

.hero-tagline {
  font-family:var(--serif);font-style:italic;font-size:1.15rem;
  color:rgba(255,255,255,.45);line-height:1.6;max-width:540px;margin-bottom:2rem;
  opacity:0;animation:fadeUp .8s ease .4s forwards;
}

.hero-meta {
  display:flex;gap:2rem;flex-wrap:wrap;
  opacity:0;animation:fadeUp .8s ease .55s forwards;
}
.hm-item { display:flex;align-items:center;gap:.6rem; }
.hm-icon { font-size:.95rem; }
.hm-text { font-size:.875rem;color:rgba(255,255,255,.55); }
.hm-text a { color:rgba(255,255,255,.7);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:1px;transition:color .2s,border-color .2s; }
.hm-text a:hover { color:var(--accent-light);border-color:var(--accent-light); }

/* Photo card */
.hero-photo-col {
  opacity:0;animation:fadeIn 1s ease .5s forwards;
  flex-shrink:0;
}
.photo-circle {
  width:180px;height:180px;border-radius:50%;
  overflow:hidden;
  border:3px solid rgba(177,4,200,.4);
  box-shadow:0 0 0 6px rgba(177,4,200,.08);
}
.photo-circle img { width:100%;height:100%;object-fit:cover;display:block; }

/* Download CTA */
.hero-cta {
  margin-top:2.5rem;
  opacity:0;animation:fadeUp .8s ease .7s forwards;
}
.btn-outline-light {
  display:inline-flex;align-items:center;gap:.6rem;
  border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);
  padding:.8rem 1.75rem;border-radius:6px;
  text-decoration:none;font-size:.85rem;font-weight:500;
  transition:border-color .2s,color .2s,background .2s;
}
.btn-outline-light:hover { border-color:rgba(177,4,200,.5);color:var(--accent-light);background:rgba(177,4,200,.06); }

/* ── Main layout: sidebar + content ── */
.resume-body {
  max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:280px 1fr;gap:0;
  padding:0 4rem;
}

/* ── Sidebar ── */
.sidebar {
  padding:4rem 2.5rem 4rem 0;
  border-right:1px solid var(--rule);
  position:sticky;top:80px;
  height:fit-content;
  align-self:start;
}

.sidebar-section { margin-bottom:3rem; }
.sidebar-section:last-child { margin-bottom:0; }

.sidebar-label {
  font-family:var(--mono);font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.25rem;
  display:flex;align-items:center;gap:.5rem;
}
.sidebar-label::before { content:'';width:16px;height:1px;background:var(--accent);display:block; }

/* Skills */
.skill-tags { display:flex;flex-direction:column;gap:.5rem; }
.skill-tag {
  font-size:.82rem;color:var(--muted);
  display:flex;align-items:center;gap:.6rem;
  padding:.4rem 0;
  border-bottom:1px solid var(--rule);
  transition:color .2s;
}
.skill-tag:last-child { border-bottom:none; }
.skill-tag::before { content:'';width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0; }
.skill-tag:hover { color:var(--ink); }

/* Tools */
.tool-pills { display:flex;flex-wrap:wrap;gap:.5rem; }
.tool-pill {
  font-family:var(--mono);font-size:.65rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.35rem .8rem;border-radius:100px;
  border:1px solid var(--rule);color:var(--muted);background:white;
  transition:border-color .2s,color .2s,background .2s;
}
.tool-pill:hover { border-color:var(--accent);color:var(--accent);background:var(--accent-dim); }

/* Section nav in sidebar */
.section-nav { display:flex;flex-direction:column;gap:.25rem; }
.snav-link {
  font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;padding:.5rem .75rem;border-radius:6px;
  transition:color .2s,background .2s;
  display:flex;align-items:center;gap:.6rem;
}
.snav-link::before { content:'';width:0;height:1px;background:var(--accent);transition:width .2s; }
.snav-link:hover { color:var(--accent);background:var(--accent-dim); }
.snav-link:hover::before { width:12px; }

/* ── Main content ── */
.resume-content { padding:4rem 0 4rem 3.5rem; }

/* Section heading */
.resume-section { margin-bottom:5rem; scroll-margin-top:120px; }
.resume-section:last-child { margin-bottom:0; }

.rs-header {
  display:flex;align-items:center;gap:1rem;
  margin-bottom:2.5rem;
  padding-bottom:1rem;
  border-bottom:1px solid var(--rule);
}
.rs-eyebrow {
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);display:flex;align-items:center;gap:.6rem;
}
.rs-eyebrow::before { content:'';width:24px;height:1px;background:var(--accent);display:block; }
.rs-title {
  font-family:var(--serif);font-size:1.5rem;font-weight:900;letter-spacing:-.03em;
}

/* ── Education entries ── */
.edu-entries { display:flex;flex-direction:column;gap:1.5rem; }
.edu-card {
  background:var(--surface);border-radius:12px;padding:1.75rem;
  border-left:3px solid transparent;
  transition:border-color .3s,transform .3s,box-shadow .3s;
}
.edu-card:hover { border-color:var(--accent);transform:translateX(4px);box-shadow:0 8px 24px rgba(14,11,18,.07); }
.edu-card-top { display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap; }
.edu-degree { font-family:var(--serif);font-size:1rem;font-weight:700;margin-bottom:.25rem; }
.edu-school { font-size:.875rem;color:var(--muted); }
.edu-year {
  font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;
  color:var(--accent);white-space:nowrap;
  background:var(--accent-dim);padding:.25rem .7rem;border-radius:100px;
  flex-shrink:0;
}

/* ── Experience entries ── */
.exp-entries { display:flex;flex-direction:column;gap:0; }
.exp-entry {
  position:relative;
  padding:0 0 3rem 2.25rem;
  border-left:1px solid var(--rule);
}
.exp-entry:last-child { padding-bottom:0;border-left:1px solid transparent; }
.exp-dot {
  position:absolute;left:-5px;top:4px;
  width:9px;height:9px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 3px var(--paper),0 0 0 4.5px rgba(177,4,200,.25);
}
.exp-top { display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem; }
.exp-title { font-family:var(--serif);font-size:1.05rem;font-weight:700; }
.exp-date {
  font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;
  color:white;background:var(--ink);
  padding:.2rem .65rem;border-radius:100px;flex-shrink:0;white-space:nowrap;
}
.exp-org { font-size:.875rem;color:var(--muted);margin-bottom:.9rem; }
.exp-bullets { list-style:none;display:flex;flex-direction:column;gap:.55rem; }
.exp-bullets li {
  font-size:.875rem;color:var(--muted);line-height:1.7;
  display:flex;gap:.75rem;align-items:flex-start;
}
.exp-bullets li::before { content:'→';color:var(--accent);flex-shrink:0;margin-top:.05em;font-size:.8rem; }

/* ── Publication ── */
.pub-card {
  background:var(--ink);border-radius:14px;padding:2rem;
  position:relative;overflow:hidden;
}
.pub-card::before { content:'"';font-family:var(--serif);font-size:8rem;font-weight:900;color:rgba(255,255,255,.03);position:absolute;top:-1.5rem;right:1.5rem;line-height:1; }
.pub-label { font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem; }
.pub-title { font-family:var(--serif);font-size:1rem;font-style:italic;color:white;line-height:1.65;margin-bottom:1.25rem; }
.pub-authors { font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.6;margin-bottom:1.25rem; }
.pub-authors strong { color:rgba(255,255,255,.7); }
.pub-link {
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);text-decoration:none;
  border-bottom:1px solid rgba(177,4,200,.3);padding-bottom:1px;
  transition:border-color .2s;
}
.pub-link:hover { border-color:var(--accent); }

/* ── Reveal ── */
.reveal { opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease; }
.reveal.visible { opacity:1;transform:translateY(0); }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }
.reveal-delay-4 { transition-delay:.4s; }
.reveal-delay-5 { transition-delay:.5s; }

@keyframes fadeUp  { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }

/* ── Responsive ── */
@media(max-width:1000px){
  #mainNav { padding:1.25rem 1.5rem; }
  .nav-links { display:none; }
  .resume-hero { padding:8rem 1.5rem 4rem; }
  .hero-inner { grid-template-columns:1fr;gap:2rem; }
  .hero-photo-col { display:none; }
  .resume-body { grid-template-columns:1fr;padding:0 1.5rem; }
  .sidebar { position:static;border-right:none;border-bottom:1px solid var(--rule);padding:2.5rem 0;display:grid;grid-template-columns:1fr 1fr;gap:2rem; }
  .section-nav { display:none; }
  .resume-content { padding:3rem 0; }
  footer { flex-direction:column;gap:1.5rem;text-align:center; }
}
@media(max-width:600px){
  .sidebar { grid-template-columns:1fr; }
  .exp-top,.edu-card-top { flex-direction:column;gap:.5rem; }
  footer { padding:2rem 1.5rem; }
}
