:root{
    --ink:#0C1A28;--navy:#0E1E2E;--navy-text:#16273B;
    --paper:#F4EFE5;--paper-2:#FBF8F1;
    --cream:#F4EFE5;--cream-dim:rgba(244,239,229,0.86);--cream-faint:rgba(244,239,229,0.62);
    --bronze:#C3AD8B;--bronze-soft:#D6C3A4;--bronze-deep:#6E5A3A;
    --line-dark:rgba(12,26,40,0.15);--line-light:rgba(244,239,229,0.18);
    --serif:"Fraunces",Georgia,serif;--sans:"Hanken Grotesk",-apple-system,sans-serif;--maxw:1180px;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;}
  body{background:var(--paper);color:var(--navy-text);font-family:var(--sans);font-weight:400;line-height:1.6;font-size:17px;letter-spacing:0.005em;overflow-x:hidden;}
  a{color:inherit;text-decoration:none;}
  ::selection{background:var(--bronze);color:var(--ink);}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.3rem,5vw,3.5rem);}

  .btn{font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink);background:var(--bronze);padding:.95rem 1.6rem;border:1px solid var(--bronze);display:inline-block;cursor:pointer;transition:background .3s,color .3s,border-color .3s;}
  .btn:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
  .btn-ghost{background:transparent;color:var(--cream);border:1px solid var(--line-light);}
  .btn-ghost:hover{border-color:var(--bronze);color:var(--bronze-soft);background:transparent;}
  .btn-line{background:transparent;color:var(--navy-text);border:1px solid rgba(12,26,40,0.28);}
  .btn-line:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}

  header{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.15rem 0;transition:padding .35s,background .35s,border-color .35s;border-bottom:1px solid transparent;}
  header.scrolled{padding:.75rem 0;background:rgba(12,26,40,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-light);}
  .nav{display:flex;align-items:center;justify-content:space-between;}
  .mark{font-family:var(--serif);font-size:1.42rem;font-weight:400;letter-spacing:-0.01em;display:flex;align-items:baseline;gap:.5rem;color:var(--cream);}
  .mark .w{font-style:italic;}
  .mark .c{font-family:var(--sans);font-size:.66rem;font-weight:600;letter-spacing:0.32em;text-transform:uppercase;color:var(--cream-faint);transform:translateY(-1px);}
  nav ul{display:flex;gap:1.9rem;list-style:none;align-items:center;}
  nav a{font-size:.76rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--cream-dim);position:relative;transition:color .3s;}
  nav a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--bronze);transition:width .32s;}
  nav a:hover{color:var(--cream);}
  nav a:hover::after{width:100%;}
  .nav .btn{padding:.68rem 1.25rem;font-size:.72rem;}

  .hero{background:radial-gradient(120% 100% at 80% 0%,#143049 0%,rgba(14,30,46,0) 58%),var(--navy);color:var(--cream);padding:8.5rem 0 3.8rem;position:relative;}
  .hero-kicker{display:flex;align-items:center;gap:.9rem;margin-bottom:1.8rem;font-size:.74rem;font-weight:600;letter-spacing:0.24em;text-transform:uppercase;color:var(--bronze);}
  .hero-kicker .ln{width:38px;height:1px;background:var(--bronze);opacity:.8;}
  .hero h1{font-family:var(--serif);font-weight:380;font-size:clamp(2.5rem,6vw,4.7rem);line-height:1.04;letter-spacing:-0.02em;max-width:16ch;margin-bottom:1.2rem;}
  .hero h1 em{font-style:italic;color:var(--bronze-soft);}
  .hero .subhead{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.2rem,2.2vw,1.65rem);color:var(--bronze-soft);margin-bottom:1.3rem;}
  .hero .sub{max-width:50ch;font-size:1.12rem;color:var(--cream-dim);line-height:1.62;margin-bottom:2.1rem;}
  .hero-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-bottom:2.4rem;}
  .hero-for{font-size:.82rem;letter-spacing:0.04em;color:var(--cream-faint);border-top:1px solid var(--line-light);padding-top:1.4rem;max-width:60ch;}
  .hero-for b{color:var(--cream);font-weight:600;}

  section{padding:clamp(3rem,6vw,5rem) 0;}
  .eyebrow{display:flex;align-items:center;gap:.85rem;margin-bottom:1.4rem;font-size:.73rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--bronze-deep);}
  .eyebrow .ln{width:30px;height:1px;background:var(--bronze-deep);opacity:.6;}
  h2{font-family:var(--serif);font-weight:400;letter-spacing:-0.015em;color:var(--ink);line-height:1.12;}

  /* WHAT WE DO */
  .intro-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;}
  .intro-lead{font-family:var(--serif);font-weight:400;font-size:clamp(1.55rem,2.9vw,2.25rem);line-height:1.25;color:var(--ink);letter-spacing:-0.01em;}
  .intro-lead b{color:var(--bronze-deep);font-weight:400;font-style:italic;}
  .intro-note{margin-top:1.4rem;font-size:1.02rem;color:var(--navy-text);max-width:48ch;}
  .what-figure img{width:100%;height:clamp(300px,36vw,420px);object-fit:cover;display:block;border:1px solid var(--line-dark);}
  .what-figure figcaption{margin-top:.6rem;font-size:.72rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--bronze-deep);}
  .build-row{display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(2rem,5vw,4.5rem);margin-top:clamp(2rem,4vw,3rem);padding-top:clamp(1.6rem,3vw,2.4rem);border-top:1px solid var(--line-dark);}
  .build-row h3{font-size:.74rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--bronze-deep);margin-bottom:1rem;}
  .build-list{list-style:none;}
  .build-list li{font-family:var(--serif);font-size:1.18rem;color:var(--ink);padding:.5rem 0;border-bottom:1px solid var(--line-dark);}
  .chips{display:flex;flex-wrap:wrap;gap:.5rem;}
  .chips span{font-size:.78rem;font-weight:500;color:var(--navy-text);border:1px solid rgba(12,26,40,0.22);padding:.4rem .8rem;border-radius:2px;}

  /* SERVICES */
  .services{background:var(--paper-2);border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);}
  .svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;flex-wrap:wrap;margin-bottom:2rem;}
  .svc-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);}
  .svc-head p{font-size:.98rem;color:var(--navy-text);max-width:34ch;}
  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}
  .card{background:#FEFCF8;border:1px solid var(--line-dark);padding:1.9rem 1.7rem 2rem;display:flex;flex-direction:column;position:relative;transition:transform .35s,box-shadow .35s;}
  .card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(12,26,40,0.12);}
  .card.feature{border:1.5px solid var(--bronze-deep);}
  .card.feature::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--bronze-deep);}
  .card .tier{font-size:.68rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--bronze-deep);margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;}
  .card .tier .rec{font-weight:600;letter-spacing:0.1em;color:#FEFCF8;background:var(--bronze-deep);padding:.22rem .5rem;font-size:.6rem;}
  .card h3{font-family:var(--serif);font-weight:440;font-size:1.42rem;line-height:1.16;color:var(--ink);margin-bottom:.5rem;}
  .card .price{font-family:var(--serif);font-weight:500;font-size:2.1rem;color:var(--ink);letter-spacing:-0.01em;margin-bottom:.2rem;}
  .card .desc{font-size:.95rem;color:var(--navy-text);padding:.9rem 0 1.1rem;margin-bottom:1rem;border-bottom:1px solid var(--line-dark);}
  .card .inc{font-size:.68rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--bronze-deep);margin-bottom:.7rem;}
  .card ul{list-style:none;flex:1;margin-bottom:1.5rem;}
  .card ul li{font-size:.92rem;color:var(--navy-text);padding:.36rem 0 .36rem 1.35rem;position:relative;}
  .card ul li::before{content:"";position:absolute;left:0;top:.85rem;width:10px;height:1px;background:var(--bronze-deep);}
  .card .note{font-size:.84rem;font-style:italic;color:rgba(12,26,40,0.6);margin-bottom:1.3rem;line-height:1.4;}

  /* APPROACH / HOW WE WORK */
  .approach .lead{font-size:1.06rem;color:var(--navy-text);max-width:60ch;margin-bottom:2rem;}
  .app-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;}
  .app-figure img{width:100%;height:clamp(250px,25vw,320px);object-fit:cover;display:block;border:1px solid var(--line-dark);}
  .app-figure figcaption{margin-top:.7rem;}
  .app-figure .lbl{display:block;font-size:.7rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:var(--bronze-deep);margin-bottom:.25rem;}
  .app-figure .cap{font-size:.95rem;color:var(--navy-text);}

  /* PHILOSOPHY */
  .phil{background:var(--navy);color:var(--cream);}
  .phil .eyebrow{color:var(--bronze-soft);}
  .phil .eyebrow .ln{background:var(--bronze-soft);}
  .phil h2{color:var(--cream);font-size:clamp(1.9rem,4vw,3rem);max-width:18ch;margin-bottom:1.6rem;}
  .phil h2 em{font-style:italic;color:var(--bronze-soft);}
  .phil-lines{max-width:50ch;}
  .phil-lines p{font-size:1.08rem;color:var(--cream-dim);padding:.55rem 0;border-bottom:1px solid var(--line-light);}
  .phil-lines p:last-child{border-bottom:none;color:var(--cream);font-weight:500;}

  /* ABOUT */
  .about-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
  .about-figure img{width:100%;height:auto;display:block;border:1px solid var(--line-dark);}
  .about-figure figcaption{margin-top:.7rem;font-size:.74rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--bronze-deep);}
  .about h2{font-size:clamp(1.7rem,3.3vw,2.5rem);max-width:20ch;margin-bottom:1.5rem;}
  .about h2 em{font-style:italic;}
  .about p{font-size:1.06rem;color:var(--navy-text);margin-bottom:1.1rem;max-width:54ch;}

  /* CONTACT */
  .contact{background:var(--navy);color:var(--cream);text-align:center;}
  .contact .eyebrow{justify-content:center;color:var(--bronze-soft);}
  .contact .eyebrow .ln{background:var(--bronze-soft);}
  .contact h2{color:var(--cream);font-size:clamp(2rem,4.5vw,3.4rem);max-width:18ch;margin:0 auto 1.8rem;}
  .contact h2 em{font-style:italic;color:var(--bronze-soft);}
  .contact .loc{margin-top:1.8rem;font-size:.78rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--cream-faint);}

  footer{background:var(--ink);color:var(--cream);padding:2.4rem 0;}
  .foot{display:flex;justify-content:space-between;align-items:center;gap:1.2rem;flex-wrap:wrap;}
  .foot small{font-size:.73rem;letter-spacing:0.1em;color:var(--cream-faint);}

  [data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease;}
  [data-reveal].in{opacity:1;transform:none;}
  .stagger.in > *{animation:rise .6s ease both;}
  .stagger.in > *:nth-child(2){animation-delay:.07s;}
  .stagger.in > *:nth-child(3){animation-delay:.14s;}
  @keyframes rise{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

  @media(max-width:900px){
    .intro-grid,.about-grid,.build-row{grid-template-columns:1fr;}
    .svc-grid,.app-grid{grid-template-columns:1fr;}
    nav ul{display:none;}
    .about-figure{max-width:440px;}
    .what-figure{order:-1;}
  }
  @media(max-width:560px){body{font-size:16px;}.mark .c{display:none;}.hero{padding:7rem 0 3rem;}}
