/* ============================================================
   HighTide Capital Group — self-hosted fonts (latin + latin-ext)
   Files served locally; weight mapping mirrors the design source.
   ============================================================ */

/* Cormorant Garamond (wordmark) */
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500 600;font-display:swap;src:url("../assets/fonts/cormorant-latin-ext.woff2") format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500 600;font-display:swap;src:url("../assets/fonts/cormorant-latin.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* Hanken Grotesk (body / UI) */
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url("../assets/fonts/hanken-latin-ext.woff2") format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url("../assets/fonts/hanken-latin.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}

/* Playfair Display (display serif) */
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:500 600;font-display:swap;src:url("../assets/fonts/playfair-italic-latin-ext.woff2") format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:500 600;font-display:swap;src:url("../assets/fonts/playfair-italic-latin.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:500 800;font-display:swap;src:url("../assets/fonts/playfair-latin-ext.woff2") format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:500 800;font-display:swap;src:url("../assets/fonts/playfair-latin.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}



:root{
  /* surfaces */
  --navy-950:#0a131c;
  --navy-900:#0d1a26;
  --navy-850:#10202e;
  --navy-800:#142634;
  --navy-700:#1a2d3d;
  --line:rgba(232,224,205,.10);
  --line-soft:rgba(232,224,205,.06);

  /* ink */
  --ivory:#f3ecdc;
  --white:#f6f3ec;
  --muted:#9aabba;
  --muted-dim:#788c9c; /* AA contrast on navy */

  /* gold */
  --gold:#c7a25c;
  --gold-light:#e0c489;
  --gold-deep:#a9854a;

  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --font-display:"Playfair Display",Georgia,serif;
  --font-logo:"Cormorant Garamond",Georgia,serif;
  --font-sans:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:120px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  background:var(--navy-900);
  color:var(--muted);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:rgba(199,162,92,.28);color:var(--white)}

/* page-top copper→gold filament */
.topbar{
  position:fixed;top:0;left:0;right:0;height:3px;z-index:120;
  background:linear-gradient(90deg,#5e3a23 0%,#a9854a 22%,#e7cf9b 50%,#a9854a 78%,#5e3a23 100%);
}

/* ---- shared layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
section{position:relative}
.eyebrow{
  font-size:12px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::after{content:"";width:46px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{content:"";width:46px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}

.h2{
  font-family:var(--font-display);font-weight:600;color:var(--white);
  font-size:clamp(34px,5vw,58px);line-height:1.04;letter-spacing:-.01em;
  margin:22px 0 0;text-wrap:balance;
}
.h2 em{font-style:italic;color:var(--gold-light)}
.lead{max-width:560px;margin-top:20px;font-size:18px;color:var(--muted);text-wrap:pretty}

.section-pad{padding:clamp(80px,11vw,150px) 0}

/* ============================================================
   WORDMARK (recreated for crisp rendering on exact navy)
   ============================================================ */
.wordmark{display:inline-flex;flex-direction:column;align-items:center;line-height:1;user-select:none}
.wordmark .wm-name{
  font-family:var(--font-logo);font-weight:600;color:var(--ivory);
  letter-spacing:.18em;text-indent:.18em;
}
.wordmark .wm-sub{
  font-family:var(--font-logo);font-weight:600;color:var(--gold);
  letter-spacing:.42em;text-indent:.42em;text-transform:uppercase;
}
.wordmark .wm-wave{margin-top:.35em}
.wordmark .wm-wave path{stroke:url(#goldgrad);fill:none}

/* hero scale */
.wordmark--hero .wm-name{font-size:clamp(40px,7vw,84px)}
.wordmark--hero .wm-sub{font-size:clamp(13px,1.7vw,21px);margin-top:.45em}
.wordmark--hero .wm-wave{width:clamp(220px,32vw,400px)}

/* nav scale */
.wordmark--nav{flex-direction:row;align-items:baseline;gap:.62em;white-space:nowrap}
.wordmark--nav .wm-name{font-size:20px;letter-spacing:.14em;text-indent:.14em;white-space:nowrap}
.wordmark--nav .wm-sub{font-size:8.5px;letter-spacing:.3em;text-indent:.3em;transform:translateY(-1px);white-space:nowrap}
.wordmark--nav .wm-wave{display:none}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:22px;left:0;right:0;z-index:110;display:flex;justify-content:center;padding:0 20px}
.nav-inner{
  display:flex;align-items:center;gap:30px;
  background:rgba(13,26,38,.62);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid var(--line);border-radius:999px;
  padding:11px 14px 11px 26px;
  box-shadow:0 14px 40px -22px rgba(0,0,0,.9);
  transition:background .4s var(--ease),border-color .4s var(--ease);
}
.nav.scrolled .nav-inner{background:rgba(10,19,28,.9)}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--muted);letter-spacing:.01em;
  transition:color .25s var(--ease);position:relative;
}
.nav-links a:hover{color:var(--white)}
.nav-cta{
  background:var(--ivory);color:#16242e;border-radius:999px;
  padding:10px 22px;font-size:13px;font-weight:600;letter-spacing:.04em;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 24px -10px rgba(224,196,137,.5);background:var(--white)}
.nav-burger{display:none;background:none;border:0;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--ivory);transition:.3s var(--ease)}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-sans);font-size:13px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  padding:16px 30px;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .3s var(--ease),background .3s var(--ease),color .3s,box-shadow .3s,border-color .3s;
}
.btn-primary{background:var(--ivory);color:#16242e}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 38px -16px rgba(224,196,137,.55)}
.btn-ghost{background:transparent;color:var(--gold-light);border-color:rgba(199,162,92,.5)}
.btn-ghost:hover{border-color:var(--gold);background:rgba(199,162,92,.08);transform:translateY(-2px)}
.btn-arrow{transition:transform .3s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% 0%,rgba(199,162,92,.10),transparent 55%),
    radial-gradient(120% 120% at 50% 120%,rgba(20,42,58,.9),transparent 60%),
    linear-gradient(180deg,var(--navy-950),var(--navy-900) 55%,var(--navy-850));
}
.hero-bgwave{position:absolute;inset:0;width:100%;height:100%;opacity:.5;pointer-events:none}
.hero-bgwave path{fill:none;stroke:url(#goldgradfaint);stroke-width:1.2}
.hero-grain{position:absolute;inset:0;opacity:.4;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");}
.hero-top{position:absolute;top:clamp(120px,18vh,190px);left:0;right:0;display:flex;justify-content:center;z-index:2}
.hero-inner{position:relative;z-index:3;width:100%;padding-bottom:clamp(72px,12vh,120px)}
.hero-copy{max-width:680px}
.hero-wave{width:140px;height:auto;margin-bottom:26px;display:block}
.hero h1{
  font-family:var(--font-display);font-weight:600;color:var(--white);
  font-size:clamp(40px,5.4vw,66px);line-height:1.08;letter-spacing:-.012em;
  margin:24px 0 0;text-wrap:balance;
}
.hero h1 em{font-style:italic;color:var(--gold-light)}
.hero-sub{margin-top:34px;font-size:clamp(17px,1.5vw,20px);max-width:600px;color:#b4c2cf;text-wrap:pretty}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px;margin-top:38px}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-dim);
  display:flex;flex-direction:column;align-items:center;gap:10px}
.hero-scroll .ln{width:1px;height:42px;background:linear-gradient(var(--gold),transparent);animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ============================================================
   PILLARS (two-card "core")
   ============================================================ */
.pillars{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:60px}
.pillar{
  border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--navy-850);
  transition:transform .45s var(--ease),border-color .45s var(--ease),box-shadow .45s var(--ease);
}
.pillar:hover{transform:translateY(-6px);border-color:rgba(199,162,92,.4);box-shadow:0 30px 60px -34px rgba(0,0,0,.9)}
.pillar-visual{
  aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;position:relative;
  background:
    radial-gradient(110% 120% at 30% 0%,rgba(199,162,92,.12),transparent 60%),
    linear-gradient(150deg,var(--navy-700),var(--navy-950));
  border-bottom:1px solid var(--line);overflow:hidden;
}
.pillar-visual .pv-icon{font-family:var(--font-display);font-size:clamp(40px,6vw,70px);color:rgba(243,236,220,.14);font-style:italic;letter-spacing:.02em}
.pillar-visual .pv-tag{position:absolute;top:20px;left:22px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}
.pillar-body{padding:30px 30px 34px}
.pillar-head{display:flex;align-items:center;justify-content:space-between;gap:16px}
.pillar-head h3{font-family:var(--font-display);font-weight:600;color:var(--white);font-size:25px}
.pillar-body p{margin-top:14px;font-size:16px;color:var(--muted)}
.pillar-role{margin-top:22px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600}

.badge{
  font-size:10.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold-light);border:1px solid rgba(199,162,92,.4);border-radius:999px;
  padding:5px 12px;white-space:nowrap;
}

/* ============================================================
   APPROACH (disciplines grid)
   ============================================================ */
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:60px;
  background:var(--line-soft);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.disc{background:var(--navy-900);padding:42px 34px;transition:background .4s var(--ease)}
.disc:hover{background:var(--navy-850)}
.disc-num{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--gold);opacity:.85}
.disc h3{font-family:var(--font-display);font-weight:600;color:var(--white);font-size:23px;margin:16px 0 12px}
.disc p{font-size:15.5px;color:var(--muted)}

/* ============================================================
   CRITERIA / STATS
   ============================================================ */
.criteria{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,90px);align-items:start;margin-top:60px}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-soft);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.stat{background:var(--navy-900);padding:30px 28px}
.stat .num{font-family:var(--font-display);font-weight:600;color:var(--gold-light);font-size:clamp(34px,4vw,48px);line-height:1}
.stat .lbl{margin-top:8px;font-size:13px;letter-spacing:.04em;color:var(--muted)}
.spec-list{display:flex;flex-direction:column}
.spec{display:grid;grid-template-columns:200px 1fr;gap:20px;padding:22px 4px;border-bottom:1px solid var(--line);align-items:baseline}
.spec:last-child{border-bottom:0}
.spec dt{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.spec dd{font-size:16.5px;color:var(--white);font-weight:500}
.spec dd span{display:block;color:var(--muted);font-weight:400;font-size:15px;margin-top:3px}

/* ============================================================
   FOCUS (filterable grid)
   ============================================================ */
.filters{margin-top:46px;display:flex;flex-direction:column;gap:14px}
.filter-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.filter-label{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted-dim);width:64px;flex-shrink:0}
.chip{
  font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--muted);
  background:transparent;border:1px solid var(--line);border-radius:999px;
  padding:8px 18px;cursor:pointer;transition:.25s var(--ease);
}
.chip:hover{color:var(--white);border-color:rgba(232,224,205,.25)}
.chip.active{background:var(--ivory);color:#16242e;border-color:var(--ivory)}

.focus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:42px}
.fcard{
  border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--navy-850);
  display:flex;flex-direction:column;transition:transform .45s var(--ease),border-color .45s var(--ease),box-shadow .45s var(--ease),opacity .4s var(--ease);
}
.fcard:hover{transform:translateY(-6px);border-color:rgba(199,162,92,.4);box-shadow:0 28px 56px -34px rgba(0,0,0,.9)}
.fcard-visual{aspect-ratio:5/3;display:flex;align-items:center;justify-content:center;position:relative;
  background:radial-gradient(120% 130% at 40% 0%,rgba(199,162,92,.10),transparent 55%),linear-gradient(155deg,var(--navy-700),var(--navy-950));
  border-bottom:1px solid var(--line);}
