/* =========================================================
   Peakflow SEO — Design System
   Botpresso-inspired: warm espresso base, cream, orange accent
   Type: Sora (display) + Plus Jakarta Sans (body)
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  /* base neutrals (warm-tinted) */
  --espresso:   #1B1622;   /* dark section bg */
  --espresso-2: #251E30;   /* dark surface */
  --espresso-3: #322942;   /* dark hairline / raised */
  --cream:      #F7F2EA;   /* light section bg */
  --cream-2:    #EFE7DA;   /* warm surface */
  --paper:      #FFFFFF;
  --tan:        #E9DAC5;

  /* ink (text) */
  --ink:        #211C2A;   /* primary text on light */
  --ink-soft:   #5C5563;   /* muted text on light */
  --ink-faint:  #8A828F;
  --on-dark:    #F7F2EA;   /* text on dark */
  --on-dark-soft:#B4ABBC;

  /* accent */
  --accent:     #E8743B;   /* warm orange */
  --accent-600: #D2602B;   /* hover */
  --accent-soft:#FBE6D8;   /* tint surface */
  --accent-ring:rgba(232,116,59,.30);

  /* lines */
  --line:       #E4DACB;
  --line-dark:  rgba(247,242,234,.12);

  /* radii */
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 22px;
  --r-xl: 32px;
  --r-pill: 999px;

  /* shadow */
  --sh-sm: 0 2px 8px rgba(33,28,42,.06);
  --sh:    0 10px 30px rgba(33,28,42,.08);
  --sh-lg: 0 30px 70px rgba(33,28,42,.14);

  /* layout */
  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 64px);

  --font-display: "Sora", system-ui, sans-serif;
  --font-body: "Plus Jakarta Sans", system-ui, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4,h5{ font-family:var(--font-display); font-weight:700; line-height:1.08; margin:0; letter-spacing:-.02em; color:var(--ink); }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }

/* ---------- Layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(64px,9vw,128px); position:relative; }
.section--tight{ padding-block:clamp(48px,6vw,80px); }
.dark{ background:var(--espresso); color:var(--on-dark); }
.dark h1,.dark h2,.dark h3,.dark h4{ color:var(--on-dark); }
.cream{ background:var(--cream); }
.paper{ background:var(--paper); }

.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-body); font-weight:700;
  font-size:13px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--accent);
}
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--accent); border-radius:2px; }
.dark .eyebrow{ color:var(--accent); }

.h-xl{ font-size:clamp(40px,6vw,76px); }
.h-lg{ font-size:clamp(32px,4.6vw,54px); }
.h-md{ font-size:clamp(26px,3.2vw,38px); }
.lead{ font-size:clamp(18px,2vw,22px); color:var(--ink-soft); line-height:1.6; }
.dark .lead{ color:var(--on-dark-soft); }
.muted{ color:var(--ink-soft); }
.center{ text-align:center; }
.measure{ max-width:62ch; }
.measure-sm{ max-width:46ch; }

.section-head{ display:flex; flex-direction:column; gap:18px; margin-bottom:clamp(36px,5vw,64px); }
.section-head.center{ align-items:center; text-align:center; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-display); font-weight:600; font-size:16px;
  padding:15px 26px; border-radius:var(--r-pill); border:1.5px solid transparent;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn--accent{ background:var(--accent); color:#fff; box-shadow:0 8px 22px var(--accent-ring); }
.btn--accent:hover{ background:var(--accent-600); transform:translateY(-2px); }
.btn--dark{ background:var(--ink); color:var(--cream); }
.btn--dark:hover{ background:#000; transform:translateY(-2px); }
.btn--ghost{ background:transparent; border-color:var(--line); color:var(--ink); }
.btn--ghost:hover{ border-color:var(--ink); }
.dark .btn--ghost{ border-color:var(--line-dark); color:var(--on-dark); }
.dark .btn--ghost:hover{ border-color:var(--on-dark); }
.btn--light{ background:var(--cream); color:var(--ink); }
.btn--light:hover{ background:#fff; transform:translateY(-2px); }
.btn--lg{ padding:18px 32px; font-size:18px; }
.btn .arr{ transition:transform .2s ease; }
.btn:hover .arr{ transform:translate(3px,-3px); }

.textlink{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:600; color:var(--accent);
}
.textlink .arr{ transition:transform .2s ease; }
.textlink:hover .arr{ transform:translate(3px,-3px); }

/* ---------- Pills / tags ---------- */
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 14px; border-radius:var(--r-pill);
  font-size:13px; font-weight:700; letter-spacing:.02em;
  background:var(--accent-soft); color:var(--accent-600);
}
.dark .pill{ background:var(--espresso-2); color:var(--on-dark); border:1px solid var(--line-dark); }
.tag{ font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); }

