:root{
  --bg:#100D0A;
  --bg-2:#15110C;
  --surface:#1A150F;
  --surface-2:#221C14;

  --text:#EFE9DE;
  --muted:#A39A8B;
  --faint:#6F665A;

  --accent:#C9A96E;
  --accent-soft:rgba(201,169,110,.16);

  --line:rgba(201,169,110,.14);
  --border:rgba(255,255,255,.06);

  --steel-dark:#5D5F63;
  --steel-mid:#9A9DA1;
  --steel-light:#E6E8EA;
  --steel-warm:#EFE3CB;

  --display:"Fraunces",Georgia,serif;
  --body:"Inter",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--body);
  font-weight:300;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ---------- ATMOSPHERE ---------- */

/* Three.js dust canvas */
#dust{
  position:fixed;
  inset:0;
  z-index:-3;
  pointer-events:none;
}

/* warm spotlight that follows cursor / drifts on scroll */
#spot{
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background:radial-gradient(
    180px 180px at var(--mx,50%) var(--my,32%),
    rgba(201,169,110,.14),
    rgba(201,169,110,.04) 30%,
    transparent 55%
  );
  transition:opacity .6s ease;
}

/* fine machined grid, very faint */
body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(circle at 50% 40%,#000 0%,transparent 80%);
}

/* ---------- LAYOUT ---------- */

.container{width:min(1180px,90%);margin-inline:auto;}

section{padding:11rem 0;position:relative;}

.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:.8rem;
}
.eyebrow::before{
  content:"";
  width:28px;
  height:1px;
  background:var(--accent);
  opacity:.6;
}

.section-head{margin-bottom:5rem;max-width:760px;}
.section-head h2{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(2.4rem,5vw,3.8rem);
  line-height:1.05;
  margin-top:1.4rem;
  letter-spacing:-.01em;
}
.section-head p{color:var(--muted);margin-top:1.4rem;max-width:560px;}

/* ---------- HERO ---------- */

.hero{
  position:relative;
  min-height:44rem;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  align-items:flex-start;
  padding-top:7rem;
  padding-bottom:2rem;
}
.hero-kicker{margin-bottom:2.4rem;}
.hero-name{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(4.5rem,15vw,12rem);
  line-height:.86;
  letter-spacing:-.02em;
  margin-bottom:2.4rem;

  /* brushed steel with warm sweep */
  background:linear-gradient(
    100deg,
    var(--steel-dark) 0%,
    var(--steel-mid) 16%,
    var(--steel-light) 34%,
    var(--steel-warm) 46%,
    var(--steel-light) 58%,
    var(--steel-mid) 78%,
    var(--steel-dark) 100%
  );
  background-size:230% 100%;
  background-position:var(--sheen,0%) 0;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero-line{
  font-size:clamp(1.05rem,1.6vw,1.3rem);
  color:var(--muted);
  max-width:560px;
  line-height:1.75;
}
.hero-line b{color:var(--text);font-weight:500;}
.hero-cue{
  position:absolute;
  bottom:2.2rem;
  left:50%;
  transform:translateX(-50%);
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--faint);
  display:inline-flex;
  align-items:center;
  gap:.7rem;
  white-space:nowrap;
}
.hero-cue span{
  display:inline-block;
  animation:nudge 2.4s var(--ease) infinite;
}
.hero-cv-label{
  font-family:var(--mono);
  font-size:.75rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  opacity:.55;
  margin-top:2.5rem;
  margin-bottom:.7rem;
}
@keyframes nudge{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* on-load reveal helper */
.rise{opacity:0;transform:translateY(26px);}

/* ---------- STATS BAND ---------- */

.stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  margin-top:auto;
  padding-top:3rem;
  padding-bottom:3rem;
  border-top:1px solid var(--border);
}
.stat{padding:3rem 2rem;position:relative;}
.stat + .stat{border-left:1px solid var(--border);}
.stat .num{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(2.6rem,4.5vw,3.6rem);
  color:var(--accent);
  line-height:1;
}
.stat .num .pre{
  display:block;
  font-family:var(--mono);
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.5rem;
}
.stat .cap{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:1rem;
}

/* ---------- ABOUT ME ---------- */

