/* ───────────────── Reset & Tokens ───────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#f5f0eb;
  --bg2:#eee8e0;
  --fg:#1a1816;
  --fg2:#5c564e;
  --accent:#c8552d;
  --accent2:#e07645;
  --warm:#d4a86a;
  --light:#faf6f2;
  --radius:12px;
  --font-sans:'DM Sans',system-ui,sans-serif;
  --font-serif:'Instrument Serif',Georgia,serif;
  --font-mono:'Space Mono',monospace;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --ease-out:cubic-bezier(.16,1,.3,1);
}
html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased}
body{
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--fg);
  line-height:1.6;
  overflow-x:hidden;
  cursor:none;
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
strong{font-weight:600}
mark{background:linear-gradient(120deg,rgba(200,85,45,.15) 0%,rgba(200,85,45,.15) 100%);color:var(--accent);
  padding:0 4px;border-radius:3px;font-weight:600}
::selection{background:var(--accent);color:#fff}
.serif-italic{font-family:var(--font-serif);font-style:italic;font-weight:400}
.container{max-width:1200px;margin:0 auto;padding:0 clamp(20px,5vw,80px)}

/* ─── Custom Cursor ─── */
.custom-cursor{pointer-events:none;position:fixed;z-index:9999;top:0;left:0;mix-blend-mode:difference}
.cursor-dot{width:6px;height:6px;background:#fff;border-radius:50%;position:absolute;transform:translate(-50%,-50%);transition:transform .15s var(--ease)}
.cursor-ring{width:40px;height:40px;border:1.5px solid rgba(255,255,255,.5);border-radius:50%;position:absolute;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease)}
body:hover .cursor-ring{}
a:hover ~ .custom-cursor .cursor-ring,
button:hover ~ .custom-cursor .cursor-ring{width:56px;height:56px}

@media(pointer:coarse){
  .custom-cursor{display:none}
  body{cursor:auto}
}

/* ─── Loader ─── */
.loader{position:fixed;inset:0;z-index:10000;background:var(--fg);display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease),visibility .6s}
.loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{text-align:center}
.loader-line{width:60px;height:2px;background:var(--accent);margin:0 auto 24px;transform-origin:left;animation:loaderBar 1.5s var(--ease-out) forwards}
@keyframes loaderBar{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.loader-text{color:var(--bg);font-family:var(--font-serif);font-style:italic;font-size:clamp(1rem,2vw,1.25rem);letter-spacing:.04em;opacity:0;animation:loaderFade .6s .3s forwards}
@keyframes loaderFade{to{opacity:1}}

/* ─── Header ─── */
.header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px clamp(20px,5vw,80px);background:rgba(245,240,235,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(26,24,22,.06);transition:transform .4s var(--ease)}
.header.hidden{transform:translateY(-100%)}
.header-name{font-family:var(--font-serif);font-size:1.2rem;letter-spacing:.02em}
.header-nav{display:flex;gap:32px}
.header-link{font-size:.85rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--fg2);position:relative;transition:color .3s}
.header-link::before{content:attr(data-index);position:absolute;top:-10px;left:0;font-family:var(--font-mono);font-size:.55rem;color:var(--accent);opacity:0;transform:translateY(4px);transition:all .3s var(--ease)}
.header-link:hover{color:var(--fg)}
.header-link:hover::before{opacity:1;transform:translateY(0)}
.menu-btn{display:none;background:none;border:none;cursor:none;width:28px;height:20px;position:relative}
.menu-line{display:block;width:100%;height:2px;background:var(--fg);position:absolute;left:0;transition:.3s var(--ease)}
.menu-line:first-child{top:0}
.menu-line:last-child{bottom:0}
.menu-btn.open .menu-line:first-child{top:50%;transform:translateY(-50%) rotate(45deg)}
.menu-btn.open .menu-line:last-child{bottom:50%;transform:translateY(50%) rotate(-45deg)}

@media(max-width:768px){
  .header-nav{display:none}
  .menu-btn{display:block}
}