.fcard-visual .fi{font-family:var(--font-display);font-style:italic;font-size:clamp(30px,4vw,46px);color:rgba(243,236,220,.16)}
.fcard-body{padding:24px 24px 26px;flex:1;display:flex;flex-direction:column}
.fcard-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.fcard-head h3{font-family:var(--font-display);font-weight:600;color:var(--white);font-size:21px;line-height:1.15}
.fcard-body p{margin-top:12px;font-size:15px;color:var(--muted);flex:1}
.fcard-meta{margin-top:20px;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600}
.fcard.is-hidden{display:none}

/* ============================================================
   ABOUT
   ============================================================ */
.about{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,7vw,100px);align-items:start;margin-top:54px}
.about-body p{font-size:17px;color:var(--muted);margin-bottom:20px;text-wrap:pretty}
.about-body p:first-child{color:#c3cfd9;font-size:19px}
.about-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.tag{font-size:12px;letter-spacing:.1em;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:7px 15px}
.about-side{position:sticky;top:120px}
.brandplate{border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 30px 70px -40px rgba(0,0,0,.9)}
.brandplate img{width:100%}

/* ============================================================
   TEAM
   ============================================================ */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:56px}
.member{display:grid;grid-template-columns:160px 1fr;gap:28px;align-items:start;
  border:1px solid var(--line);border-radius:18px;background:var(--navy-850);padding:28px;
  transition:border-color .4s var(--ease)}