/* =========================================================
   HEADER
   ========================================================= */
.topbar{
  background:var(--ink); color:var(--cream);
  font-size:13.5px; letter-spacing:.01em;
}
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:16px; min-height:42px; }
.topbar a{ color:var(--cream); opacity:.85; }
.topbar a:hover{ opacity:1; }
.topbar .star{ color:var(--accent); }
.topbar-right{ display:flex; align-items:center; gap:22px; }
@media (max-width:760px){ .topbar-left span{ display:none; } }

.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(247,242,234,.82); backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:background .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.site-header.scrolled{ background:rgba(247,242,234,.96); box-shadow:var(--sh-sm); border-color:var(--line); }
.nav{ display:flex; align-items:center; gap:28px; min-height:74px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:800; font-size:21px; letter-spacing:-.02em; color:var(--ink); }
.brand .mark{
  width:34px; height:34px; border-radius:11px; flex:none;
  background:linear-gradient(135deg, var(--accent), #F0A35E);
  position:relative; box-shadow:0 4px 12px var(--accent-ring);
}
.brand .mark::after{ content:""; position:absolute; inset:9px 9px auto auto; width:9px; height:9px; border-radius:50%; background:#fff; }
.brand b{ font-weight:800; }
.brand span{ color:var(--accent); }

.nav-menu{ display:flex; align-items:center; gap:4px; margin-left:8px; }
.nav-item{ position:relative; }
.nav-link{
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 14px; border-radius:var(--r-pill);
  font-family:var(--font-display); font-weight:600; font-size:15.5px; color:var(--ink);
  transition:background .15s ease, color .15s ease;
}
.nav-link:hover{ background:var(--cream-2); }
.nav-link .chev{ width:9px; height:9px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg) translateY(-2px); transition:transform .2s ease; opacity:.6; }
.nav-item.open .nav-link .chev{ transform:rotate(-135deg) translateY(-1px); }
.nav-item.open .nav-link{ background:var(--cream-2); }

.nav-actions{ margin-left:auto; display:flex; align-items:center; gap:12px; }

/* dropdown */
.dropdown{
  position:absolute; top:calc(100% + 12px); left:50%; transform:translateX(-50%) translateY(8px);
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--sh-lg); padding:14px; min-width:300px;
  opacity:0; visibility:hidden; pointer-events:none; transition:opacity .2s ease, transform .2s ease;
  z-index:70;
}
.dropdown.wide{ min-width:620px; }
.nav-item.open .dropdown{ opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.dropdown::before{ content:""; position:absolute; top:-7px; left:50%; transform:translateX(-50%) rotate(45deg); width:14px; height:14px; background:var(--paper); border-left:1px solid var(--line); border-top:1px solid var(--line); }
.dd-grid{ display:grid; gap:6px; }
.dropdown.wide .dd-grid{ grid-template-columns:1fr 1fr; gap:6px; }
.dd-link{ display:flex; gap:13px; align-items:flex-start; padding:12px; border-radius:var(--r); transition:background .15s ease; }
.dd-link:hover{ background:var(--cream); }
.dd-ico{ width:40px; height:40px; border-radius:11px; flex:none; display:grid; place-items:center; background:var(--accent-soft); color:var(--accent-600); }
.dd-ico svg{ width:21px; height:21px; }
.dd-txt b{ display:block; font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--ink); margin-bottom:2px; }
.dd-txt span{ font-size:13px; color:var(--ink-soft); line-height:1.45; }
.dd-foot{ margin-top:8px; padding:14px 12px 6px; border-top:1px solid var(--line); display:flex; justify-content:space-between; align-items:center; }
.dd-foot .textlink{ font-size:14px; }