/* ─── Mobile Nav ─── */
.mobile-nav{position:fixed;inset:0;z-index:99;background:var(--fg);display:flex;flex-direction:column;justify-content:center;padding:60px 40px;opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s}
.mobile-nav.open{opacity:1;visibility:visible}
.mobile-link{display:block;font-family:var(--font-serif);font-style:italic;font-size:clamp(2rem,8vw,4rem);color:var(--bg);margin-bottom:16px;transform:translateY(30px);opacity:0;transition:transform .5s var(--ease-out),opacity .5s var(--ease-out)}
.mobile-nav.open .mobile-link{transform:translateY(0);opacity:1}
.mobile-nav.open .mobile-link:nth-child(1){transition-delay:.1s}
.mobile-nav.open .mobile-link:nth-child(2){transition-delay:.15s}
.mobile-nav.open .mobile-link:nth-child(3){transition-delay:.2s}
.mobile-nav.open .mobile-link:nth-child(4){transition-delay:.25s}
.mobile-nav.open .mobile-link:nth-child(5){transition-delay:.3s}
.mobile-nav-footer{margin-top:auto;display:flex;gap:24px}
.mobile-nav-footer a{color:var(--bg);opacity:.5;font-size:.85rem}

/* ─── Hero ─── */
.hero{min-height:100vh;display:flex;align-items:flex-end;padding:160px clamp(20px,5vw,80px) 80px;gap:60px}
.hero-content{flex:1.4}
.hero-side{flex:.6;display:flex;flex-direction:column;gap:16px;padding-bottom:12px}
.hero-overline{display:flex;align-items:center;gap:10px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:24px}
.overline-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-h1{font-family:var(--font-serif);font-weight:400;font-size:clamp(3rem,7.5vw,7rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:40px}
.hero-line{display:block}
.hero-stroke{-webkit-text-stroke:1.5px var(--fg);color:transparent;transition:color .4s}
.hero-stroke:hover{color:var(--fg)}
.hero-footer{max-width:480px}
.hero-p{font-size:1.05rem;color:var(--fg2);margin-bottom:28px;line-height:1.7}
.hero-cta-row{display:flex;align-items:center;gap:24px}
.cta-pill{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border:1.5px solid var(--fg);border-radius:100px;font-size:.9rem;font-weight:600;transition:all .35s var(--ease)}
.cta-pill:hover{background:var(--fg);color:var(--bg)}
.cta-pill svg{transition:transform .3s var(--ease)}
.cta-pill:hover svg{transform:translate(3px,-3px)}
.cta-text{font-size:.9rem;font-weight:600;color:var(--fg2);position:relative}
.cta-text::after{content:'';position:absolute;bottom:-2px;left:0;width:100%;height:1.5px;background:var(--fg2);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease)}
.cta-text:hover::after{transform:scaleX(1);transform-origin:left}

.hero-card{padding:20px 24px;background:var(--light);border:1px solid rgba(26,24,22,.06);border-radius:var(--radius);transition:transform .3s var(--ease),box-shadow .3s}
.hero-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(26,24,22,.06)}
.hero-card-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--fg2);margin-bottom:4px}
.hero-card-value{display:block;font-family:var(--font-serif);font-size:1.3rem;margin-bottom:2px}
.hero-card-sub{display:block;font-size:.8rem;color:var(--fg2)}

@media(max-width:900px){
  .hero{flex-direction:column;align-items:stretch;min-height:auto;padding-top:140px;gap:40px}
  .hero-side{flex-direction:row;flex-wrap:wrap}
  .hero-card{flex:1;min-width:140px}
}

/* ─── Ticker ─── */
.ticker{overflow:hidden;padding:24px 0;border-top:1px solid rgba(26,24,22,.08);border-bottom:1px solid rgba(26,24,22,.08);background:var(--light)}
.ticker-track{display:flex;gap:0;width:max-content;animation:ticker 25s linear infinite}
.ticker-track span{font-family:var(--font-serif);font-style:italic;font-size:clamp(1rem,2vw,1.4rem);color:var(--fg);white-space:nowrap;padding:0 12px}
.ticker-sep{color:var(--warm) !important;font-style:normal !important}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ─── Section Shared ─── */
.section-grid{display:grid;grid-template-columns:.35fr .65fr;gap:60px;max-width:1200px;margin:0 auto;padding:120px clamp(20px,5vw,80px)}
.section-tag{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);letter-spacing:.05em;display:block;margin-bottom:12px}
.section-h2{font-family:var(--font-serif);font-weight:400;font-size:clamp(2rem,4vw,3.5rem);line-height:1.15}
.section-header{margin-bottom:60px}
.section-header .section-tag{margin-bottom:12px}
.section-header .section-h2{max-width:600px}