.member:hover{border-color:rgba(199,162,92,.35)}
.member .photo{aspect-ratio:1;border-radius:14px;overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(155deg,var(--navy-700),var(--navy-950));display:flex;align-items:center;justify-content:center}
.member .photo .ph-mono{font-family:monospace;font-size:10px;letter-spacing:.05em;color:var(--muted-dim);text-align:center;padding:0 8px}
.member .photo image-slot,.member .photo img{width:100%;height:100%;object-fit:cover}
.member h3{font-family:var(--font-display);font-weight:600;color:var(--white);font-size:24px}
.member .mrole{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:7px;font-weight:600}
.member .mbio{margin-top:16px;font-size:15.5px;color:var(--muted)}
.member .mlinks{margin-top:18px;display:flex;gap:18px;font-size:13px;letter-spacing:.04em}
.member .mlinks a{color:var(--gold-light);transition:.25s}
.member .mlinks a:hover{color:var(--white)}

/* ============================================================
   ENGAGE (open to)
   ============================================================ */
.engage-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.engage{border:1px solid var(--line);border-radius:18px;background:var(--navy-850);padding:38px 32px;
  transition:transform .4s var(--ease),border-color .4s var(--ease)}
.engage:hover{transform:translateY(-5px);border-color:rgba(199,162,92,.4)}
.engage .en-no{font-family:var(--font-display);font-style:italic;color:var(--gold);font-size:17px}
.engage h3{font-family:var(--font-display);font-weight:600;color:var(--white);font-size:24px;margin:14px 0 14px}
.engage p{font-size:15.5px;color:var(--muted)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{margin-top:50px;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;background:none;border:0;cursor:pointer;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:30px 4px;font-family:var(--font-display);font-weight:500;color:var(--white);
  font-size:clamp(20px,2.4vw,26px);transition:color .25s}
.faq-q:hover{color:var(--gold-light)}
.faq-icon{flex-shrink:0;width:34px;height:34px;border:1px solid var(--line);border-radius:999px;
  display:flex;align-items:center;justify-content:center;position:relative;transition:.3s var(--ease)}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;background:var(--gold);transition:.3s var(--ease)}