/* burger */
.burger{ display:none; width:46px; height:46px; border-radius:12px; border:1px solid var(--line); background:var(--paper); flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.burger span{ width:20px; height:2px; background:var(--ink); border-radius:2px; transition:.2s; }
.burger.active span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.active span:nth-child(2){ opacity:0; }
.burger.active span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0 0 0 auto; width:min(420px,90vw); z-index:90;
  background:var(--cream); box-shadow:var(--sh-lg); padding:24px;
  transform:translateX(100%); transition:transform .3s ease; overflow-y:auto;
}
.mobile-menu.open{ transform:translateX(0); }
.m-overlay{ position:fixed; inset:0; background:rgba(27,22,34,.5); opacity:0; visibility:hidden; transition:.3s; z-index:85; }
.m-overlay.open{ opacity:1; visibility:visible; }
.m-group{ border-bottom:1px solid var(--line); }
.m-head{ display:flex; align-items:center; justify-content:space-between; width:100%; background:none; border:0; padding:18px 4px; font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--ink); text-align:left; }
.m-head .chev{ width:9px;height:9px;border-right:2px solid var(--ink-soft);border-bottom:2px solid var(--ink-soft);transform:rotate(45deg);transition:.2s; }
.m-group.open .m-head .chev{ transform:rotate(-135deg); }
.m-sub{ display:none; padding:0 4px 16px; flex-direction:column; gap:2px; }
.m-group.open .m-sub{ display:flex; }
.m-sub a{ padding:9px 12px; border-radius:10px; color:var(--ink-soft); font-weight:500; }
.m-sub a:hover{ background:var(--cream-2); color:var(--ink); }
@media (max-width:1000px){
  .nav-menu, .nav-actions .btn--ghost{ display:none; }
  .burger{ display:flex; }
}

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; overflow:hidden; background:var(--espresso); color:var(--on-dark); padding-block:clamp(64px,9vw,120px); }
.hero .wrap{ position:relative; z-index:2; }
.hero-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(30px,5vw,64px); align-items:center; }
.hero h1{ font-size:clamp(38px,5.6vw,72px); color:var(--on-dark); }
.hero h1 .hl{ color:var(--accent); position:relative; white-space:nowrap; }
.hero .kicker{ display:inline-flex; align-items:center; gap:10px; padding:8px 16px; border-radius:var(--r-pill); background:var(--espresso-2); border:1px solid var(--line-dark); font-size:14px; font-weight:600; color:var(--on-dark-soft); margin-bottom:26px; }
.hero .kicker .dot{ width:8px;height:8px;border-radius:50%;background:#3FCF8E; box-shadow:0 0 0 4px rgba(63,207,142,.18); }
.hero p.lead{ margin-top:22px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:34px; }
.hero-rating{ display:flex; align-items:center; gap:14px; margin-top:30px; color:var(--on-dark-soft); font-size:14px; }
.stars{ display:inline-flex; gap:3px; color:var(--accent); }
.stars svg{ width:18px; height:18px; }

/* hero visual: abstract */
.hero-visual{ position:relative; aspect-ratio:1/1; }
.hero-orb{ position:absolute; border-radius:50%; filter:blur(2px); }
.blob{ position:absolute; border-radius:46% 54% 60% 40%/52% 44% 56% 48%; }

/* floating result cards */
.float-card{
  position:absolute; background:var(--paper); color:var(--ink);
  border-radius:var(--r); padding:16px 18px; box-shadow:var(--sh-lg);
  display:flex; flex-direction:column; gap:4px; min-width:170px;
}
.float-card .fc-label{ font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-faint); }
.float-card .fc-val{ font-family:var(--font-display); font-weight:800; font-size:30px; color:var(--ink); letter-spacing:-.02em; }
.float-card .fc-val span{ color:var(--accent); }
.float-card .fc-trend{ display:flex; align-items:center; gap:6px; font-size:13px; font-weight:700; color:#1F9D6B; }

@media (max-width:900px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-visual{ max-width:440px; margin:0 auto; width:100%; }
}

/* =========================================================
   STAT STRIP
   ========================================================= */
.stat-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat{ display:flex; flex-direction:column; gap:6px; }
.stat .num{ font-family:var(--font-display); font-weight:800; font-size:clamp(38px,5vw,60px); letter-spacing:-.03em; line-height:1; color:var(--ink); }
.dark .stat .num{ color:var(--on-dark); }
.stat .num .u{ color:var(--accent); }
.stat .lbl{ font-size:14.5px; color:var(--ink-soft); line-height:1.4; }
.dark .stat .lbl{ color:var(--on-dark-soft); }
@media (max-width:760px){ .stat-strip{ grid-template-columns:1fr 1fr; gap:30px 20px; } }

/* ---------- Logo wall ---------- */
.logo-note{ text-align:center; font-size:14px; color:var(--ink-soft); margin-bottom:30px; }
.dark .logo-note{ color:var(--on-dark-soft); }
.logo-wall{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(28px,5vw,64px); }
.logo-wm{ font-family:var(--font-display); font-weight:700; font-size:24px; letter-spacing:.02em; color:var(--ink-faint); opacity:.7; transition:opacity .2s, color .2s; }
.dark .logo-wm{ color:var(--on-dark-soft); opacity:.55; }
.logo-wm:hover{ opacity:1; color:var(--ink); }
.dark .logo-wm:hover{ color:var(--on-dark); opacity:1; }

/* marquee */
.marquee{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; gap:clamp(40px,6vw,80px); width:max-content; animation:marquee 32s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* =========================================================
   CARDS / GRIDS
   ========================================================= */
.grid{ display:grid; gap:24px; }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:980px){ .g-3,.g-4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:680px){ .g-2,.g-3,.g-4{ grid-template-columns:1fr; } }

.card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; transition:transform .2s ease, box-shadow .2s ease, border-color .2s; }
.card:hover{ transform:translateY(-4px); box-shadow:var(--sh); border-color:transparent; }
.card .c-ico{ width:54px; height:54px; border-radius:15px; display:grid; place-items:center; background:var(--accent-soft); color:var(--accent-600); margin-bottom:20px; }
.card .c-ico svg{ width:27px; height:27px; }
.card h3{ font-size:21px; margin-bottom:10px; }
.card p{ color:var(--ink-soft); font-size:16px; }
.card .textlink{ margin-top:18px; font-size:15px; }

