:root{
  --ink:#10171f;
  --ink-2:#1a232e;
  --paper:#f5efe4;
  --paper-2:#ece3d3;
  --brass:#c08a3e;
  --brass-bright:#e0a84e;
  --cream:#fbf7ee;
  --muted:#8a93a0;
  --muted-dark:#5c6675;
  --line:rgba(16,23,31,.12);
  --line-dark:rgba(245,239,228,.14);
  --maxw:1240px;
  --measure:66ch;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  font-weight:400;
  line-height:1.65;
  letter-spacing:-.005em;
  font-feature-settings:"ss01","cv01","liga","kern";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* editorial paragraph defaults: comfortable measure + rhythm */
p{max-width:var(--measure);line-height:1.65}
/* film grain overlay */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  font-weight:600;color:var(--brass);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--brass);display:inline-block}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:-.015em}

/* ---------- NAV ---------- */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:background .4s ease,backdrop-filter .4s ease,border-color .4s;
  border-bottom:1px solid transparent;
}
header.nav.scrolled{
  background:rgba(245,239,228,.82);backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--serif);font-size:1.35rem;letter-spacing:-.02em;font-weight:500;display:flex;align-items:center;gap:.6rem}
.brand .mark{
  width:36px;height:36px;position:relative;z-index:0;
  perspective:140px;transform-style:preserve-3d;
  display:grid;place-items:center;
  font-size:.7rem;font-weight:700;font-family:var(--sans);letter-spacing:.02em;line-height:1;
  color:var(--ink);
}
/* the JFH letters sit flat and crisp on top of the orbiting rings (rings are z-index:-1) */
/* two tilted rings orbiting on different axes = gyroscope */
.brand .mark::before,.brand .mark::after{
  content:"";position:absolute;inset:1px;border-radius:50%;pointer-events:none;
  transform-style:preserve-3d;backface-visibility:visible;will-change:transform;z-index:-1;
}
.brand .mark::before{border:1.5px solid var(--ink);animation:gyroA 4.2s linear infinite}
.brand .mark::after{border:1.5px solid var(--brass);animation:gyroB 5.6s linear infinite}
/* faint static outer hoop so the orbit reads as a sphere */

@keyframes gyroA{from{transform:rotateZ(0deg) rotateX(70deg)}to{transform:rotateZ(360deg) rotateX(70deg)}}
@keyframes gyroB{from{transform:rotateZ(0deg) rotateY(70deg)}to{transform:rotateZ(-360deg) rotateY(70deg)}}
@keyframes breathe{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}
@media (prefers-reduced-motion: reduce){
  .brand .mark::before,.brand .mark::after,.hero-bg,.page-hero-bg,.marquee-track{animation:none}
  .reveal{transition:none;opacity:1;transform:none}
  *{scroll-behavior:auto}
}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--ink);position:relative;opacity:.82;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.nav-links a.active{opacity:1;color:var(--brass)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;height:1.5px;width:0;background:var(--brass);transition:width .28s ease}
.nav-links a:hover::after{width:100%}
.nav-links a.active::after{width:100%}
.nav-links a.btn-primary::after{display:none}
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--sans);font-weight:600;font-size:.92rem;
  padding:.72em 1.4em;border-radius:100px;cursor:pointer;border:none;
  transition:transform .2s ease,box-shadow .25s ease,background .25s;
}
.btn-primary{background:var(--ink);color:var(--cream)}
.nav-links a.btn-primary{color:var(--cream);opacity:1}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px -10px rgba(16,23,31,.5)}
.btn-brass{background:var(--brass);color:#1a1206}
.btn-brass:hover{background:var(--brass-bright);transform:translateY(-2px);box-shadow:0 12px 28px -10px rgba(192,138,62,.6)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(3px)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);display:block;transition:.3s}