.faq-icon::before{width:13px;height:1.5px}
.faq-icon::after{width:1.5px;height:13px}
.faq-item.open .faq-icon{background:var(--gold);border-color:var(--gold)}
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after{background:#16242e}
.faq-item.open .faq-icon::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-a-inner{padding:0 4px 30px;max-width:760px;font-size:16.5px;color:var(--muted)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:
   radial-gradient(100% 120% at 50% 0%,rgba(199,162,92,.08),transparent 55%),
   linear-gradient(180deg,var(--navy-850),var(--navy-950));
   border-top:1px solid var(--line)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,7vw,90px);margin-top:50px;align-items:start}
.contact-side h2{font-family:var(--font-display);font-weight:600;color:var(--white);font-size:clamp(34px,4.6vw,52px);line-height:1.05}
.contact-side h2 em{font-style:italic;color:var(--gold-light)}
.contact-links{margin-top:34px;display:flex;flex-direction:column;gap:2px}
.contact-links a{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);
  font-size:16px;color:var(--white);transition:.25s}
.contact-links a:hover{color:var(--gold-light);padding-left:6px}
.contact-links a .cl-k{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-dim);width:90px}
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-dim)}
.field input,.field textarea{
  font-family:var(--font-sans);font-size:16px;color:var(--white);
  background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;
  padding:15px 16px;transition:border-color .25s,background .25s}
