
  :root{
    --bg:#0C1108;
    --paper:#161C0D;
    --ink:#EDE5D6;
    --mute:#9A9080;
    --line:rgba(237,229,214,.13);
    --accent:#A87640;
    --accent-2:#C49460;
    --serif:'Cormorant Garamond',Georgia,serif;
    --sans:'Inter Tight',system-ui,-apple-system,sans-serif;
    --ease:cubic-bezier(.22,.61,.36,1);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;overflow-x:hidden;max-width:100vw}
  body{
    font-family:var(--sans);color:var(--ink);background:var(--bg);
    font-weight:400;line-height:1.55;font-size:15.5px;letter-spacing:.005em;
    -webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100vw;position:relative;
  }
  ::selection{background:var(--accent);color:var(--bg)}
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  button{font:inherit;cursor:pointer;border:0;background:0;color:inherit}
  p{color:var(--ink);opacity:.85}

  /* type */
  .eyebrow{font-size:10.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);font-weight:500}
  h1,h2,h3,h4{font-family:var(--serif);font-weight:300;letter-spacing:-.02em;line-height:.98}
  em{font-style:italic;font-weight:400}
  .wrap{max-width:1560px;margin:0 auto;padding:0 40px}
  @media(max-width:760px){.wrap{padding:0 22px}}

  /* nav */
  .nav{
    position:fixed;top:0;left:0;right:0;z-index:60;
    padding:22px 40px;
    display:flex;align-items:center;justify-content:space-between;
    transition:background .5s var(--ease),backdrop-filter .5s var(--ease),padding .35s;
  }
  .nav.scrolled{
    padding:12px 40px;
    background:rgba(10,14,6,.96);
    backdrop-filter:blur(28px) saturate(140%);-webkit-backdrop-filter:blur(28px) saturate(140%);
    border-bottom:1px solid var(--line);
    box-shadow:0 12px 40px rgba(0,0,0,.45);
  }
  @media(max-width:760px){.nav,.nav.scrolled{padding-left:22px;padding-right:22px}}
  .brand{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-size:24px;letter-spacing:.01em;font-weight:400}
  .brand-mark{
    width:34px;height:34px;border:1px solid var(--ink);
    display:grid;place-items:center;position:relative;transform:rotate(45deg);
  }
  .brand-mark::after{content:"";width:10px;height:10px;background:var(--accent)}
  .brand-name{display:flex;flex-direction:column;line-height:1}
  .brand-name span:last-child{font-family:var(--sans);font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);margin-top:5px}
  .nav-links{display:flex;gap:36px;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
  .nav-links a{position:relative;padding:6px 0;opacity:.85;transition:opacity .3s}
  .nav-links a:hover{opacity:1}
  .nav-links a::after{
    content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
    background:var(--accent);transform:scaleX(0);transform-origin:right;
    transition:transform .5s var(--ease);
  }
  .nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
  .nav-cta{
    background:var(--accent);border:1px solid var(--accent);padding:11px 22px;border-radius:99px;
    font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
    color:var(--bg);transition:background .35s,color .35s,border-color .35s;
  }
  .nav-cta:hover{background:var(--bg);color:var(--accent);border-color:var(--accent)}
  @media(max-width:900px){.nav-links{display:none}}
  @media(max-width:560px){
    .brand{gap:10px;font-size:18px}.brand-mark{width:28px;height:28px}
    .brand-mark::after{width:8px;height:8px}
    .brand-name span:last-child{font-size:8px;margin-top:3px}
    .nav-cta{padding:9px 16px;font-size:10px}
    .nav,.nav.scrolled{padding-left:16px;padding-right:16px;padding-top:14px;padding-bottom:14px}
  }

  /* hero */
  .hero{position:relative;height:100svh;min-height:720px;overflow:hidden}
  .hero-img{
    position:absolute;inset:0;
    background-image:url('../img/hero.jpg');
    background-size:cover;background-position:center;
    transform:scale(1.08);animation:kb 22s var(--ease) forwards;
    filter:brightness(.48) contrast(1.05) saturate(.9);
  }
  @keyframes kb{to{transform:scale(1)}}
  .hero::after{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:
      linear-gradient(180deg,rgba(12,17,8,.55) 0%,rgba(12,17,8,.18) 30%,rgba(12,17,8,.55) 70%,rgba(12,17,8,.92) 100%),
      radial-gradient(ellipse at left bottom,rgba(0,0,0,.45) 0%,rgba(0,0,0,0) 65%);
  }
  .hero-content{
    position:relative;z-index:2;height:100%;
    max-width:1560px;margin:0 auto;padding:120px 40px 70px;
    display:flex;flex-direction:column;justify-content:flex-end;
  }
  @media(max-width:760px){.hero-content{padding:100px 22px 60px}}
  .hero-tag{
    display:flex;gap:14px;align-items:center;margin-bottom:36px;flex-wrap:wrap;line-height:1.4;
    font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:rgba(237,229,214,.85);
  }
  .hero-tag .dot{width:6px;height:6px;background:var(--accent);border-radius:99px;display:inline-block;box-shadow:0 0 16px var(--accent)}
  .hero h1{
    font-family:var(--serif);font-weight:300;
    font-size:clamp(56px,11vw,200px);line-height:.88;letter-spacing:-.045em;
    max-width:18ch;
  }
  .hero h1 em{font-weight:400}
  .hero-foot{
    display:flex;justify-content:space-between;align-items:flex-end;
    gap:48px;flex-wrap:wrap;margin-top:56px;
    border-top:1px solid rgba(237,229,214,.22);padding-top:22px;
  }
  .hero-foot p{max-width:46ch;font-size:15.5px;color:rgba(237,229,214,.95);font-weight:300;line-height:1.65;text-shadow:0 1px 12px rgba(0,0,0,.6);opacity:1}
  .scroll-cue{display:flex;align-items:center;gap:12px;font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:rgba(237,229,214,.7)}
  .scroll-bar{display:inline-block;width:38px;height:1px;background:rgba(237,229,214,.4);position:relative;overflow:hidden}
  .scroll-bar::after{content:"";position:absolute;inset:0;background:var(--accent);transform:translateX(-100%);animation:slide 2.6s infinite var(--ease)}
  @keyframes slide{50%{transform:translateX(0)}100%{transform:translateX(100%)}}
  @media(max-width:760px){
    .hero h1{font-size:clamp(40px,11vw,72px)!important;line-height:.95}
    .hero-tag{font-size:9.5px;letter-spacing:.24em;margin-bottom:28px}
    .hero-foot{margin-top:36px;gap:24px;padding-top:18px}
    .hero-foot p{font-size:14px}
    .hero-foot .scroll-cue{display:none}
  }

  /* ticker */
  .ticker{
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    overflow:hidden;white-space:nowrap;padding:20px 0;
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:clamp(20px,2.6vw,32px);color:var(--mute);letter-spacing:-.005em;
    background:var(--paper);
  }
  .ticker-track{display:inline-block;animation:tick 42s linear infinite}
  .ticker-track span{margin:0 22px}
  .ticker-track .sep{color:var(--accent);margin:0 8px}
  @keyframes tick{to{transform:translateX(-50%)}}

  /* sections */
  section{padding:110px 0;position:relative}
  @media(max-width:760px){section{padding:72px 0}}
  .sec-head{
    display:grid;grid-template-columns:1fr 2.2fr;gap:80px;
    align-items:end;margin-bottom:90px;position:relative;
  }
  @media(max-width:900px){.sec-head{grid-template-columns:1fr;gap:28px;margin-bottom:56px}}
  .sec-head .label{display:flex;align-items:center;gap:18px}
  .sec-head .label::before{content:"";width:36px;height:1px;background:var(--accent)}
  .sec-head h2{font-size:clamp(40px,6.2vw,92px);font-weight:300;letter-spacing:-.03em}
  @media(max-width:900px){.sec-head{gap:20px;margin-bottom:48px}.sec-head h2{font-size:clamp(32px,8vw,48px)}}

  /* manifesto */
  .manifesto{position:relative}
  .manifesto-grid{display:grid;grid-template-columns:1fr 1fr;gap:120px;align-items:start}
  @media(max-width:900px){.manifesto-grid{grid-template-columns:1fr;gap:60px}}
  .manifesto-quote{
    font-family:var(--serif);font-weight:300;
    font-size:clamp(28px,3.4vw,46px);line-height:1.18;letter-spacing:-.018em;
    color:var(--ink);
  }
  .manifesto-quote em{color:var(--accent)}
  .manifesto-quote::before{content:"\201C";font-size:1.6em;line-height:0;vertical-align:-.18em;color:var(--accent);margin-right:.05em}
  .manifesto-side p{font-size:16px!important;color:rgba(237,229,214,.78)!important;line-height:1.85;margin-bottom:18px;max-width:46ch;opacity:1}
  .signature{margin-top:36px;display:flex;gap:28px;align-items:center}
  .signature .sig-mark{font-family:var(--serif);font-style:italic;font-size:36px;color:var(--accent)}
  .signature .sig-meta{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
  .signature .sig-meta strong{display:block;color:var(--ink);font-weight:400;margin-bottom:4px;font-family:var(--serif);font-size:14px;letter-spacing:.04em;text-transform:none}
  @media(max-width:760px){.manifesto-quote{font-size:22px;line-height:1.3}.manifesto-side p{font-size:15px!important}}

  /* founder note */
  .founder-note{background:var(--paper);position:relative;overflow:hidden}
  .fn-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:90px;align-items:center}
  @media(max-width:900px){.fn-grid{grid-template-columns:1fr;gap:36px}}
  .fn-portrait{
    position:relative;aspect-ratio:4/5;overflow:hidden;
    background:#141a0b url('../img/studio_interior.jpg') center/cover no-repeat;
    box-shadow:0 30px 80px rgba(0,0,0,.5);
  }
  .fn-portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(12,17,8,.5))}
  .fn-portrait .badge{
    position:absolute;left:24px;bottom:24px;z-index:2;
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:14px;color:rgba(237,229,214,.85);letter-spacing:.02em;
  }
  .fn-portrait .badge::before{content:"— ";color:var(--accent)}
  .fn-text .eyebrow{margin-bottom:32px;display:block}
  .fn-text h2{
    font-family:var(--serif);font-weight:300;
    font-size:clamp(36px,4.6vw,64px);line-height:1.05;letter-spacing:-.025em;margin-bottom:36px;
  }
  .fn-text h2 em{color:var(--accent)}
  .fn-quote{
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:clamp(22px,2.4vw,30px);line-height:1.4;letter-spacing:-.012em;
    color:var(--ink);margin-bottom:36px;padding-left:24px;border-left:1px solid var(--accent);
  }
  .fn-bio{font-size:14.5px;color:var(--mute);line-height:1.8;margin-bottom:28px;max-width:52ch;opacity:1}
  .fn-vents{display:flex;flex-wrap:wrap;gap:8px;margin-top:36px;padding-top:36px;border-top:1px solid var(--line)}
  .fn-vent{
    font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    padding:9px 16px;border:1px solid var(--line);border-radius:99px;
    color:var(--ink);transition:border-color .3s,background .3s,color .3s;
  }
  .fn-vent:hover{border-color:var(--accent);background:var(--accent);color:var(--bg)}
  .fn-sign{margin-top:40px;display:flex;align-items:center;gap:24px}
  .fn-sign .glyph{font-family:var(--serif);font-style:italic;font-size:48px;font-weight:300;color:var(--accent);line-height:1}
  .fn-sign .who{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
  .fn-sign .who strong{display:block;font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink);font-weight:400;letter-spacing:.02em;text-transform:none;margin-bottom:4px}
  @media(max-width:900px){.fn-grid{gap:36px}.fn-portrait{aspect-ratio:4/4;max-height:420px}.fn-text h2{font-size:clamp(28px,5vw,40px)!important;line-height:1.1}.fn-quote{font-size:18px;line-height:1.5;padding-left:18px}.fn-bio{font-size:14.5px}}

  /* index strip */
  .index-strip{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:0}
  .index-grid{display:grid;grid-template-columns:repeat(4,1fr)}
  @media(max-width:900px){.index-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:760px){.index-grid{grid-template-columns:1fr 1fr}}
  .ix{padding:60px 36px;border-right:1px solid var(--line);position:relative;overflow:hidden}
  .ix:last-child{border-right:0}
  .ix .num{font-family:var(--serif);font-size:13px;letter-spacing:.04em;color:var(--accent);margin-bottom:48px}
  .ix .v{font-family:var(--serif);font-weight:300;font-size:clamp(48px,5.2vw,76px);line-height:1;letter-spacing:-.03em}
  .ix .v sup{font-size:.45em;vertical-align:super;margin-left:3px;color:var(--mute)}
  .ix .l{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-top:18px}
  @media(max-width:760px){.ix{padding:36px 20px}.ix .v{font-size:42px}.ix .l{font-size:10px}.ix .num{font-size:11px;margin-bottom:24px}}

  /* featured projects */
  .feature{position:relative;padding:0;border-bottom:1px solid var(--line)}
  .feat-grid{display:grid;grid-template-columns:1fr 1fr;min-height:760px;align-items:stretch}
  @media(max-width:900px){.feat-grid{grid-template-columns:1fr}}
  .feat-img{position:relative;overflow:hidden;min-height:520px}
  .feat-img>div{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1.4s var(--ease)}
  .feature:hover .feat-img>div{transform:scale(1.04)}
  .feat-img::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 55%,rgba(12,17,8,.35) 100%);opacity:.8;transition:opacity .8s var(--ease)}
  .feature:hover .feat-img::after{opacity:.4}
  .feat-text{
    padding:90px 80px;display:flex;flex-direction:column;justify-content:center;
    background:var(--paper);position:relative;
  }
  @media(max-width:900px){.feat-text{padding:48px 22px 60px}}
  .feat-num{position:absolute;top:32px;right:32px;font-family:var(--serif);font-size:12px;letter-spacing:.18em;color:var(--mute)}
  .feat-loc{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);margin-bottom:24px}
  .feat-name{font-family:var(--serif);font-weight:300;font-size:clamp(40px,5vw,72px);line-height:1;letter-spacing:-.025em;margin-bottom:32px}
  .feat-name em{color:var(--accent)}
  .feat-desc{font-size:15px;line-height:1.75;color:var(--mute)!important;max-width:50ch;margin-bottom:36px;opacity:1}
  .feat-meta{display:flex;gap:50px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--line)}
  .feat-meta dl div{display:flex;flex-direction:column;gap:6px}
  .feat-meta dt{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute)}
  .feat-meta dd{font-family:var(--serif);font-size:18px;color:var(--ink);font-weight:400}
  .feature.reverse .feat-grid{direction:rtl}
  .feature.reverse .feat-text{direction:ltr}
  .feature.reverse .feat-img{direction:ltr}
  @media(max-width:900px){.feature .feat-grid{grid-template-columns:1fr!important;direction:ltr!important}.feature .feat-img{order:1;min-height:320px!important;aspect-ratio:5/4}.feature .feat-text{order:2}.feat-name{font-size:36px!important}.feat-desc{font-size:14px}.feat-meta{gap:24px}.feat-meta dd{font-size:15px}}

  /* detail strip */
  .detail-strip{height:60vh;min-height:420px;position:relative;overflow:hidden;background-image:url('../img/detail.jpg');background-size:cover;background-position:center}
  .detail-strip::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,17,8,.4),rgba(12,17,8,.6))}
  .detail-strip .pull{position:absolute;inset:0;z-index:2;display:grid;place-items:center;text-align:center;padding:0 22px}
  .detail-strip h3{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(40px,7vw,108px);line-height:1;letter-spacing:-.03em;max-width:14ch}
  .detail-strip h3 span{color:var(--accent)}

  /* gallery */
  .gallery{padding:0;display:grid;grid-template-columns:2fr 1fr;gap:4px;height:60vh;min-height:480px;background:var(--bg)}
  .gallery>div{background-size:cover;background-position:center;position:relative;overflow:hidden}
  .gallery>div::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(12,17,8,.6))}
  .gallery .gcap{position:absolute;left:24px;bottom:24px;z-index:2;font-family:var(--serif);font-style:italic;font-size:18px;color:#fff}
  @media(max-width:760px){.gallery{grid-template-columns:1fr;gap:4px;height:auto}.gallery>div{aspect-ratio:5/4;height:auto}}

  /* process / timeline */
  .timeline{padding:120px 0;background:var(--paper)}
  .tl-rows{margin-top:64px}
  .tl-row{
    display:grid;grid-template-columns:auto 1fr 2fr auto;gap:48px;
    padding:36px 0;border-bottom:1px solid var(--line);align-items:center;
    transition:padding .5s var(--ease),background .5s;
  }
  .tl-row:hover{padding-left:18px;background:linear-gradient(90deg,rgba(168,118,64,.06),transparent 50%)}
  .tl-step{width:64px;height:64px;border-radius:99px;border:1px solid var(--accent);display:grid;place-items:center;font-family:var(--serif);font-size:24px;color:var(--accent);font-weight:300}
  .tl-name{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3vw,42px);letter-spacing:-.02em;line-height:1}
  .tl-name em{color:var(--accent)}
  .tl-desc{font-size:14.5px;color:var(--mute);line-height:1.7;max-width:60ch;opacity:1}
  .tl-time{font-family:var(--serif);font-size:14px;color:var(--mute);white-space:nowrap;font-style:italic}
  @media(max-width:900px){.tl-row{grid-template-columns:auto 1fr;gap:24px;padding:24px 0}.tl-desc,.tl-time{display:none}.tl-step{width:48px;height:48px;font-size:16px}.tl-name{font-size:24px}}

  /* contact */
  .contact{background:var(--bg);padding:160px 0 60px}
  .contact h2{font-family:var(--serif);font-weight:300;font-size:clamp(56px,11vw,200px);line-height:.9;letter-spacing:-.045em;margin-bottom:80px}
  .contact h2 em{color:var(--accent);font-weight:400}
  .contact h2 a{position:relative;display:inline-block;transition:transform .6s var(--ease)}
  .contact h2 a:hover{transform:translateX(14px)}
  .contact h2 a::after{content:" →";color:var(--accent)}
  .contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;padding-top:48px;border-top:1px solid var(--line)}
  @media(max-width:900px){.contact-grid{grid-template-columns:1fr 1fr;gap:40px}.contact{padding:90px 0 40px}.contact h2{font-size:48px!important;line-height:1;margin-bottom:48px}}
  @media(max-width:560px){.contact-grid{grid-template-columns:1fr}}
  .ci strong{display:block;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute);margin-bottom:14px;font-weight:500}
  .ci{font-family:var(--serif);font-size:18px;line-height:1.6;color:var(--ink);font-weight:400}
  .ci a:hover{color:var(--accent)}

  footer{margin-top:120px;padding-top:32px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;font-size:11px;color:var(--mute);letter-spacing:.16em;text-transform:uppercase}
  footer .socials{display:flex;gap:28px}
  footer a{transition:color .3s}
  footer a:hover{color:var(--accent)}

  /* reveals — only hidden when JS is present (.js class on <html>) so content
     is always visible if JS fails or in no-script environments */
  .js .reveal{opacity:0;transform:translateY(48px);transition:opacity 1.2s var(--ease),transform 1.2s var(--ease);will-change:transform,opacity}
  .reveal.in,.js .reveal.in{opacity:1;transform:none}
  .js .reveal.d1{transition-delay:.1s}.js .reveal.d2{transition-delay:.2s}.js .reveal.d3{transition-delay:.3s}
  .js .r-up{opacity:0;transform:translateY(60px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
  .r-up.in,.js .r-up.in{opacity:1;transform:none}
  .js .r-zoom{opacity:0;transform:scale(.94);transition:opacity 1.2s var(--ease),transform 1.4s var(--ease)}
  .r-zoom.in,.js .r-zoom.in{opacity:1;transform:scale(1)}
  .js .r-fade{opacity:0;transition:opacity 1.4s var(--ease)}
  .r-fade.in,.js .r-fade.in{opacity:1}

  /* cursor */
  .cursor{position:fixed;top:0;left:0;width:8px;height:8px;border-radius:99px;background:var(--accent);pointer-events:none;z-index:200;mix-blend-mode:difference;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease)}
  @media(hover:none){.cursor{display:none}}

  /* progress */
  .progress{position:fixed;top:0;left:0;height:2px;background:var(--accent);z-index:80;width:0;transition:width .15s linear}

  /* focus */
  a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
