:root{
  --ink:#151513;
  --paper:#f4f3ee;
  --paper-2:#e9e7df;
  --red:#e5241b;
  --red-dark:#bf1c14;
  --ink-soft:#57554f;
  --line:#1a1a18;
  --line-soft:#d6d3c9;
  --on-dark:#f4f3ee;
  --on-dark-soft:#a6a39a;
  --wrapper-padding:4.5rem;   /* generous vertical rhythm via content-wrapper */
}
html{scroll-behavior:smooth;scroll-padding-top:5rem}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{background:var(--paper);color:var(--ink);font-family:"Hanken Grotesk",system-ui,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit}
h1,h2,h3,.display{font-family:"Bricolage Grotesque",sans-serif}

/* header (fixed chrome, deliberately not a content-wrapper section) */
header.site{position:sticky;top:0;z-index:30;background:var(--paper);border-bottom:2px solid var(--ink)}
.bar{display:flex;align-items:center;justify-content:space-between;height:4.5rem;position:relative}
.wordmark{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.25rem;letter-spacing:-.03em;text-decoration:none}
.wordmark .dot{color:var(--red)}
nav.primary{display:flex;gap:1.75rem;align-items:center}
nav.primary a{text-decoration:none;font-weight:600;font-size:.9rem}
nav.primary a:hover{color:var(--red)}
nav.primary .res{border:2px solid var(--ink);padding:.4rem .85rem;font-weight:700}
nav.primary .res:hover{background:var(--ink);color:var(--paper)}

