@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Libre+Franklin:wght@200;300;400;500;600;700&display=swap');
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --obsidian:#080808;--charcoal:#111;--graphite:#1a1a1a;--slate:#2a2a2a;
  --ash:#5a5a5a;--stone:#888;--silver:#aaa;--mist:#ccc;
  --pearl:#e6e2db;--ivory:#f2efe9;--white:#faf9f6;
  --gold:#c4a265;--gold-l:#d9bc82;
  --sage-d:#253025;--sage:#3f6340;
  --font-h:'Cormorant Garamond',Georgia,serif;
  --font-b:'Libre Franklin',system-ui,sans-serif;
  --t:cubic-bezier(.4,0,.2,1)
}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--graphite);background:var(--white);overflow-x:hidden;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-h);font-weight:300}
::selection{background:var(--gold);color:var(--obsidian)}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.5rem 3.5rem;display:flex;align-items:center;justify-content:space-between;transition:all .45s var(--t);background:transparent}
nav.scrolled{background:rgba(8,8,8,.93);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);padding:1rem 3.5rem;border-bottom:1px solid rgba(196,162,101,.06)}
.logo{font-family:var(--font-h);font-size:1.05rem;font-weight:400;color:var(--pearl);letter-spacing:.2em;text-transform:uppercase;white-space:nowrap}
.logo b{color:var(--gold);font-weight:500}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{color:rgba(230,226,219,.45);font-size:.62rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;transition:color .35s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-cta{padding:.5rem 1.4rem!important;border:1px solid rgba(196,162,101,.3)!important;color:var(--gold)!important;transition:all .35s!important}
.nav-cta:hover{background:var(--gold)!important;color:var(--obsidian)!important}
.nav-dd{position:relative}
.nav-dd-menu{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);padding:.8rem 0;min-width:210px;background:rgba(8,8,8,.96);backdrop-filter:blur(20px);border:1px solid rgba(196,162,101,.06);margin-top:.6rem;z-index:100}
.nav-dd:hover .nav-dd-menu{display:block}
.nav-dd-menu a{display:block;padding:.4rem 1.5rem;font-size:.58rem}
.hamburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:4px;z-index:1001}
.hamburger span{display:block;width:24px;height:1px;background:var(--pearl);transition:all .35s}
.mob-menu{display:none;position:fixed;inset:0;z-index:999;background:rgba(8,8,8,.98);padding:5.5rem 2.5rem 3rem;overflow-y:auto;flex-direction:column;gap:.4rem}
.mob-menu.open{display:flex}
.mob-menu a{font-family:var(--font-h);font-size:1.4rem;color:var(--pearl);padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.03);display:block}
.mob-menu a:hover{color:var(--gold)}
.mob-sub{padding-left:1rem}
.mob-sub a{font-size:1.1rem;color:var(--silver);border:none;padding:.35rem 0}

/* PAGE HERO */
.ph{min-height:52vh;background:var(--obsidian);display:flex;align-items:flex-end;padding:0 3.5rem 4.5rem;position:relative;overflow:hidden}
.ph::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 50% at 18% 60%,rgba(196,162,101,.04),transparent 70%),radial-gradient(ellipse 35% 40% at 82% 30%,rgba(63,99,64,.03),transparent 60%)}
.ph::after{content:'';position:absolute;bottom:0;left:3.5rem;right:3.5rem;height:1px;background:linear-gradient(90deg,rgba(196,162,101,.28),rgba(196,162,101,.04))}
.ph-c{position:relative;z-index:2;max-width:680px}
.ph .ol{font-size:.62rem;font-weight:500;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem;display:flex;align-items:center;gap:1rem;opacity:0;animation:fi .8s ease .25s forwards}
.ph .ol::before{content:'';width:28px;height:1px;background:var(--gold)}
.ph h1{font-size:clamp(2.4rem,4.5vw,3.8rem);color:var(--pearl);line-height:1.08;margin-bottom:1rem;opacity:0;animation:fu .8s ease .4s forwards}
.ph h1 em{font-style:italic;color:var(--gold)}
.ph .sub{font-size:1rem;color:var(--stone);font-weight:300;line-height:1.85;max-width:500px;opacity:0;animation:fu .8s ease .55s forwards}

