/*
Theme Name: Trilly Co
Theme URI: https://trillycorp.com/
Author: Trilly Co
Version: 1.9.5
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: trillyco
*/

@import url('https://api.fontshare.com/v2/css?f[]=satoshi@400,500,700,900&f[]=cabinet-grotesk@500,700,800&f[]=clash-display@600,700&display=swap');

/* ── tokens ────────────────────────────────── */
:root,
[data-theme="light"] {
  /* type */
  --text-xs:   clamp(0.72rem,  0.66rem + 0.3vw,  0.82rem);
  --text-sm:   clamp(0.85rem,  0.78rem + 0.35vw, 0.95rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.1rem);
  --text-lg:   clamp(1.15rem,  1rem    + 0.75vw, 1.45rem);
  --text-xl:   clamp(1.45rem,  1.1rem  + 1.25vw, 2.1rem);
  --text-2xl:  clamp(2rem,     1.2rem  + 2.5vw,  3.4rem);
  --text-3xl:  clamp(2.8rem,   1rem    + 4vw,    5.6rem);

  /* spacing — strict 4px grid */
  --sp-1: .25rem; --sp-2: .5rem; --sp-3: .75rem; --sp-4: 1rem;
  --sp-5: 1.25rem; --sp-6: 1.5rem; --sp-8: 2rem; --sp-10: 2.5rem;
  --sp-12: 3rem; --sp-14: 3.5rem; --sp-16: 4rem; --sp-20: 5rem; --sp-24: 6rem;

  /* surfaces — warm sand */
  --bg:        #f6f4ef;
  --surf:      #faf9f6;
  --surf2:     #f0ece3;
  --surf3:     #e8e2d8;
  --border:    color-mix(in oklab, #1a1612 10%, transparent);
  --divider:   color-mix(in oklab, #1a1612 7%, transparent);

  /* text */
  --tx:        #1c1812;
  --tx-muted:  #5a5549;
  --tx-faint:  #8a8377;
  --tx-inv:    #faf8f3;

  /* accent — deep teal */
  --accent:       #0b5c62;
  --accent-hover: #09474c;
  --accent-soft:  color-mix(in oklab, #0b5c62 9%, var(--surf));

  /* gold */
  --gold:      #b08818;
  --gold-soft: color-mix(in oklab, #b08818 12%, var(--surf));

  /* elevation */
  --sh-sm: 0 1px 3px rgb(0 0 0/.06), 0 1px 2px rgb(0 0 0/.04);
  --sh-md: 0 4px 16px rgb(0 0 0/.07), 0 2px 6px rgb(0 0 0/.04);
  --sh-lg: 0 12px 48px rgb(0 0 0/.11), 0 4px 16px rgb(0 0 0/.06);
  --sh-xl: 0 24px 80px rgb(0 0 0/.14), 0 8px 24px rgb(0 0 0/.08);

  /* radius */
  --r-sm: .375rem; --r-md: .6rem; --r-lg: 1rem;
  --r-xl: 1.5rem;  --r-2xl: 2rem; --r-full: 9999px;

  /* fonts */
  --font-body:    'Satoshi', system-ui, sans-serif;
  --font-display: 'Cabinet Grotesk', system-ui, sans-serif;
  --font-accent:  'Clash Display', 'Cabinet Grotesk', system-ui, sans-serif;

  --ease: cubic-bezier(.16,1,.3,1);
  --dur: 200ms;
  --content: 1160px;
}

[data-theme="dark"] {
  --bg:        #131210;
  --surf:      #1b1916;
  --surf2:     #22201d;
  --surf3:     #2b2925;
  --border:    color-mix(in oklab, #f0ece3 9%, transparent);
  --divider:   color-mix(in oklab, #f0ece3 6%, transparent);
  --tx:        #ede8df;
  --tx-muted:  #b0a99e;
  --tx-faint:  #7a7268;
  --tx-inv:    #131210;
  --accent:       #5fa8ae;
  --accent-hover: #7dc0c6;
  --accent-soft:  color-mix(in oklab, #5fa8ae 10%, var(--surf));
  --gold:      #d4a830;
  --gold-soft: color-mix(in oklab, #d4a830 12%, var(--surf));
  --sh-sm: 0 1px 3px rgb(0 0 0/.25);
  --sh-md: 0 4px 16px rgb(0 0 0/.32);
  --sh-lg: 0 12px 48px rgb(0 0 0/.42);
  --sh-xl: 0 24px 80px rgb(0 0 0/.52);
}
@media (prefers-color-scheme:dark){ :root:not([data-theme]){
  --bg:#131210; --surf:#1b1916; --surf2:#22201d; --surf3:#2b2925;
  --border:color-mix(in oklab,#f0ece3 9%,transparent); --divider:color-mix(in oklab,#f0ece3 6%,transparent);
  --tx:#ede8df; --tx-muted:#b0a99e; --tx-faint:#7a7268; --tx-inv:#131210;
  --accent:#5fa8ae; --accent-hover:#7dc0c6; --accent-soft:color-mix(in oklab,#5fa8ae 10%,#1b1916);
  --gold:#d4a830; --gold-soft:color-mix(in oklab,#d4a830 12%,#1b1916);
  --sh-sm:0 1px 3px rgb(0 0 0/.25); --sh-md:0 4px 16px rgb(0 0 0/.32);
  --sh-lg:0 12px 48px rgb(0 0 0/.42); --sh-xl:0 24px 80px rgb(0 0 0/.52);
}}

/* ── reset ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  scroll-padding-top:5.5rem;
  -webkit-text-size-adjust:none;
  text-size-adjust:none;
}
body{
  font-family:var(--font-body);
  font-size:var(--text-base);
  line-height:1.65;
  color:var(--tx);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100dvh;
}
h1,h2,h3,h4{line-height:1.06;text-wrap:balance}
p{line-height:1.7;color:var(--tx-muted);max-width:68ch}
p + p{margin-top:var(--sp-3)}
a{text-decoration:none;color:inherit}
img,svg{display:block;max-width:100%;height:auto}
button{background:none;border:0;cursor:pointer;font:inherit;color:inherit}
ul{list-style:none}
input,textarea,select{font:inherit;color:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--r-sm)}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

/* ── layout ─────────────────────────────────── */
.wrap{width:min(calc(100% - var(--sp-8)),var(--content));margin-inline:auto}
.sec{padding-block:clamp(var(--sp-14),7vw,var(--sp-24))}
.sec-tight{padding-block:clamp(var(--sp-8),5vw,var(--sp-14))}

/* ── skip link ─────────────────────────────── */
.skip{position:absolute;left:-99em;top:var(--sp-4);background:var(--accent);color:var(--tx-inv);padding:.6rem 1rem;border-radius:var(--r-md);font-weight:700;z-index:9999}
.skip:focus{left:var(--sp-4)}

/* ── nav ────────────────────────────────────── */
.site-nav{
  position:sticky;top:0;z-index:800;
  background:color-mix(in srgb,var(--bg) 82%,transparent);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--divider);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:var(--sp-6);padding-block:.85rem;
}
/* brand */
.brand{display:flex;align-items:center;gap:.75rem;font-family:var(--font-display);font-size:var(--text-base);font-weight:800;letter-spacing:-.04em;color:var(--tx)}
.brand-icon{
  width:2.5rem;height:2.5rem;border-radius:.85rem;
  background:linear-gradient(135deg,var(--accent),color-mix(in oklab,var(--accent) 55%,var(--gold)));
  display:grid;place-items:center;color:white;flex-shrink:0;
  box-shadow:var(--sh-sm);
}
.brand-icon svg{width:1.3rem;height:1.3rem}
.brand-sub{font-family:var(--font-body);font-size:var(--text-xs);font-weight:600;color:var(--tx-muted);letter-spacing:.02em;display:block;margin-top:.1rem}
/* nav links */
.nav-links{display:flex;align-items:center;gap:var(--sp-6)}
.nav-links a{font-size:var(--text-sm);font-weight:700;color:var(--tx-muted);transition:color var(--dur) var(--ease)}
.nav-links a:hover{color:var(--tx)}
.nav-right{display:flex;align-items:center;gap:var(--sp-3)}
.theme-btn{
  width:44px;height:44px;border-radius:50%;
  border:1px solid var(--border);background:var(--surf);
  display:grid;place-items:center;
  color:var(--tx-muted);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
.theme-btn:hover{background:var(--surf2);color:var(--tx)}

/* ── eyebrow ────────────────────────────────── */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.44rem .9rem;
  border-radius:var(--r-full);
  background:var(--accent-soft);
  border:1px solid color-mix(in oklab,var(--accent) 18%,var(--border));
  font-size:var(--text-xs);font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);line-height:1;
}
.eyebrow .dot{
  width:.45rem;height:.45rem;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}

/* ── section head ───────────────────────────── */
.s-head{display:flex;flex-direction:column;gap:var(--sp-3);margin-bottom:var(--sp-10)}
.s-head h2{
  font-family:var(--font-display);
  font-size:var(--text-2xl);
  font-weight:800;letter-spacing:-.055em;
  color:var(--tx);max-width:14ch;
}
.s-head p{font-size:var(--text-lg);max-width:58ch}

/* ── buttons ────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  min-height:48px;padding:.85rem 1.45rem;
  border-radius:var(--r-full);
  font-size:var(--text-sm);font-weight:800;line-height:1;
  transition:transform var(--dur) var(--ease),
             background var(--dur) var(--ease),
             box-shadow var(--dur) var(--ease),
             border-color var(--dur) var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:none}
.btn-primary{background:var(--accent);color:white;box-shadow:var(--sh-md)}
.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--sh-lg)}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--tx)}
.btn-outline:hover{background:var(--surf2)}
.btn-ghost{background:transparent;border:1.5px solid var(--border);color:var(--tx-muted)}
.btn-ghost:hover{border-color:var(--tx-muted);color:var(--tx)}
.btn-row{display:flex;flex-wrap:wrap;gap:var(--sp-3)}
.btn-row.col{flex-direction:column;align-items:flex-start}

/* ── hero ───────────────────────────────────── */
.hero{padding-top:clamp(var(--sp-10),7vw,var(--sp-20));padding-bottom:clamp(var(--sp-12),7vw,var(--sp-24))}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(320px,.98fr);gap:clamp(var(--sp-8),4vw,var(--sp-16));align-items:center}

/* left copy */
.hero-kicker{margin-bottom:var(--sp-5)}
.hero-h1{
  font-family:var(--font-display);
  font-size:clamp(2.9rem,6vw,5.4rem);
  font-weight:800;
  letter-spacing:-.015em;
  color:var(--tx);
  max-width:8.5ch;
  line-height:.96;
  text-wrap:balance;
}
.hero-lead{
  margin-top:var(--sp-6);
  font-size:clamp(1.08rem,1rem + .5vw,1.42rem);
  color:var(--tx-muted);
  max-width:34ch;
  line-height:1.62;
}
.hero-btns{margin-top:var(--sp-7)}
.hero-micro{
  margin-top:var(--sp-4);
  font-size:var(--text-sm);
  color:var(--tx-muted);
  max-width:52ch;
}

/* right panel */
.hero-panel{
  background:linear-gradient(160deg,var(--surf) 0%,var(--surf2) 100%);
  border:1px solid var(--border);border-radius:var(--r-2xl);
  padding:clamp(var(--sp-6),3.5vw,var(--sp-8));
  box-shadow:var(--sh-xl);position:relative;overflow:hidden;
}
.hero-panel::after{
  content:'';position:absolute;
  inset:auto -8% -18% auto;
  width:240px;height:240px;
  background:radial-gradient(circle,var(--accent-soft) 0%,transparent 72%);
  pointer-events:none;
}
.panel-eyebrow{margin-bottom:var(--sp-5)}

/* signal cards 2×2 */
.signal-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
.signal-card{
  padding:var(--sp-4);
  border-radius:var(--r-lg);
  background:color-mix(in oklab,var(--surf2) 90%,var(--accent) 3%);
  border:1px solid var(--border);
}
.signal-card strong{
  display:block;
  font-family:var(--font-display);
  font-size:1.05rem;font-weight:800;letter-spacing:-.025em;
  color:var(--tx);margin-bottom:var(--sp-2);
}
.signal-card p{
  font-size:var(--text-sm);color:var(--tx-muted);
  max-width:unset;line-height:1.55;
}

/* metric strip — 3 chips */
.metric-strip{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--sp-3);margin-top:var(--sp-5);
}
.metric-chip{
  padding:var(--sp-4);
  border-radius:var(--r-lg);
  background:var(--surf);
  border:1px solid var(--border);
}
.metric-chip strong{
  display:block;
  font-family:var(--font-display);
  font-size:.92rem;font-weight:800;letter-spacing:-.02em;
  color:var(--tx);
  margin-bottom:var(--sp-1);          /* 4px gap */
  line-height:1.25;
}
.metric-chip span{
  display:block;
  font-size:var(--text-xs);
  color:var(--tx-faint);
  font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  line-height:1.2;
}

/* ── stat strip ─────────────────────────────── */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}
.stat-card{
  padding:var(--sp-5);
  border-radius:var(--r-xl);
  background:linear-gradient(170deg,var(--surf),var(--surf2));
  border:1px solid var(--border);box-shadow:var(--sh-sm);
}
.stat-card .label{
  font-size:var(--text-xs);font-weight:800;letter-spacing:.09em;
  text-transform:uppercase;color:var(--tx-faint);
  display:block;margin-bottom:var(--sp-2);
}
.stat-card strong{
  display:block;
  font-family:var(--font-display);
  font-size:1.7rem;font-weight:800;letter-spacing:-.04em;
  color:var(--tx);line-height:1;margin-bottom:var(--sp-2);
}
.stat-card p{font-size:var(--text-sm);color:var(--tx-muted);max-width:unset;line-height:1.5}

/* ── audience cards ─────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6);align-items:stretch}
.audience-card{
  display:flex;flex-direction:column;
  padding:clamp(var(--sp-6),4vw,var(--sp-8));
  border-radius:var(--r-2xl);
  background:linear-gradient(170deg,var(--surf),var(--surf2));
  border:1px solid var(--border);box-shadow:var(--sh-md);
}
.audience-card.is-featured{
  background:linear-gradient(170deg,color-mix(in oklab,var(--accent) 6%,var(--surf)),var(--surf2));
}
.a-tag{
  display:inline-flex;padding:.35rem .75rem;
  border-radius:var(--r-full);
  background:var(--gold-soft);border:1px solid color-mix(in oklab,var(--gold) 20%,var(--border));
  font-size:var(--text-xs);font-weight:800;letter-spacing:.07em;text-transform:uppercase;
  color:var(--tx);line-height:1;margin-bottom:var(--sp-4);
}
.audience-card h3{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,2.8vw,2.5rem);
  font-weight:800;letter-spacing:-.015em;
  color:var(--tx);margin-bottom:var(--sp-5);
}
.audience-card ul{display:flex;flex-direction:column;gap:var(--sp-3);flex:1}
.audience-card li{
  position:relative;padding-left:1.2rem;
  font-size:var(--text-base);color:var(--tx-muted);line-height:1.6;
}
.audience-card li::before{
  content:'';position:absolute;left:0;top:.65rem;
  width:.38rem;height:.38rem;border-radius:50%;background:var(--accent);
}
.a-btns{display:flex;flex-wrap:wrap;gap:var(--sp-3);margin-top:var(--sp-6)}

/* ── service cards ──────────────────────────── */
.service-card{
  padding:clamp(var(--sp-6),4vw,var(--sp-8));
  border-radius:var(--r-2xl);
  background:linear-gradient(170deg,var(--surf),var(--surf2));
  border:1px solid var(--border);box-shadow:var(--sh-sm);
}
.service-card h3{
  font-family:var(--font-display);
  font-size:clamp(1.5rem,2.5vw,2.2rem);
  font-weight:800;letter-spacing:-.04em;
  color:var(--tx);margin-bottom:var(--sp-5);
}
.bullet-list{display:flex;flex-direction:column;gap:var(--sp-3)}
.bullet-list li{
  position:relative;padding-left:1.2rem;
  font-size:var(--text-base);color:var(--tx-muted);line-height:1.6;
}
.bullet-list li::before{
  content:'';position:absolute;left:0;top:.65rem;
  width:.38rem;height:.38rem;border-radius:50%;background:var(--accent);
}

/* ── info pair ──────────────────────────────── */
.info-pair{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6);align-items:stretch}
.info-card{
  padding:clamp(var(--sp-6),4vw,var(--sp-8));
  border-radius:var(--r-2xl);
  background:linear-gradient(170deg,var(--surf),var(--surf2));
  border:1px solid var(--border);box-shadow:var(--sh-sm);
}
.info-card h3{
  font-family:var(--font-display);
  font-size:clamp(1.5rem,2.5vw,2.2rem);
  font-weight:800;letter-spacing:-.04em;
  color:var(--tx);margin-bottom:var(--sp-5);
}
.info-card p{font-size:var(--text-base);line-height:1.7}

/* ── process steps ──────────────────────────── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}
.process-card{
  padding:var(--sp-6);
  border-radius:var(--r-xl);
  background:linear-gradient(170deg,var(--surf),var(--surf2));
  border:1px solid var(--border);box-shadow:var(--sh-sm);
}
.process-num{
  font-family:var(--font-accent);font-size:2.4rem;font-weight:700;
  letter-spacing:-.06em;color:var(--accent);
  display:block;margin-bottom:var(--sp-3);line-height:1;
}
.process-card h3{
  font-family:var(--font-display);font-size:1.15rem;font-weight:800;
  letter-spacing:-.025em;color:var(--tx);margin-bottom:var(--sp-3);
}
.process-card p{font-size:var(--text-sm);color:var(--tx-muted);max-width:unset;line-height:1.6}

/* ── support panels ─────────────────────────── */
.support-pair{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6)}
.support-panel{
  padding:clamp(var(--sp-6),4vw,var(--sp-8));
  border-radius:var(--r-2xl);
  background:linear-gradient(170deg,var(--surf),var(--surf2));
  border:1px solid var(--border);box-shadow:var(--sh-md);
}
.support-panel h3{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,2.8vw,2.4rem);
  font-weight:800;letter-spacing:-.015em;
  color:var(--tx);margin-bottom:var(--sp-3);
}
.support-panel > p{font-size:var(--text-base);line-height:1.7;margin-bottom:var(--sp-6)}
.support-tiles{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}
.support-tile{
  padding:var(--sp-4);
  border-radius:var(--r-lg);
  background:var(--surf2);
  border:1px solid var(--border);
}
.support-tile strong{
  display:block;font-size:var(--text-sm);font-weight:800;
  color:var(--tx);margin-bottom:var(--sp-2);line-height:1.3;
}
.support-tile p{font-size:var(--text-sm);color:var(--tx-muted);max-width:unset;line-height:1.55}

/* ── quote band ─────────────────────────────── */
.quote-band{
  padding:clamp(var(--sp-10),6vw,var(--sp-16));
  border-radius:var(--r-2xl);
  background:linear-gradient(135deg,#0b3d41,var(--accent),#164245);
  box-shadow:var(--sh-xl);position:relative;overflow:hidden;
}
.quote-band::before{
  content:'';position:absolute;
  inset:-20% auto auto 68%;width:320px;height:320px;
  background:radial-gradient(circle,rgba(255,255,255,.12),transparent 68%);
  pointer-events:none;
}
.quote-band .eyebrow{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.14);color:white;margin-bottom:var(--sp-5)}
.quote-band h2{
  font-family:var(--font-accent);
  font-size:clamp(2.2rem,4vw,4.2rem);
  font-weight:700;letter-spacing:-.055em;
  color:white;max-width:12ch;margin-bottom:var(--sp-4);
}
.quote-band p{color:rgba(255,255,255,.88);font-size:var(--text-lg);max-width:52ch;margin-bottom:var(--sp-7)}
.quote-band .btn-outline{border-color:rgba(255,255,255,.22);color:white}
.quote-band .btn-outline:hover{background:rgba(255,255,255,.1)}

/* ── faq ────────────────────────────────────── */
.faq-stack{display:flex;flex-direction:column;gap:var(--sp-4)}
.faq-item{
  padding:var(--sp-6);
  border-radius:var(--r-xl);
  background:linear-gradient(170deg,var(--surf),var(--surf2));
  border:1px solid var(--border);
}
.faq-item h3{
  font-family:var(--font-display);font-size:1.2rem;
  font-weight:800;letter-spacing:-.025em;
  color:var(--tx);margin-bottom:var(--sp-3);
}
.faq-item p{font-size:var(--text-base);color:var(--tx-muted);max-width:unset}

/* ── contact form ───────────────────────────── */
.contact-shell{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(var(--sp-10),5vw,var(--sp-16));
  align-items:start;
  padding:clamp(var(--sp-8),6vw,var(--sp-12));
  border-radius:var(--r-2xl);
  background:linear-gradient(170deg,var(--surf),var(--surf2));
  border:1px solid var(--border);box-shadow:var(--sh-xl);
}
.contact-copy .eyebrow{margin-bottom:var(--sp-4)}
.contact-copy h2{
  font-family:var(--font-accent);
  font-size:clamp(2.2rem,4vw,3.8rem);
  font-weight:700;letter-spacing:-.055em;
  color:var(--tx);margin-bottom:var(--sp-4);
}
.contact-copy > p{font-size:var(--text-lg);line-height:1.7;margin-bottom:var(--sp-6)}
.contact-meta{display:flex;flex-direction:column;gap:var(--sp-2)}
.contact-meta span{font-size:var(--text-sm);color:var(--tx-faint);display:flex;align-items:center;gap:.5rem}
.contact-meta span::before{content:'→';color:var(--accent);font-weight:800}
.c-form{display:flex;flex-direction:column;gap:var(--sp-5)}
.c-form label{display:flex;flex-direction:column;gap:var(--sp-2);font-size:var(--text-sm);font-weight:700;color:var(--tx)}
.c-form input,.c-form textarea,.c-form select{
  padding:var(--sp-4);
  border-radius:var(--r-lg);
  border:1.5px solid var(--border);
  background:var(--bg);color:var(--tx);
  font-size:var(--text-base);
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
  width:100%;
}
.c-form input:focus,.c-form textarea:focus,.c-form select:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 18%,transparent);
}
.c-form textarea{min-height:148px;resize:vertical;line-height:1.6}
.c-form .helper{font-size:var(--text-xs);color:var(--tx-faint);margin-top:calc(-1 * var(--sp-2))}
.form-status{font-size:var(--text-sm);color:var(--tx-muted);min-height:1.4em}

