/* ============================================================
   VICTOR DELVAT — shared stylesheet (multi-page, bold edition)
   ============================================================ */
:root{
  --paper:#F4F0E6;
  --paper-2:#ECE5D6;
  --surface:#FBF8F1;
  --ink:#1A1620;
  --ink-soft:#332C38;
  --muted:#6B6270;
  --muted-2:#968D9C;
  --line:rgba(26,22,32,0.14);
  --line-soft:rgba(26,22,32,0.07);
  --clay:#7C2230;
  --clay-deep:#5E1721;
  --gold:#B07C2E;
  --gold-soft:#CBA869;
  --dark:#17121A;
  --dark-paper:#EFE7DA;
  --map-land:rgba(26,22,32,0.085);
  --map-hi:rgba(124,34,48,0.42);

  --maxw:1320px;
  --gut:clamp(1.25rem,5vw,5.5rem);

  --ease:cubic-bezier(0.22,1,0.36,1);
  --ease-soft:cubic-bezier(0.65,0.05,0.36,1);
  --r:16px;

  --f-display:"Fraunces",Georgia,serif;
  --f-body:"Inter",system-ui,-apple-system,sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,monospace;
}

/* ---------- view transitions (cross-page) ---------- */
@view-transition{ navigation:auto; }
@keyframes vt-out{ to{ opacity:0; transform:translateY(-14px) scale(.992); } }
@keyframes vt-in{ from{ opacity:0; transform:translateY(22px) scale(.992); } }
::view-transition-old(root){ animation:vt-out .42s var(--ease) both; }
::view-transition-new(root){ animation:vt-in .55s var(--ease) both; }

/* ============================================================ RESET */
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:var(--f-body);background:var(--paper);color:var(--ink);
  font-size:clamp(1rem,0.55vw + 0.9rem,1.12rem);line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--clay);color:#fff}

/* warm wash + film grain */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 120% at 82% -10%, rgba(176,124,46,0.10), transparent 55%),
    radial-gradient(90% 90% at -10% 110%, rgba(124,34,48,0.07), transparent 50%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{position:relative;z-index:1;padding-block:clamp(4.5rem,11vh,9rem)}
main{position:relative;z-index:1}

/* ============================================================ TYPE HELPERS */
.label{font-family:var(--f-mono);font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);font-weight:500}
.display{font-family:var(--f-display);font-weight:380;line-height:0.9;letter-spacing:-0.025em;font-optical-sizing:auto}
.serif{font-family:var(--f-display)}
.lead{font-size:clamp(1.2rem,1.4vw + 0.9rem,1.75rem);line-height:1.42;letter-spacing:-0.01em;color:var(--ink-soft);max-width:34ch}

.reveal-line{display:block;overflow:hidden}
.reveal-line > span{display:block;transform:translateY(110%);transition:transform 0.95s var(--ease)}
.in .reveal-line > span{transform:translateY(0)}
.in .reveal-line:nth-child(2) > span{transition-delay:0.08s}
.in .reveal-line:nth-child(3) > span{transition-delay:0.16s}

.r-up{opacity:0;transform:translateY(26px);transition:opacity 0.85s var(--ease),transform 0.85s var(--ease)}
.in .r-up,.r-up.in{opacity:1;transform:none}
.r-up[data-d="1"]{transition-delay:0.08s}
.r-up[data-d="2"]{transition-delay:0.16s}
.r-up[data-d="3"]{transition-delay:0.24s}
.r-up[data-d="4"]{transition-delay:0.32s}
.r-up[data-d="5"]{transition-delay:0.40s}

/* ============================================================ CURSOR */
.cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;mix-blend-mode:multiply;opacity:0}
.cursor{width:40px;height:40px;border:1px solid rgba(26,22,32,0.45);transform:translate(-50%,-50%);
  transition:width .35s var(--ease),height .35s var(--ease),opacity .3s,background .35s var(--ease),border-color .35s}