/* HOME HERO */
.hh{min-height:100vh;background:var(--obsidian);display:flex;align-items:center;position:relative;overflow:hidden;padding:0 3.5rem}
.hh::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 40% at 10% 50%,rgba(196,162,101,.045),transparent 70%),radial-gradient(ellipse 30% 50% at 88% 35%,rgba(63,99,64,.03),transparent 60%)}
.hh::after{content:'';position:absolute;bottom:0;left:3.5rem;right:3.5rem;height:1px;background:linear-gradient(90deg,rgba(196,162,101,.3),rgba(196,162,101,.02))}
.hh-c{position:relative;z-index:2;max-width:760px;padding:8rem 0}
.hh .ol{font-size:.62rem;font-weight:500;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:2.2rem;display:flex;align-items:center;gap:1rem;opacity:0;animation:fi .9s ease .35s forwards}
.hh .ol::before{content:'';width:32px;height:1px;background:var(--gold)}
.hh h1{font-size:clamp(2.8rem,5.5vw,4.8rem);color:var(--pearl);line-height:1.06;margin-bottom:1.8rem;font-weight:300;opacity:0;animation:fu .9s ease .55s forwards}
.hh h1 em{font-style:italic;color:var(--gold)}
.hh .hb{font-size:1.05rem;color:var(--stone);max-width:520px;font-weight:300;line-height:1.9;margin-bottom:3rem;opacity:0;animation:fu .9s ease .75s forwards}
.hh .ha{display:flex;gap:1.3rem;align-items:center;flex-wrap:wrap;opacity:0;animation:fu .9s ease .95s forwards}
.scroll-i{position:absolute;right:3.5rem;bottom:2.5rem;display:flex;flex-direction:column;align-items:center;gap:.8rem;opacity:0;animation:fi 1s ease 1.3s forwards}
.scroll-i span{font-size:.52rem;letter-spacing:.25em;text-transform:uppercase;color:var(--ash);writing-mode:vertical-rl}
.scroll-ln{width:1px;height:44px;background:linear-gradient(to bottom,var(--gold),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:1}50%{opacity:.25}}

/* UTILITIES */
.sec{padding:7rem 3.5rem}
.sec-d{background:var(--obsidian);color:var(--pearl)}
.sec-iv{background:var(--ivory)}
.sec-w{background:var(--white)}
.con{max-width:1140px;margin:0 auto}
.con-n{max-width:780px;margin:0 auto}
.ol-sm{font-size:.6rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.3rem}
.h-lg{font-size:clamp(1.9rem,3.2vw,2.8rem);line-height:1.14;margin-bottom:1rem}
.bt{color:var(--ash);font-weight:300;font-size:.95rem;line-height:1.9}
.sec-d .bt{color:var(--stone)}
.gl{width:36px;height:1px;background:var(--gold);margin:1.8rem 0}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--font-b);font-size:.62rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;transition:all .35s var(--t);cursor:pointer;border:none}
.btn-g{padding:.95rem 2.4rem;background:var(--gold);color:var(--obsidian)}
.btn-g:hover{background:var(--gold-l);box-shadow:0 6px 35px rgba(196,162,101,.18);transform:translateY(-1px)}
.btn-og{padding:.95rem 2.4rem;background:transparent;color:var(--gold);border:1px solid rgba(196,162,101,.3)}
.btn-og:hover{background:var(--gold);color:var(--obsidian)}
.btn-od{padding:.95rem 2.4rem;background:transparent;color:var(--graphite);border:1px solid rgba(0,0,0,.12)}
.btn-od:hover{background:var(--graphite);color:var(--pearl)}
.btn-gh{padding:.95rem 0;background:transparent;color:var(--ash)}
.btn-gh:hover{color:var(--gold)}