.about-body{
  display:flex;
  flex-direction:column;
  gap:1.4rem;
  max-width:680px;
}
.about-body p{
  color:var(--muted);
}
.about-photos{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(.6rem,1.2vw,1rem);
  margin-top:clamp(3rem,5vw,4.5rem);
  width:100%;
}
.about-photo{margin:0;min-width:0;width:100%;height:220px;}
.about-photo-wrap{
  position:relative;
  height:220px;
  width:100%;
  border-radius:8px;
  overflow:hidden;
  border:1px solid rgba(201,169,110,.22);
  background:linear-gradient(120deg,#26221b,#1b1812 60%,#211d16);
  transition:border-color .35s var(--ease),transform .35s var(--ease),box-shadow .35s var(--ease);
}
.about-photo-wrap:hover{
  transform:scale(1.02);
  border-color:rgba(201,169,110,.5);
  box-shadow:0 8px 32px rgba(0,0,0,.4),0 0 0 1px rgba(201,169,110,.14);
}
.about-photo-wrap img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.about-caption{
  margin-top:.9rem;
  font-family:var(--mono);
  font-size:.68rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--faint);
  text-align:center;
}
#about{padding-bottom:2.5rem;}
#about .section-head h2{text-wrap:balance;}
.section-divider{
  width:min(1180px,90%);
  margin-inline:auto;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,169,110,.35) 30%,rgba(201,169,110,.35) 70%,transparent);
}

/* ---------- EXPERIENCE / TIMELINE ---------- */

.timeline{position:relative;padding-left:clamp(1.6rem,6vw,4.5rem);}
.timeline-rail{
  position:absolute;
  left:0;top:.4rem;bottom:.4rem;
  width:1px;
  background:linear-gradient(var(--accent),rgba(201,169,110,.15));
  transform:scaleY(0);
  transform-origin:top;
}
.entry{
  position:relative;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;
  padding-block:clamp(3rem,6vw,5rem);
}
.entry + .entry{border-top:1px solid var(--border);}
.entry::before{
  content:"";
  position:absolute;
  left:calc(clamp(1.6rem,6vw,4.5rem) * -1);
  top:50%;
  width:11px;height:11px;
  margin-left:-5px;margin-top:-5px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 5px rgba(201,169,110,.10),0 0 22px rgba(201,169,110,.45);
  transform:scale(0);
}
.entry-date{
  font-family:var(--mono);
  font-size:.74rem;
  letter-spacing:.16em;
  color:var(--accent);
  text-transform:uppercase;
}
.entry-role{
  color:var(--muted);
  font-family:var(--mono);
  font-size:.74rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-top:.4rem;
}
.entry h3{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(1.9rem,3.2vw,2.7rem);
  line-height:1.05;
  margin:1.1rem 0 1.2rem;
}
.entry p{color:var(--muted);max-width:46ch;}

/* media placeholder + reveal wipe */
.media{
  position:relative;
  aspect-ratio:4/3;
  border-radius:6px;
  overflow:hidden;
  border:1px solid var(--border);
  will-change:clip-path;
  /* brushed-steel placeholder */
  background:
    repeating-linear-gradient(
      115deg,
      rgba(255,255,255,.03) 0px,
      rgba(255,255,255,.03) 1px,
      transparent 1px,
      transparent 4px
    ),
    linear-gradient(120deg,#26221b,#1b1812 60%,#211d16);
}
.media-note{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--faint);
  padding:1rem;
}
.media img{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transform:scale(1.12);
  will-change:transform;
}

/* ---------- WHAT I BRING ---------- */

/* fallback card grid (mobile / reduced-motion / no-JS) */
.brings{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.bring{background:var(--bg);padding:clamp(2rem,4vw,3rem);transition:background .4s ease;}
.bring:hover{background:var(--surface);}
.bring .b-no{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--accent);}
.bring h3{font-family:var(--display);font-weight:500;font-size:1.5rem;margin:1.1rem 0 .8rem;}
.bring p{color:var(--muted);font-size:.98rem;}