.cursor-dot{width:5px;height:5px;background:var(--ink);transform:translate(-50%,-50%)}
.cursor.is-hover{width:66px;height:66px;background:rgba(124,34,48,0.10);border-color:transparent}
.cursor.is-hover-dark{border-color:rgba(239,231,218,0.6)}
body.cursor-ready{cursor:none}
body.cursor-ready a,body.cursor-ready button{cursor:none}

/* ============================================================ PROGRESS */
.progress{position:fixed;top:0;left:0;height:2px;width:100%;transform:scaleX(0);transform-origin:0 50%;background:var(--clay);z-index:300}

/* ============================================================ NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem var(--gut);transition:padding .5s var(--ease),background .5s var(--ease),box-shadow .5s var(--ease),backdrop-filter .5s}
.nav.shrunk{padding:0.85rem var(--gut);background:rgba(244,240,230,0.72);backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);box-shadow:0 1px 0 var(--line-soft)}
.nav-name{font-family:var(--f-display);font-size:1.18rem;font-weight:450;letter-spacing:-0.01em;display:flex;align-items:center;gap:.5rem}
.nav-name .dot{width:7px;height:7px;border-radius:50%;background:var(--clay);display:inline-block}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-family:var(--f-mono);font-size:0.74rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);position:relative;padding:.3rem 0;transition:color .3s var(--ease)}
.nav-links a .idx{color:var(--muted-2);margin-right:.4rem}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1px;width:100%;background:var(--ink);transform:scaleX(0);transform-origin:100% 50%;transition:transform .4s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:0 50%}
.nav-links a.active .idx{color:var(--clay)}

.btn-resume{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-mono);font-size:0.74rem;letter-spacing:0.06em;text-transform:uppercase;
  border:1px solid var(--line);border-radius:100px;padding:.6rem 1.1rem;color:var(--ink);position:relative;overflow:hidden;
  transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease)}
.btn-resume span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:.55rem}
.btn-resume::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0}
.btn-resume:hover{color:var(--paper);border-color:var(--ink)}
.btn-resume:hover::before{transform:translateY(0)}
.btn-resume svg{width:14px;height:14px}
.nav-toggle{display:none}

/* mobile menu */
.menu{position:fixed;inset:0;z-index:190;background:var(--paper);display:flex;flex-direction:column;justify-content:center;gap:1rem;padding:var(--gut);transform:translateY(-100%);transition:transform .6s var(--ease)}
.menu.open{transform:translateY(0)}
.menu a{font-family:var(--f-display);font-size:clamp(2rem,9vw,3.5rem);font-weight:380;letter-spacing:-0.02em;display:flex;align-items:baseline;gap:1rem}
.menu a .idx{font-family:var(--f-mono);font-size:0.9rem;color:var(--clay)}

/* inner pages: clear the fixed nav */
main > .section:first-child:not(.hero){padding-top:clamp(7rem,15vh,11rem)}

/* dark-themed pages (contact): make the nav legible over dark */
body.on-dark .nav-name{color:var(--dark-paper)}
body.on-dark .nav-name .dot{background:var(--gold)}
body.on-dark .nav-links a{color:rgba(239,231,218,0.55)}
body.on-dark .nav-links a:hover,body.on-dark .nav-links a.active{color:var(--dark-paper)}
body.on-dark .nav-links a::after{background:var(--dark-paper)}
body.on-dark .nav-links a.active .idx{color:var(--gold)}
body.on-dark .btn-resume{color:var(--dark-paper);border-color:rgba(239,231,218,0.32)}
body.on-dark .btn-resume::before{background:var(--dark-paper)}
body.on-dark .btn-resume:hover{color:var(--dark)}
body.on-dark .nav.shrunk{background:rgba(23,18,26,0.62);box-shadow:0 1px 0 rgba(239,231,218,0.1)}
body.on-dark .nav-toggle span{background:var(--dark-paper)}
body.on-dark .cursor{border-color:rgba(239,231,218,0.5);mix-blend-mode:screen}
body.on-dark .cursor-dot{background:var(--dark-paper);mix-blend-mode:screen}