/* GRIDS */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px}
.sg-wrap{background:rgba(196,162,101,.06);border:1px solid rgba(196,162,101,.06)}
.sg-card{background:var(--obsidian);padding:2.6rem 2rem;transition:background .45s}
.sg-card:hover{background:rgba(196,162,101,.02)}
.sg-num{font-family:var(--font-h);font-size:.8rem;color:rgba(196,162,101,.22);margin-bottom:1.5rem;letter-spacing:.1em}
.sg-bar{width:18px;height:1px;background:var(--gold);margin-bottom:1.2rem}
.sg-card h3{font-size:1.25rem;color:var(--pearl);margin-bottom:.7rem;font-weight:400}
.sg-card p{color:var(--ash);font-weight:300;font-size:.88rem;line-height:1.8}
.sg-link{display:inline-block;margin-top:1rem;font-size:.58rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);transition:opacity .3s}
.sg-link:hover{opacity:.7}

/* VALUES */
.vg{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(0,0,0,.05)}
.vi{padding:2.5rem 2.2rem 2.5rem 0;border-bottom:1px solid rgba(0,0,0,.05);border-right:1px solid rgba(0,0,0,.05)}
.vi:nth-child(3n){border-right:none}
.vi-n{font-family:var(--font-h);font-size:2.4rem;font-weight:300;color:var(--pearl);line-height:1;margin-bottom:1rem}
.vi h3{font-size:1.15rem;color:var(--graphite);margin-bottom:.5rem;font-weight:400}
.vi p{color:var(--ash);font-weight:300;font-size:.88rem;line-height:1.85}

/* SERVICE DETAIL */
.sd{display:grid;grid-template-columns:.32fr 1fr;gap:3.5rem;align-items:start;padding:4rem 0;border-bottom:1px solid rgba(0,0,0,.04)}
.sd:last-child{border-bottom:none}
.sd-left{position:sticky;top:7rem}
.sd-n{font-family:var(--font-h);font-size:3.5rem;font-weight:300;color:var(--pearl);line-height:1;margin-bottom:.8rem}
.sd-bar{width:24px;height:1px;background:var(--gold);margin-bottom:1rem}
.sd-label{font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--stone)}
.sd-right h2{font-size:clamp(1.6rem,2.5vw,2.2rem);color:var(--graphite);line-height:1.2;margin-bottom:1.2rem}
.sd-right .lead{color:var(--ash);font-weight:400;font-size:1rem;line-height:1.85;margin-bottom:1rem}
.sd-right .det{color:var(--ash);font-weight:300;font-size:.92rem;line-height:1.9;margin-bottom:.8rem}
.sd-feats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.sd-feat{padding:1.1rem 1.3rem;background:var(--ivory);border-left:2px solid var(--gold)}
.sd-feat h4{font-family:var(--font-b);font-size:.78rem;font-weight:600;color:var(--graphite);margin-bottom:.25rem}
.sd-feat p{font-size:.78rem;color:var(--ash);font-weight:300;line-height:1.65}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.tc{background:var(--ivory);display:grid;grid-template-columns:1fr 1.2fr;overflow:hidden;border:1px solid rgba(0,0,0,.03);transition:all .45s var(--t)}
.tc:hover{box-shadow:0 25px 70px rgba(0,0,0,.05);transform:translateY(-3px)}
.tc-ph{min-height:360px;background:linear-gradient(155deg,var(--graphite),var(--slate));position:relative}
.tc-lbl{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.1);font-weight:500}
.tc-info{padding:2.2rem;display:flex;flex-direction:column;justify-content:center}
.tc-name{font-size:1.4rem;color:var(--graphite);margin-bottom:.25rem;font-weight:400}
.tc-role{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:1rem}
.tc-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}
.tc-tag{padding:.25rem .75rem;border:1px solid rgba(0,0,0,.06);font-size:.58rem;color:var(--ash);font-weight:500}
.tc-bio{color:var(--ash);font-weight:300;font-size:.88rem;line-height:1.8}
.tc-feat{grid-column:1/-1;grid-template-columns:.8fr 1fr}
.tc-feat .tc-ph{min-height:440px}