/* node graph (enabled only when JS adds .fx-on) */
.graph-wrap{display:none;}
.fx-on .brings{display:none;}
.fx-on > .container .section-head{display:none;}
#strengths.fx-on{padding-block:5rem 0;}
#strengths.fx-on + #education{padding-top:5rem;}
.fx-on .graph-wrap{display:block;position:relative;width:100%;height:100vh;overflow:hidden;}
.graph-head{position:absolute;top:clamp(2rem,7vh,4.5rem);left:clamp(1.5rem,6vw,5rem);right:0;z-index:3;}
.graph-head .eyebrow{margin-bottom:1.2rem;}
.graph-head h2{font-family:var(--display);font-weight:400;font-size:clamp(2.2rem,4.5vw,3.4rem);line-height:1.04;letter-spacing:-.01em;}
.graph-stage{position:absolute;inset:0;transform-origin:0 0;}
.graph-lines{position:absolute;inset:0;width:100%;height:100%;}
.graph-lines line{stroke:var(--accent);stroke-width:1;opacity:.16;vector-effect:non-scaling-stroke;}
.gnode{
  position:absolute;
  transform:translate(-50%,-50%);
  width:122px;height:122px;
  border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
  background:radial-gradient(circle at 50% 32%,var(--surface-2),var(--bg-2));
  border:1px solid var(--line);
  box-shadow:0 0 0 6px rgba(201,169,110,.03),0 12px 44px rgba(0,0,0,.5);
  transition:border-color .4s ease,box-shadow .4s ease;
}
.gnode .gnum{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;color:var(--accent);}
.gnode .glabel{font-family:var(--display);font-size:.82rem;color:var(--muted);margin-top:.35rem;padding:0 .9rem;line-height:1.15;transition:color .4s ease;}
.gnode.hub{width:56px;height:56px;background:var(--accent);border:none;box-shadow:0 0 34px rgba(201,169,110,.5);}
.gnode.active{border-color:var(--accent);box-shadow:0 0 0 6px rgba(201,169,110,.10),0 0 56px rgba(201,169,110,.34);}
.gnode.active .glabel{color:var(--text);}
.gnode-desc{
  position:absolute;
  top:calc(100% + 14px);
  left:50%;
  width:190px;
  text-align:center;
  font-family:var(--body);
  font-size:.78rem;
  color:var(--muted);
  line-height:1.45;
  opacity:0;
  pointer-events:none;
  white-space:normal;
}
.graph-panel{position:absolute;left:50%;transform:translateX(-50%);bottom:clamp(2.5rem,9vh,5.5rem);width:min(560px,90%);text-align:center;z-index:3;opacity:0;}
.gp-no{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);}
.gp-title{font-family:var(--display);font-weight:500;font-size:clamp(1.6rem,3vw,2.4rem);margin:.6rem 0 .8rem;line-height:1.05;}
.gp-desc{color:var(--muted);max-width:42ch;margin:0 auto;}
.graph-hint{position:absolute;right:clamp(1.5rem,6vw,5rem);top:clamp(2rem,7vh,4.5rem);font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);z-index:3;}

/* ---------- EDUCATION (ledger) ---------- */

.ledger{border-top:1px solid var(--line);}
.ledger-row{
  position:relative;
  display:grid;
  grid-template-columns:1fr auto;
  column-gap:2rem;
  align-items:baseline;
  padding:2.4rem 1.4rem 2.4rem 1.6rem;
  border-bottom:1px solid var(--border);
  transition:padding-left .4s var(--ease),background .4s ease;
}
.ledger-row::before{
  content:"";
  position:absolute;
  left:0;top:50%;
  height:0;width:2px;
  background:var(--accent);
  transform:translateY(-50%);
  transition:height .4s var(--ease);
}
.ledger-row:hover{padding-left:2.4rem;background:linear-gradient(90deg,var(--accent-soft),transparent 60%);}
.ledger-row:hover::before{height:calc(100% - 2.8rem);}
.ledger-row .inst{
  font-family:var(--display);
  font-weight:500;
  font-size:clamp(1.5rem,3vw,2.3rem);
  line-height:1.1;
}
.ledger-row .when{
  font-family:var(--mono);
  font-size:.74rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  white-space:nowrap;
}
.ledger-row .detail{grid-column:1/-1;color:var(--muted);margin-top:.9rem;max-width:60ch;}
.edu-grades{grid-column:1/-1;margin-top:1.3rem;display:flex;flex-wrap:wrap;gap:.6rem;}
.pill{
  font-family:var(--mono);
  font-size:.74rem;
  letter-spacing:.06em;
  padding:.5rem .9rem;
  border:1px solid var(--line);
  border-radius:999px;
  color:var(--accent);
  background:var(--accent-soft);
}
.pill.neutral{color:var(--muted);background:transparent;border-color:var(--border);}
.ledger-anim-rule{
  position:absolute;
  bottom:0;left:0;
  width:100%;height:1px;
  background:var(--border);
  display:block;
  pointer-events:none;
  transform-origin:left center;
}

/* ---------- CONTACT ---------- */

