
  :root{
    --bg:#0B1D12;
    --paper:#122A1A;
    --ink:#F4EFE4;
    --mute:#96AA96;
    --line:rgba(244,239,228,.15);
    --accent:#C9A87C;
    --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;
    -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}

  /* ---------- 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}
  .display{font-family:var(--serif); font-weight:300; line-height:.92; letter-spacing:-.035em}
  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(11,29,18,.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{
    border:1px solid var(--ink); padding:11px 22px; border-radius:99px;
    font-size:11px; letter-spacing:.18em; text-transform:uppercase;
    transition:background .35s, color .35s, border-color .35s;
  }
  .nav-cta:hover{background:var(--accent); border-color:var(--accent); color:var(--bg)}
  @media (max-width:900px){.nav-links{display:none}}

  /* ---------- hero ---------- */
  .hero{
    position:relative; height:100svh; min-height:720px; overflow:hidden;
  }
  .hero-img{
    position:absolute; inset:0;
    background:
      linear-gradient(165deg, #060F08 0%, #0F2818 30%, #1C4228 55%, #0A1C10 80%, #060F08 100%);
    transform:scale(1.08); animation:kb 22s var(--ease) forwards;
  }
  .hero-img::before{
    content:""; position:absolute; inset:0;
    background-image:
      repeating-linear-gradient(0deg, transparent, transparent 60px, rgba(201,168,124,.025) 60px, rgba(201,168,124,.025) 61px),
      repeating-linear-gradient(90deg, transparent, transparent 80px, rgba(201,168,124,.018) 80px, rgba(201,168,124,.018) 81px);
  }
  @keyframes kb{to{transform:scale(1)}}
  .hero::after{
    content:""; position:absolute; inset:0; pointer-events:none;
    background:
      linear-gradient(180deg,rgba(11,29,18,.75) 0%,rgba(11,29,18,.25) 22%,rgba(11,29,18,.45) 55%,rgba(11,29,18,.96) 100%),
      radial-gradient(ellipse at left bottom,rgba(0,0,0,.6) 0%,rgba(0,0,0,0) 65%);
  }
  .hero-content{
    position:relative; z-index:2; height:100%;
    max-width:1560px; margin:0 auto; padding:0 40px 70px;
    display:flex; flex-direction:column; justify-content:flex-end;
  }
  @media (max-width:760px){.hero-content{padding:0 22px 60px}}
  .hero-tag{
    display:flex; gap:14px; align-items:center; margin-bottom:36px;
    font-size:11px; letter-spacing:.32em; text-transform:uppercase; color:rgba(244,239,228,.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(64px,12vw,224px); 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(244,239,228,.22); padding-top:22px;
  }
  .hero-foot p{max-width:46ch; font-size:15.5px; color:rgba(244,239,228,.95); font-weight:300; line-height:1.65; text-shadow:0 1px 12px rgba(0,0,0,.6)}
  .scroll-cue{display:flex;align-items:center;gap:12px;font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:rgba(244,239,228,.7)}
  .scroll-bar{display:inline-block;width:38px;height:1px;background:rgba(244,239,228,.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%)}}

  /* ---------- 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}
  @keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  .ticker-track span{margin:0 22px}
  .ticker-track .sep{color:var(--accent); margin:0 8px}

  /* ---------- sections ---------- */
  section{padding:140px 0; position:relative}
  @media (max-width:760px){section{padding:90px 0}}
  .sec-head{
    display:grid; grid-template-columns:1fr 2.2fr; gap:80px;
    align-items:end; margin-bottom:90px;
  }
  @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}

  /* ---------- 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:15px; color:var(--mute); line-height:1.85; margin-bottom:18px; max-width:46ch}
  .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}

  /* ---------- company 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:48px}}
  .fn-portrait{
    position:relative; aspect-ratio:4/5; overflow:hidden;
    background:
      radial-gradient(circle at 30% 20%, rgba(201,168,124,.12), transparent 60%),
      linear-gradient(135deg, #122A1A, #0B1D12);
    box-shadow:0 30px 80px rgba(0,0,0,.5);
    display:flex; align-items:center; justify-content:center;
    border:1px solid var(--line);
  }
  .fn-portrait::after{
    content:""; position:absolute; inset:0;
    background:linear-gradient(180deg,transparent 50%,rgba(11,29,18,.5));
  }
  .fn-portrait-inner{
    font-family:var(--serif); font-size:clamp(80px,12vw,160px); font-weight:300;
    color:var(--accent); opacity:.18; letter-spacing:-.05em; line-height:1; z-index:1;
    position:relative;
  }
  .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(244,239,228,.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}
  .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}

  /* ---------- 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)}}
  .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}

  /* ---------- 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-text{
    padding:90px 80px; display:flex; flex-direction:column; justify-content:center;
    background:var(--bg); position:relative;
  }
  @media (max-width:900px){.feat-text{padding:70px 22px}}
  .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-desc{font-size:15px; line-height:1.75; color:var(--mute); max-width:50ch; margin-bottom:36px}
  .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}

  /* ---------- discipline / services ---------- */
  .disc{padding-top:160px}

  /* ---------- process ---------- */
  .process{background:var(--paper)}
  .process-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:48px}
  @media (max-width:900px){.process-grid{grid-template-columns:1fr 1fr; gap:40px}}
  @media (max-width:560px){.process-grid{grid-template-columns:1fr}}
  .step{padding-top:32px; border-top:1px solid var(--accent); position:relative}
  .step .n{font-family:var(--serif); font-size:13px; letter-spacing:.06em; color:var(--accent); margin-bottom:64px; display:block}
  .step h3{font-family:var(--serif); font-weight:400; font-size:30px; line-height:1.05; margin-bottom:16px; letter-spacing:-.015em}
  .step p{font-size:14px; color:var(--mute); line-height:1.7}

  /* ---------- detail strip ---------- */
  .detail-strip{
    height:60vh; min-height:420px; position:relative; overflow:hidden;
    background:linear-gradient(135deg, #0B1D12 0%, #1A3D28 40%, #0A1810 100%);
  }
  .detail-strip::before{
    content:""; position:absolute; inset:0;
    background-image:
      repeating-linear-gradient(45deg, transparent, transparent 40px, rgba(201,168,124,.03) 40px, rgba(201,168,124,.03) 41px);
  }
  .detail-strip::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(11,29,18,.3),rgba(11,29,18,.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)}

  /* ---------- 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}}
  @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)}

  /* ---------- reveal ---------- */
  .reveal{opacity:0; transform:translateY(48px); transition:opacity 1.2s var(--ease), transform 1.2s var(--ease)}
  .reveal.in{opacity:1; transform:none}
  .reveal.d1{transition-delay:.1s} .reveal.d2{transition-delay:.2s} .reveal.d3{transition-delay:.3s}

  /* ---------- 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}