/* ============================================================ HERO */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding-top:6rem;padding-bottom:3rem;position:relative;z-index:1}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:clamp(1.5rem,4vh,3rem);flex-wrap:wrap}
.hero-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,0.92fr);align-items:start;gap:clamp(1.5rem,4vw,3.5rem)}
.hero-name{font-size:clamp(3rem,11.5vw,11rem);letter-spacing:-0.04em;line-height:0.88}
.hero-name em{font-style:italic;font-weight:320;color:var(--clay)}
.hero-role{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;margin-top:clamp(2.5rem,7vh,5.5rem);
  font-family:var(--f-mono);font-size:clamp(0.78rem,1.1vw,0.95rem);letter-spacing:0.04em;text-transform:uppercase;color:var(--ink-soft)}
.hero-role .sep{width:34px;height:1px;background:var(--line);display:inline-block}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1.15fr);gap:clamp(1.5rem,3vw,3.2rem);align-items:end;margin-top:clamp(2rem,5vh,4rem)}
.hero-lead{align-self:end}
.hero-meta{display:flex;flex-direction:column;gap:.9rem;align-items:flex-start;justify-self:end}
.hero-stats{display:flex;gap:clamp(0.8rem,1.6vw,1.5rem);flex-wrap:nowrap}
.hero-stats .stat{flex:none}
.stat .num{font-family:var(--f-display);font-size:clamp(1.9rem,3vw,2.8rem);line-height:1;font-weight:400;display:block}
.stat .cap{font-family:var(--f-mono);font-size:0.62rem;letter-spacing:0.07em;text-transform:uppercase;color:var(--muted);margin-top:.5rem;white-space:nowrap}
.scroll-cue{display:flex;align-items:center;gap:.7rem;margin-top:clamp(2rem,5vh,3.5rem);font-family:var(--f-mono);font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted)}
.scroll-cue .line{position:relative;width:46px;height:1px;background:var(--line);overflow:hidden}
.scroll-cue .line::after{content:"";position:absolute;inset:0;background:var(--ink);transform:translateX(-100%);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:translateX(-100%)}50%{transform:translateX(0)}100%{transform:translateX(100%)}}

/* ============================================================ PORTRAIT / PHOTO SLOTS */
.portrait{position:relative;justify-self:end;align-self:start;height:clamp(400px,66vh,720px);aspect-ratio:4/5;width:auto;max-width:100%}
.portrait.is-empty{border:1px dashed var(--line);border-radius:18px;background:var(--paper-2);overflow:hidden}
.portrait:not(.is-empty) img{object-position:50% 12%;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 15%,#000 95%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 8%,#000 90%,transparent 100%);
  -webkit-mask-composite:source-in;
  mask-image:linear-gradient(to right,transparent 0,#000 15%,#000 95%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 8%,#000 90%,transparent 100%);
  mask-composite:intersect}
.portrait:not(.is-empty)::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(to right,var(--paper),transparent 20%),linear-gradient(to top,var(--paper),transparent 14%)}
.portrait img,.photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.portrait figcaption,.photo figcaption{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--f-mono);font-size:0.64rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted-2);line-height:1.7}
.portrait.is-empty,.photo.is-empty{border-style:dashed}
.photo{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--r);background:var(--paper-2)}