/* TIMELINE */
.tl-s{display:grid;grid-template-columns:90px 1fr;gap:2.5rem;padding:3.5rem 0;border-bottom:1px solid rgba(0,0,0,.04)}
.tl-s:last-child{border-bottom:none}
.tl-n{font-family:var(--font-h);font-size:4rem;font-weight:300;color:var(--pearl);line-height:1;text-align:right}
.tl-r h2{font-size:clamp(1.4rem,2.2vw,1.8rem);color:var(--graphite);margin-bottom:.8rem;font-weight:400}
.tl-r .lead{color:var(--ash);font-weight:400;font-size:.98rem;line-height:1.85;margin-bottom:.8rem}
.tl-r .det{color:var(--ash);font-weight:300;font-size:.9rem;line-height:1.9}
.tl-bar{width:24px;height:1px;background:var(--gold);margin:1.2rem 0}

/* DIFF GRID */
.dg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(196,162,101,.06);border:1px solid rgba(196,162,101,.06)}
.dc{background:var(--obsidian);padding:2.6rem 2rem;transition:background .45s}
.dc:hover{background:rgba(196,162,101,.02)}
.dc h3{font-size:1.2rem;color:var(--pearl);margin-bottom:.7rem;font-weight:400}
.dc-bar{width:18px;height:1px;background:var(--gold);margin-bottom:1rem}
.dc p{color:var(--ash);font-weight:300;font-size:.88rem;line-height:1.85}

/* STATS */
.stats-r{display:grid;grid-template-columns:repeat(4,1fr);gap:2.5rem;text-align:center}
.st-n{font-family:var(--font-h);font-size:2.6rem;font-weight:300;line-height:1;margin-bottom:.4rem}
.st-l{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);font-weight:600}

/* SPEC LIST */
.spec-list{list-style:none}
.spec-list li{padding:1.1rem 0;border-bottom:1px solid rgba(255,255,255,.05);color:var(--stone);font-weight:300;font-size:.92rem;display:flex;align-items:baseline;gap:.8rem}
.spec-list li::before{content:'';width:5px;height:1px;min-width:5px;background:var(--gold);margin-top:.6rem}
.spec-list-light li{border-color:rgba(0,0,0,.05);color:var(--ash)}

/* URGENCY */
.urg-g{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
.urg-c{padding:2.2rem 0;border-top:1px solid rgba(196,162,101,.12)}
.urg-c h3{font-size:1.2rem;color:var(--pearl);margin-bottom:.7rem;font-weight:400}
.urg-c p{color:var(--ash);font-weight:300;font-size:.88rem;line-height:1.8}

/* CONTACT */
.c-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;align-items:start}
.cl-line{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}
.cl-label{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);font-weight:600;min-width:60px}
.cl-div{width:16px;height:1px;background:var(--gold);opacity:.35}
.cl-val{color:var(--graphite);font-weight:400;font-size:.95rem}
.cl-val a{color:var(--graphite);transition:color .3s}
.cl-val a:hover{color:var(--gold)}
.cf{background:var(--ivory);padding:2.5rem;border:1px solid rgba(0,0,0,.03)}
.cf-t{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:2rem}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.fld{margin-bottom:1.5rem}
.fld label{display:block;font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ash);margin-bottom:.6rem}
.fld input,.fld textarea,.fld select{width:100%;padding:.9rem 0;border:none;border-bottom:1px solid rgba(0,0,0,.08);font-family:var(--font-b);font-size:.9rem;font-weight:300;background:transparent;color:var(--graphite);outline:none;transition:border-color .35s;border-radius:0;-webkit-appearance:none}
.fld input::placeholder,.fld textarea::placeholder{color:var(--mist)}
.fld input:focus,.fld textarea:focus,.fld select:focus{border-color:var(--gold)}
.fld textarea{resize:vertical;min-height:90px}
.sub-btn{width:100%;padding:1.05rem;background:var(--gold);color:var(--obsidian);border:none;font-family:var(--font-b);font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:all .35s}
.sub-btn:hover{background:var(--gold-l);box-shadow:0 6px 35px rgba(196,162,101,.18)}
.f-note{text-align:center;font-size:.65rem;color:var(--stone);margin-top:1.2rem}
.cta-band{text-align:center;position:relative}
.cta-band::before{content:'';position:absolute;top:0;left:3.5rem;right:3.5rem;height:1px;background:linear-gradient(90deg,transparent,rgba(0,0,0,.05),transparent)}

