/* ---- Swap in licensed brand fonts here ----
  @font-face{font-family:'Proxima Nova';src:url('assets/fonts/ProximaNova-Light.woff2') format('woff2');font-weight:300;font-display:swap}
  @font-face{font-family:'Proxima Nova';src:url('assets/fonts/ProximaNova-Regular.woff2') format('woff2');font-weight:400;font-display:swap}
  @font-face{font-family:'Proxima Nova';src:url('assets/fonts/ProximaNova-Medium.woff2') format('woff2');font-weight:500;font-display:swap}
  @font-face{font-family:'Proxima Nova';src:url('assets/fonts/ProximaNova-Semibold.woff2') format('woff2');font-weight:600;font-display:swap}
  @font-face{font-family:'Azo Sans';src:url('assets/fonts/AzoSans-Light.woff2') format('woff2');font-weight:300;font-display:swap}
  @font-face{font-family:'Azo Sans';src:url('assets/fonts/AzoSans-Regular.woff2') format('woff2');font-weight:400;font-display:swap}
  -------------------------------------------------- */
  :root{
    --black:#000;
    --white:#fff;
    --gray:#898989;        /* main gray tone */
    --silver:#a8a9ad;      /* alt gray / metallic */
    --charcoal:#0e0e0e;    /* panel fill on dark */
    --hair-l:rgba(0,0,0,.13);
    --hair-d:rgba(255,255,255,.15);
    --max:1280px;
    --gut:clamp(1.4rem,5vw,5rem);
    --sp:clamp(5.5rem,11vw,10.5rem);
    --proxima:'Proxima Nova','Hanken Grotesk',-apple-system,'Segoe UI',Arial,sans-serif;
    --azo:'Azo Sans','Jost','Hanken Grotesk',sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    background:var(--white);color:var(--black);
    font-family:var(--proxima);font-weight:400;line-height:1.6;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  ::selection{background:var(--black);color:var(--white)}
  .wrap{max-width:var(--max);margin:0 auto;padding-inline:var(--gut)}

  /* Greyfield angled / chamfered mark — silver */
  .mark{display:inline-block;width:34px;height:8px;background:var(--silver);
    clip-path:polygon(15% 0,100% 0,100% 100%,0 100%);vertical-align:middle}
  .mark.sm{width:24px;height:6px}

  .eyebrow{font-family:var(--azo);font-weight:400;font-size:.7rem;
    letter-spacing:.28em;text-transform:uppercase;color:var(--gray);
    display:flex;align-items:center;gap:.85rem}

  /* ---------------- Header ---------------- */
  header{position:fixed;top:0;left:0;right:0;z-index:60;
    transition:background .45s ease,box-shadow .45s ease;background:transparent}
  header.solid{background:var(--white);box-shadow:0 1px 0 var(--hair-l)}
  .nav{display:flex;align-items:center;justify-content:space-between;
    height:clamp(72px,8.5vw,94px)}
  .brand{display:flex;align-items:center;height:clamp(15px,1.8vw,19px)}
  .brand img{height:100%;width:auto;display:block}
  .brand .l-black{display:none}
  header.solid .brand .l-white{display:none}
  header.solid .brand .l-black{display:block}
  .nav-links{display:flex;gap:clamp(1.8rem,3vw,3rem);align-items:center}
  .nav-links a{font-family:var(--azo);font-size:.72rem;letter-spacing:.22em;
    text-transform:uppercase;color:rgba(255,255,255,.78);position:relative;
    padding:.4rem 0;transition:color .3s ease}
  header.solid .nav-links a{color:var(--gray)}
  .nav-links a::after{content:"";position:absolute;left:0;bottom:.02rem;height:1px;width:0;
    background:currentColor;transition:width .35s ease}
  .nav-links a:hover{color:var(--white)}
  header.solid .nav-links a:hover{color:var(--black)}
  .nav-links a:hover::after{width:100%}
  .menu-btn{display:none;background:none;border:0;cursor:pointer;font-family:var(--azo);
    font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#fff;padding:.4rem}
  header.solid .menu-btn{color:var(--black)}

  /* ---------------- Sections ---------------- */
  section{padding-block:var(--sp)}
  .dark{background:var(--black);color:var(--white)}
  .dark .eyebrow{color:var(--silver)}
  .seclabel{margin-bottom:clamp(2.4rem,5vw,4rem)}
  h1,h2,h3{font-family:var(--proxima);font-weight:300;letter-spacing:-.018em}

  /* ---------------- Hero (dark) ---------------- */
  .hero{padding-top:clamp(8rem,15vh,11rem);padding-bottom:var(--sp);
    min-height:100svh;display:flex;align-items:center}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;
    gap:clamp(2.5rem,6vw,6rem);align-items:center;width:100%}
  .hero h1{font-size:clamp(2.7rem,6.4vw,5rem);line-height:1.04;margin-top:1.7rem}
  .hero h1 .dim{color:var(--silver)}
  .hero .lead{margin-top:clamp(1.8rem,3vw,2.4rem);max-width:46ch;
    font-size:clamp(1rem,1.25vw,1.12rem);line-height:1.75;color:var(--silver)}
  .hero .down{margin-top:clamp(2.2rem,4vw,3rem);display:inline-flex;align-items:center;
    gap:.8rem;font-family:var(--azo);font-size:.72rem;letter-spacing:.24em;
    text-transform:uppercase;color:var(--white)}
  .hero .down .line{width:46px;height:1px;background:var(--silver);transition:width .35s ease}
  .hero .down:hover .line{width:72px}
  .hero-visual{position:relative;aspect-ratio:4/5;width:100%;background:var(--charcoal);
    overflow:hidden;border:1px solid var(--hair-d)}
  .hero-visual svg,.hero-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%}
  .panel-tag{position:absolute;left:1.3rem;bottom:1.2rem;font-family:var(--azo);
    font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--silver)}

  /* ---------------- About (light) ---------------- */
  .about-grid{display:grid;grid-template-columns:.42fr 1fr;gap:clamp(2rem,6vw,6rem);
    align-items:start}
  .lede{font-size:clamp(1.5rem,2.9vw,2.25rem);line-height:1.32;font-weight:300;
    letter-spacing:-.015em;max-width:24ch}
  .about-body{font-size:clamp(1rem,1.2vw,1.1rem);line-height:1.85;color:var(--gray);
    max-width:54ch}
  .about-body p+p{margin-top:1.35rem}

  /* ---------------- Approach (dark, sequence) ---------------- */
  .approach h2{font-size:clamp(2rem,4vw,3rem);line-height:1.08;margin-top:1.2rem;max-width:16ch}
  .steps{border-top:1px solid var(--hair-d);margin-top:clamp(2.5rem,5vw,3.5rem)}
  .step{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.4rem,4vw,3.5rem);
    align-items:start;padding:clamp(1.7rem,3vw,2.6rem) 0;border-bottom:1px solid var(--hair-d)}
  .step .num{font-family:var(--azo);font-weight:300;font-size:.78rem;letter-spacing:.12em;
    color:var(--silver);padding-top:.5rem}
  .step .sbody{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(.6rem,3vw,3rem);
    align-items:baseline}
  .step h3{font-size:clamp(1.4rem,2.4vw,1.95rem);line-height:1.15;font-weight:300;color:var(--white)}
  .step p{font-size:clamp(.96rem,1.1vw,1.04rem);line-height:1.7;color:var(--silver);max-width:42ch}

  /* ---------------- Asset classes (light list) ---------------- */
  .assets-list{border-top:1px solid var(--hair-l)}
  .arow{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.2rem,4vw,3.5rem);
    align-items:baseline;padding:clamp(1.6rem,3vw,2.4rem) 0;border-bottom:1px solid var(--hair-l)}
  .arow .amark{padding-top:.55rem}
  .arow .amark .mark{transition:width .4s ease}
  .arow:hover .amark .mark{width:50px}
  .arow .abody{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(.6rem,3vw,3rem);
    align-items:baseline}
  .arow h3{font-size:clamp(1.35rem,2.3vw,1.9rem);line-height:1.2;font-weight:400;
    letter-spacing:-.012em}
  .arow p{font-size:clamp(.95rem,1.1vw,1.02rem);line-height:1.7;color:var(--gray);max-width:44ch}

  /* ---------------- Work (dark gallery) ---------------- */
  .work h2{font-size:clamp(2rem,4vw,3rem);line-height:1.1;margin-top:1.2rem;max-width:18ch}
  .work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,2.5vw,2.2rem)}
  .proj .frame{aspect-ratio:4/3;background:var(--charcoal);overflow:hidden;position:relative;
    border:1px solid var(--hair-d)}
  .proj .frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  .proj .meta{display:flex;justify-content:space-between;align-items:baseline;
    margin-top:1rem;gap:1rem}
  .proj .meta .k{font-size:.82rem;letter-spacing:.01em;color:var(--white);font-weight:400}
  .proj .meta .s{font-family:var(--azo);font-size:.62rem;letter-spacing:.22em;
    text-transform:uppercase;color:var(--silver);white-space:nowrap}
  .work-note{margin-top:clamp(2.5rem,4vw,3.2rem);font-size:.84rem;letter-spacing:.02em;
    color:var(--silver);display:flex;align-items:center;gap:.85rem}

  /* ---------------- Contact (light) ---------------- */
  .contact-grid{display:grid;grid-template-columns:.8fr 1fr;gap:clamp(2.5rem,6vw,6rem);
    align-items:start}
  .contact h2{font-size:clamp(2.2rem,4.5vw,3.4rem);line-height:1.06;margin-top:1.2rem}
  .contact .intro{margin-top:1.5rem;font-size:clamp(1rem,1.2vw,1.1rem);line-height:1.75;
    color:var(--gray);max-width:38ch}
  .contact-list{border-top:1px solid var(--hair-l)}
  .crow{display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:baseline;
    padding:clamp(1.3rem,2.4vw,1.9rem) 0;border-bottom:1px solid var(--hair-l)}
  .crow .lbl{font-family:var(--azo);font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;
    color:var(--silver);padding-top:.4rem}
  .crow .val{font-size:clamp(1.25rem,2.1vw,1.65rem);font-weight:300;letter-spacing:-.01em}
  .crow .val.muted{color:var(--silver)}
  a.email{position:relative;display:inline-block}
  a.email::after{content:"";position:absolute;left:0;bottom:.06em;height:1px;width:0;
    background:var(--black);transition:width .4s ease}
  a.email:hover::after{width:100%}

  /* ---------------- Footer (dark) ---------------- */
  footer{background:var(--black);color:var(--white)}
  .foot{padding-block:clamp(3.5rem,6vw,5rem);display:grid;grid-template-columns:1fr auto;
    gap:2.5rem;align-items:end}
  .foot img{height:18px;width:auto;margin-bottom:1.5rem}
  .foot .flines{font-size:.84rem;letter-spacing:.02em;line-height:1.9;color:var(--silver)}
  .foot .flines strong{color:var(--white);font-weight:400}
  .foot .copy{font-family:var(--azo);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--gray);text-align:right}

  /* ---------------- reveal ---------------- */
  .reveal{opacity:0;transform:translateY(18px);
    transition:opacity .9s cubic-bezier(.2,.6,.2,1),transform .9s cubic-bezier(.2,.6,.2,1)}
  .reveal.in{opacity:1;transform:none}

  /* ---------------- responsive ---------------- */
  @media(max-width:900px){
    .hero{min-height:auto;padding-top:clamp(7rem,18vh,9rem)}
    .hero-grid{grid-template-columns:1fr;gap:clamp(2.5rem,8vw,4rem)}
    .hero-visual{aspect-ratio:16/13;order:2}.hero-copy{order:1}
    .about-grid{grid-template-columns:1fr;gap:1.6rem}
    .step .sbody{grid-template-columns:1fr;gap:.55rem}
    .arow{grid-template-columns:1fr}.arow .amark{display:none}
    .arow .abody{grid-template-columns:1fr;gap:.55rem}
    .work-grid{grid-template-columns:1fr;gap:2.5rem}.proj .frame{aspect-ratio:16/11}
    .contact-grid{grid-template-columns:1fr;gap:2rem}
    .foot{grid-template-columns:1fr}.foot .copy{text-align:left}
  }
  @media(max-width:620px){
    .nav-links{display:none}.menu-btn{display:block}
    .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
      align-items:flex-start;gap:0;padding:.4rem var(--gut) 1.4rem}
    header:not(.solid) .nav-links.open{background:var(--black);border-bottom:1px solid var(--hair-d)}
    header.solid .nav-links.open{background:var(--white);border-bottom:1px solid var(--hair-l)}
    .nav-links.open a{padding:.85rem 0;font-size:.8rem}
    .brand{height:auto;max-width:60vw}
    .brand img{height:auto;width:100%}
  }
  @media(prefers-reduced-motion:reduce){
    *{scroll-behavior:auto!important}
    .reveal{opacity:1;transform:none;transition:none}
  }
  :focus-visible{outline:2px solid var(--silver);outline-offset:3px}