/* ============================================================ SECTION HEADER */
.sec-head{display:flex;align-items:baseline;gap:1rem;margin-bottom:clamp(2.5rem,6vw,4.5rem);border-bottom:1px solid var(--line);padding-bottom:1.4rem;flex-wrap:wrap}
.sec-head .idx{font-family:var(--f-mono);font-size:0.8rem;color:var(--clay);letter-spacing:0.05em}
.sec-head h1,.sec-head h2{font-size:clamp(2.2rem,5.5vw,4.6rem);font-weight:360;letter-spacing:-0.03em;line-height:1}
.sec-head h1 em,.sec-head h2 em{font-style:italic;color:var(--muted)}
.sec-head .aside{margin-left:auto;max-width:30ch;color:var(--muted);font-size:0.95rem}

/* ============================================================ ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.about-lead{font-family:var(--f-display);font-weight:340;font-size:clamp(1.6rem,2.5vw,2.4rem);line-height:1.3;letter-spacing:-0.015em}
.about-lead strong{font-weight:500;color:var(--clay-deep)}
.about-body p{color:var(--ink-soft);margin-bottom:1.3rem;max-width:46ch}
.about-body p:last-child{margin-bottom:0}
.pullquote{margin-top:clamp(3rem,7vw,5rem);border-top:1px solid var(--line);padding-top:clamp(2rem,4vw,3rem);display:grid;grid-template-columns:auto 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.pullquote .q{font-family:var(--f-display);font-style:italic;font-weight:330;font-size:clamp(1.8rem,3.8vw,3.4rem);line-height:1.18;letter-spacing:-0.02em}
.pullquote .q .mark{color:var(--clay)}
.pullquote .attr{font-family:var(--f-mono);font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);white-space:nowrap;padding-top:.6rem}
.values{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:clamp(2.5rem,5vw,3.5rem)}
.chip{font-family:var(--f-mono);font-size:0.76rem;letter-spacing:0.03em;border:1px solid var(--line);border-radius:100px;padding:.5rem 1rem;color:var(--ink-soft);transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease)}
.chip:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ============================================================ PATH / JOURNEY */
.path-list{display:flex;flex-direction:column}
.stop{display:grid;grid-template-columns:0.6fr 1.6fr 1fr;gap:clamp(1rem,3vw,3rem);padding:clamp(1.6rem,3.5vw,2.6rem) 0;border-top:1px solid var(--line);align-items:start;position:relative;transition:background .5s var(--ease)}
.stop:last-child{border-bottom:1px solid var(--line)}
.stop:hover{background:linear-gradient(90deg,rgba(124,34,48,0.05),transparent 70%)}
.stop .yr{font-family:var(--f-mono);font-size:0.8rem;color:var(--muted);letter-spacing:0.03em;padding-top:.45rem}
.stop .place h3{font-family:var(--f-display);font-size:clamp(1.4rem,2.6vw,2.1rem);font-weight:400;letter-spacing:-0.015em;line-height:1.1}
.stop .place .loc{display:flex;align-items:center;gap:.55rem;margin-top:.6rem;font-size:0.92rem;color:var(--muted)}
.stop .place .loc svg{width:14px;height:14px;color:var(--clay);flex:none}
.stop .detail{color:var(--ink-soft);font-size:0.97rem;padding-top:.3rem}
.stop .detail .courses{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}
.stop .detail .courses span{font-family:var(--f-mono);font-size:0.68rem;color:var(--muted);border:1px solid var(--line-soft);border-radius:6px;padding:.25rem .5rem}
.stop .num-big{position:absolute;right:0;top:50%;transform:translateY(-50%);font-family:var(--f-display);font-size:clamp(3rem,8vw,7rem);font-style:italic;color:rgba(26,22,32,0.05);font-weight:300;pointer-events:none;z-index:-1}