/* ---------- HERO ---------- */
.hero{position:relative;padding:170px 0 90px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;will-change:transform,opacity;animation:breathe 12s ease-in-out infinite;
  background:
    radial-gradient(60% 80% at 78% 18%,rgba(192,138,62,.16),transparent 60%),
    radial-gradient(50% 60% at 12% 95%,rgba(16,23,31,.06),transparent 60%);
}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.35fr .9fr;gap:60px;align-items:end}
.hero h1{font-size:clamp(3rem,7.4vw,6.4rem);font-weight:300;margin:.32em 0 .35em}
.hero h1 em{font-style:italic;color:var(--brass);font-weight:400}
.hero .lead{font-size:1.12rem;max-width:30ch;color:var(--muted-dark);line-height:1.6}
.hero-cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.hero-aside{padding-bottom:8px}
.hero-stat{display:block;border-top:1px solid var(--line);padding:20px 0;transition:border-color .25s}
.hero-stat .n{font-family:var(--serif);font-size:2.4rem;line-height:1;letter-spacing:-.02em;transition:color .25s}
.hero-stat .l{font-size:.84rem;color:var(--muted-dark);margin-top:6px;letter-spacing:.02em}
a.hero-stat:hover{border-color:var(--brass)}
a.hero-stat:hover .n{color:var(--brass)}
.marquee{margin-top:64px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap;padding:18px 0}
.marquee-track{display:inline-block;animation:slide 34s linear infinite}
.marquee span{font-family:var(--serif);font-style:italic;font-size:1.55rem;color:var(--ink);opacity:.55;margin:0 .9em}
.marquee b{color:var(--brass);font-style:normal;font-family:var(--sans);font-weight:600;font-size:.7em;letter-spacing:.2em;text-transform:uppercase;vertical-align:middle;margin:0 .9em}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* page hero (interior pages) */
.page-hero{position:relative;padding:150px 0 60px;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;z-index:0;will-change:transform,opacity;animation:breathe 14s ease-in-out infinite;
  background:radial-gradient(60% 80% at 80% 10%,rgba(192,138,62,.14),transparent 60%);
}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-size:clamp(2.6rem,6vw,5rem);font-weight:300;margin:.3em 0 .35em}
.page-hero h1 em{font-style:italic;color:var(--brass);font-weight:400}
.page-hero .lead{font-size:1.12rem;max-width:50ch;color:var(--muted-dark);line-height:1.65}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- SECTIONS ---------- */
section{position:relative}
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2.1rem,4.6vw,3.6rem);font-weight:300;margin:.4em 0 .3em}
.sec-head h2 em{font-style:italic;color:var(--brass)}
.sec-head p{color:var(--muted-dark);font-size:1.06rem;line-height:1.65;max-width:54ch}

/* HOME intro */
.home-intro{padding:30px 0 110px}
.home-intro .grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.home-intro h2{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:300}
.home-intro h2 em{font-style:italic;color:var(--brass)}
.home-intro p{color:var(--muted-dark);font-size:1.05rem;line-height:1.78;margin-bottom:1.1em}
.home-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:70px}
.home-card{background:var(--paper);padding:40px 34px;transition:background .3s}
.home-card:hover{background:var(--cream)}
.home-card .k{font-family:var(--serif);font-size:.95rem;color:var(--brass)}
.home-card h3{font-size:1.5rem;font-weight:400;margin:14px 0 10px}
.home-card p{color:var(--muted-dark);font-size:.98rem;line-height:1.6;margin-bottom:18px}
.home-card a{font-size:.86rem;font-weight:600;letter-spacing:.04em;color:var(--ink);display:inline-flex;align-items:center;gap:.4em}
.home-card a .arr{transition:transform .25s}
.home-card:hover a .arr{transform:translateX(3px)}

/* SERVICES */
.services-section{padding:84px 0;background:var(--ink);color:var(--cream)}
.services-section .eyebrow{color:var(--brass-bright)}
.services-section .sec-head h2{color:var(--cream)}
.services-section .sec-head p{color:rgba(251,247,238,.66)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-dark);margin-top:40px;border:1px solid var(--line-dark)}
.svc{background:var(--ink);padding:34px 32px;position:relative;transition:background .35s}
.svc:hover{background:var(--ink-2)}
.svc-link{position:absolute;inset:0;z-index:2}
.svc-num{font-family:var(--serif);font-size:.85rem;color:var(--brass);opacity:.8}
.svc h3{font-size:1.42rem;font-weight:400;margin:12px 0 10px;color:var(--cream)}
.svc p{color:rgba(251,247,238,.62);font-size:.94rem;line-height:1.55;max-width:46ch}
.svc .tags{margin-top:16px;display:flex;flex-wrap:wrap;gap:7px}
.svc .tags i{font-style:normal;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(251,247,238,.5);border:1px solid var(--line-dark);padding:.38em .75em;border-radius:100px}
.svc.wide{grid-column:1 / -1}
.svc-arrow{position:absolute;top:34px;right:32px;color:var(--brass);opacity:0;transform:translate(-6px,6px);transition:.3s}
.svc:hover .svc-arrow{opacity:1;transform:none}