/* service card (dark variant) */
.svc-card{ position:relative; overflow:hidden; }
.svc-card .num{ position:absolute; top:22px; right:26px; font-family:var(--font-display); font-weight:800; font-size:15px; color:var(--ink-faint); }

/* =========================================================
   PROCESS
   ========================================================= */
.steps{ display:grid; gap:24px; grid-template-columns:repeat(3,1fr); counter-reset:step; }
@media (max-width:860px){ .steps{ grid-template-columns:1fr; } }
.step{ position:relative; padding:32px; border-radius:var(--r-lg); background:var(--espresso-2); border:1px solid var(--line-dark); }
.step .badge{ width:48px;height:48px;border-radius:50%; display:grid;place-items:center; font-family:var(--font-display); font-weight:800; font-size:20px; background:var(--accent); color:#fff; margin-bottom:20px; }
.step h3{ font-size:21px; margin-bottom:10px; color:var(--on-dark); }
.step p{ color:var(--on-dark-soft); font-size:16px; }

/* =========================================================
   TABS (services / industries)
   ========================================================= */
.tabs{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:40px; }
.tab{ padding:11px 20px; border-radius:var(--r-pill); border:1.5px solid var(--line); background:var(--paper); font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--ink-soft); transition:.18s; }
.tab:hover{ border-color:var(--ink-soft); color:var(--ink); }
.tab.active{ background:var(--ink); border-color:var(--ink); color:var(--cream); }
.tab-panel{ display:none; }
.tab-panel.active{ display:block; animation:fade .35s ease; }
@keyframes fade{ from{ opacity:0; transform:translateY(8px);} to{ opacity:1; transform:none;} }

.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,60px); align-items:center; }
@media (max-width:860px){ .split{ grid-template-columns:1fr; } }
.feature-list{ display:grid; gap:14px; margin-top:8px; }
.feature-list li{ display:flex; gap:12px; align-items:flex-start; font-size:16.5px; }
.feature-list .ck{ width:24px;height:24px;border-radius:50%; flex:none; display:grid;place-items:center; background:var(--accent-soft); color:var(--accent-600); margin-top:1px; }
.feature-list .ck svg{ width:13px;height:13px; }