#education{padding-bottom:5rem;}
.contact{
  text-align:center;
  position:relative;
  overflow:hidden;
  isolation:isolate;
  padding-top:4rem;
}
.contact-bg{
  position:absolute;
  left:0;right:0;
  top:-15%;
  height:130%;
  will-change:transform;
  pointer-events:none;
}
.contact-bg img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  filter:blur(3px);
  display:block;
}
.contact-bg::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,.77) 220px);
  z-index:1;
}
.contact-bg::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at 50% 50%,transparent 25%,rgba(0,0,0,.6) 100%);
  z-index:2;
}
.contact > .container{position:relative;z-index:1;}
.contact h2{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(2.6rem,6vw,4.6rem);
  line-height:1.02;
  letter-spacing:-.01em;
}
.contact p{color:var(--muted);max-width:540px;margin:1.6rem auto 2.8rem;}
.contact-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;align-items:center;}
.button{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:1rem 2.1rem;
  border-radius:999px;
  background:var(--accent);
  color:#171205;
  text-decoration:none;
  font-weight:500;
  font-size:.95rem;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.button:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(201,169,110,.22);}
.button.ghost{background:transparent;color:var(--text);border:1px solid var(--border);}
.hero-cv{display:inline-flex;margin-top:0;}
.button.ghost:hover{border-color:var(--accent);box-shadow:none;}
.contact-meta{margin-top:3rem;font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;color:var(--faint);text-transform:uppercase;}

/* ---------- FOOTER ---------- */

footer{
  border-top:1px solid var(--border);
  padding:2.4rem 0;
}
footer .container{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;}
footer .sig{font-family:var(--display);font-size:1.1rem;}
footer .meta{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;color:var(--faint);text-transform:uppercase;}

/* ---------- CARD SHEEN (brushed-steel reflection on hover) ---------- */
.stat{position:relative;}
.stat::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:radial-gradient(
    170px circle at var(--cx,50%) var(--cy,50%),
    rgba(255,242,214,.10),
    transparent 60%
  );
  opacity:0;
  transition:opacity .45s ease;
}
.stat:hover::after{opacity:1;}

/* ---------- A* CARD GLOW (gravity hover) ---------- */
.stat:has(.astar){
  box-shadow:
    0 0 0   0 rgba(201,169,110,0),
    0 0 0   0 rgba(201,169,110,0),
    inset 0 0 0 1px rgba(201,169,110,0);
  transition:box-shadow 1.8s ease;
}
.stat:has(.astar):hover{
  box-shadow:
    0 0 28px 6px rgba(201,169,110,.09),
    0 0  8px 0   rgba(201,169,110,.13),
    inset 0 0 0 1px rgba(201,169,110,.18);
}

/* ---------- A* STAR PILLS ---------- */
.pill.star{
  position:relative;
  overflow:hidden;
  animation:pillGlow 4.2s ease-in-out infinite;
}
.pill.star::before{
  content:"";
  position:absolute;
  top:0;left:-120%;
  width:55%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,242,214,.55),transparent);
  transform:skewX(-18deg);
  animation:pillSweep 5.5s var(--ease) infinite;
  pointer-events:none;
}
.pill.star::after{
  content:"\2726"; /* sparkle */
  position:absolute;
  top:3px;right:8px;
  font-size:.6rem;
  color:var(--steel-warm);
  opacity:0;
  animation:twinkle 3.4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes pillSweep{0%{left:-120%;}22%{left:150%;}100%{left:150%;}}
@keyframes pillGlow{0%,100%{box-shadow:0 0 12px rgba(201,169,110,.14);}50%{box-shadow:0 0 22px rgba(201,169,110,.30);}}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.6) rotate(0deg);}50%{opacity:.9;transform:scale(1) rotate(90deg);}}


/* ---------- EMAIL DROPDOWN ---------- */
.email-menu{position:relative;display:inline-block;}
.email-pop{
  position:absolute;
  bottom:calc(100% + .8rem);
  left:50%;
  transform:translateX(-50%) translateY(8px);
  min-width:248px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  padding:.5rem;
  box-shadow:0 18px 50px rgba(0,0,0,.55);
  opacity:0;visibility:hidden;
  transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;
  z-index:60;
}
.email-menu.open .email-pop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.email-pop::after{
  content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:7px solid transparent;border-top-color:var(--surface);
}
.email-opt{
  display:flex;align-items:center;gap:.7rem;width:100%;
  padding:.7rem .9rem;border-radius:8px;
  background:none;border:none;cursor:pointer;text-align:left;
  font-family:var(--body);font-size:.92rem;color:var(--text);text-decoration:none;
  transition:background .25s ease;
}
/* ---------- A* SHIMMER GRADIENT ---------- */
.astar{
  color:var(--accent);
}
.email-opt:hover{background:var(--surface-2);}
.email-opt .ico{
  font-family:var(--mono);font-size:.66rem;color:var(--accent);
  width:1.8rem;flex:none;text-align:center;letter-spacing:.04em;
  border:1px solid var(--line);border-radius:6px;padding:.3rem 0;
}
.email-opt .lbl{flex:1;line-height:1.25;}