/* STORY */
.story-section{padding:80px 0 130px}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-top:18px}
.story-lead h2{font-size:clamp(2.3rem,4.8vw,3.8rem);font-weight:300;line-height:1.05}
.story-lead h2 em{font-style:italic;color:var(--brass)}
.story-body p{color:var(--muted-dark);font-size:1.05rem;line-height:1.78;margin-bottom:1.25em}
.story-body p:first-child::first-letter{
  font-family:var(--serif);font-size:3.4rem;float:left;line-height:.82;margin:.06em .12em 0 0;color:var(--brass);font-weight:500;
}
.pullquote{
  margin:120px auto 0;max-width:24ch;text-align:center;
}
.pullquote p{font-family:var(--serif);font-style:italic;font-size:clamp(1.8rem,4vw,3rem);font-weight:300;line-height:1.18;letter-spacing:-.01em}
.pullquote .cite{margin-top:24px;font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);font-weight:600;font-family:var(--sans)}

/* VALUES (scoped) */
.values-section{padding:80px 0 130px}
.values-intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-top:18px}
.values-intro h2{font-size:clamp(2.3rem,4.8vw,3.8rem);font-weight:300;line-height:1.05}
.values-intro h2 em{font-style:italic;color:var(--brass)}
.values-intro .values-lede p{color:var(--muted-dark);font-size:1.05rem;line-height:1.78;margin-bottom:1.25em}
.value-list{margin-top:96px;display:flex;flex-direction:column}
.value-block{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:baseline;padding:54px 0;border-top:1px solid var(--line)}
.value-block:last-child{border-bottom:1px solid var(--line)}
.value-block .value-mark{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--brass);letter-spacing:.02em}
.value-block h3{font-size:clamp(1.9rem,3.4vw,2.7rem);font-weight:300;line-height:1.08;margin-top:14px}
.value-block h3 em{font-style:italic;color:var(--brass)}
.value-block .value-body p{color:var(--muted-dark);font-size:1.08rem;line-height:1.74;margin-bottom:1.1em;max-width:52ch}
.value-block .value-body p:last-child{margin-bottom:0}
.values-close{margin:120px auto 0;max-width:30ch;text-align:center}
.values-close p{font-family:var(--serif);font-style:italic;font-size:clamp(1.8rem,4vw,3rem);font-weight:300;line-height:1.18;letter-spacing:-.01em}
.values-close .cite{margin-top:24px;font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);font-weight:600;font-family:var(--sans)}
@media(max-width:900px){
  .values-intro{grid-template-columns:1fr;gap:30px}
  .value-block{grid-template-columns:1fr;gap:18px;padding:42px 0}
  .value-list{margin-top:60px}
  .values-close{margin-top:80px}
}