@media(max-width:768px){
  .section-grid{grid-template-columns:1fr;gap:32px;padding:80px 20px}
}

/* ─── About ─── */
.about{background:var(--light)}
.big-text{font-size:clamp(1.15rem,2vw,1.45rem);line-height:1.65;color:var(--fg);margin-bottom:20px}
.body-text{font-size:1rem;color:var(--fg2);line-height:1.75;margin-bottom:40px}
.stat-row{display:flex;gap:40px;flex-wrap:wrap}
.stat-block{display:flex;flex-direction:column}
.stat-num{font-family:var(--font-serif);font-size:clamp(2.5rem,5vw,3.5rem);line-height:1;color:var(--accent)}
.stat-suffix{font-family:var(--font-serif);font-size:clamp(1.5rem,3vw,2rem);color:var(--accent);margin-left:2px}
.stat-unit{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--fg2);margin-top:6px}

/* ─── Work ─── */
.work{padding:120px 0}
.work-list{display:flex;flex-direction:column;gap:0}
.work-item{padding:40px 0;border-top:1px solid rgba(26,24,22,.1)}
.work-item:last-child{border-bottom:1px solid rgba(26,24,22,.1)}
.work-top{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;flex-wrap:wrap}
.work-role{font-family:var(--font-serif);font-size:clamp(1.3rem,2.5vw,1.8rem);margin-bottom:4px}
.work-company{font-size:.9rem;color:var(--fg2);font-weight:500}
.work-right{text-align:right}
.work-period{font-family:var(--font-mono);font-size:.8rem;display:block;margin-bottom:4px}
.work-loc{font-size:.8rem;color:var(--fg2)}
.work-points{margin-bottom:16px}
.work-points li{position:relative;padding-left:20px;font-size:.95rem;color:var(--fg2);margin-bottom:8px;line-height:1.6}
.work-points li::before{content:'—';position:absolute;left:0;color:var(--warm)}
.work-tags{display:flex;gap:8px;flex-wrap:wrap}
.work-tags span{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:6px 14px;background:var(--bg2);border-radius:100px;color:var(--fg2)}

/* ─── Skills ─── */
.skills{padding:120px 0;background:var(--light)}
.skills-mosaic{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.mosaic-col{display:flex;flex-direction:column;gap:20px}
.mosaic-card{padding:32px;border-radius:var(--radius);background:var(--bg);border:1px solid rgba(26,24,22,.06);transition:transform .3s var(--ease),box-shadow .3s}
.mosaic-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(26,24,22,.06)}
.mosaic-card h4{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--fg2);margin-bottom:16px;font-weight:600}
.mosaic-card.mosaic-accent{background:var(--fg);color:var(--bg)}
.mosaic-card.mosaic-accent h4{color:rgba(245,240,235,.6)}
.mosaic-card.mosaic-warm{background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);color:#fff}
.mosaic-card.mosaic-warm h4{color:rgba(255,255,255,.7)}
.mosaic-list{display:flex;flex-wrap:wrap;gap:8px}
.mosaic-chip{font-size:.85rem;padding:8px 16px;border-radius:100px;background:rgba(26,24,22,.06);font-weight:500;transition:transform .2s var(--ease)}
.mosaic-chip:hover{transform:scale(1.05)}
.mosaic-card.mosaic-accent .mosaic-chip{background:rgba(245,240,235,.1);color:var(--bg)}
.mosaic-card.mosaic-warm .mosaic-chip{background:rgba(255,255,255,.2);color:#fff}
.mosaic-chip-main{font-weight:700}
.mosaic-card.mosaic-accent .mosaic-chip-main{background:var(--accent);color:#fff}
.mosaic-card.mosaic-warm .mosaic-chip-main{background:rgba(255,255,255,.35)}

@media(max-width:768px){
  .skills-mosaic{grid-template-columns:1fr}
}

/* ─── Projects ─── */
.projects{padding:120px 0}
.project-stack{display:flex;flex-direction:column;gap:0}
.project-block{display:block;border-top:1px solid rgba(26,24,22,.1);transition:background .35s var(--ease)}
.project-block:last-child{border-bottom:1px solid rgba(26,24,22,.1)}
.project-block:hover{background:var(--light)}
.project-block-inner{display:flex;align-items:flex-start;gap:24px;padding:48px 0}
.project-index{font-family:var(--font-mono);font-size:.8rem;color:var(--accent);padding-top:8px;flex-shrink:0}
.project-main{flex:1}
.project-title{font-family:var(--font-serif);font-size:clamp(1.4rem,3vw,2.2rem);line-height:1.2;margin-bottom:12px;transition:color .3s}
.project-block:hover .project-title{color:var(--accent)}
.project-blurb{font-size:.95rem;color:var(--fg2);line-height:1.65;max-width:560px;margin-bottom:16px}
.project-chips{display:flex;gap:8px;flex-wrap:wrap}
.project-chips span{font-size:.73rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:5px 12px;border:1px solid rgba(26,24,22,.12);border-radius:100px;color:var(--fg2)}
.project-end{display:flex;flex-direction:column;align-items:flex-end;gap:12px;flex-shrink:0;padding-top:8px}
.project-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);padding:4px 12px;background:rgba(200,85,45,.08);border-radius:100px}
.project-arrow{transition:transform .35s var(--ease)}
.project-block:hover .project-arrow{transform:translate(4px,-4px)}