.journey{position:relative;width:100%;aspect-ratio:950/620;margin-bottom:clamp(2.5rem,6vw,4.5rem);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  background:radial-gradient(120% 130% at 50% -20%, rgba(176,124,46,0.10), transparent 55%),radial-gradient(90% 90% at 95% 110%, rgba(124,34,48,0.08), transparent 55%),var(--surface)}
.world-base,.map-overlay{position:absolute;inset:0;width:100%;height:100%}
.world-base path{fill:var(--map-land);stroke:none;transition:fill 1.2s var(--ease)}
.world-base #france,.world-base #usa{fill:var(--map-land)}
.journey.in .world-base #france,.journey.in .world-base #usa{fill:var(--map-hi)}
.map-overlay{overflow:visible}
.route{fill:none;stroke:var(--gold);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:var(--len);stroke-dashoffset:var(--len);transition:stroke-dashoffset 2.1s var(--ease-soft);filter:drop-shadow(0 1px 1px rgba(176,124,46,0.35))}
.journey.in .route{stroke-dashoffset:0}
.route-ghost{fill:none;stroke:var(--line);stroke-width:1;stroke-dasharray:2 6}
.plane{fill:var(--ink)}
.plane-wrap{opacity:0;transition:opacity .4s var(--ease)}
.journey.in .plane-wrap{opacity:1}
.mk-ring{fill:none;stroke:var(--clay);stroke-width:2;opacity:0;transform-box:fill-box;transform-origin:center}
.journey.in .mk-ring{animation:pulse 2.6s var(--ease) infinite}
.mk-dot{fill:var(--clay)}.mk-dot.gold{fill:var(--gold)}
@keyframes pulse{0%{opacity:.55;transform:scale(.6)}70%{opacity:0;transform:scale(2.6)}100%{opacity:0;transform:scale(2.6)}}
.city{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;gap:.15rem;align-items:center;pointer-events:none;text-align:center;opacity:0;transition:opacity .7s var(--ease)}
.journey.in .city{opacity:1}
.city .c-name{font-family:var(--f-display);font-size:clamp(.8rem,1.5vw,1.15rem);font-weight:500;line-height:1;letter-spacing:-.01em;color:var(--ink);white-space:nowrap}
.city .c-meta{font-family:var(--f-mono);font-size:clamp(.5rem,.9vw,.66rem);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.city .c-tag{font-family:var(--f-mono);font-size:clamp(.46rem,.8vw,.58rem);letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.1rem}
.city.below{flex-direction:column-reverse}
.journey-cap{position:absolute;left:clamp(1rem,3vw,2rem);bottom:clamp(1rem,3vw,1.6rem);font-family:var(--f-mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);display:flex;align-items:center;gap:.6rem}
.journey-cap .pin{width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* ============================================================ WORK */
.work-list{display:flex;flex-direction:column;gap:0}
.job{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(1.2rem,3vw,3rem);padding:clamp(1.8rem,4vw,3rem) 0;border-top:1px solid var(--line);align-items:center;cursor:pointer;position:relative}
.job:last-child{border-bottom:1px solid var(--line)}
.job .j-main{display:flex;flex-direction:column;gap:.2rem}
.job .j-title{font-family:var(--f-display);font-size:clamp(1.6rem,3.6vw,2.9rem);font-weight:400;letter-spacing:-0.02em;line-height:1.04;transition:color .4s var(--ease);display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}
.job .j-title .tag{font-family:var(--f-mono);font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--clay);border:1px solid var(--clay);border-radius:100px;padding:.2rem .55rem;transform:translateY(-3px)}
.job .j-org{color:var(--muted);font-size:0.97rem;margin-top:.35rem}
.job .j-side{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}
.job .j-yr{font-family:var(--f-mono);font-size:0.78rem;color:var(--muted)}
.job .j-arrow{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .4s var(--ease),border-color .4s var(--ease),transform .4s var(--ease)}
.job .j-arrow svg{width:16px;height:16px;transition:transform .4s var(--ease),color .4s var(--ease)}
.job:hover .j-title{color:var(--clay-deep)}
.job:hover .j-arrow{background:var(--ink);border-color:var(--ink);transform:rotate(45deg)}
.job:hover .j-arrow svg{color:var(--paper);transform:rotate(-45deg)}
.job-detail{grid-column:1 / -1;display:grid;grid-template-rows:0fr;transition:grid-template-rows .55s var(--ease)}
.job-detail-inner{overflow:hidden}
.job.open .job-detail{grid-template-rows:1fr}
.job-detail ul{list-style:none;padding-top:1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.9rem 2.5rem;max-width:60rem}
.job-detail li{position:relative;padding-left:1.4rem;color:var(--ink-soft);font-size:0.96rem;line-height:1.5}
.job-detail li::before{content:"";position:absolute;left:0;top:.6em;width:6px;height:6px;border-radius:50%;background:var(--clay)}

/* logos */
.logo{position:relative;display:inline-flex;align-items:center;justify-content:center;flex:none;width:58px;height:58px;padding:5px;overflow:hidden;border:1px solid var(--line);border-radius:13px;background:var(--surface);
  font-family:var(--f-mono);font-weight:500;font-size:0.5rem;letter-spacing:0.04em;line-height:1.18;text-transform:uppercase;color:var(--ink-soft);text-align:center;transition:border-color .4s var(--ease),background .4s var(--ease)}
.logo img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:9px;background:var(--surface);z-index:1}
.logo b{font-weight:600}
.job:hover .j-logo{border-color:var(--clay)}
.logo-uni{display:flex;width:54px;height:54px;margin-bottom:1.1rem}