.field input:focus,.field textarea:focus{outline:none;border-color:rgba(199,162,92,.6);background:rgba(199,162,92,.05)}
.field textarea{resize:vertical;min-height:130px}
.form .btn{grid-column:1/-1;justify-self:start}
.form-note{grid-column:1/-1;font-size:13px;color:var(--muted-dim)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--line);background:var(--navy-950);padding:54px 0 40px}
.footer-top{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.footer-nav{display:flex;gap:26px;flex-wrap:wrap}
.footer-nav a{font-size:14px;color:var(--muted);transition:.25s}
.footer-nav a:hover{color:var(--white)}
.footer-bottom{margin-top:40px;padding-top:24px;border-top:1px solid var(--line-soft);
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  font-size:13px;color:var(--muted-dim)}
.footer-bottom a{color:var(--muted);transition:.25s}
.footer-bottom a:hover{color:var(--gold-light)}

/* ============================================================
   REVEAL animation
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  .reveal[data-d="1"]{transition-delay:.08s}
  .reveal[data-d="2"]{transition-delay:.16s}
  .reveal[data-d="3"]{transition-delay:.24s}
  .reveal[data-d="4"]{transition-delay:.32s}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-inner{padding:11px 14px 11px 22px;gap:14px}
  .pillars,.criteria,.about,.team-grid,.contact-grid{grid-template-columns:1fr}
  .approach-grid,.focus-grid,.engage-grid{grid-template-columns:1fr 1fr}
  .about-side{position:static}
  .member{grid-template-columns:120px 1fr;gap:20px}
  .spec{grid-template-columns:1fr;gap:6px}
  .spec dt{margin-bottom:0}
}
@media (max-width:600px){
  .wrap{padding:0 20px}
  body{font-size:16px}
  .approach-grid,.focus-grid,.engage-grid,.stats{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .member{grid-template-columns:1fr}
  .member .photo{width:120px}
  .hero-cta .btn{flex:1}
}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:130;background:rgba(8,15,22,.96);backdrop-filter:blur(14px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.drawer.open{opacity:1;pointer-events:auto}
.drawer a{font-family:var(--font-display);font-size:30px;color:var(--white);padding:14px;transition:color .25s}
.drawer a:hover{color:var(--gold-light)}
.drawer-close{position:absolute;top:26px;right:26px;background:none;border:0;color:var(--ivory);font-size:30px;cursor:pointer;line-height:1}
/* ============================================================
   Production additions — accessibility, images, new components.
   Pure additions; the core design system is untouched.
   ============================================================ */

/* accessible focus states */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}
.btn:focus-visible,.nav-cta:focus-visible,.chip:focus-visible{outline-offset:2px}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{outline:none;border-color:rgba(199,162,92,.7);background:rgba(199,162,92,.06)}

/* skip link */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--ivory);color:#16242e;
  padding:12px 22px;border-radius:0 0 12px 0;font-weight:600;font-size:14px}
.skip-link:focus{left:0}

/* brandplate keeps intrinsic aspect ratio */
.brandplate img{height:auto}