/* TEAM */
.team-section{padding:80px 0 120px;background:var(--paper-2)}
.team-lead{display:grid;grid-template-columns:1fr;gap:28px;margin-top:56px}
/* the two founders sit as a pair directly under the CEO */
.founders{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
/* denser 3-across grid so more of the team is visible at once */
.bros{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:24px}
.bro{background:var(--cream);border:1px solid var(--line);border-radius:6px;padding:28px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.bro.lead-card{padding:44px 48px}
.bro::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--brass),var(--brass-bright))}
.bro.lead-card::before{height:4px}
.bro .role{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:700;line-height:1.4}
.bro h3{font-size:1.45rem;font-weight:400;margin:8px 0 5px;line-height:1.1}
.bro .creds{font-size:.85rem;color:var(--ink);font-weight:600;margin-bottom:14px;line-height:1.45}
.bro p{color:var(--muted-dark);font-size:.93rem;line-height:1.6;max-width:none}
/* lead card stays larger */
.bro.lead-card .role{font-size:.78rem;letter-spacing:.18em}
.bro.lead-card h3{font-size:2rem;margin:10px 0 6px}
.bro.lead-card .creds{font-size:.96rem;margin-bottom:18px}
.bro.lead-card p{font-size:1.04rem;line-height:1.72}
.bro .initial{position:absolute;right:-8px;bottom:-26px;font-family:var(--serif);font-size:8.5rem;line-height:1;color:var(--ink);opacity:.045;font-weight:500;pointer-events:none}
.bro.lead-card .initial{font-size:13rem;right:-10px;bottom:-34px}
.bro-foot{margin-top:auto;padding-top:18px;display:flex;align-items:center;justify-content:space-between;gap:14px;position:relative;z-index:1}
.bro-link{font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--ink);display:inline-flex;align-items:center;gap:.45em}
.bro-link .arr{transition:transform .25s}
.bro:hover .bro-link{color:var(--brass)}
.bro:hover .bro-link .arr{transform:translateX(3px)}

/* ---------- SOCIALS (reusable icon row, cards + profiles) ---------- */
.socials{display:inline-flex;align-items:center;gap:10px}
.socials a{
  width:30px;height:30px;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--line);color:var(--muted-dark);
  transition:color .2s,border-color .2s,background .2s,transform .2s;
}
.socials a:hover{color:var(--brass);border-color:var(--brass);transform:translateY(-2px)}
.socials svg{width:15px;height:15px;display:block}
.profile-socials{margin-top:8px}
.profile-head .profile-socials{margin-top:14px}

/* PROFILE (interior team member page) */
.profile-section{padding:40px 0 120px}
.profile{max-width:760px;margin:0 auto}
.back-link{display:inline-flex;align-items:center;gap:.5em;font-size:.88rem;font-weight:600;letter-spacing:.02em;color:var(--muted-dark);margin-bottom:46px;transition:color .2s}
.back-link:hover{color:var(--brass)}
.back-link .arr{transition:transform .25s}
.back-link:hover .arr{transform:translateX(-3px)}
.profile-head{display:flex;gap:30px;align-items:center;padding-bottom:34px;border-bottom:1px solid var(--line);margin-bottom:38px}
.profile-mono{flex:none;width:96px;height:96px;border-radius:50%;background:var(--ink);color:var(--cream);display:grid;place-items:center;font-family:var(--serif);font-size:2.6rem;font-weight:400;letter-spacing:-.01em}
.profile-head .role{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);font-weight:600}
.profile-head h1{font-size:clamp(2.2rem,4.6vw,3rem);font-weight:400;margin:8px 0 8px}
.profile-head .creds{font-size:.96rem;color:var(--ink);font-weight:600}
.profile-intro p{color:var(--muted-dark);font-size:1.1rem;line-height:1.75;margin-bottom:1.1em}
.profile-block{margin-top:42px}
.profile-block h2{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);font-weight:600;font-family:var(--sans);margin-bottom:20px}
.profile-list{list-style:none;display:flex;flex-direction:column;gap:18px}
.profile-list li{position:relative;padding-left:26px;color:var(--ink);font-size:1.02rem;line-height:1.6}
.profile-list li::before{content:"";position:absolute;left:0;top:.62em;width:9px;height:9px;border-radius:50%;background:var(--brass)}
.profile-list li b{font-weight:600}
.profile-list li span{display:block;color:var(--muted-dark);font-size:.96rem;margin-top:3px}
.profile-edu li{padding-left:26px}
.profile-edu li::before{content:"";position:absolute;left:0;top:.62em;width:9px;height:9px;border-radius:50%;background:transparent;border:1.5px solid var(--brass)}
@media(max-width:560px){
  .profile-head{flex-direction:column;align-items:flex-start;gap:20px}
  .profile-mono{width:74px;height:74px;font-size:2rem}
}