.certs{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem;margin-top:clamp(2.5rem,5vw,4rem)}
.cert{border:1px solid var(--line);border-radius:var(--r);padding:1.6rem;background:var(--surface);transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);display:flex;flex-direction:column;gap:.6rem}
.cert:hover{transform:translateY(-5px);box-shadow:0 18px 40px -22px rgba(26,22,32,0.3);border-color:var(--clay)}
.cert .c-ico{width:30px;height:30px;color:var(--clay)}
.cert .c-ico svg{width:100%;height:100%}
.cert h4{font-family:var(--f-display);font-size:1.25rem;font-weight:450;letter-spacing:-0.01em}
.cert p{font-size:0.88rem;color:var(--muted)}

/* ============================================================ NEXT-STEP CTA */
.next-step{position:relative;z-index:1;display:block;border-top:1px solid var(--line);padding-block:clamp(3.5rem,9vw,7rem);transition:background .5s var(--ease)}
.next-step:hover{background:linear-gradient(180deg,rgba(124,34,48,0.04),transparent)}
.next-inner{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut);display:flex;flex-direction:column;gap:.6rem}
.next-step .ns-label{font-family:var(--f-mono);font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted)}
.next-step .ns-title{font-family:var(--f-display);font-weight:380;font-size:clamp(2.6rem,9vw,7rem);line-height:0.95;letter-spacing:-0.03em;display:flex;align-items:center;gap:clamp(1rem,3vw,2.5rem);flex-wrap:wrap;transition:color .4s var(--ease)}
.next-step:hover .ns-title{color:var(--clay-deep)}
.next-step .ns-arrow{display:inline-flex;align-items:center;justify-content:center;width:clamp(54px,8vw,92px);height:clamp(54px,8vw,92px);border:1px solid var(--line);border-radius:50%;transition:background .45s var(--ease),border-color .45s var(--ease),transform .45s var(--ease);flex:none}
.next-step .ns-arrow svg{width:42%;height:42%;transition:transform .45s var(--ease),color .45s var(--ease)}
.next-step:hover .ns-arrow{background:var(--clay);border-color:var(--clay);transform:rotate(45deg)}
.next-step:hover .ns-arrow svg{color:var(--paper);transform:rotate(-45deg)}