/* visual panel */
.viz{ border-radius:var(--r-xl); aspect-ratio:5/4; position:relative; overflow:hidden; background:linear-gradient(150deg,var(--cream-2),var(--tan)); border:1px solid var(--line); }
.viz.dark-viz{ background:linear-gradient(150deg,var(--espresso-2),var(--espresso-3)); border-color:var(--line-dark); }

/* =========================================================
   CASE STUDY CARDS
   ========================================================= */
.case-card{ border-radius:var(--r-lg); overflow:hidden; background:var(--paper); border:1px solid var(--line); transition:transform .2s, box-shadow .2s; display:flex; flex-direction:column; }
.case-card:hover{ transform:translateY(-4px); box-shadow:var(--sh); }
.case-top{ aspect-ratio:16/10; position:relative; overflow:hidden; display:grid; place-items:center; }
.case-metric{ font-family:var(--font-display); font-weight:800; font-size:clamp(34px,4vw,52px); color:#fff; letter-spacing:-.02em; position:relative; z-index:2; text-align:center; line-height:1; }
.case-metric small{ display:block; font-size:14px; font-weight:600; letter-spacing:.04em; opacity:.92; margin-top:8px; }
.case-body{ padding:24px; display:flex; flex-direction:column; gap:10px; flex:1; }
.case-body .tag{ color:var(--accent-600); }
.case-body h3{ font-size:20px; }
.case-body p{ color:var(--ink-soft); font-size:15.5px; flex:1; }

/* =========================================================
   TESTIMONIALS (carousel)
   ========================================================= */
.tcar{ position:relative; }
.tcar-viewport{ overflow:hidden; }
.tcar-track{ display:flex; transition:transform .5s cubic-bezier(.4,0,.2,1); }
.tslide{ min-width:100%; padding:0 4px; }
.tquote{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(32px,5vw,56px); box-shadow:var(--sh-sm); }
.tquote .mark{ font-family:var(--font-display); font-size:80px; line-height:.6; color:var(--accent); height:42px; }
.tquote q{ display:block; font-family:var(--font-display); font-weight:500; font-size:clamp(20px,2.6vw,29px); line-height:1.4; letter-spacing:-.01em; color:var(--ink); quotes:none; margin:18px 0 28px; }
.tquote .who{ display:flex; align-items:center; gap:14px; }
.tquote .ava{ width:54px;height:54px;border-radius:50%; flex:none; background:linear-gradient(135deg,var(--accent),#F0A35E); display:grid;place-items:center; color:#fff; font-family:var(--font-display); font-weight:800; font-size:20px; }
.tquote .who b{ display:block; font-family:var(--font-display); font-size:16px; }
.tquote .who span{ font-size:14px; color:var(--ink-soft); }
.tcar-nav{ display:flex; align-items:center; justify-content:center; gap:14px; margin-top:30px; }
.tcar-btn{ width:50px;height:50px;border-radius:50%; border:1.5px solid var(--line); background:var(--paper); display:grid;place-items:center; color:var(--ink); transition:.18s; }
.tcar-btn:hover{ background:var(--ink); color:var(--cream); border-color:var(--ink); }
.tcar-dots{ display:flex; gap:8px; }
.tdot{ width:9px;height:9px;border-radius:50%; background:var(--line); border:0; padding:0; transition:.2s; }
.tdot.active{ background:var(--accent); width:26px; border-radius:6px; }

/* =========================================================
   AWARDS / BADGES
   ========================================================= */
.badges{ display:grid; grid-template-columns:repeat(5,1fr); gap:20px; }
@media (max-width:860px){ .badges{ grid-template-columns:repeat(2,1fr); } }
.badge-card{ border:1px solid var(--line-dark); border-radius:var(--r); padding:24px 18px; text-align:center; display:flex; flex-direction:column; gap:12px; align-items:center; background:var(--espresso-2); }
.badge-medal{ width:56px;height:56px; border-radius:50%; display:grid;place-items:center; background:linear-gradient(135deg,var(--accent),#F0A35E); color:#fff; }
.badge-card b{ font-family:var(--font-display); font-size:15px; color:var(--on-dark); }
.badge-card span{ font-size:13px; color:var(--on-dark-soft); }

/* =========================================================
   TEAM
   ========================================================= */
.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
@media (max-width:860px){ .team-grid{ grid-template-columns:repeat(2,1fr); } }
.member{ text-align:center; }
.member .photo{ aspect-ratio:1/1; border-radius:var(--r-lg); overflow:hidden; margin-bottom:16px; position:relative; display:grid; place-items:center; }
.member .photo .initials{ font-family:var(--font-display); font-weight:800; font-size:46px; color:#fff; opacity:.95; }
.member b{ font-family:var(--font-display); font-size:18px; display:block; }
.member span{ color:var(--ink-soft); font-size:14.5px; }

/* =========================================================
   FAQ
   ========================================================= */
.faq{ max-width:840px; margin:0 auto; display:grid; gap:14px; }
.faq-item{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; transition:box-shadow .2s, border-color .2s; }
.faq-item.open{ box-shadow:var(--sh); border-color:transparent; }
.faq-q{ width:100%; text-align:left; background:none; border:0; padding:24px 26px; display:flex; align-items:center; justify-content:space-between; gap:20px; font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--ink); }
.faq-ico{ width:30px;height:30px; flex:none; border-radius:50%; background:var(--accent-soft); color:var(--accent-600); position:relative; display:grid; place-items:center; }
.faq-ico::before,.faq-ico::after{ content:""; position:absolute; background:currentColor; border-radius:2px; }
.faq-ico::before{ width:13px; height:2.5px; }
.faq-ico::after{ width:2.5px; height:13px; transition:transform .25s ease; }
.faq-item.open .faq-ico::after{ transform:rotate(90deg); opacity:0; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-a-inner{ padding:0 26px 26px; color:var(--ink-soft); font-size:16.5px; line-height:1.65; }

/* =========================================================
   CTA BANNER
   ========================================================= */
.cta{ position:relative; overflow:hidden; border-radius:var(--r-xl); background:var(--accent); color:#fff; padding:clamp(40px,6vw,72px); }
.cta h2{ color:#fff; }
.cta .lead{ color:rgba(255,255,255,.92); }
.cta-grid{ display:grid; grid-template-columns:1.3fr 1fr; gap:40px; align-items:center; position:relative; z-index:2; }
@media (max-width:820px){ .cta-grid{ grid-template-columns:1fr; } }
.cta-points{ display:grid; gap:14px; }
.cta-points li{ display:flex; gap:12px; align-items:flex-start; font-size:16.5px; }
.cta-points .ck{ width:26px;height:26px;border-radius:50%; flex:none; background:rgba(255,255,255,.22); display:grid;place-items:center; color:#fff; }
.cta-points .ck svg{ width:14px;height:14px; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--espresso); color:var(--on-dark-soft); padding-top:clamp(56px,7vw,88px); }
.footer-top{ display:grid; grid-template-columns:1.4fr repeat(4,1fr); gap:40px 24px; padding-bottom:48px; border-bottom:1px solid var(--line-dark); }
@media (max-width:980px){ .footer-top{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-top{ grid-template-columns:1fr; } }
.footer .brand{ color:var(--on-dark); margin-bottom:18px; }
.footer-col h5{ font-family:var(--font-display); font-size:14px; letter-spacing:.1em; text-transform:uppercase; color:var(--on-dark); margin-bottom:18px; }
.footer-col a{ display:block; padding:7px 0; color:var(--on-dark-soft); font-size:15px; }
.footer-col a:hover{ color:var(--accent); }
.footer-blurb{ font-size:15px; line-height:1.6; max-width:30ch; margin-bottom:22px; }
.socials{ display:flex; gap:10px; }
.socials a{ width:40px;height:40px;border-radius:11px; border:1px solid var(--line-dark); display:grid;place-items:center; color:var(--on-dark); transition:.2s; }
.socials a:hover{ background:var(--accent); border-color:var(--accent); color:#fff; }
.socials svg{ width:18px; height:18px; }
.footer-bottom{ display:flex; align-items:center; justify-content:space-between; gap:20px; padding-block:28px; flex-wrap:wrap; font-size:14px; }
.footer-bottom .links{ display:flex; gap:22px; flex-wrap:wrap; }

/* =========================================================
   PAGE HERO (inner pages)
   ========================================================= */
.page-hero{ background:var(--espresso); color:var(--on-dark); padding-block:clamp(56px,7vw,96px); position:relative; overflow:hidden; }
.page-hero .wrap{ position:relative; z-index:2; }
.crumbs{ display:flex; gap:8px; align-items:center; font-size:14px; color:var(--on-dark-soft); margin-bottom:22px; }
.crumbs a:hover{ color:var(--accent); }
.crumbs .sep{ opacity:.5; }
.page-hero h1{ font-size:clamp(36px,5.4vw,68px); color:var(--on-dark); max-width:18ch; }
.page-hero .lead{ margin-top:20px; max-width:60ch; }

/* =========================================================
   PRICING
   ========================================================= */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch; }
@media (max-width:920px){ .price-grid{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; } }
.price-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl); padding:34px; display:flex; flex-direction:column; gap:18px; position:relative; }
.price-card.featured{ background:var(--espresso); color:var(--on-dark); border-color:var(--espresso); box-shadow:var(--sh-lg); transform:translateY(-12px); }
@media (max-width:920px){ .price-card.featured{ transform:none; } }
.price-card.featured h3,.price-card.featured .price{ color:var(--on-dark); }
.price-card.featured .price-feat li{ color:var(--on-dark-soft); }
.price-tag{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--accent); color:#fff; font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:6px 16px; border-radius:var(--r-pill); }
.price-card h3{ font-size:22px; }
.price-card .ptype{ font-size:14.5px; color:var(--ink-soft); }
.price-card.featured .ptype{ color:var(--on-dark-soft); }
.price{ font-family:var(--font-display); font-weight:800; font-size:48px; letter-spacing:-.03em; color:var(--ink); }
.price small{ font-size:16px; font-weight:600; color:var(--ink-soft); }
.price-card.featured .price small{ color:var(--on-dark-soft); }
.price-feat{ display:grid; gap:12px; margin:6px 0 8px; }
.price-feat li{ display:flex; gap:11px; align-items:flex-start; font-size:15.5px; color:var(--ink-soft); }
.price-feat .ck{ width:22px;height:22px;border-radius:50%; flex:none; background:var(--accent-soft); color:var(--accent-600); display:grid;place-items:center; }
.price-feat .ck svg{ width:12px;height:12px; }
.price-card .btn{ margin-top:auto; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,60px); align-items:start; }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field label{ font-family:var(--font-display); font-weight:600; font-size:14.5px; }
.field input,.field select,.field textarea{
  font-family:var(--font-body); font-size:16px; padding:14px 16px;
  border:1.5px solid var(--line); border-radius:var(--r-sm); background:var(--paper); color:var(--ink); transition:.18s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-ring); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:520px){ .field-row{ grid-template-columns:1fr; } }
.contact-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(28px,4vw,44px); box-shadow:var(--sh-sm); }
.info-item{ display:flex; gap:16px; align-items:flex-start; padding:20px 0; border-bottom:1px solid var(--line); }
.info-item:last-child{ border-bottom:0; }
.info-ico{ width:48px;height:48px;border-radius:13px; flex:none; background:var(--accent-soft); color:var(--accent-600); display:grid;place-items:center; }
.info-item b{ font-family:var(--font-display); display:block; margin-bottom:3px; }
.info-item span{ color:var(--ink-soft); font-size:15.5px; }

/* =========================================================
   MISC: reveal animation
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .marquee-track{ animation:none; }
  *{ scroll-behavior:auto; }
}

/* divider shapes */
.deco{ position:absolute; pointer-events:none; z-index:1; }

/* big quote block */
.bigquote{ font-family:var(--font-display); font-weight:600; font-size:clamp(26px,3.6vw,46px); line-height:1.28; letter-spacing:-.02em; max-width:20ch; }
.bigquote .hl{ color:var(--accent); }

/* value props list */
.vlist{ display:grid; gap:28px; }
.vrow{ display:flex; gap:18px; align-items:flex-start; }
.vrow .vico{ width:50px;height:50px;border-radius:14px;flex:none; background:var(--accent-soft); color:var(--accent-600); display:grid; place-items:center; }
.vrow .vico svg{ width:24px;height:24px; }
.vrow h4{ font-size:19px; margin-bottom:6px; }
.vrow p{ color:var(--ink-soft); font-size:16px; }

/* stat callout band */
.band{ background:var(--accent-soft); }