/* CONTACT / FORM */
.contact-section{padding:80px 0 130px;background:var(--ink);color:var(--cream)}
.contact-section .eyebrow{color:var(--brass-bright)}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:70px;margin-top:24px;align-items:start}
.contact-copy h2{color:var(--cream);font-size:clamp(2.2rem,4.6vw,3.6rem);font-weight:300}
.contact-copy h2 em{font-style:italic;color:var(--brass)}
.contact-copy p{color:rgba(251,247,238,.66);font-size:1.06rem;line-height:1.7;margin-top:18px;max-width:42ch}
.contact-meta{margin-top:40px;border-top:1px solid var(--line-dark);padding-top:26px;display:flex;flex-direction:column;gap:14px}
.contact-meta a,.contact-meta span{color:rgba(251,247,238,.8);font-size:.98rem;display:flex;align-items:center;gap:10px}
.contact-meta a:hover{color:var(--brass-bright)}
form.intake{background:var(--ink-2);border:1px solid var(--line-dark);border-radius:12px;padding:42px}
.field{margin-bottom:22px}
.field label{display:block;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(251,247,238,.7);margin-bottom:9px;font-weight:600}
.field label .req{color:var(--brass-bright)}
.field input,.field textarea{
  width:100%;background:rgba(245,239,228,.04);border:1px solid var(--line-dark);border-radius:8px;
  padding:14px 16px;color:var(--cream);font-family:var(--sans);font-size:1rem;transition:border .2s,background .2s;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(251,247,238,.32)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--brass);background:rgba(245,239,228,.07)}