/* ============================================================ CONTACT (dark) */
.contact{position:relative;z-index:1;background:var(--dark);color:var(--dark-paper);padding-block:clamp(5rem,12vh,9rem);overflow:hidden;min-height:100svh;display:flex;align-items:center}
.contact::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(80% 90% at 85% 0%,rgba(124,34,48,0.34),transparent 58%)}
.contact .label{color:rgba(239,231,218,0.6)}
.contact-head{font-family:var(--f-display);font-weight:330;font-size:clamp(2.8rem,9vw,7.5rem);line-height:0.96;letter-spacing:-0.03em;margin-block:1.5rem 0}
.contact-head em{font-style:italic;color:var(--gold-soft)}
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2.5rem,6vw,5rem);margin-top:clamp(2.5rem,6vw,4.5rem);align-items:end}
.contact-cta{display:inline-flex;align-items:center;gap:1rem;margin-top:2rem;font-family:var(--f-display);font-size:clamp(1.6rem,3.5vw,2.6rem);font-weight:400;letter-spacing:-0.02em;color:var(--dark-paper);position:relative}
.contact-cta .u{position:relative}
.contact-cta .u::after{content:"";position:absolute;left:0;bottom:2px;height:1px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:0 50%;transition:transform .5s var(--ease)}
.contact-cta:hover .u::after{transform:scaleX(1)}
.contact-cta .arrow{width:54px;height:54px;border-radius:50%;border:1px solid rgba(239,231,218,0.3);display:flex;align-items:center;justify-content:center;flex:none;transition:background .4s var(--ease),transform .4s var(--ease)}
.contact-cta .arrow svg{width:20px;height:20px;transition:transform .4s var(--ease)}
.contact-cta:hover .arrow{background:var(--clay);border-color:var(--clay);transform:rotate(45deg)}
.contact-cta:hover .arrow svg{transform:rotate(-45deg)}
.contact-links{display:flex;flex-direction:column;gap:.2rem}
.contact-links a{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0;border-bottom:1px solid rgba(239,231,218,0.14);font-size:1rem;transition:padding-left .4s var(--ease)}
.contact-links a .k{font-family:var(--f-mono);font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(239,231,218,0.55)}
.contact-links a .v{display:flex;align-items:center;gap:.6rem}
.contact-links a svg{width:15px;height:15px;opacity:.5;transition:opacity .4s,transform .4s var(--ease)}
.contact-links a:hover{padding-left:.5rem}
.contact-links a:hover svg{opacity:1;transform:translate(2px,-2px)}

/* ============================================================ SITE FOOTER */
.site-foot{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;
  max-width:var(--maxw);margin-inline:auto;padding:1.8rem var(--gut);border-top:1px solid var(--line);
  font-family:var(--f-mono);font-size:0.72rem;letter-spacing:0.05em;color:var(--muted);text-transform:uppercase}
.site-foot a{transition:color .3s}
.site-foot a:hover{color:var(--ink)}
.to-top{display:inline-flex;align-items:center;gap:.5rem}
.to-top svg{width:13px;height:13px}
.contact .foot-in{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;margin-top:clamp(3.5rem,8vw,6rem);padding-top:1.6rem;border-top:1px solid rgba(239,231,218,0.14);font-family:var(--f-mono);font-size:0.72rem;letter-spacing:0.05em;color:rgba(239,231,218,0.5);text-transform:uppercase}
.contact .foot-in a{transition:color .3s}.contact .foot-in a:hover{color:var(--dark-paper)}

/* ============================================================ MARQUEE */
.marquee{border-block:1px solid var(--line);padding-block:1.4rem;overflow:hidden;position:relative;z-index:1;background:var(--paper-2)}
.marquee-track{display:flex;gap:3rem;width:max-content;animation:slide 38s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:var(--f-display);font-size:clamp(1.4rem,3vw,2.4rem);font-weight:380;letter-spacing:-0.01em;color:var(--ink-soft);display:flex;align-items:center;gap:3rem;white-space:nowrap}
.marquee-item > span{display:none}
.marquee-item::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--clay);flex:none;opacity:.8}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============================================================ TILT */
.tilt{transition:transform .4s var(--ease)}

