/* ============================================================
   ComTALK Design System v4
   3-layer token architecture · Editorial typography · Responsive
   Loads AFTER bootstrap & style.css so this is the source of truth.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,900;1,9..144,500&family=Inter:wght@400;500;600;700;800&display=swap');

/* ============================================================
   L1 — PRIMITIVE TOKENS
   ============================================================ */
:root{
  --c-burgundy-100:#F4E4EC; --c-burgundy-300:#C97AA0;
  --c-burgundy-500:#8E2657; --c-burgundy-700:#6C1B41; --c-burgundy-900:#3F0F26;
  --c-orange-100:#FFE7D6; --c-orange-500:#FC5404; --c-orange-700:#C04203;
  --c-mustard-100:#FFF3D1; --c-mustard-500:#F9B208; --c-mustard-700:#C68A05;
  --c-cream-50:#FCFAF6; --c-cream-100:#FBF8F4; --c-cream-200:#F4ECE2; --c-cream-300:#E8DCCC;
  --c-ink-100:#EFEAE8; --c-ink-300:#B9ADAA; --c-ink-500:#6A5A57; --c-ink-700:#4B3B36; --c-ink-900:#1A1413;

  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px;
  --s-6:24px; --s-8:32px; --s-10:40px; --s-12:48px;
  --s-16:64px; --s-20:80px; --s-24:96px; --s-32:128px;

  --t-xs:clamp(11px,.7vw,12px);
  --t-sm:clamp(13px,.85vw,14px);
  --t-base:clamp(15px,1vw,16px);
  --t-lg:clamp(17px,1.2vw,19px);
  --t-xl:clamp(20px,1.5vw,24px);
  --t-2xl:clamp(28px,2.4vw,38px);
  --t-3xl:clamp(34px,3.6vw,58px);
  --t-4xl:clamp(48px,6.5vw,110px);

  --r-sm:4px; --r-md:8px; --r-lg:14px; --r-pill:999px;
  --shadow-sm:0 2px 8px rgba(26,20,19,.06);
  --shadow-md:0 12px 32px rgba(26,20,19,.10);
  --shadow-lg:0 24px 60px rgba(26,20,19,.18);
  --shadow-focus:0 0 0 3px var(--c-mustard-500);

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --d-fast:160ms; --d-base:260ms; --d-slow:400ms;

  /* L2 — SEMANTIC */
  --voice-seeker:var(--c-burgundy-500);
  --voice-comtalk:var(--c-orange-500);
  --voice-warmth:var(--c-mustard-500);
  --surface:var(--c-cream-100);
  --surface-elev:#fff;
  --surface-paper:var(--c-cream-200);
  --surface-deep:var(--c-burgundy-700);
  --surface-deep-mid:var(--c-burgundy-900);
  --surface-night:var(--c-ink-900);
  --text:var(--c-ink-700);
  --text-strong:var(--c-ink-900);
  --text-quiet:var(--c-ink-500);
  --on-deep:#fff;
  --on-deep-mute:rgba(255,255,255,.7);
  --line:rgba(26,20,19,.08);
  --line-strong:rgba(26,20,19,.18);
}

/* ============================================================
   RESET + BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,sans-serif !important;
  background:var(--surface);
  color:var(--text);
  line-height:1.6;
  font-size:var(--t-base);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;transition:color var(--d-fast) var(--ease)}
:focus-visible{outline:2px solid var(--voice-comtalk);outline-offset:3px;border-radius:4px}
::selection{background:var(--c-mustard-100);color:var(--text-strong)}

h1,h2,h3,h4,h5,h6{
  font-family:'Fraunces',Georgia,serif !important;
  color:var(--text-strong);
  letter-spacing:-.02em;
  line-height:1.15;
  font-weight:500;
  font-optical-sizing:auto;
  margin:0;
}
h1{font-size:var(--t-3xl);font-weight:600;letter-spacing:-.025em}
h2{font-size:var(--t-2xl);font-weight:500}
h3{font-size:var(--t-xl);font-weight:500}
h4{font-size:var(--t-lg);font-weight:600;letter-spacing:-.01em}
h5{font-size:var(--t-base);font-weight:600}
p{margin:0;line-height:1.7}

.serif{font-family:'Fraunces',Georgia,serif;font-optical-sizing:auto;letter-spacing:-.015em}
.italic{font-style:italic}

/* Visually hide text but keep it for screen readers and search engines.
   Used for keyword-rich phrases inside headings whose visible art-typography
   doesn't carry the same keywords. */
.v4-sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.eyebrow{
  font-family:'Inter',sans-serif;
  font-size:var(--t-xs);
  text-transform:uppercase;
  letter-spacing:.3em;
  font-weight:700;
  color:var(--voice-comtalk);
}
.eyebrow.on-deep{color:var(--c-mustard-500)}
.eyebrow.on-surface{color:var(--voice-seeker)}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.v4-wrap{
  max-width:1280px;
  margin:0 auto;
  padding:0 var(--s-6);
}
@media(min-width:768px){.v4-wrap{padding:0 var(--s-10)}}
@media(min-width:1280px){.v4-wrap{padding:0 var(--s-6)}}

/* ============================================================
   COMPARE RIBBON (dev only — remove for prod)
   ============================================================ */