/* ── footer ─────────────────────────────────── */
.site-footer{padding-block:var(--sp-10) var(--sp-12)}
.footer-top{border-top:1px solid var(--divider);padding-top:var(--sp-8)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--sp-8);margin-bottom:var(--sp-8)}
.footer-col strong{
  display:block;font-family:var(--font-display);
  font-size:1.05rem;font-weight:800;letter-spacing:-.025em;
  color:var(--tx);margin-bottom:var(--sp-4);
}
.footer-col p,.footer-col a{font-size:var(--text-sm);color:var(--tx-faint);line-height:1.7}
.footer-col a{display:block;transition:color var(--dur) var(--ease)}
.footer-col a:hover{color:var(--tx-muted)}
.footer-col .link-stack{display:flex;flex-direction:column;gap:var(--sp-2)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;font-size:var(--text-xs);color:var(--tx-faint);border-top:1px solid var(--divider);padding-top:var(--sp-5);gap:var(--sp-4);flex-wrap:wrap}

/* ── reveal animation ───────────────────────── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ── responsive ─────────────────────────────── */
@media(max-width:1024px){
  .hero-grid,.contact-shell{grid-template-columns:1fr}
  .process-grid,.stat-strip{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-grid .footer-col:first-child{grid-column:1/-1}
}
@media(max-width:820px){
  .nav-links{display:none}
  .two-col,.info-pair,.support-pair,.service-grid{grid-template-columns:1fr}
  .metric-strip{grid-template-columns:1fr}
}
@media(max-width:640px){
  .wrap{width:calc(100% - var(--sp-5))}
  .process-grid,.stat-strip{grid-template-columns:1fr}
  .signal-grid{grid-template-columns:1fr}
  .support-tiles{grid-template-columns:1fr}
  .btn-row{flex-direction:column}
  .a-btns{flex-direction:column}
  .footer-grid{grid-template-columns:1fr}
  .metric-strip{grid-template-columns:1fr}
  .quote-band h2{font-size:clamp(1.9rem,6vw,2.8rem)}
}
.service-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6)}
