:root{
    --ground:#F0F1EC;      /* alpine fog */
    --ink:#20241F;         /* granite */
    --pine:#44523F;        /* pine */
    --lichen:#97A18A;      /* lichen */
    --hairline:#CDD1C6;
    --display:'Italiana', serif;
    --body:'Jost', sans-serif;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    background:var(--ground);
    color:var(--ink);
    font-family:var(--body);
    font-weight:300;
    line-height:1.65;
    -webkit-font-smoothing:antialiased;
  }
  ::selection{background:var(--pine);color:var(--ground)}
  img{display:block;width:100%;height:100%;object-fit:cover}
  a{color:inherit;text-decoration:none}

  /* ---------- nav ---------- */
  nav{
    position:fixed;top:0;left:0;right:0;z-index:50;
    display:flex;justify-content:space-between;align-items:center;
    padding:1.4rem 4vw;
    mix-blend-mode:darken;
  }
  .wordmark{font-family:var(--display);font-size:1.6rem;letter-spacing:.32em;padding-left:.32em}
  nav ul{display:flex;gap:2.4rem;list-style:none}
  nav ul a{
    font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;
    position:relative;padding-bottom:3px;
  }
  nav ul a::after{
    content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--ink);
    transition:width .35s ease;
  }
  nav ul a:hover::after,nav ul a:focus-visible::after{width:100%}
  a:focus-visible{outline:1px solid var(--pine);outline-offset:4px}

  /* ---------- hero ---------- */
  header{
    position:relative;height:100svh;min-height:580px;
    display:flex;flex-direction:column;justify-content:center;align-items:center;
    overflow:hidden;text-align:center;
  }
  .contours{
    position:absolute;inset:-12%;width:124%;height:124%;
    opacity:.5;
  }
  .contours path{
    fill:none;stroke:var(--lichen);stroke-width:1;
    vector-effect:non-scaling-stroke;
  }
  @keyframes drift{
    from{transform:translate3d(0,0,0)}
    to{transform:translate3d(-2.4%,1.6%,0)}
  }
  .contours{animation:drift 26s ease-in-out infinite alternate}

  .hero-mark{
    position:relative;
    font-family:var(--display);
    font-size:clamp(3.2rem,11.5vw,9.5rem);
    letter-spacing:.14em;padding-left:.14em;white-space:nowrap;
    line-height:1;color:var(--ink);
  }
  .hero-sub{
    position:relative;margin-top:1.6rem;
    font-size:clamp(.78rem,1.4vw,.95rem);
    letter-spacing:.34em;text-transform:uppercase;color:var(--pine);
  }
  .hero-loc{
    position:relative;margin-top:.9rem;
    font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--lichen);
  }
  .hero-down{
    position:absolute;bottom:2.4rem;left:50%;transform:translateX(-50%);
    font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--lichen);
  }
  @keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
  .hero-mark{animation:rise 1.1s .15s cubic-bezier(.2,.7,.2,1) both}
  .hero-sub{animation:rise 1.1s .4s cubic-bezier(.2,.7,.2,1) both}
  .hero-loc{animation:rise 1.1s .55s cubic-bezier(.2,.7,.2,1) both}

  /* ---------- shared section bones ---------- */
  section{padding:9rem 6vw}
  .eyebrow{
    font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--lichen);
    display:flex;align-items:center;gap:1.2rem;margin-bottom:3rem;
  }
  .eyebrow::after{content:'';flex:1;height:1px;background:var(--hairline)}

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

  /* ---------- statement ---------- */
  .statement{max-width:880px;margin:0 auto}
  .statement h2{
    font-family:var(--display);font-weight:400;
    font-size:clamp(1.9rem,4.4vw,3.4rem);line-height:1.3;letter-spacing:.02em;
  }
  .statement h2 em{font-style:normal;color:var(--pine)}
  .statement p{margin-top:2.4rem;max-width:560px;font-size:1.02rem;color:#3c4138}
  .materials{
    margin-top:3.6rem;display:flex;flex-wrap:wrap;gap:0;
    border-top:1px solid var(--hairline);
  }
  .materials span{
    flex:1;min-width:130px;padding:1.1rem 0;
    font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--pine);
    border-bottom:1px solid var(--hairline);text-align:left;
  }

  /* ---------- work ---------- */
  .project{
    display:grid;grid-template-columns:1fr 1fr;gap:5vw;align-items:end;
    margin-bottom:8.5rem;
  }
  .project:last-child{margin-bottom:0}
  .project.flip .p-media{order:2}
  .p-media{
    position:relative;overflow:hidden;
    aspect-ratio:4/3;background:var(--hairline);
  }
  .project.wide{grid-template-columns:1fr;gap:2.4rem}
  .project.wide .p-media{aspect-ratio:21/9}
  .p-media img{transition:transform 1.4s cubic-bezier(.2,.7,.2,1)}
  .p-media:hover img{transform:scale(1.035)}
  .p-meta .p-index{
    font-size:.7rem;letter-spacing:.3em;color:var(--lichen);text-transform:uppercase;
  }
  .p-meta h3{
    font-family:var(--display);font-weight:400;
    font-size:clamp(1.7rem,3.4vw,2.6rem);letter-spacing:.03em;line-height:1.15;
    margin:.7rem 0 .35rem;
  }
  .p-meta .p-loc{
    font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--pine);
  }
  .p-meta p{margin-top:1.4rem;max-width:46ch;font-size:.96rem;color:#3c4138}
  .p-strip{
    display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.6rem;
  }
  .p-strip .p-media{aspect-ratio:1/1}

  /* ---------- studio ---------- */
  .studio-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:5vw;max-width:1100px;
  }
  .person{border-top:1px solid var(--ink);padding-top:1.6rem}
  .person h3{font-family:var(--display);font-weight:400;font-size:1.9rem;letter-spacing:.04em}
  .person .where{
    margin-top:.3rem;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--pine);
  }
  .person p{margin-top:1.3rem;font-size:.94rem;color:#3c4138;max-width:42ch}
  .studio-note{
    margin-top:5rem;max-width:680px;
    font-family:var(--display);font-size:clamp(1.3rem,2.6vw,1.9rem);line-height:1.45;color:var(--pine);
  }

  /* ---------- contact / footer ---------- */
  footer{
    position:relative;background:var(--ink);color:var(--ground);
    padding:8rem 6vw 3rem;overflow:hidden;
  }
  footer .contours{opacity:.18;animation:none}
  footer .contours path{stroke:var(--lichen)}
  .f-inner{position:relative;max-width:1100px}
  footer .eyebrow{color:var(--lichen)}
  footer .eyebrow::after{background:#3a4036}
  footer h2{
    font-family:var(--display);font-weight:400;
    font-size:clamp(2.2rem,6vw,4.6rem);line-height:1.15;letter-spacing:.02em;max-width:18ch;
  }
  .f-link{
    display:inline-block;margin-top:2.6rem;
    font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;
    border-bottom:1px solid var(--lichen);padding-bottom:.5rem;color:var(--ground);
    transition:color .3s,border-color .3s;
  }
  .f-link:hover{color:var(--lichen)}
  .f-base{
    position:relative;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
    margin-top:6rem;padding-top:1.6rem;border-top:1px solid #3a4036;
    font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:#8b9183;
  }

  @media (max-width:760px){
    nav ul{gap:1.3rem}
    nav ul a{font-size:.62rem;letter-spacing:.16em}
    section{padding:6rem 6vw}
    .project,.studio-grid{grid-template-columns:1fr;gap:1.8rem}
    .project.flip .p-media{order:0}
    .project{margin-bottom:5.5rem}
    .p-strip{grid-template-columns:repeat(3,1fr);gap:.7rem}
  }
  @media (prefers-reduced-motion:reduce){
    *,.contours{animation:none!important;transition:none!important}
    .reveal{opacity:1;transform:none}
    html{scroll-behavior:auto}
  }


/* ---------- WordPress compatibility ---------- */
body.admin-bar nav{top:32px}
@media (max-width:782px){ body.admin-bar nav{top:46px} }
.statement .wp-block-image img{height:auto}