.v4-ribbon{
  position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:300;
  background:var(--surface-night);color:#fff;
  padding:7px 8px 7px 16px;border-radius:999px;
  display:flex;align-items:center;gap:8px;
  font:600 11px/1 'Inter',sans-serif;letter-spacing:.04em;
  box-shadow:0 18px 48px rgba(0,0,0,.2);
}
.v4-ribbon .pill{background:var(--voice-comtalk);padding:6px 12px;border-radius:999px;font-weight:700}
.v4-ribbon a{padding:6px 10px;opacity:.6;color:#fff}
.v4-ribbon a:hover{opacity:1}

/* ============================================================
   UTILITY BAR + NAV
   ============================================================ */
.v4-util{
  background:var(--surface-deep-mid);
  color:rgba(255,255,255,.85);
  font-size:var(--t-xs);
}
.v4-util .v4-wrap{
  display:flex;justify-content:space-between;align-items:center;
  padding:var(--s-2) var(--s-6);gap:var(--s-3);flex-wrap:wrap;
}
.v4-util a{color:#fff;font-variant-numeric:tabular-nums}
.v4-util .badge{color:var(--c-mustard-500);text-transform:uppercase;letter-spacing:.2em;font-weight:700}
@media(max-width:600px){.v4-util .v4-wrap{justify-content:center;text-align:center}}

.v4-nav{
  background:var(--voice-seeker);
  color:#fff;
  position:sticky;top:0;z-index:60;
}
.v4-nav .v4-wrap{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:var(--s-6);align-items:center;
  padding-top:var(--s-3);padding-bottom:var(--s-3);
}
.v4-logo{display:flex;align-items:center;gap:var(--s-3);color:#fff}
.v4-logo-img{
  /* Logo is visually larger than the nav strip — overflows symmetrically
     so the nav stays its compact height. Transparent PNG sits directly
     on the burgundy bar; a soft drop-shadow gives separation. */
  height:110px;width:auto;display:block;
  margin-block:-22px;
  filter:drop-shadow(0 4px 14px rgba(0,0,0,.35));
  transition:transform var(--d-fast) var(--ease),filter var(--d-base) var(--ease);
}
.v4-logo:hover .v4-logo-img{
  transform:translateY(-1px);
  filter:drop-shadow(0 8px 22px rgba(252,84,4,.5));
}
@media(max-width:980px){.v4-logo-img{height:84px;margin-block:-16px}}
@media(max-width:600px){.v4-logo-img{height:64px;margin-block:-10px}}

/* Legacy text wordmark (kept for any pages still using it). */
.v4-logo .word{
  font-family:'Fraunces',serif;
  font-weight:700;
  font-size:clamp(20px,2vw,26px);
  letter-spacing:-.02em;
  color:#fff;
  font-variation-settings:"opsz" 144;
  line-height:1;
}
.v4-logo .word .t{color:var(--c-mustard-500)}
.v4-logo .sub{
  display:block;
  font:600 9px/1 'Inter',sans-serif;
  letter-spacing:.25em;
  color:var(--c-mustard-500);
  text-transform:uppercase;
  margin-top:3px;
}
.v4-nav-links{
  list-style:none;
  display:flex;justify-content:center;align-items:center;
  gap:var(--s-2);flex-wrap:wrap;
  margin:0;padding:0;
}
.v4-nav-links li{position:relative}
.v4-nav-links a{
  padding:8px 14px;border-radius:999px;
  font:600 13px/1 'Inter',sans-serif;
  color:#fff;letter-spacing:.02em;
  transition:background var(--d-fast) var(--ease);
}
.v4-nav-links a:hover,
.v4-nav-links a.on{background:rgba(255,255,255,.14);color:#fff}
.v4-nav-cta{
  background:var(--voice-comtalk);color:#fff;
  font:700 13px/1 'Inter',sans-serif;letter-spacing:.02em;
  padding:12px 22px;border-radius:999px;
  display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 8px 24px rgba(252,84,4,.32);
  transition:transform var(--d-fast) var(--ease),box-shadow var(--d-base) var(--ease);
}
.v4-nav-cta:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(252,84,4,.4);color:#fff}

/* Mobile nav */
.v4-burger{
  display:none;
  background:transparent;border:none;color:#fff;
  cursor:pointer;padding:10px;
  width:44px;height:44px;
  align-items:center;justify-content:center;
}
.v4-burger span{
  display:block;width:22px;height:2px;background:#fff;
  position:relative;
  transition:transform var(--d-base) var(--ease),opacity var(--d-fast) var(--ease);
}
.v4-burger span::before,
.v4-burger span::after{
  content:"";position:absolute;left:0;width:22px;height:2px;background:#fff;
  transition:transform var(--d-base) var(--ease),top var(--d-fast) var(--ease);
}
.v4-burger span::before{top:-7px}
.v4-burger span::after{top:7px}
.v4-burger[aria-expanded="true"] span{background:transparent}
.v4-burger[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.v4-burger[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

@media(max-width:980px){
  .v4-nav .v4-wrap{grid-template-columns:auto auto;align-items:center}
  .v4-burger{display:inline-flex}
  .v4-nav-links{
    grid-column:1/-1;
    display:none;
    flex-direction:column;align-items:stretch;gap:0;
    padding-top:var(--s-4);border-top:1px solid rgba(255,255,255,.15);
    margin-top:var(--s-3);
  }
  .v4-nav-links.open{display:flex}
  .v4-nav-links a{
    padding:14px var(--s-4);border-radius:0;text-align:left;
    border-bottom:1px solid rgba(255,255,255,.08);
  }
  .v4-nav-cta{
    grid-column:1/-1;
    justify-self:stretch;justify-content:center;
    margin-top:var(--s-3);
    display:none;
  }
  .v4-nav-links.open + .v4-nav-cta{display:inline-flex}
}

/* ============================================================
   PAGE HEADER (sub-pages — about, services, etc.)
   ============================================================ */
.v4-pageheader{
  position:relative;
  padding:var(--s-20) 0 var(--s-16);
  background:linear-gradient(135deg,var(--c-burgundy-700) 0%,var(--c-burgundy-900) 100%);
  color:#fff;overflow:hidden;
  isolation:isolate;
}
.v4-pageheader::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at top right,rgba(252,84,4,.22),transparent 50%),
    radial-gradient(ellipse at bottom left,rgba(249,178,8,.10),transparent 55%);
  pointer-events:none;
}
/* Optional: page headers can opt-in to a background photo via .v4-pageheader-photo
   The class must be added IN ADDITION to v4-pageheader. Use only with clean
   photos that don't have embedded text. */
.v4-pageheader.v4-pageheader-photo{
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
.v4-pageheader.v4-pageheader-photo::before{
  background:
    radial-gradient(ellipse at left center,rgba(63,15,38,.75),transparent 60%),
    linear-gradient(180deg,rgba(0,0,0,.25) 0%,rgba(63,15,38,.65) 100%);
}
.v4-pageheader .crumbs{
  font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.3em;
  color:var(--c-mustard-500);font-weight:700;margin-bottom:var(--s-4);
  display:inline-flex;align-items:center;gap:var(--s-3);
}
.v4-pageheader .crumbs::before{content:"";display:inline-block;width:40px;height:1px;background:var(--c-mustard-500)}
.v4-pageheader h1{
  font-family:'Fraunces',serif;
  color:#fff;
  font-size:clamp(40px,6vw,80px);
  line-height:1.05;
  letter-spacing:-.03em;
  max-width:18ch;
  margin-bottom:var(--s-5);
}
.v4-pageheader h1 em{font-style:italic;color:var(--c-mustard-500)}
.v4-pageheader .lead{
  font-size:var(--t-lg);line-height:1.65;
  color:rgba(255,255,255,.85);max-width:60ch;
}

/* ============================================================
   HERO (home only)
   ============================================================ */
.v4-hero{
  position:relative;
  min-height:84vh;
  background:#e7e2db center/cover no-repeat;
  display:flex;align-items:center;
  overflow:hidden;isolation:isolate;
}
.v4-hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at left center,rgba(63,15,38,.7) 0%,rgba(63,15,38,.15) 50%,transparent 75%),
    linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,.5) 100%);
}
.v4-hero .v4-wrap{padding-block:var(--s-24);position:relative;z-index:1}
.v4-hero-stack{max-width:760px}
.v4-hero .meta{
  font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.3em;
  color:var(--c-mustard-500);font-weight:700;margin-bottom:var(--s-5);
  display:inline-flex;align-items:center;gap:var(--s-3);
}
.v4-hero .meta::before{content:"";display:inline-block;width:48px;height:1px;background:var(--c-mustard-500)}
.v4-hero-words{
  font-family:'Fraunces',serif;
  font-variation-settings:"opsz" 144;
}
.v4-hero-seeker{
  display:block;color:#fff;font-weight:600;
  font-size:clamp(28px,4.4vw,64px);line-height:1.05;letter-spacing:-.025em;
}
.v4-hero-talk{
  display:block;color:var(--c-mustard-500);font-style:italic;font-weight:500;
  font-size:clamp(64px,13vw,180px);line-height:.92;letter-spacing:-.045em;
  margin-top:var(--s-3);
  text-shadow:0 4px 40px rgba(0,0,0,.3);
}
.v4-hero-sub{
  color:rgba(255,255,255,.88);font-size:var(--t-lg);line-height:1.65;
  max-width:54ch;margin-top:var(--s-6);
}
.v4-hero-sub b{color:#fff;font-weight:600}
.v4-hero-cta{margin-top:var(--s-8);display:flex;gap:var(--s-4);align-items:center;flex-wrap:wrap}

.v4-meta-strip{
  position:absolute;bottom:0;left:0;right:0;
  padding:var(--s-5) var(--s-6);
  background:linear-gradient(0deg,rgba(63,15,38,.85),rgba(63,15,38,0));
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s-4);
  font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.22em;
  color:rgba(255,255,255,.75);font-variant-numeric:tabular-nums;z-index:1;
}
.v4-meta-strip b{color:#fff;font-weight:700;display:block;font-size:13px;letter-spacing:.1em;margin-bottom:2px}

@media(max-width:768px){
  .v4-hero{min-height:auto;display:block}
  .v4-hero .v4-wrap{padding-block:var(--s-16) var(--s-10)}
  .v4-hero-stack{max-width:none}
  .v4-hero-seeker{font-size:clamp(22px,7vw,40px)}
  .v4-hero-talk{font-size:clamp(56px,18vw,110px);text-align:left}
  .v4-hero-sub{font-size:var(--t-base);max-width:none}
  .v4-hero-cta{gap:var(--s-3)}
  .v4-btn-call{font-size:var(--t-lg);padding:12px 20px;width:100%;justify-content:center}
  .v4-btn-ghost-light{width:100%;text-align:center}

  /* Stop absolute-positioning the meta strip — flow it below the CTA so it
     doesn't slam into the call-now pill on mobile. Stack rows for readability. */
  .v4-meta-strip{
    position:static;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:var(--s-4) var(--s-5);
    padding:var(--s-6);
    background:rgba(63,15,38,.45);
    font-size:10px;letter-spacing:.18em;
  }
  .v4-meta-strip > div{min-width:0}
}

@media(max-width:480px){
  .v4-meta-strip{grid-template-columns:1fr}
  .v4-meta-strip b{font-size:12px}
}

/* Hero deck — admin-managed carousel (multi-slide rotation) */
.v4-hero-deck{position:relative}
.v4-hero-slide{display:none;opacity:0;transition:opacity 600ms var(--ease)}
.v4-hero-slide.is-active{display:flex;opacity:1}
.v4-hero-dots{
  position:absolute;left:50%;bottom:64px;transform:translateX(-50%);
  display:flex;gap:10px;z-index:3;
}
.v4-hero-dot{
  width:10px;height:10px;border-radius:50%;border:none;
  background:rgba(255,255,255,.4);
  cursor:pointer;padding:0;
  transition:background var(--d-fast) var(--ease),transform var(--d-fast) var(--ease);
}
.v4-hero-dot:hover{background:rgba(255,255,255,.7);transform:scale(1.15)}
.v4-hero-dot.is-active{background:var(--c-mustard-500);transform:scale(1.3)}
@media(max-width:768px){.v4-hero-dots{bottom:90px}}

/* ============================================================
   BUTTONS
   ============================================================ */
.v4-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);
  padding:14px 26px;min-height:48px;
  border:none;cursor:pointer;
  border-radius:999px;
  font:600 14px/1 'Inter',sans-serif;letter-spacing:.02em;
  transition:transform var(--d-fast) var(--ease),box-shadow var(--d-base) var(--ease),background var(--d-base) var(--ease);
  box-shadow:var(--shadow-sm);
  text-decoration:none;
}
.v4-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.v4-btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}
.v4-btn-primary{background:var(--voice-comtalk);color:#fff}
.v4-btn-primary:hover{background:var(--c-orange-700);color:#fff}
.v4-btn-dark{background:var(--voice-seeker);color:#fff}
.v4-btn-dark:hover{background:var(--c-burgundy-700);color:#fff}
.v4-btn-ghost{background:transparent;color:var(--voice-seeker);box-shadow:inset 0 0 0 2px var(--voice-seeker)}
.v4-btn-ghost:hover{background:var(--voice-seeker);color:#fff;box-shadow:inset 0 0 0 2px var(--voice-seeker)}
.v4-btn-ghost-light{
  background:transparent;color:#fff;
  font-size:var(--t-base);font-weight:600;
  border-bottom:2px solid #fff;border-radius:0;padding:2px 0;min-height:0;
  box-shadow:none;
}
.v4-btn-ghost-light:hover{transform:none;background:transparent;color:var(--c-mustard-500);border-color:var(--c-mustard-500);box-shadow:none}

.v4-btn-call{
  display:inline-flex;align-items:center;gap:var(--s-3);
  background:var(--voice-comtalk);color:#fff;
  font-family:'Fraunces',serif;font-weight:600;font-variant-numeric:tabular-nums;
  font-size:clamp(18px,1.8vw,24px);letter-spacing:-.01em;
  padding:14px 26px;border-radius:999px;
  box-shadow:0 12px 32px rgba(252,84,4,.4);
  transition:transform var(--d-fast) var(--ease),box-shadow var(--d-base) var(--ease);
  text-decoration:none;
}
.v4-btn-call:hover{transform:translateY(-2px);box-shadow:0 18px 48px rgba(252,84,4,.5);color:#fff}
.v4-btn-call .dot{
  width:10px;height:10px;border-radius:50%;background:#fff;
  box-shadow:0 0 0 4px rgba(255,255,255,.3);
  animation:v4-pulse 2s infinite;
}
@keyframes v4-pulse{50%{box-shadow:0 0 0 9px rgba(255,255,255,.12)}}

.v4-link-arrow{
  display:inline-flex;align-items:center;gap:var(--s-2);
  font-weight:600;color:var(--text-strong);
  border-bottom:2px solid var(--voice-seeker);padding-bottom:3px;
  transition:gap var(--d-fast) var(--ease),color var(--d-fast) var(--ease);
}
.v4-link-arrow:hover{gap:var(--s-3);color:var(--voice-seeker)}

/* ============================================================
   WELCOME / TWO-COL EDITORIAL
   ============================================================ */
.v4-welcome{padding:var(--s-24) 0;background:var(--surface)}
.v4-welcome .v4-wrap{
  display:grid;grid-template-columns:.85fr 1.1fr;gap:var(--s-16);align-items:center;
}
.v4-welcome h2{
  font-size:var(--t-3xl);line-height:1.1;letter-spacing:-.025em;
  color:var(--text-strong);margin:var(--s-4) 0 var(--s-6);
}
.v4-welcome h2 em{font-style:italic;color:var(--voice-seeker)}
.v4-welcome p{font-size:var(--t-lg);line-height:1.75;max-width:54ch;color:var(--text)}
.v4-welcome p + p{margin-top:var(--s-4)}
.v4-welcome .figure{
  position:relative;border-radius:6px;overflow:hidden;
  aspect-ratio:4/5;box-shadow:0 30px 80px rgba(63,15,38,.25);
}
.v4-welcome .figure img{width:100%;height:100%;object-fit:cover}
.v4-welcome .figure .caption{
  position:absolute;left:var(--s-5);bottom:var(--s-5);
  background:rgba(255,255,255,.95);backdrop-filter:blur(6px);
  padding:var(--s-3) var(--s-4);border-radius:4px;font-size:var(--t-xs);
  color:var(--text-strong);font-weight:600;letter-spacing:.1em;text-transform:uppercase;
}
.v4-welcome .figure .caption b{
  display:block;font:600 var(--t-base)/1.2 'Fraunces',serif;
  text-transform:none;letter-spacing:-.01em;color:var(--voice-seeker);margin-top:3px;
}
.v4-welcome .signature{
  margin-top:var(--s-8);display:flex;align-items:center;gap:var(--s-4);
  font-size:var(--t-sm);color:var(--text-quiet);
}
.v4-welcome .signature .line{width:48px;height:1px;background:var(--line-strong)}
@media(max-width:900px){
  .v4-welcome{padding:var(--s-16) 0}
  .v4-welcome .v4-wrap{grid-template-columns:1fr;gap:var(--s-10)}
  .v4-welcome .figure{aspect-ratio:5/4}
}

/* ============================================================
   GOALS — split with image
   ============================================================ */
.v4-goals{
  display:grid;grid-template-columns:1.1fr .9fr;
  background:linear-gradient(135deg,var(--voice-seeker) 0%,var(--c-burgundy-700) 100%);
  color:#fff;
}
.v4-goals-content{
  padding:var(--s-20) var(--s-12) var(--s-20) clamp(24px,8vw,120px);
}
.v4-goals h2{
  font-size:var(--t-3xl);letter-spacing:-.02em;line-height:1.1;
  color:#fff;margin:var(--s-3) 0 var(--s-10);max-width:14ch;
}
.v4-goals h2 em{font-style:italic;color:var(--c-mustard-500)}
.v4-goal-item{
  display:grid;grid-template-columns:auto 1fr;gap:var(--s-5);align-items:start;
  padding:var(--s-6) 0;border-top:1px solid rgba(255,255,255,.15);
}
.v4-goal-item:last-child{border-bottom:1px solid rgba(255,255,255,.15)}
.v4-goal-item .n{
  font-family:'Fraunces',serif;font-weight:700;font-size:var(--t-2xl);
  color:var(--c-mustard-500);font-variant-numeric:tabular-nums;line-height:1;min-width:60px;
}
.v4-goal-item h3{color:#fff;letter-spacing:-.01em;margin-bottom:var(--s-2)}
.v4-goal-item p{color:rgba(255,255,255,.78);font-size:var(--t-base);line-height:1.7;max-width:50ch}
.v4-goals-image{
  background-position:center;background-size:cover;background-repeat:no-repeat;
  position:relative;min-height:360px;
}
.v4-goals-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(270deg,rgba(63,15,38,0) 60%,rgba(63,15,38,.6) 100%);
}
@media(max-width:900px){
  .v4-goals{grid-template-columns:1fr}
  .v4-goals-image{min-height:280px}
  .v4-goals-content{padding:var(--s-12) var(--s-6)}
}

/* ============================================================
   OBJECTIVES — 5-col editorial entries
   ============================================================ */
.v4-objectives{padding:var(--s-24) 0;background:var(--surface-paper)}
.v4-objectives .head{margin-bottom:var(--s-12)}
.v4-objectives h2{
  font-size:var(--t-3xl);letter-spacing:-.02em;color:var(--text-strong);
  margin-top:var(--s-3);max-width:20ch;line-height:1.1;
}
.v4-objectives h2 em{font-style:italic;color:var(--voice-seeker)}
.v4-objectives-grid{
  display:grid;grid-template-columns:repeat(5,1fr);
  border-top:1px solid var(--line-strong);
}
.v4-obj{
  padding:var(--s-8) var(--s-5) var(--s-6) 0;
  border-right:1px solid var(--line);
  transition:background var(--d-base) var(--ease);
}
.v4-obj:last-child{border-right:none}
.v4-obj:hover{background:var(--surface-elev)}
.v4-obj .n{
  font-family:'Fraunces',serif;font-weight:700;font-size:32px;
  color:var(--voice-comtalk);line-height:1;margin-bottom:var(--s-5);
  font-variant-numeric:tabular-nums;
}
.v4-obj h4{
  font-size:var(--t-base);color:var(--text-strong);line-height:1.4;
}
@media(max-width:900px){
  .v4-objectives{padding:var(--s-16) 0}
  .v4-objectives-grid{grid-template-columns:repeat(2,1fr)}
  .v4-obj{border-bottom:1px solid var(--line);padding-right:var(--s-4)}
  .v4-obj:nth-child(even){border-right:none}
}
@media(max-width:520px){
  .v4-objectives-grid{grid-template-columns:1fr}
  .v4-obj{border-right:none}
}

/* ============================================================
   NAME STORY / EDITORIAL QUOTE
   ============================================================ */
.v4-name-story{
  padding:var(--s-24) 0;background:var(--surface);
  position:relative;overflow:hidden;
}
.v4-name-story::before{
  content:"\201C";
  position:absolute;left:-30px;top:-100px;
  font:900 480px/1 'Fraunces',serif;color:var(--c-burgundy-100);
  pointer-events:none;z-index:0;
}
.v4-name-story .v4-wrap{
  position:relative;z-index:1;
  display:grid;grid-template-columns:.4fr 1fr;gap:var(--s-12);align-items:center;
}
.v4-name-story .label{
  font-family:'Fraunces',serif;font-weight:500;font-style:italic;
  font-size:var(--t-xl);color:var(--text-quiet);letter-spacing:-.01em;
}
.v4-name-story .label b{
  display:block;font-style:normal;font-weight:700;
  color:var(--voice-seeker);font-size:var(--t-2xl);
  margin-top:var(--s-2);text-transform:uppercase;letter-spacing:.04em;
}
.v4-name-story blockquote{
  font-family:'Fraunces',serif;font-weight:500;font-size:var(--t-2xl);
  line-height:1.35;letter-spacing:-.018em;color:var(--text-strong);margin:0;
}
.v4-name-story blockquote em{font-style:italic;color:var(--voice-comtalk)}
.v4-name-story .attr{
  margin-top:var(--s-6);font-size:var(--t-sm);color:var(--text-quiet);
  text-transform:uppercase;letter-spacing:.22em;font-weight:600;
}
@media(max-width:900px){
  .v4-name-story{padding:var(--s-16) 0}
  .v4-name-story .v4-wrap{grid-template-columns:1fr;gap:var(--s-6)}
  .v4-name-story::before{font-size:280px;left:-10px;top:-40px}
}

/* ============================================================
   SERVICES — 3-card grid
   ============================================================ */
.v4-services{padding:var(--s-24) 0 var(--s-16);background:var(--surface-paper)}
.v4-services .head{
  margin-bottom:var(--s-12);
  display:flex;justify-content:space-between;align-items:flex-end;gap:var(--s-6);flex-wrap:wrap;
}
.v4-services h2{
  font-size:var(--t-3xl);letter-spacing:-.02em;color:var(--text-strong);
  max-width:18ch;line-height:1.1;margin-top:var(--s-3);
}
.v4-services h2 em{font-style:italic;color:var(--voice-seeker)}
.v4-services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-5);
}
.v4-svc{
  position:relative;aspect-ratio:3/4;border-radius:8px;overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:var(--s-6);color:#fff;
  box-shadow:0 12px 36px rgba(26,20,19,.08);
  /* Image-positioning rules applied to the element that ACTUALLY carries the
     inline background-image url. Faces usually sit in the upper third, so
     focal point is set 30% from the top. */
  background-size:cover;
  background-position:center 30%;
  background-repeat:no-repeat;
  background-color:#2a1318;
  transition:transform var(--d-base) var(--ease),box-shadow var(--d-base) var(--ease);
  isolation:isolate;text-decoration:none;
}
.v4-svc:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(26,20,19,.18);color:#fff}
.v4-svc::after{content:"";position:absolute;inset:0;z-index:-1}
/* Gentler gradients — image is the star; brand tint sits over the bottom 60% */
.v4-svc-orange::after  {background:linear-gradient(180deg,rgba(252,84,4,0)  0%,rgba(252,84,4,.25) 40%,rgba(252,84,4,.88) 100%)}
.v4-svc-burgundy::after{background:linear-gradient(180deg,rgba(63,15,38,0)  0%,rgba(63,15,38,.25) 40%,rgba(63,15,38,.85) 100%)}
.v4-svc-mustard::after {background:linear-gradient(180deg,rgba(249,178,8,0) 0%,rgba(249,178,8,.20) 40%,rgba(198,138,5,.88) 100%)}
.v4-svc .tag{
  font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.2em;font-weight:700;
  opacity:.85;margin-bottom:var(--s-3);
}
.v4-svc h3{color:#fff;letter-spacing:-.015em;line-height:1.15;font-size:var(--t-2xl);font-weight:500}
.v4-svc .arrow{margin-top:var(--s-4);font-size:var(--t-sm);font-weight:600;display:inline-flex;align-items:center;gap:var(--s-2);transition:gap var(--d-fast) var(--ease)}
.v4-svc:hover .arrow{gap:var(--s-3)}
@media(max-width:900px){
  .v4-services{padding:var(--s-16) 0}
  .v4-services-grid{grid-template-columns:1fr;gap:var(--s-4)}
  .v4-svc{aspect-ratio:5/3}
}

/* ============================================================
   HELP CTA
   ============================================================ */
.v4-help{
  padding:var(--s-24) 0;
  background:var(--surface);
}
.v4-help .v4-wrap{
  background-color:var(--surface-night);
  background-image:
    linear-gradient(135deg,rgba(26,20,19,.92) 0%,rgba(26,20,19,.78) 100%),
    url('../img/site/community-silhouettes.jpg'),
    url('../img/New/holding.jpg');
  background-size:cover;
  background-position:center;
  color:#fff;
  border-radius:8px;padding:var(--s-16) var(--s-12);
  position:relative;overflow:hidden;
}
.v4-help .v4-wrap::before{
  content:"";position:absolute;right:-120px;top:-120px;width:380px;height:380px;
  background:radial-gradient(circle,var(--voice-comtalk) 0%,transparent 65%);
  opacity:.45;pointer-events:none;
}
.v4-help .head{max-width:540px;margin-bottom:var(--s-12);position:relative}
.v4-help h2{font-size:var(--t-3xl);letter-spacing:-.02em;line-height:1.1;color:#fff;margin-top:var(--s-3)}
.v4-help h2 em{font-style:italic;color:var(--c-mustard-500)}
.v4-help .head p{font-size:var(--t-base);line-height:1.7;color:rgba(255,255,255,.75);margin-top:var(--s-4);max-width:46ch}
.v4-help-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4);position:relative;
}
.v4-help-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:6px;padding:var(--s-6);color:#fff;
  transition:background var(--d-base) var(--ease),transform var(--d-base) var(--ease);
  text-decoration:none;
}
.v4-help-card:hover{background:rgba(255,255,255,.1);transform:translateY(-4px);color:#fff}
.v4-help-card .small{
  font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.22em;
  color:rgba(255,255,255,.6);font-weight:600;margin-bottom:var(--s-3);
}
.v4-help-card .big{
  font-family:'Fraunces',serif;font-weight:600;font-size:var(--t-xl);
  letter-spacing:-.01em;font-variant-numeric:tabular-nums;color:#fff;
}
.v4-help-card .arrow{
  margin-top:var(--s-4);font-size:var(--t-xs);color:var(--c-mustard-500);
  text-transform:uppercase;letter-spacing:.2em;font-weight:700;
  display:inline-flex;align-items:center;gap:var(--s-2);transition:gap var(--d-fast) var(--ease);
}
.v4-help-card:hover .arrow{gap:var(--s-3)}
.v4-help-card.primary{background:var(--voice-comtalk);border-color:transparent}
.v4-help-card.primary:hover{background:var(--c-orange-700)}
.v4-help-card.primary .small{color:rgba(255,255,255,.85)}
.v4-help-card.primary .arrow{color:#fff}
.v4-help .reassure{
  margin-top:var(--s-8);font-family:'Fraunces',serif;font-style:italic;
  color:rgba(255,255,255,.65);font-size:var(--t-base);position:relative;
}
@media(max-width:900px){
  .v4-help{padding:var(--s-16) 0}
  .v4-help .v4-wrap{padding:var(--s-10) var(--s-6)}
  .v4-help-grid{grid-template-columns:1fr}
}

/* ============================================================
   CONTENT PAGES — generic article / list patterns
   For pages other than home that use existing markup,
   these styles upgrade their existing structure.
   ============================================================ */
.v4-content-section{padding:var(--s-20) 0}
.v4-content-section .v4-wrap{max-width:1100px}
.v4-prose h2,
.v4-prose h3{margin-bottom:var(--s-4)}
.v4-prose h2{font-size:var(--t-2xl);color:var(--text-strong);font-weight:500;letter-spacing:-.02em}
.v4-prose h3{font-size:var(--t-xl);color:var(--voice-seeker);font-weight:500}
.v4-prose p{font-size:var(--t-base);line-height:1.75;color:var(--text);margin-bottom:var(--s-4);max-width:72ch}
.v4-prose p:last-child{margin-bottom:0}
.v4-prose ul,.v4-prose ol{margin:0 0 var(--s-4) var(--s-5);padding:0}
.v4-prose ul li,.v4-prose ol li{margin-bottom:var(--s-2);line-height:1.7}
.v4-prose blockquote{
  border-left:4px solid var(--voice-comtalk);
  padding:var(--s-4) var(--s-5);margin:var(--s-6) 0;
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  font-size:var(--t-lg);color:var(--text-strong);
}

/* Tile grid (resources, news, projects) */
.v4-tiles{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:var(--s-6);
}
.v4-tile{
  background:var(--surface-elev);
  border-radius:8px;overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--d-base) var(--ease),box-shadow var(--d-base) var(--ease);
  display:flex;flex-direction:column;text-decoration:none;color:inherit;
}
.v4-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);color:inherit}
.v4-tile .v4-tile-img{
  aspect-ratio:16/10;background:#ddd center/cover no-repeat;
}
.v4-tile .v4-tile-body{padding:var(--s-5)}
.v4-tile h3{
  font-size:var(--t-xl);font-weight:500;color:var(--text-strong);
  letter-spacing:-.015em;margin-bottom:var(--s-3);line-height:1.25;
}
.v4-tile p{font-size:var(--t-sm);line-height:1.65;color:var(--text)}
.v4-tile .meta{
  font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.2em;
  color:var(--text-quiet);font-weight:700;margin-bottom:var(--s-3);
}

/* Form (contact, book) */
.v4-form{
  display:grid;gap:var(--s-5);
  max-width:640px;
}
.v4-form-field{display:grid;gap:var(--s-2)}
.v4-form-field label{
  font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.18em;
  font-weight:700;color:var(--text-strong);
}
.v4-form-field input,
.v4-form-field textarea,
.v4-form-field select{
  width:100%;
  padding:14px var(--s-4);min-height:48px;
  border:1px solid var(--line-strong);background:var(--surface-elev);
  border-radius:6px;
  font:400 var(--t-base)/1.5 'Inter',sans-serif;color:var(--text-strong);
  transition:border-color var(--d-fast) var(--ease),box-shadow var(--d-fast) var(--ease);
}
.v4-form-field textarea{min-height:140px;resize:vertical;font-family:'Inter',sans-serif}
.v4-form-field input:focus,
.v4-form-field textarea:focus,
.v4-form-field select:focus{
  border-color:var(--voice-seeker);
  box-shadow:0 0 0 3px rgba(142,38,87,.18);outline:none;
}
.v4-form-field .helper{font-size:var(--t-xs);color:var(--text-quiet)}

/* ============================================================
   FOOTER
   ============================================================ */
.v4-footer{
  background:var(--surface-night);color:rgba(255,255,255,.7);
  padding:var(--s-16) 0 var(--s-6);font-size:var(--t-sm);
}
.v4-footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--s-10);
  margin-bottom:var(--s-10);
}
.v4-footer h4{
  color:#fff;font-size:var(--t-xs);text-transform:uppercase;
  letter-spacing:.3em;font-weight:700;margin-bottom:var(--s-4);
  font-family:'Inter',sans-serif;
}
.v4-footer ul{list-style:none;display:flex;flex-direction:column;gap:var(--s-2);margin:0;padding:0}
.v4-footer a{color:rgba(255,255,255,.7)}
.v4-footer a:hover{color:var(--c-mustard-500)}
.v4-footer .brand{font:700 28px/1 'Fraunces',serif;letter-spacing:-.02em;color:#fff}
.v4-footer .brand .t{color:var(--voice-comtalk)}
.v4-footer .brand-sub{margin-top:var(--s-3);max-width:32ch;line-height:1.7}
.v4-footer-logo{
  display:block;
  height:96px;width:auto;
  filter:drop-shadow(0 6px 20px rgba(0,0,0,.4));
  margin-bottom:var(--s-3);
}
.v4-footer-legal{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:var(--s-5);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s-3);
  font-size:var(--t-xs);text-transform:uppercase;letter-spacing:.22em;
}
.v4-footer-staff{
  font-size:11px;letter-spacing:.15em;opacity:.55;
}
.v4-footer-staff a{color:rgba(255,255,255,.55)}
.v4-footer-staff a:hover{color:var(--c-mustard-500);opacity:1}
@media(max-width:900px){.v4-footer-grid{grid-template-columns:1fr 1fr;gap:var(--s-6)}}
@media(max-width:600px){.v4-footer-grid{grid-template-columns:1fr}}