@media(max-width:600px){
  .project-block-inner{flex-direction:column;gap:12px;padding:36px 0}
  .project-end{flex-direction:row;align-items:center}
}

/* ─── Credentials ─── */
.credentials{background:var(--bg)}
.cred-list{display:flex;flex-direction:column;gap:0}
.cred-item{display:flex;align-items:flex-start;gap:16px;padding:24px 0;border-bottom:1px solid rgba(26,24,22,.08)}
.cred-marker{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid rgba(26,24,22,.1);color:var(--accent)}
.cred-body{flex:1}
.cred-body h4{font-family:var(--font-serif);font-size:1.1rem;margin-bottom:2px}
.cred-body p{font-size:.85rem;color:var(--fg2)}
.cred-year{font-family:var(--font-mono);font-size:.75rem;color:var(--fg2);flex-shrink:0;padding-top:4px}

/* ─── Contact ─── */
.contact{padding:140px 0 100px;text-align:center;background:var(--fg);color:var(--bg)}
.contact .section-tag{color:var(--warm)}
.contact-h2{font-family:var(--font-serif);font-weight:400;font-size:clamp(2.5rem,6vw,5rem);line-height:1.1;margin:16px 0 24px}
.contact-sub{font-size:1.05rem;color:rgba(245,240,235,.6);max-width:460px;margin:0 auto 48px}
.contact-big-link{display:inline-block;font-family:var(--font-serif);font-style:italic;font-size:clamp(1.2rem,3vw,2rem);color:var(--accent2);border-bottom:2px solid transparent;transition:border-color .3s}
.contact-big-link:hover{border-color:var(--accent2)}
.contact-row{display:flex;justify-content:center;align-items:center;gap:16px;margin:24px 0 40px;font-size:.9rem;color:rgba(245,240,235,.5)}
.contact-dot{width:4px;height:4px;border-radius:50%;background:rgba(245,240,235,.3)}
.contact-socials{display:flex;justify-content:center;gap:32px}
.contact-socials a{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgba(245,240,235,.5);transition:color .3s}
.contact-socials a:hover{color:var(--bg)}

/* ─── Footer ─── */
.site-footer{background:var(--fg);border-top:1px solid rgba(245,240,235,.06);padding:24px 0}
.footer-grid{display:flex;justify-content:space-between;font-size:.8rem;color:rgba(245,240,235,.3)}

/* ─── Animations ─── */
.anim-slide{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.anim-slide.visible{opacity:1;transform:translateY(0)}
.anim-reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.anim-reveal.visible{opacity:1;transform:translateY(0)}

/* ─── Grain Overlay ─── */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:200px}

/* ─── Smooth scroll offset ─── */
section[id]{scroll-margin-top:80px}