/* ---------- SCROLL PROGRESS + DOT NAV ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:70;
  background:rgba(255,255,255,.04);
}
.scroll-progress span{
  display:block;height:100%;width:0;
  background:linear-gradient(90deg,var(--accent),var(--steel-warm));
  box-shadow:0 0 12px rgba(201,169,110,.5);
}
.dotnav {
  position: fixed;
  right: clamp(1.2rem, 2.4vw, 2.2rem);
  top: 50%;
  transform: translateY(-50%);
  z-index: 60;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}
.dotnav .dot{position:relative;display:block;width:11px;height:11px;}
.dotnav .dot span{
  position:absolute;inset:0;margin:auto;width:7px;height:7px;border-radius:50%;
  border:1px solid var(--faint);background:transparent;
  transition:all .35s var(--ease);
}
.dotnav .dot:hover span{border-color:var(--accent);}
.dotnav .dot.active span{
  background:var(--accent);border-color:var(--accent);
  box-shadow:0 0 12px rgba(201,169,110,.6);transform:scale(1.15);
}
.dotnav .dot::after{
  content:attr(data-label);
  position:absolute;right:calc(100% + .9rem);top:50%;
  transform:translateY(-50%) translateX(6px);
  font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;
}
.dotnav .dot:hover::after,.dotnav .dot.active::after{opacity:1;transform:translateY(-50%) translateX(0);}
.dotnav .dot.active::after{color:var(--accent);}

/* ---------- FOCUS / A11Y ---------- */
a:focus-visible,.button:focus-visible,.email-opt:focus-visible,.dot:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px;}

/* ---------- IMAGE INFO DISCLOSURE ---------- */
.info-btn{
  position:absolute;
  bottom:10px;right:10px;
  width:22px;height:22px;
  background:none;
  border:none;
  padding:0;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  transition:opacity .25s ease;
  z-index:2;
  color:var(--accent);
}
.info-btn svg{width:22px;height:22px;display:block;}
.media:hover .info-btn,
.about-photo-wrap:hover .info-btn,
.info-btn[aria-expanded="true"]{opacity:1;}
.info-card{
  position:absolute;
  bottom:42px;right:10px;
  width:260px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:10px;
  padding:.75rem 1rem;
  font-family:var(--body);
  font-size:.82rem;
  color:var(--muted);
  line-height:1.5;
  box-shadow:0 8px 32px rgba(0,0,0,.55);
  opacity:0;
  visibility:hidden;
  transform:translateY(4px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
  z-index:3;
}
.info-card.open{opacity:1;visibility:visible;transform:translateY(0);}
.info-card a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;}
.info-card a:hover{color:var(--text);}

/* ---------- RESPONSIVE ---------- */
@media(max-width:820px){
  section{padding:7rem 0;}
  #education{padding-bottom:0;}
  .contact{padding-top:0;}
  .entry{grid-template-columns:1fr;}
  .entry .media{order:-1;}
  .brings{grid-template-columns:1fr;}
  .edu-card{grid-template-columns:1fr;gap:1rem;}
  .stats{grid-template-columns:1fr;}
  .stat + .stat{border-left:none;border-top:1px solid var(--border);}
  .dotnav{display:none;}

  .info-btn{opacity:.5;}

  /* Mobile bring cards: gold ledger border + noise texture */
  .bring{
    position:relative;
    border-left:2px solid rgba(201,169,110,.4);
  }
  .bring::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
    background-repeat:repeat;
    background-size:180px 180px;
    opacity:.04;
  }
}

/* ---------- REDUCED MOTION ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;}
  html{scroll-behavior:auto;}
  .rise{opacity:1;transform:none;}
  .media{clip-path:none;}
  .about-photo-wrap{transform:none !important;}
  .media img{transform:none;}
  .timeline-rail{transform:scaleY(1);}
  .entry::before{transform:scale(1);}
  .hero-name{background-position:42% 0;}
}