/* ============================================================
   FLOATING CTA
   ============================================================ */
.v4-fab{
  position:fixed;right:20px;bottom:20px;z-index:90;
  background:var(--voice-seeker);color:#fff;
  padding:14px 22px;border-radius:999px;
  font:700 14px/1 'Inter',sans-serif;letter-spacing:.04em;
  box-shadow:0 18px 48px rgba(63,15,38,.4);
  display:flex;align-items:center;gap:var(--s-2);
  transition:transform var(--d-fast) var(--ease);
  text-decoration:none;
}
.v4-fab:hover{transform:translateY(-3px);color:#fff}
.v4-fab .dot{
  width:8px;height:8px;border-radius:50%;background:var(--c-mustard-500);
  box-shadow:0 0 0 5px rgba(249,178,8,.3);animation:v4-pulse 2s infinite;
}
@media(max-width:600px){.v4-fab{right:14px;bottom:14px;padding:12px 18px;font-size:13px}}

/* Hide legacy floating widgets — v4-fab takes their place */
.open-button,
#back-top > a{display:none !important}
#back-top{position:static}
.chat-popup{
  position:fixed;bottom:90px;right:20px;z-index:95;
  background:var(--surface-elev);box-shadow:var(--shadow-lg);
  border-radius:8px;padding:var(--s-5);max-width:340px;
}

/* ============================================================
   COMPATIBILITY — legacy bootstrap-based pages get baseline lift
   ============================================================ */
.blog_area{padding:var(--s-16) 0 !important;background:var(--surface)}
.blog_left_sidebar .blog_item{
  background:var(--surface-elev);
  border-radius:8px;padding:var(--s-6) var(--s-8);
  margin-bottom:var(--s-5);
  box-shadow:var(--shadow-sm);
}
.blog_left_sidebar .blog_item h2{
  font-size:var(--t-2xl);color:var(--text-strong);
  margin-bottom:var(--s-3);
}
.blog_left_sidebar .blog_item p{font-size:var(--t-base);line-height:1.7;color:var(--text)}
.hero-area.hero-height2{min-height:48vh}
.section-padding{padding:var(--s-16) 0 !important}
.whole-wrap{padding:var(--s-12) 0}
.about-tittle h2,
.about-tittleValues h2{color:#fff !important;font-family:'Fraunces',serif !important;font-size:var(--t-2xl)}
.about-details p{color:rgba(255,255,255,.85) !important;font-size:var(--t-base)}

/* ============================================================
   MOTION RESPECT
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    transition-duration:.01ms!important;
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    scroll-behavior:auto!important;
  }
}

/* ============================================================
   HIDE THE PREVIOUS modern-enhancements LAYER (avoid clash)
   ============================================================ */
/* style.css legacy: tone down where it conflicts */
.btn-ans:not(.v4-btn){
  /* Inherits from v4-btn-primary if class added in markup */
}