/* ============================================================ RESPONSIVE */
@media (max-width:900px){
  .nav-links{display:none}
  .nav-toggle{display:flex;flex-direction:column;gap:5px;width:30px;height:30px;align-items:center;justify-content:center}
  .nav-toggle span{width:22px;height:1.5px;background:var(--ink);transition:transform .4s var(--ease),opacity .3s}
  .nav-toggle[aria-expanded="true"] span:first-child{transform:translateY(3.25px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:last-child{transform:translateY(-3.25px) rotate(-45deg)}
  .hero-head{grid-template-columns:1fr;gap:2rem}
  .portrait{height:auto;width:min(72%,300px);aspect-ratio:4/5;justify-self:start}
  .hero-stats{flex-wrap:wrap;gap:1.4rem}
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-meta{justify-self:start}
  .about-grid{grid-template-columns:1fr;gap:2rem}
  .stop{grid-template-columns:1fr;gap:.6rem}
  .stop .yr{padding-top:0}
  .stop .num-big{display:none}
  .job{grid-template-columns:auto 1fr;gap:1rem}
  .job .j-side{grid-column:2;flex-direction:row;align-items:center;justify-content:space-between;width:100%;margin-top:.4rem}
  .pullquote{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .sec-head .aside{margin-left:0;flex-basis:100%}
}
@media (hover:none){.cursor,.cursor-dot{display:none!important}}

/* ============================================================ REDUCED MOTION */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:0.001ms!important;animation-iteration-count:1!important;transition-duration:0.001ms!important}
  .reveal-line > span{transform:none}.r-up{opacity:1;transform:none}.marquee-track{animation:none}
  .cursor,.cursor-dot{display:none!important}body.cursor-ready{cursor:auto}
  ::view-transition-old(root),::view-transition-new(root){animation:none!important}
}
a:focus-visible,button:focus-visible{outline:2px solid var(--clay);outline-offset:3px;border-radius:2px}

/* ============================================================ CONTACT FORM */
.cform{margin-top:2.2rem;max-width:34rem;display:flex;flex-direction:column;gap:1.5rem}
.cform .field{display:flex;flex-direction:column;gap:.5rem}
.cform label{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(236,234,230,0.55)}
.cform input,.cform textarea{
  width:100%;background:transparent;border:none;border-bottom:1px solid rgba(236,234,230,0.22);
  color:var(--dark-paper);font-family:var(--f-body);font-size:1.05rem;line-height:1.5;
  padding:.55rem 0;transition:border-color .4s var(--ease);
}
.cform textarea{resize:vertical;min-height:3.4rem}
.cform input::placeholder,.cform textarea::placeholder{color:rgba(236,234,230,0.28)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--gold)}
.cform-submit{
  align-self:flex-start;margin-top:.4rem;display:inline-flex;align-items:center;
  font-family:var(--f-mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  border:1px solid rgba(236,234,230,0.32);border-radius:100px;padding:.85rem 1.6rem;
  color:var(--dark-paper);position:relative;overflow:hidden;
  transition:color .45s var(--ease),border-color .45s var(--ease);
}
.cform-submit::before{content:"";position:absolute;inset:0;background:var(--gold);transform:translateY(101%);transition:transform .55s var(--ease);z-index:0}
.cform-submit span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:.6rem}
.cform-submit svg{width:15px;height:15px}
.cform-submit:hover{color:var(--dark);border-color:var(--gold)}
.cform-submit:hover::before{transform:translateY(0)}
.cform-submit[disabled]{opacity:.55;pointer-events:none}
.cform-status{min-height:1.3em;font-family:var(--f-mono);font-size:.78rem;letter-spacing:.02em;color:rgba(236,234,230,0.6);margin-top:.2rem}
.cform-status.ok{color:var(--gold-soft)}
.cform-status.err{color:#E08A7D}