/* pillar photography (navy/gold treated) */
.pillar-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pillar-visual .pv-scrim{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,19,28,.55),rgba(10,19,28,.08) 45%,rgba(10,19,28,.35))}
.pillar-visual .pv-tag{z-index:2}

/* focus-card photography (navy/gold treated) */
.fcard-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.fcard-visual .pv-scrim{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,19,28,.45),rgba(10,19,28,.08) 45%,rgba(10,19,28,.3))}

/* partner proof points */
.stats--proof{grid-template-columns:repeat(4,1fr);margin-top:56px}
.proof-note{margin-top:16px;font-size:13px;color:var(--muted-dim)}
@media (max-width:900px){.stats--proof{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.stats--proof{grid-template-columns:1fr}}

/* expandable full bios */
.bio-more{margin-top:16px}
.bio-more summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-light);
  transition:color .25s var(--ease)}
.bio-more summary::-webkit-details-marker{display:none}
.bio-more summary::after{content:"+";font-family:var(--font-display);font-size:15px;transform:translateY(-1px)}
.bio-more[open] summary::after{content:"\2212"}
.bio-more summary:hover{color:var(--white)}
.bio-more p{margin-top:14px;font-size:15px;color:var(--muted)}

/* engage card link */
.engage-link{display:inline-block;margin-top:18px;font-size:13px;letter-spacing:.04em;color:var(--gold-light);transition:color .25s}
.engage-link:hover{color:var(--white)}

/* contact: static address row */
.contact-links .cl-static{display:flex;align-items:center;gap:14px;padding:16px 0;
  border-bottom:1px solid var(--line);font-size:16px;color:var(--white)}
.contact-links .cl-static .cl-k{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-dim);width:90px;flex-shrink:0}
.contact-links .cl-static address{font-style:normal}

/* form: select styling to match inputs */
.field select{
  font-family:var(--font-sans);font-size:16px;color:var(--white);
  background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;
  padding:15px 42px 15px 16px;transition:border-color .25s,background .25s;
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23c7a25c' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;
}
.field select:focus{outline:none;border-color:rgba(199,162,92,.6);background-color:rgba(199,162,92,.05)}
.field select option{background:var(--navy-850);color:var(--white)}
.field .optional{color:var(--muted-dim);letter-spacing:.08em;text-transform:none;font-size:11px}

/* form status message */
.form-status{grid-column:1/-1;font-size:15px;display:none;border-radius:12px;padding:14px 16px}
.form-status.ok{display:block;color:#cfe3cf;background:rgba(110,160,110,.12);border:1px solid rgba(110,160,110,.35)}
.form-status.err{display:block;color:#e3cfcf;background:rgba(180,110,110,.12);border:1px solid rgba(180,110,110,.35)}

/* honeypot */
.hp{position:absolute;left:-9999px;height:0;overflow:hidden}

/* subpage hero (For Owners, thanks) */
.page-hero{position:relative;display:flex;align-items:flex-end;min-height:62svh;overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% 0%,rgba(199,162,92,.10),transparent 55%),
    linear-gradient(180deg,var(--navy-950),var(--navy-900) 55%,var(--navy-850))}
.page-hero .hero-inner{padding-top:180px;padding-bottom:clamp(56px,9vh,90px)}
.page-hero h1{font-family:var(--font-display);font-weight:600;color:var(--white);
  font-size:clamp(36px,4.8vw,58px);line-height:1.08;letter-spacing:-.012em;margin:24px 0 0;text-wrap:balance}
.page-hero h1 em{font-style:italic;color:var(--gold-light)}

/* thanks page */
.thanks-main{min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;
  background:radial-gradient(120% 90% at 50% 0%,rgba(199,162,92,.08),transparent 55%),linear-gradient(180deg,var(--navy-950),var(--navy-900))}
.thanks-card{max-width:560px;padding:40px 28px}
.thanks-card .h2{margin-top:26px}
.thanks-card p{margin-top:20px;font-size:17px;color:var(--muted)}
.thanks-card .btn{margin-top:34px}