/* mobile nav toggle */
.nav-toggle{display:none;width:2.75rem;height:2.75rem;align-items:center;justify-content:center;border:2px solid var(--ink);background:var(--paper);cursor:pointer;padding:0}
.nav-toggle .bars,.nav-toggle .bars::before,.nav-toggle .bars::after{display:block;width:1.3rem;height:2px;background:var(--ink);transition:transform .2s ease, opacity .2s ease}
.nav-toggle .bars{position:relative}
.nav-toggle .bars::before{content:"";position:absolute;left:0;top:-6px}
.nav-toggle .bars::after{content:"";position:absolute;left:0;top:6px}
.nav-toggle[aria-expanded="true"] .bars{background:transparent}
.nav-toggle[aria-expanded="true"] .bars::before{transform:translateY(6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bars::after{transform:translateY(-6px) rotate(-45deg)}
@media(prefers-reduced-motion:reduce){.nav-toggle .bars,.nav-toggle .bars::before,.nav-toggle .bars::after{transition:none}}

@media(max-width:760px){
  .nav-toggle{display:inline-flex}
  nav.primary{display:none;position:absolute;top:calc(100% + 2px);right:0;flex-direction:column;align-items:stretch;gap:0;min-width:12rem;background:var(--paper);border:2px solid var(--ink);padding:.4rem;z-index:40;box-shadow:6px 6px 0 var(--red)}
  nav.primary.open{display:flex}
  nav.primary a{padding:.8rem 1rem;font-size:1rem}
  nav.primary a:not(:last-child){border-bottom:1px solid var(--line-soft)}
  nav.primary .res{border:none;text-align:center;background:var(--ink);color:var(--paper);margin-top:.4rem;padding:.85rem 1rem}
  nav.primary .res:hover{background:var(--red);color:#fff}
}

/* hero */
.hero .eyebrow{font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft)}
.hero .eyebrow b{color:var(--ink)}
.hero h1{font-weight:800;font-size:clamp(3.2rem,11vw,8.5rem);line-height:.92;letter-spacing:-.04em;margin-top:1.5rem;max-width:14ch}
.hero h1 .hl{position:relative;white-space:nowrap;color:var(--red)}
.hero p.lede{font-size:1.3rem;max-width:46ch;margin-top:2rem;color:var(--ink-soft)}
.hero p.lede b{color:var(--ink);font-weight:600}
.hero-actions{margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.btn{display:inline-block;text-decoration:none;font-weight:700;font-size:1rem;padding:.95rem 1.6rem;background:var(--ink);color:var(--paper)}
.btn:hover{background:var(--red)}
.btn.ghost{background:transparent;color:var(--ink);border:2px solid var(--ink);padding:calc(.95rem - 2px) calc(1.6rem - 2px)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.hero-links{margin-top:2.25rem;display:flex;gap:1.5rem;flex-wrap:wrap}
.hero-links a{font-weight:600;font-size:.92rem;text-decoration:none;border-bottom:2px solid var(--red);padding-bottom:2px}
.hero-links a:hover{color:var(--red)}

/* section scaffolding (background + border live here; padding comes from content-wrapper) */
.section{border-top:2px solid var(--ink)}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem}
.section-head h2{font-weight:800;font-size:clamp(2rem,4.5vw,3.2rem);letter-spacing:-.03em;line-height:1}

/* work */
.work-card{border:2px solid var(--ink);background:var(--paper);padding:2rem;height:100%;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .15s, box-shadow .15s}
.work-card:hover{transform:translate(-4px,-4px);box-shadow:8px 8px 0 var(--red)}
.work-cat{font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--red-dark)}
.work-card h3{font-weight:800;font-size:1.85rem;letter-spacing:-.02em;margin-top:.5rem;line-height:1.02}
.work-card p{color:var(--ink-soft);margin-top:.9rem;font-size:1.02rem}
.work-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1.4rem}
.work-tags span{font-weight:600;font-size:.74rem;border:1.5px solid var(--line-soft);padding:.25rem .6rem}
.work-go{margin-top:1.6rem;font-weight:700;font-size:.95rem;display:inline-flex;align-items:center;gap:.4rem}
.work-card:hover .work-go{color:var(--red-dark)}

/* skills (dark full-bleed band) */
.skills{background:var(--ink);color:var(--on-dark);border-top:2px solid var(--ink)}
.skills h2{font-weight:800;font-size:clamp(2rem,4.5vw,3.2rem);letter-spacing:-.03em;line-height:1;margin-bottom:2.25rem}
.chips{display:flex;flex-wrap:wrap;gap:.6rem}
.chips span{border:1.5px solid #3a3a36;padding:.5rem .95rem;font-weight:600;font-size:.95rem;color:var(--on-dark)}
.chips span:hover{border-color:var(--red);color:#fff}

/* about */
.about p{font-size:1.1rem}
.about .narrative p{max-width:54ch}
.about .narrative p + p{margin-top:1.1rem}
.about h3{font-weight:700;font-size:1.3rem;letter-spacing:-.01em;margin-top:2rem}
.about .meta{font-weight:600;color:var(--red-dark);font-size:.95rem;text-transform:uppercase;letter-spacing:.06em}
.enjoy{border:2px solid var(--ink);padding:1.75rem}
.enjoy h3{margin-top:0;font-family:"Bricolage Grotesque";font-weight:800;font-size:1.2rem}
.enjoy ul{list-style:none;margin:1rem 0 0;padding:0}
.enjoy li{padding:.55rem 0;border-bottom:1px solid var(--line-soft);font-weight:500}
.enjoy li:last-child{border-bottom:none}
.enjoy li::before{content:"—";color:var(--red);font-weight:700;margin-right:.6rem}

/* contact (red full-bleed band, extra vertical room) */
.contact{background:var(--red);color:#fff;border-top:2px solid var(--ink);--wrapper-padding:6rem}
.contact h2{font-weight:800;font-size:clamp(2.4rem,6vw,4.5rem);letter-spacing:-.03em;line-height:.98;max-width:16ch}
.contact p{font-size:1.25rem;max-width:42ch;margin-top:1.5rem;color:#ffdfdc}
.contact-actions{margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap}
.contact .btn{background:#fff;color:var(--red)}
.contact .btn:hover{background:var(--ink);color:#fff}
.contact .btn.ghost{background:transparent;color:#fff;border:2px solid #fff}
.contact .btn.ghost:hover{background:#fff;color:var(--red)}

/* footer (fixed chrome) */
footer{background:var(--ink);color:var(--on-dark-soft);padding:2.5rem 0}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-weight:500;font-size:.9rem}
footer a{color:var(--on-dark);text-decoration:none;border-bottom:2px solid var(--red);padding-bottom:1px}
.foot .links{display:flex;gap:1.25rem}