.field textarea{resize:vertical;min-height:110px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{position:relative}
.chip input{position:absolute;opacity:0;width:0;height:0}
.chip label{
  display:inline-block;text-transform:none;letter-spacing:0;font-weight:500;font-size:.92rem;margin:0;
  border:1px solid var(--line-dark);border-radius:100px;padding:.6em 1.1em;cursor:pointer;color:rgba(251,247,238,.78);transition:.2s;
}
.chip input:checked + label{background:var(--brass);border-color:var(--brass);color:#1a1206}
form .btn{width:100%;justify-content:center;margin-top:8px;font-size:1rem;padding:1em}
.form-note{font-size:.82rem;color:rgba(251,247,238,.45);margin-top:16px;text-align:center}
.form-status{margin-top:18px;font-size:.95rem;border-radius:8px;padding:14px 16px;display:none}
.form-status.show{display:block}
.form-status.ok{background:rgba(80,180,120,.14);border:1px solid rgba(80,180,120,.4);color:#bfe9cf}
.form-status.err{background:rgba(210,90,70,.14);border:1px solid rgba(210,90,70,.4);color:#f0c2b8}
.success-state{display:none;text-align:center;padding:30px 10px}
.success-state.show{display:block}
.success-state .tick{width:62px;height:62px;border-radius:50%;background:var(--brass);display:grid;place-items:center;margin:0 auto 22px;color:#1a1206;font-size:1.8rem}
.success-state h3{font-size:2rem;font-weight:400;color:var(--cream)}
.success-state p{color:rgba(251,247,238,.66);margin-top:12px;line-height:1.6}

/* FOOTER */
footer{background:var(--paper-2);padding:60px 0 40px}
.foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:30px}
.foot .brand{font-size:1.6rem}
.foot .tag{font-family:var(--serif);font-style:italic;color:var(--muted-dark);font-size:1.05rem;margin-top:6px}
.foot-right{text-align:right;font-size:.88rem;color:var(--muted-dark);line-height:1.8}
.foot-right a:hover{color:var(--brass)}
.copyright{margin-top:40px;border-top:1px solid var(--line);padding-top:22px;font-size:.82rem;color:var(--muted-dark);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .hero-grid,.story-grid,.svc-grid,.contact-grid,.home-intro .grid,.home-cards{grid-template-columns:1fr}
  /* open mobile menu flows HORIZONTALLY (row, wraps as needed) */
  .nav-links{
    display:none;position:absolute;top:74px;left:0;right:0;
    background:rgba(245,239,228,.96);backdrop-filter:blur(14px) saturate(1.2);
    flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;
    row-gap:16px;column-gap:26px;padding:22px 28px;border-bottom:1px solid var(--line);
    box-shadow:0 18px 30px -22px rgba(16,23,31,.45);
  }
  .nav-links.open{display:flex}
  .nav-links a{font-size:1rem;opacity:1;padding:.2em 0}
  .nav-links a.btn-primary{flex-basis:100%;justify-content:center;text-align:center;margin-top:4px}
  .nav-toggle{display:flex}
  .bros{grid-template-columns:repeat(2,1fr);gap:18px}
  .hero-aside{display:flex;gap:30px;padding-top:30px}
  .hero-stat{border-top:none;flex:1;padding:0}
  .pullquote{margin-top:70px}
  .story-grid{gap:34px}
  .svc{padding:28px 24px}
  form.intake{padding:36px 26px}
}
@media(max-width:560px){
  .two{grid-template-columns:1fr}
  .bros,.founders{grid-template-columns:1fr}
  .hero-aside{flex-direction:column;gap:18px}
}

/* ---------- DARK MODE (system / prefers-color-scheme) ---------- */
@media (prefers-color-scheme: dark){
  :root{
    --ink:#f3ece0;            /* primary TEXT becomes warm cream */
    --ink-2:#1d2630;          /* elevated dark surface */
    --paper:#0d1318;          /* page background */
    --paper-2:#121a21;        /* secondary surface (footer / team) */
    --cream:#fbf7ee;          /* on-dark text for already-dark sections */
    --brass:#d59a4c;          /* slightly brighter so it reads on dark */
    --brass-bright:#ecb761;
    --muted:#8a93a0;
    --muted-dark:#aab3c0;     /* readable secondary text on dark */
    --line:rgba(243,236,224,.14);
    --line-dark:rgba(243,236,224,.12);
  }
  body{background:var(--paper);color:var(--ink)}
  body::after{opacity:.05}

  /* nav */
  header.nav.scrolled{
    background:rgba(13,19,24,.82);border-bottom:1px solid var(--line);
  }
  .nav-links a{color:var(--ink)}
  .nav-toggle span{background:var(--ink)}
  .brand .mark{color:var(--ink)}
  .brand .mark::before{border-color:var(--ink)}
  @media(max-width:900px){
    .nav-links{background:rgba(13,19,24,.96)}
  }

  /* buttons: invert primary so it stays high-contrast */
  .btn-primary{background:var(--ink);color:#0d1318}
  .nav-links a.btn-primary{color:#0d1318}
  .btn-ghost{border-color:var(--line);color:var(--ink)}
  .btn-ghost:hover{border-color:var(--ink)}

  /* hero atmospheres: deepen so glow reads on dark */
  .hero-bg{
    background:
      radial-gradient(60% 80% at 78% 18%,rgba(213,154,76,.18),transparent 60%),
      radial-gradient(50% 60% at 12% 95%,rgba(120,150,190,.08),transparent 60%);
  }
  .page-hero-bg{background:radial-gradient(60% 80% at 80% 10%,rgba(213,154,76,.16),transparent 60%)}
  .marquee span{color:var(--ink);opacity:.5}

  /* surfaces */
  .home-card{background:var(--paper)}
  .home-card:hover{background:var(--ink-2)}
  .home-card a{color:var(--ink)}
  .team-section{background:var(--paper-2)}
  .bro{background:var(--ink-2);border-color:var(--line)}
  .bro .creds{color:var(--ink)}
  .bro .initial{color:var(--ink);opacity:.05}
  .bro-link{color:var(--ink)}
  footer{background:var(--paper-2)}

  /* hero stat numbers + first-letter use --ink (text), already correct */

  /* dark sections (services / contact) already use --ink bg.
     In dark mode --ink is now light, so repaint them as the elevated dark surface */
  .services-section,.contact-section{background:var(--ink-2);color:var(--cream)}
  .svc{background:var(--ink-2)}
  .svc:hover{background:#232e39}
  .svc h3{color:var(--cream)}
  .svc-grid{background:var(--line-dark);border-color:var(--line-dark)}
  .services-section .sec-head h2,.contact-copy h2{color:var(--cream)}
  form.intake{background:#0d1318;border-color:var(--line-dark)}
  .field input,.field textarea{background:rgba(243,236,224,.05);color:var(--cream)}

  /* profile */
  .profile-mono{background:var(--brass);color:#1a1206}
  .profile-head .creds,.profile-list li{color:var(--ink)}
  .profile-list li b{color:var(--ink)}

  /* socials chips readable on dark */
  .socials a{border-color:var(--line);color:var(--muted-dark)}
}