/* FOOTER */
footer{background:var(--obsidian);border-top:1px solid rgba(255,255,255,.03);padding:4.5rem 3.5rem 2rem}
.f-inner{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:3.5rem;border-bottom:1px solid rgba(255,255,255,.03)}
.f-brand{color:var(--ash);font-weight:300;font-size:.85rem;line-height:1.8;max-width:280px;margin-top:1.2rem}
.f-col h4{font-family:var(--font-b);font-size:.56rem;letter-spacing:.25em;text-transform:uppercase;color:var(--stone);font-weight:600;margin-bottom:1.3rem}
.f-col a{display:block;color:var(--ash);font-size:.85rem;font-weight:300;margin-bottom:.65rem;transition:color .3s}
.f-col a:hover{color:var(--gold)}
.f-bot{max-width:1140px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding-top:2rem}
.f-bot p{font-size:.62rem;color:var(--slate);letter-spacing:.04em}
.f-legal{display:flex;gap:1.5rem}
.f-legal a{font-size:.62rem;color:var(--slate);transition:color .3s}
.f-legal a:hover{color:var(--gold)}

/* REVEAL */
.rv{opacity:0;transform:translateY(16px);transition:opacity .65s var(--t),transform .65s var(--t)}
.rv.vis{opacity:1;transform:translateY(0)}
@keyframes fi{from{opacity:0}to{opacity:1}}
@keyframes fu{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* RESPONSIVE */
@media(max-width:1024px){
  .g3,.dg,.vg{grid-template-columns:repeat(2,1fr)}
  .vi:nth-child(2n){border-right:none}
  .f-inner{grid-template-columns:1fr 1fr}
  .tc,.tc-feat{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .sd{grid-template-columns:1fr;gap:1.2rem}
  .sd-left{position:static}
  .sd-feats{grid-template-columns:1fr}
  .stats-r{grid-template-columns:repeat(2,1fr)}
  .urg-g{grid-template-columns:1fr}
}
@media(max-width:768px){
  nav{padding:1.2rem 1.8rem}
  nav.scrolled{padding:.9rem 1.8rem}
  .nav-links{display:none}
  .hamburger{display:flex}
  .sec{padding:4.5rem 1.8rem}
  .ph,.hh{padding-left:1.8rem;padding-right:1.8rem}
  .ph{min-height:42vh;padding-bottom:3.5rem}
  .hh-c{padding:6.5rem 0 4.5rem}
  .scroll-i{display:none}
  .g2,.c-grid{grid-template-columns:1fr;gap:2.5rem}
  .g3,.dg,.vg{grid-template-columns:1fr}
  .vi{border-right:none!important}
  .fr{grid-template-columns:1fr}
  .tl-s{grid-template-columns:50px 1fr;gap:1.2rem}
  .tl-n{font-size:2.8rem}
  .f-inner{grid-template-columns:1fr}
  .f-bot{flex-direction:column;gap:.8rem;text-align:center}
  .f-legal{justify-content:center}
  .hh .ha{flex-direction:column;align-items:flex-start}
  footer{padding:3.5rem 1.8rem 1.5rem}
  .tc-ph{min-height:260px}
  .tc-feat .tc-ph{min-height:300px}
  .cta-band::before{left:1.8rem;right:1.8rem}
}
