/*
Theme Name: Keshab Joshi — Digital Marketing Expert
Theme URI: https://krjoshi.com.np/
Author: Keshab Joshi
Author URI: https://krjoshi.com.np/
Description: Premium, conversion-engineered theme for Keshab Joshi — Google Ads Expert in Nepal. Pure PHP, vanilla JS, hand-built design system. Production-ready, SEO-optimized, accessible.
Version: 3.2.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU GPL v2 or later
Text Domain: keshab-joshi
Tags: business, portfolio, blog, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready, two-columns, right-sidebar
*/

/* ==========================================================================
   TABLE OF CONTENTS
   --------------------------------------------------------------------------
   01. Tokens (colors, fonts, spacing, motion)
   02. Reset & base
   03. Typography
   04. Layout primitives (container, grid)
   05. Buttons
   06. Forms
   07. Header & mega menu
   08. Footer
   09. Hero (front page)
   10. Marquee ticker
   11. Proof cards / clients
   12. Bento services grid
   13. About split
   14. Results strip
   15. Case study rows
   16. Process timeline
   17. Industries grid
   18. International / world map
   19. Testimonials
   20. Differentiators
   21. FAQ accordion
   22. Final CTA
   23. Inner page (page.php) — service template
   24. Sidebar
   25. Single post / case study
   26. Archive / blog index
   27. 404
   28. WhatsApp float / back-to-top
   29. Utility, reveal, motion
   30. Responsive
========================================================================== */

/* --------------------------------------------------------------------------
   01. TOKENS
-------------------------------------------------------------------------- */
:root {
  /* Surfaces */
  --bg-dark:       #0A0E1A;
  --bg-dark-2:     #131A2D;
  --bg-dark-3:     #1B2440;
  --bg-light:      #FAFBFC;
  --bg-pure:       #FFFFFF;

  /* Text */
  --text-primary:  #0F172A;
  --text-body:     #475569;
  --text-muted:    #94A3B8;
  --text-on-dark:  #E2E8F0;
  --text-on-dark-muted: #94A3B8;

  /* Borders */
  --border:        #E2E8F0;
  --border-strong: #CBD5E1;
  --border-dark:   rgba(255,255,255,0.08);
  --border-dark-2: rgba(255,255,255,0.12);

  /* Accent */
  --accent:        #00D4A1;
  --accent-dark:   #00A67E;
  --accent-light:  #5EEAC4;
  --accent-glow:   rgba(0,212,161,0.18);
  --accent-surface:#E8FFF7;
  --accent-2:      #6366F1;
  --accent-2-dark: #4F46E5;
  --accent-2-glow: rgba(99,102,241,0.15);
  --accent-3:      #F59E0B;

  /* Tag colors */
  --tag-health-bg:#DCFCE7; --tag-health-fg:#166534;
  --tag-fin-bg:   #DBEAFE; --tag-fin-fg:#1E40AF;
  --tag-hosp-bg:  #FED7AA; --tag-hosp-fg:#9A3412;
  --tag-gads-bg:  #FEF3C7; --tag-gads-fg:#92400E;
  --tag-meta-bg:  #E0E7FF; --tag-meta-fg:#4338CA;
  --tag-seo-bg:   #D1FAE5; --tag-seo-fg:#065F46;

  /* Typography */
  --font-display: 'Sora', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-body:    'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-serif:   'Instrument Serif', Georgia, serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  /* Spacing (4px scale) */
  --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-30: 120px; --s-40: 160px;

  /* Radii */
  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 20px; --r-2xl: 28px;
  --r-pill: 999px;

  /* Shadows */
  --sh-sm: 0 1px 2px rgba(15,23,42,0.04);
  --sh-md: 0 4px 16px rgba(15,23,42,0.06);
  --sh-lg: 0 12px 40px rgba(15,23,42,0.08);
  --sh-xl: 0 24px 60px rgba(15,23,42,0.12);
  --sh-glow: 0 0 40px var(--accent-glow);
  --sh-card-hover: 0 18px 48px rgba(15,23,42,0.10), 0 0 0 1px var(--accent);

  /* Motion */
  --ease-spring: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --t-micro:  200ms;
  --t-base:   400ms;
  --t-reveal: 700ms;

  /* Container */
  --container: 1280px;
  --container-px: 24px;

  /* Layout */
  --header-h: 72px;
  --section-py: 120px;
}

@media (max-width: 768px) {
  :root { --section-py: 80px; --container-px: 20px; --header-h: 64px; }
}

/* --------------------------------------------------------------------------
   02. RESET & BASE
-------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

html {
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.7;
  color: var(--text-body);
  background: var(--bg-pure);
  overflow-x: hidden;
  font-feature-settings: 'cv02','cv03','cv04','cv11';
}

img, svg, video { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
input, textarea, select { font-family: inherit; font-size: inherit; color: inherit; }
a { color: var(--accent-dark); text-decoration: none; transition: color var(--t-micro) var(--ease-spring); }
a:hover { color: var(--accent); }
ul, ol { list-style: none; }

::selection { background: var(--accent); color: #02281f; }

:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 9999;
  background: var(--bg-dark); color: #fff; padding: 12px 18px; border-radius: 0 0 8px 0;
}
.skip-link:focus { left: 0; }

/* --------------------------------------------------------------------------
   03. TYPOGRAPHY
-------------------------------------------------------------------------- */
h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  color: var(--text-primary);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
}

h1 {
  font-size: clamp(40px, 6.5vw, 72px);
  line-height: 0.98;
  letter-spacing: -0.04em;
  font-weight: 700;
}
h2 {
  font-size: clamp(32px, 4.5vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  font-weight: 700;
}
h3 { font-size: clamp(22px, 2.5vw, 28px); line-height: 1.25; }
h4 { font-size: 19px; }

p { margin-bottom: 1em; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--accent-dark);
}
.eyebrow .dot {
  width: 6px; height: 6px; border-radius: 999px; background: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-glow);
  animation: pulse 2.4s var(--ease-spring) infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 var(--accent-glow); }
  50%      { box-shadow: 0 0 0 8px transparent; }
}

.serif-italic, em.serif {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  color: var(--accent-dark);
  letter-spacing: -0.01em;
}
.dark .serif-italic, .dark em.serif { color: var(--accent-light); }

.mono { font-family: var(--font-mono); font-feature-settings: 'tnum'; }

/* --------------------------------------------------------------------------
   04. LAYOUT PRIMITIVES
-------------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-left: var(--container-px);
  padding-right: var(--container-px);
}
.container.narrow { max-width: 920px; }
.container.tight  { max-width: 720px; }

.section { padding-top: var(--section-py); padding-bottom: var(--section-py); position: relative; }
.section.tight { padding-top: 80px; padding-bottom: 80px; }

.section.dark {
  background: var(--bg-dark);
  color: var(--text-on-dark);
}
.section.dark h1, .section.dark h2, .section.dark h3, .section.dark h4 { color: #fff; }
.section.dark .eyebrow { color: var(--accent-light); }

.section-head { max-width: 760px; margin: 0 auto 64px; text-align: center; }
.section-head.left { margin-left: 0; text-align: left; }
.section-head h2 { margin-top: 14px; }
.section-head p { margin-top: 18px; font-size: 18px; color: var(--text-body); }
.dark .section-head p { color: var(--text-on-dark-muted); }

/* --------------------------------------------------------------------------
   05. BUTTONS
-------------------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 15px;
  border-radius: 10px;
  letter-spacing: -0.005em;
  transition: transform var(--t-micro) var(--ease-spring),
              background var(--t-micro) var(--ease-spring),
              box-shadow var(--t-micro) var(--ease-spring),
              color var(--t-micro) var(--ease-spring);
  position: relative;
  white-space: nowrap;
  cursor: pointer;
  border: 1px solid transparent;
}
.btn .arrow { transition: transform var(--t-micro) var(--ease-spring); display: inline-block; }
.btn:hover .arrow { transform: translateX(3px); }

.btn.primary {
  background: var(--accent);
  color: #02281f;
  box-shadow: var(--sh-glow);
}
.btn.primary:hover { background: var(--accent-light); transform: translateY(-2px); box-shadow: 0 12px 40px rgba(0,212,161,0.35); }

.btn.secondary {
  background: transparent;
  color: var(--text-primary);
  border-color: var(--border-strong);
}
.btn.secondary:hover { background: var(--bg-light); transform: translateY(-2px); border-color: var(--accent); color: var(--accent-dark); }
/* Dark contexts — make secondary buttons visible (this was the "See Case Studies" bug) */
.dark .btn.secondary,
.hero .btn.secondary,
.page-hero .btn.secondary,
.post-hero .btn.secondary,
.archive-hero .btn.secondary,
.final-cta .btn.secondary,
.err-page .btn.secondary,
.industries .btn.secondary,
.results .btn.secondary {
  color: #fff;
  border-color: rgba(255,255,255,0.22);
  background: rgba(255,255,255,0.04);
}
.dark .btn.secondary:hover,
.hero .btn.secondary:hover,
.page-hero .btn.secondary:hover,
.post-hero .btn.secondary:hover,
.archive-hero .btn.secondary:hover,
.final-cta .btn.secondary:hover,
.err-page .btn.secondary:hover,
.industries .btn.secondary:hover,
.results .btn.secondary:hover {
  background: rgba(255,255,255,0.10);
  border-color: var(--accent-light);
  color: #fff;
}
/* Ghost buttons visible on dark too */
.dark .btn.ghost,
.hero .btn.ghost,
.page-hero .btn.ghost,
.post-hero .btn.ghost,
.final-cta .btn.ghost { color: #fff; }
.dark .btn.ghost:hover,
.hero .btn.ghost:hover,
.page-hero .btn.ghost:hover,
.post-hero .btn.ghost:hover,
.final-cta .btn.ghost:hover { color: var(--accent-light); }

.btn.ghost {
  background: transparent;
  color: var(--text-primary);
  padding: 12px 14px;
}
.dark .btn.ghost { color: #fff; }
.btn.ghost:hover { color: var(--accent-dark); }
.dark .btn.ghost:hover { color: var(--accent-light); }

.btn.pill { border-radius: 999px; }
.btn.lg { padding: 18px 28px; font-size: 16px; }
.btn.sm { padding: 10px 16px; font-size: 13.5px; }

.btn.wa {
  background: #25D366; color: #fff;
}
.btn.wa:hover { background: #1ebd5b; transform: translateY(-2px); }

.cta-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }

/* Text link with underline animation */
.link-arrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 600; color: var(--accent-dark);
  border-bottom: 1.5px solid transparent;
  padding-bottom: 2px;
  transition: border-color var(--t-micro), color var(--t-micro);
}
.link-arrow:hover { border-bottom-color: currentColor; color: var(--accent); }
.link-arrow .arrow { transition: transform var(--t-micro) var(--ease-spring); }
.link-arrow:hover .arrow { transform: translateX(4px); }

/* --------------------------------------------------------------------------
   06. FORMS
-------------------------------------------------------------------------- */
.field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.field label {
  font-size: 13px; font-weight: 600;
  color: var(--text-primary); letter-spacing: -0.005em;
}
.field input,
.field textarea,
.field select {
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg-pure);
  font-size: 15px;
  color: var(--text-primary);
  transition: border-color var(--t-micro), box-shadow var(--t-micro), transform var(--t-micro);
  width: 100%;
}
.field input:focus,
.field textarea:focus,
.field select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-glow);
}
.field textarea { resize: vertical; min-height: 140px; line-height: 1.6; }
.field .hint { font-size: 12px; color: var(--text-muted); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .field-row { grid-template-columns: 1fr; } }

.checkbox-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
.checkbox-grid label {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; border: 1px solid var(--border); border-radius: 10px;
  font-weight: 500; cursor: pointer;
  transition: border-color var(--t-micro), background var(--t-micro);
}
.checkbox-grid label:hover { border-color: var(--accent); background: var(--accent-surface); }
.checkbox-grid input { accent-color: var(--accent-dark); }

/* --------------------------------------------------------------------------
   07. HEADER & MEGA MENU
-------------------------------------------------------------------------- */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 90;
  height: var(--header-h);
  background: var(--bg-pure);
  border-bottom: 1px solid var(--border);
  transition: background var(--t-micro), border-color var(--t-micro), box-shadow var(--t-micro);
}
/* Front page / dark-hero pages start transparent */
.site-header.transparent {
  background: transparent;
  border-bottom-color: transparent;
}
.site-header.scrolled {
  background: rgba(255,255,255,0.92);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom-color: var(--border);
  box-shadow: var(--sh-sm);
}
.site-header.transparent.scrolled { background: rgba(255,255,255,0.92); }

.header-inner {
  height: 100%;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}

.brand {
  display: inline-flex; flex-direction: column; gap: 2px;
  color: var(--text-primary);
}
.brand .wordmark {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 17px;
  letter-spacing: -0.04em;
  line-height: 1;
}
.brand .tagline {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-dark);
  font-weight: 500;
  transition: color var(--t-micro);
}
.brand:hover .tagline { color: var(--accent); }

.site-header.transparent:not(.scrolled) .brand { color: #fff; }
.site-header.transparent:not(.scrolled) .brand .tagline { color: var(--accent-light); }

.primary-nav { display: flex; align-items: center; gap: 6px; }
.primary-nav > li { position: relative; }
.primary-nav a.nav-link {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 14px; border-radius: 10px;
  font-size: 14.5px; font-weight: 500;
  color: var(--text-primary);
  transition: color var(--t-micro), background var(--t-micro);
}
.site-header.transparent:not(.scrolled) .primary-nav a.nav-link { color: #fff; }
.primary-nav a.nav-link:hover { color: var(--accent-dark); }
.primary-nav a.nav-link .caret { transition: transform var(--t-micro); }
.primary-nav > li:hover a.nav-link .caret,
.primary-nav > li.open a.nav-link .caret { transform: rotate(180deg); }

/* Mega menu */
.mega {
  position: fixed;
  left: 50%; transform: translateX(-50%) translateY(8px);
  top: calc(var(--header-h));
  width: min(1100px, calc(100vw - 32px));
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--sh-xl);
  padding: 28px;
  display: none;
  z-index: 100;
}
.primary-nav > li:hover .mega,
.primary-nav > li.open .mega { display: grid; animation: megaIn 220ms var(--ease-spring); }
@keyframes megaIn { from { opacity: 0; transform: translateX(-50%) translateY(2px); } to { opacity: 1; transform: translateX(-50%) translateY(8px); } }

.mega { grid-template-columns: 1.4fr 1.4fr 1fr; gap: 28px; }
.mega .col { display: flex; flex-direction: column; gap: 4px; }
.mega .col-title {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}
.mega .m-item {
  display: grid; grid-template-columns: 32px 1fr; gap: 12px;
  padding: 10px;
  border-radius: 10px;
  transition: background var(--t-micro), transform var(--t-micro);
}
.mega .m-item:hover { background: var(--bg-light); transform: translateX(2px); }
.mega .m-item .ico {
  width: 32px; height: 32px; border-radius: 8px;
  display: grid; place-items: center;
  background: var(--accent-surface);
  color: var(--accent-dark);
}
.mega .m-item .t {
  font-family: var(--font-display); font-weight: 600;
  color: var(--text-primary); font-size: 14.5px;
  letter-spacing: -0.01em; line-height: 1.2;
}
.mega .m-item .d { font-size: 12.5px; color: var(--text-muted); margin-top: 2px; }
.mega .feature {
  background: linear-gradient(180deg, #0A0E1A, #131A2D);
  color: #fff; padding: 22px; border-radius: 14px;
  display: flex; flex-direction: column; justify-content: space-between;
  min-height: 200px;
}
.mega .feature .eyebrow { color: var(--accent-light); }
.mega .feature h4 { color: #fff; margin-top: 8px; font-size: 18px; }
.mega .feature p  { color: var(--text-on-dark-muted); font-size: 13.5px; }

.cta-button-header .btn { padding: 11px 18px; font-size: 14px; }

/* Hamburger */
.hamb {
  display: none;
  width: 44px; height: 44px;
  border-radius: 10px;
  align-items: center; justify-content: center;
  background: rgba(15,23,42,0.04);
}
.site-header.transparent:not(.scrolled) .hamb { background: rgba(255,255,255,0.10); }
.hamb span { display: block; width: 18px; height: 2px; background: currentColor; border-radius: 2px; margin: 2px 0; transition: transform var(--t-micro); }
.site-header.transparent:not(.scrolled) .hamb { color: #fff; }

@media (max-width: 1024px) {
  .primary-nav, .cta-button-header { display: none; }
  .hamb { display: inline-flex; }
}

/* Mobile drawer */
.mobile-drawer {
  position: fixed; inset: 0;
  background: var(--bg-dark);
  color: #fff;
  z-index: 200;
  transform: translateX(100%);
  transition: transform 360ms var(--ease-spring);
  overflow-y: auto;
  padding: 28px 24px 80px;
}
.mobile-drawer.open { transform: translateX(0); }
.mobile-drawer .close-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 32px; }
.mobile-drawer .close { width: 44px; height: 44px; border-radius: 10px; background: rgba(255,255,255,0.08); display: grid; place-items: center; }
.mobile-drawer details { border-top: 1px solid var(--border-dark); padding: 16px 0; }
.mobile-drawer summary {
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-display); font-weight: 600; font-size: 18px; color: #fff;
  list-style: none;
}
.mobile-drawer summary::-webkit-details-marker { display: none; }
.mobile-drawer summary::after { content: '+'; font-weight: 300; font-size: 22px; color: var(--accent-light); transition: transform var(--t-micro); }
.mobile-drawer details[open] summary::after { transform: rotate(45deg); }
.mobile-drawer details a {
  display: block; padding: 8px 0; color: var(--text-on-dark-muted);
  font-size: 15px;
}
.mobile-drawer details a:hover { color: var(--accent-light); }
.mobile-drawer .m-cta { margin: 28px 0; display: flex; flex-direction: column; gap: 10px; }
.mobile-drawer .m-contact { margin-top: 24px; display: flex; flex-wrap: wrap; gap: 8px; }

/* --------------------------------------------------------------------------
   08. FOOTER
-------------------------------------------------------------------------- */
.site-footer { background: var(--bg-dark); color: var(--text-on-dark); padding-top: 0; margin-top: 0; }
.footer-cta {
  background: linear-gradient(135deg, #0A0E1A 0%, #131A2D 50%, #0F1B36 100%);
  position: relative; overflow: hidden;
  padding: 80px 0;
  border-bottom: 1px solid var(--border-dark);
}
.footer-cta::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(600px 300px at 80% 20%, var(--accent-glow), transparent 60%),
              radial-gradient(500px 280px at 20% 80%, var(--accent-2-glow), transparent 60%);
  pointer-events: none;
}
.footer-cta .inner { position: relative; display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center; }
.footer-cta h2 { color: #fff; font-size: clamp(34px, 4.5vw, 56px); }
.footer-cta p { color: var(--text-on-dark-muted); font-size: 18px; max-width: 460px; margin-top: 14px; }
.footer-cta .right { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
@media (max-width: 900px) { .footer-cta .inner { grid-template-columns: 1fr; } }

.footer-main { padding: 80px 0 32px; }
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr repeat(4, 1fr);
  gap: 48px;
}
@media (max-width: 1024px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .footer-grid { grid-template-columns: 1fr; } }
.footer-col h5 {
  color: #fff; font-size: 14px; font-weight: 600; letter-spacing: -0.005em;
  text-transform: uppercase; letter-spacing: 0.12em;
  margin-bottom: 18px;
  font-family: var(--font-mono);
}
.footer-col ul li { margin-bottom: 10px; }
.footer-col ul a { color: var(--text-on-dark-muted); font-size: 14px; }
.footer-col ul a:hover { color: var(--accent-light); }
.footer-brand .brand { color: #fff; }
.footer-brand .brand .wordmark { font-size: 20px; }
.footer-brand p { margin: 14px 0; color: var(--text-on-dark-muted); font-size: 14.5px; max-width: 320px; }
.footer-brand .socials { display: flex; gap: 8px; margin-top: 16px; }
.footer-brand .socials a {
  width: 36px; height: 36px; display: grid; place-items: center;
  border-radius: 10px; background: rgba(255,255,255,0.05);
  color: #fff; transition: background var(--t-micro), transform var(--t-micro);
}
.footer-brand .socials a:hover { background: var(--accent); color: #02281f; transform: translateY(-2px); }

.footer-newsletter {
  margin-top: 20px; background: rgba(255,255,255,0.04);
  padding: 16px; border-radius: 12px; border: 1px solid var(--border-dark);
}
.footer-newsletter label { font-size: 12px; color: var(--text-on-dark-muted); display: block; margin-bottom: 8px; }
.footer-newsletter .row { display: flex; gap: 6px; }
.footer-newsletter input {
  flex: 1; padding: 10px 12px; border-radius: 8px;
  background: rgba(255,255,255,0.05); border: 1px solid var(--border-dark);
  color: #fff; font-size: 13.5px;
}
.footer-newsletter input::placeholder { color: var(--text-on-dark-muted); }
.footer-newsletter button {
  padding: 10px 14px; background: var(--accent); color: #02281f;
  font-weight: 600; border-radius: 8px; font-size: 13.5px;
}

.footer-bottom {
  border-top: 1px solid var(--border-dark);
  padding: 22px 0;
  display: flex; flex-wrap: wrap; gap: 18px; justify-content: space-between;
  color: var(--text-on-dark-muted); font-size: 13.5px;
}
.footer-bottom .locations { font-family: var(--font-mono); font-size: 12px; }
.footer-bottom .credit { font-style: italic; }

/* --------------------------------------------------------------------------
   09. HERO (FRONT PAGE)
-------------------------------------------------------------------------- */
.hero {
  position: relative;
  min-height: 100vh;
  background: var(--bg-dark);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.hero .mesh {
  position: absolute; inset: -10%;
  pointer-events: none; z-index: 0;
  background:
    radial-gradient(45vmax 45vmax at 15% 20%, rgba(0,212,161,0.20), transparent 60%),
    radial-gradient(40vmax 40vmax at 80% 30%, rgba(99,102,241,0.20), transparent 60%),
    radial-gradient(50vmax 50vmax at 50% 90%, rgba(8,42,80,0.55), transparent 60%);
  filter: blur(30px);
  animation: meshDrift 22s ease-in-out infinite;
}
@keyframes meshDrift {
  0%, 100% { transform: translate(0,0) scale(1); }
  50%      { transform: translate(2%, -2%) scale(1.05); }
}
.hero .spotlight {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(420px circle at var(--mx, 50%) var(--my, 30%), rgba(0,212,161,0.10), transparent 70%);
  transition: background 80ms linear;
}
.hero .grid-overlay {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
}
.hero .container { position: relative; z-index: 2; }

.hero-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 64px;
  align-items: center;
  padding: calc(var(--header-h) + 60px) 0 100px;
  min-height: 100vh;
}
@media (max-width: 1024px) {
  .hero-grid { grid-template-columns: 1fr; padding-top: calc(var(--header-h) + 40px); padding-bottom: 80px; }
}

.hero-left .eyebrow { color: var(--accent-light); }
.hero h1 { color: #fff; margin: 18px 0 22px; max-width: 12ch; }
.hero h1 .swap {
  position: relative;
  display: inline-block;
  color: var(--accent);
  min-width: 5ch;
}
.hero h1 .swap .swap-word {
  display: inline-block;
  background: linear-gradient(120deg, var(--accent), var(--accent-light));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  transition: opacity 350ms var(--ease-spring), transform 350ms var(--ease-spring);
}
.hero h1 .swap .swap-word.out { opacity: 0; transform: translateY(-12px) rotate(-2deg); }
.hero h1 .swap .swap-word.in  { opacity: 1; transform: translateY(0) rotate(0); }
.hero h1 .swap::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -4px;
  height: 3px; background: linear-gradient(90deg, var(--accent), transparent);
  border-radius: 2px; transform-origin: left;
  animation: underlineSweep 3.5s var(--ease-spring) infinite;
}
@keyframes underlineSweep { 0%,100% { transform: scaleX(0); } 30%,70% { transform: scaleX(1); } }

.hero-lede { font-size: 18px; color: var(--text-on-dark-muted); max-width: 520px; margin-bottom: 32px; line-height: 1.7; }

.hero-stats {
  margin-top: 56px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  padding-top: 28px;
  border-top: 1px solid var(--border-dark);
}
@media (max-width: 720px) { .hero-stats { grid-template-columns: repeat(2, 1fr); gap: 24px; } }
.hero-stat .num {
  font-family: var(--font-mono);
  font-size: clamp(26px, 3.4vw, 36px);
  font-weight: 500;
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1;
  display: flex; align-items: baseline; gap: 6px;
}
.hero-stat .num .pre, .hero-stat .num .suf { color: var(--accent-light); font-weight: 500; }
.hero-stat .lbl { display: block; margin-top: 8px; color: var(--text-on-dark-muted); font-size: 12.5px; font-family: var(--font-mono); letter-spacing: 0.04em; }

/* Right column portrait */
.hero-right { position: relative; min-height: 480px; display: flex; justify-content: center; align-items: center; }
.portrait-wrap {
  position: relative;
  width: min(420px, 100%);
  aspect-ratio: 4 / 5;
}
.portrait {
  width: 100%; height: 100%;
  border-radius: 38% 62% 60% 40% / 42% 38% 62% 58%;
  background:
    linear-gradient(135deg, rgba(0,212,161,0.25), rgba(99,102,241,0.20)),
    linear-gradient(180deg, #1B2440 0%, #0A0E1A 100%);
  border: 1px solid var(--border-dark-2);
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,0.45), inset 0 0 0 1px rgba(255,255,255,0.04);
  animation: blobShift 12s ease-in-out infinite;
}
@keyframes blobShift {
  0%,100% { border-radius: 38% 62% 60% 40% / 42% 38% 62% 58%; }
  50%     { border-radius: 60% 40% 38% 62% / 58% 60% 38% 42%; }
}
.portrait img { width: 100%; height: 100%; object-fit: cover; }
.portrait-initials {
  width: 100%; height: 100%; display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 96px;
  color: rgba(255,255,255,0.16); letter-spacing: -0.04em;
}

.badge-card {
  position: absolute;
  background: rgba(15,23,42,0.85);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border: 1px solid var(--border-dark-2);
  border-radius: 14px;
  padding: 12px 14px;
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: #fff;
  box-shadow: var(--sh-lg);
  animation: floaty 5.5s ease-in-out infinite;
}
.badge-card .ico {
  width: 32px; height: 32px; border-radius: 8px; background: var(--accent-glow);
  display: grid; place-items: center; color: var(--accent-light);
}
.badge-card .mini { color: var(--text-on-dark-muted); font-size: 11px; font-family: var(--font-mono); }
.badge-1 { top: 8%;   left: -8%; }
.badge-2 { top: 30%;  right: -10%; animation-delay: -1.5s; }
.badge-3 { bottom: 20%; left: -12%; animation-delay: -3s; }
.badge-4 { bottom: 5%;  right: -4%; animation-delay: -2s; }
@keyframes floaty {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

.scroll-cue {
  position: absolute; left: 50%; bottom: 32px; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: var(--text-on-dark-muted); font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  z-index: 2;
}
.scroll-cue .line { width: 1px; height: 36px; background: linear-gradient(180deg, var(--accent), transparent); animation: scrollLine 2.2s ease-in-out infinite; }
@keyframes scrollLine { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); transform-origin: top; } 51% { transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* --------------------------------------------------------------------------
   10. MARQUEE TICKER
-------------------------------------------------------------------------- */
.ticker {
  background: var(--bg-dark-2);
  color: var(--text-on-dark-muted);
  border-top: 1px solid var(--border-dark);
  border-bottom: 1px solid var(--border-dark);
  padding: 18px 0;
  overflow: hidden;
}
.ticker-track {
  display: inline-flex; gap: 56px; white-space: nowrap;
  animation: tickerScroll 38s linear infinite;
}
.ticker:hover .ticker-track { animation-play-state: paused; }
.ticker .item {
  display: inline-flex; align-items: center; gap: 18px;
  font-family: var(--font-mono); font-size: 13.5px; letter-spacing: 0.06em;
}
.ticker .star { color: var(--accent); }
@keyframes tickerScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.geo-line {
  text-align: center; padding: 14px 0; font-family: var(--font-mono);
  font-size: 12.5px; color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  background: var(--bg-pure);
}
.geo-line .flags { letter-spacing: 0.12em; }

/* --------------------------------------------------------------------------
   11. CLIENT PROOF CARDS
-------------------------------------------------------------------------- */
.proof-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { .proof-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .proof-grid { grid-template-columns: 1fr; } }

.proof-card {
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 26px;
  transition: transform var(--t-micro) var(--ease-spring),
              border-color var(--t-micro), box-shadow var(--t-micro);
  position: relative;
  overflow: hidden;
}
.proof-card:hover { transform: translateY(-4px); border-color: var(--accent); box-shadow: var(--sh-md); }
.proof-card .logo {
  font-family: var(--font-display); font-weight: 700;
  font-size: 16px; color: var(--text-primary); letter-spacing: -0.02em;
  margin-bottom: 14px;
}
.proof-card .tag { display: inline-flex; padding: 4px 10px; border-radius: 999px; font-size: 11.5px; font-weight: 600; }
.proof-card .metric {
  margin-top: 14px;
  font-size: 15px; color: var(--text-primary); font-weight: 600; letter-spacing: -0.01em;
  line-height: 1.5;
}
.proof-card .country {
  margin-top: 14px; display: flex; justify-content: space-between; align-items: center;
  color: var(--text-muted); font-family: var(--font-mono); font-size: 12px;
}
.proof-card .arrow {
  position: absolute; right: 22px; top: 22px; opacity: 0;
  transition: opacity var(--t-micro), transform var(--t-micro);
  color: var(--accent-dark);
}
.proof-card:hover .arrow { opacity: 1; transform: translate(4px, -4px); }

.proof-footer {
  text-align: center; margin-top: 36px; font-family: var(--font-mono);
  font-size: 13px; color: var(--text-muted); letter-spacing: 0.04em;
}

/* --------------------------------------------------------------------------
   12. BENTO SERVICES
-------------------------------------------------------------------------- */
.bento {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 240px;
  gap: 16px;
}
@media (max-width: 1024px) { .bento { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; } }
@media (max-width: 720px)  { .bento { grid-template-columns: 1fr 1fr; grid-auto-rows: 200px; } }

.bento-card {
  position: relative;
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 24px;
  display: flex; flex-direction: column; justify-content: space-between;
  transition: transform var(--t-micro) var(--ease-spring),
              border-color var(--t-micro), box-shadow var(--t-micro);
  overflow: hidden;
}
.bento-card:hover { transform: translateY(-2px) scale(1.005); border-color: var(--accent); box-shadow: var(--sh-md); }
.bento-card .icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--accent-surface); color: var(--accent-dark);
  display: grid; place-items: center;
}
.bento-card h3 { font-size: 22px; margin-top: 16px; }
.bento-card .desc { color: var(--text-body); font-size: 14.5px; line-height: 1.55; margin-top: 6px; }
.bento-card .pills { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.bento-card .pill {
  font-size: 11px; padding: 4px 9px; border-radius: 999px;
  background: var(--bg-light); color: var(--text-body); font-weight: 500;
  font-family: var(--font-mono); letter-spacing: 0.04em;
}
.bento-card .more {
  margin-top: 14px;
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--accent-dark); font-weight: 600; font-size: 14px;
  opacity: 0; transform: translateY(4px); transition: opacity var(--t-micro), transform var(--t-micro);
}
.bento-card:hover .more { opacity: 1; transform: translateY(0); }

.bento-card.large { grid-column: span 3; grid-row: span 2; }
.bento-card.dark {
  background: var(--bg-dark);
  color: #fff;
  border-color: var(--border-dark-2);
}
.bento-card.dark h3 { color: #fff; }
.bento-card.dark .desc { color: var(--text-on-dark-muted); }
.bento-card.dark .pill { background: rgba(255,255,255,0.06); color: #fff; }
.bento-card.dark .icon { background: var(--accent-glow); color: var(--accent-light); }
.bento-card.span-2 { grid-column: span 2; }

@media (max-width: 1024px) {
  .bento-card.large { grid-column: span 2; grid-row: span 2; }
}
@media (max-width: 720px) {
  .bento-card.large { grid-column: span 2; grid-row: span 2; }
  .bento-card.span-2 { grid-column: span 2; }
}

/* Mini dashboard mockup inside Google Ads card */
.mini-dash {
  margin-top: 16px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg-light);
  padding: 10px;
  font-family: var(--font-mono); font-size: 11px;
}
.mini-dash .row { display: grid; grid-template-columns: 1fr auto; gap: 8px; padding: 4px 0; border-bottom: 1px dashed var(--border); color: var(--text-body); }
.mini-dash .row:last-child { border-bottom: 0; }
.mini-dash .row .v { color: var(--accent-dark); font-weight: 600; }

/* Mini chart in SEO card */
.mini-chart {
  margin-top: 12px;
  width: 100%; height: 56px;
  background: linear-gradient(180deg, var(--accent-surface), transparent);
  border-radius: 8px;
  position: relative;
}
.mini-chart svg { width: 100%; height: 100%; }

/* --------------------------------------------------------------------------
   13. ABOUT SPLIT
-------------------------------------------------------------------------- */
.about-split { display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px; align-items: center; }
@media (max-width: 1024px) { .about-split { grid-template-columns: 1fr; gap: 48px; } }

.about-photo-wrap { position: relative; }
.about-photo {
  width: 100%; aspect-ratio: 5/6;
  border-radius: 38% 62% 60% 40% / 42% 38% 62% 58%;
  background:
    linear-gradient(135deg, rgba(0,212,161,0.10), rgba(99,102,241,0.08)),
    var(--bg-light);
  border: 1px solid var(--border);
  overflow: hidden;
  position: relative; z-index: 2;
  animation: blobShift 12s ease-in-out infinite;
}
.about-photo img { width: 100%; height: 100%; object-fit: cover; }
.about-photo .initials {
  width: 100%; height: 100%; display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 96px;
  color: var(--accent); letter-spacing: -0.04em;
}
.about-deco {
  position: absolute; inset: 0;
  background-image: radial-gradient(var(--border-strong) 1.2px, transparent 1.2px);
  background-size: 16px 16px;
  border-radius: var(--r-lg);
  transform: translate(24px, 24px);
  z-index: 1; opacity: 0.7;
}
.about-availability {
  position: absolute; top: 18px; left: -10px; z-index: 3;
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 8px 14px;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12.5px; font-weight: 600; color: var(--text-primary);
  box-shadow: var(--sh-md);
}
.about-availability .dot { width: 8px; height: 8px; border-radius: 999px; background: var(--accent); animation: pulse 2.4s var(--ease-spring) infinite; }

.about-proof {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  margin-top: 28px;
}
.about-proof .item {
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 18px;
  transition: border-color var(--t-micro), transform var(--t-micro);
  position: relative; overflow: hidden;
}
.about-proof .item:hover { border-color: var(--accent); transform: translateY(-2px); }
.about-proof .ico {
  width: 36px; height: 36px; border-radius: 10px; background: var(--accent-surface);
  color: var(--accent-dark); display: grid; place-items: center; margin-bottom: 10px;
}
.about-proof .t { font-family: var(--font-display); font-weight: 600; color: var(--text-primary); margin-bottom: 2px; font-size: 15.5px; }
.about-proof .d { font-size: 13.5px; color: var(--text-body); }
.about-proof .reveal { font-family: var(--font-mono); font-size: 12px; color: var(--accent-dark); margin-top: 8px; opacity: 0; transition: opacity var(--t-micro); }
.about-proof .item:hover .reveal { opacity: 1; }

/* --------------------------------------------------------------------------
   14. RESULTS STRIP (dark)
-------------------------------------------------------------------------- */
.results { background: var(--bg-dark); }
.results-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
@media (max-width: 900px) { .results-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }

.results-item .num {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(56px, 7.5vw, 96px);
  letter-spacing: -0.05em;
  color: #fff;
  line-height: 0.95;
  font-feature-settings: 'tnum';
}
.results-item .num .suf, .results-item .num .pre {
  color: var(--accent-light); font-weight: 600; font-size: 0.5em; letter-spacing: -0.02em;
}
.results-item .lbl {
  margin-top: 16px;
  font-size: 14px; color: var(--text-on-dark-muted);
  font-family: var(--font-mono);
}
.results-item .spark {
  margin-top: 12px; opacity: 0.6;
  display: block; width: 64px; height: 18px;
}

/* --------------------------------------------------------------------------
   15. CASE STUDY ROWS
-------------------------------------------------------------------------- */
.cs-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  padding: 36px;
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  background: var(--bg-pure);
  margin-bottom: 24px;
  transition: transform var(--t-micro), box-shadow var(--t-micro), border-color var(--t-micro);
  position: relative;
  overflow: hidden;
}
.cs-row::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--accent); transform: scaleY(0); transform-origin: top;
  transition: transform var(--t-base) var(--ease-spring);
}
.cs-row:hover { transform: translateY(-3px); box-shadow: var(--sh-md); border-color: var(--border-strong); }
.cs-row:hover::before { transform: scaleY(1); }

.cs-row .tags { display: flex; gap: 6px; flex-wrap: wrap; }
.cs-row .industry { margin-left: auto; color: var(--text-muted); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; }
.cs-row .head-row { display: flex; align-items: center; gap: 12px; }
.cs-row h3 { font-size: 26px; margin-top: 14px; max-width: 720px; }
.cs-row p { color: var(--text-body); font-size: 15.5px; max-width: 720px; }
.cs-row .metric-row {
  display: flex; gap: 28px; flex-wrap: wrap; align-items: center;
  margin-top: 24px; padding-top: 22px;
  border-top: 1px dashed var(--border);
}
.cs-row .metric { font-family: var(--font-mono); }
.cs-row .metric .v { font-size: 26px; color: var(--accent-dark); font-weight: 600; letter-spacing: -0.02em; }
.cs-row .metric .l { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.cs-row .more { margin-left: auto; }

.tag {
  display: inline-flex; padding: 5px 11px; border-radius: 999px;
  font-size: 11.5px; font-weight: 600; font-family: var(--font-mono); letter-spacing: 0.02em;
}
.tag.healthcare { background: var(--tag-health-bg); color: var(--tag-health-fg); }
.tag.finance    { background: var(--tag-fin-bg);   color: var(--tag-fin-fg); }
.tag.hospitality{ background: var(--tag-hosp-bg);  color: var(--tag-hosp-fg); }
.tag.google     { background: var(--tag-gads-bg);  color: var(--tag-gads-fg); }
.tag.meta       { background: var(--tag-meta-bg);  color: var(--tag-meta-fg); }
.tag.seo        { background: var(--tag-seo-bg);   color: var(--tag-seo-fg); }
.tag.market     { background: var(--bg-light); color: var(--text-body); }

/* --------------------------------------------------------------------------
   16. PROCESS TIMELINE
-------------------------------------------------------------------------- */
.process { position: relative; }
.process .container { position: relative; }
.process .timeline {
  position: relative;
  padding-left: 96px;
}
.process .timeline::before {
  content: ''; position: absolute; left: 36px; top: 6px; bottom: 6px;
  width: 2px; background: linear-gradient(180deg, var(--accent), var(--accent-2));
  border-radius: 2px; opacity: 0.18;
}
.process .timeline::after {
  content: ''; position: absolute; left: 36px; top: 6px;
  width: 2px; background: linear-gradient(180deg, var(--accent), var(--accent-2));
  border-radius: 2px;
  height: var(--p-progress, 0%);
  transition: height 200ms linear;
}
.process .step {
  position: relative;
  padding: 18px 0 56px;
}
.process .step:last-child { padding-bottom: 0; }
.process .step .num {
  position: absolute;
  left: -96px; top: -12px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 80px;
  color: var(--accent);
  opacity: 0.22;
  line-height: 1; letter-spacing: -0.06em;
  transition: opacity var(--t-base) var(--ease-spring);
}
.process .step.active .num,
.process .step:hover .num { opacity: 1; }
.process .step .dot {
  position: absolute; left: -65px; top: 22px;
  width: 14px; height: 14px; border-radius: 999px;
  background: var(--bg-pure); border: 2px solid var(--accent);
  z-index: 2; box-shadow: 0 0 0 4px var(--bg-pure);
}
.process .step h3 { font-size: 22px; margin-bottom: 8px; }
.process .step p { color: var(--text-body); max-width: 640px; }
@media (max-width: 720px) {
  .process .timeline { padding-left: 60px; }
  .process .step .num { left: -60px; font-size: 56px; }
  .process .step .dot { left: -41px; }
  .process .timeline::before, .process .timeline::after { left: 12px; }
}

/* --------------------------------------------------------------------------
   17. INDUSTRIES GRID (dark bento)
-------------------------------------------------------------------------- */
.industries { background: var(--bg-dark); }
.ind-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 900px) { .ind-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .ind-grid { grid-template-columns: 1fr; } }
.ind-card {
  position: relative;
  background: var(--bg-dark-2);
  border: 1px solid var(--border-dark);
  border-radius: var(--r-lg);
  padding: 26px;
  color: #fff;
  transition: background var(--t-micro), transform var(--t-micro), border-color var(--t-micro);
  min-height: 180px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.ind-card:hover { background: var(--bg-dark-3); transform: translateY(-3px); border-color: var(--accent); }
.ind-card .icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--accent-glow); color: var(--accent-light);
  display: grid; place-items: center;
  transition: transform var(--t-base) var(--ease-spring);
}
.ind-card:hover .icon { transform: rotate(-6deg) scale(1.06); }
.ind-card h4 { color: #fff; font-size: 19px; margin-top: 16px; }
.ind-card .ex {
  margin-top: 12px; color: var(--text-on-dark-muted); font-size: 13.5px;
}
.ind-card .more { margin-top: 12px; color: var(--accent-light); font-size: 13px; opacity: 0; transition: opacity var(--t-micro); }
.ind-card:hover .more { opacity: 1; }

/* --------------------------------------------------------------------------
   18. INTERNATIONAL / WORLD MAP
-------------------------------------------------------------------------- */
.intl { background: var(--bg-light); }
.intl-grid {
  display: grid; grid-template-columns: 1fr 1.2fr;
  gap: 56px; align-items: center;
}
@media (max-width: 1024px) { .intl-grid { grid-template-columns: 1fr; } }
.intl-list { display: grid; gap: 16px; margin-top: 20px; }
.intl-list .it {
  display: grid; grid-template-columns: 40px 1fr; gap: 14px;
  padding: 14px 16px;
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  transition: border-color var(--t-micro), transform var(--t-micro);
}
.intl-list .it:hover { border-color: var(--accent); transform: translateX(2px); }
.intl-list .it .ico { width: 40px; height: 40px; border-radius: 10px; background: var(--accent-surface); display: grid; place-items: center; color: var(--accent-dark); }
.intl-list .it .t { font-family: var(--font-display); font-weight: 600; color: var(--text-primary); font-size: 15.5px; letter-spacing: -0.01em; }
.intl-list .it .d { font-size: 13.5px; color: var(--text-body); margin-top: 2px; }

.world-map {
  position: relative;
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 28px;
  overflow: hidden;
}
.world-map svg { width: 100%; height: auto; }
.world-map .legend {
  margin-top: 16px; display: flex; flex-wrap: wrap; gap: 12px; font-family: var(--font-mono); font-size: 12px; color: var(--text-muted);
}

/* --------------------------------------------------------------------------
   19. TESTIMONIALS
-------------------------------------------------------------------------- */
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .testimonials-grid { grid-template-columns: 1fr; } }

.t-card {
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  position: relative;
  transition: transform var(--t-micro), border-color var(--t-micro), box-shadow var(--t-micro);
}
.t-card:hover { transform: translateY(-3px); border-color: var(--border-strong); box-shadow: var(--sh-md); }
.t-card .open-quote {
  font-family: var(--font-serif); font-style: italic; font-size: 72px;
  color: var(--accent); line-height: 0.5; margin-bottom: 12px;
}
.t-card .quote {
  font-size: 16.5px; line-height: 1.6; color: var(--text-primary);
}
.t-card .quote .hi { font-family: var(--font-serif); font-style: italic; color: var(--accent-dark); font-weight: 500; }
.t-card .stars { color: var(--accent-3); margin: 16px 0; letter-spacing: 2px; }
.t-card .who { display: flex; gap: 12px; align-items: center; padding-top: 14px; border-top: 1px solid var(--border); }
.t-card .avatar {
  width: 44px; height: 44px; border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 16px;
}
.t-card .who .n { font-family: var(--font-display); font-weight: 600; color: var(--text-primary); font-size: 14.5px; }
.t-card .who .r { color: var(--text-muted); font-size: 12.5px; }
.t-card .verify { margin-left: auto; color: var(--accent-2); font-size: 12px; display: inline-flex; align-items: center; gap: 4px; }

/* --------------------------------------------------------------------------
   20. DIFFERENTIATORS
-------------------------------------------------------------------------- */
.diff-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .diff-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .diff-grid { grid-template-columns: 1fr; } }
.diff-card {
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  transition: transform var(--t-micro), border-color var(--t-micro), box-shadow var(--t-micro);
  position: relative;
}
.diff-card.featured { border-color: var(--accent); background: linear-gradient(180deg, var(--accent-surface) 0%, var(--bg-pure) 30%); }
.diff-card:hover { transform: translateY(-3px); border-color: var(--accent); box-shadow: var(--sh-md); }
.diff-card .num {
  font-family: var(--font-display); font-weight: 700;
  font-size: 48px; color: var(--accent-dark);
  letter-spacing: -0.04em; line-height: 1; margin-bottom: 14px;
  transition: transform var(--t-micro) var(--ease-spring);
}
.diff-card:hover .num { transform: scale(1.06); }
.diff-card h4 { font-size: 19px; position: relative; padding-bottom: 6px; }
.diff-card h4::after {
  content: ''; position: absolute; left: 0; bottom: 0; height: 2px;
  width: 0; background: var(--accent);
  transition: width var(--t-base) var(--ease-spring);
}
.diff-card:hover h4::after { width: 36px; }
.diff-card p { color: var(--text-body); font-size: 14.5px; margin-top: 8px; }

/* --------------------------------------------------------------------------
   21. FAQ ACCORDION
-------------------------------------------------------------------------- */
.faq { max-width: 820px; margin: 0 auto; }
.faq-search {
  position: relative; margin-bottom: 28px;
}
.faq-search input {
  width: 100%;
  padding: 14px 18px 14px 46px;
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  background: var(--bg-pure);
  font-size: 15px;
}
.faq-search input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-glow); }
.faq-search .ic { position: absolute; left: 18px; top: 50%; transform: translateY(-50%); color: var(--text-muted); }

.faq-item {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--bg-pure);
  margin-bottom: 10px;
  overflow: hidden;
  transition: border-color var(--t-micro), box-shadow var(--t-micro);
}
.faq-item.open { border-color: var(--accent); box-shadow: 0 8px 32px rgba(0,212,161,0.08); }
.faq-item .q {
  width: 100%;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding: 20px 24px;
  font-family: var(--font-display); font-weight: 600;
  font-size: 17px; color: var(--text-primary);
  letter-spacing: -0.01em; text-align: left;
  transition: background var(--t-micro);
}
.faq-item .q:hover { background: var(--bg-light); }
.faq-item .q .pre { color: var(--text-muted); font-family: var(--font-mono); font-size: 13px; font-weight: 500; margin-right: 10px; }
.faq-item .q .ic {
  width: 28px; height: 28px; border-radius: 999px;
  background: var(--bg-light); color: var(--text-primary);
  display: grid; place-items: center; flex-shrink: 0;
  font-size: 20px; line-height: 1;
  transition: transform var(--t-base) var(--ease-spring), background var(--t-micro), color var(--t-micro);
}
.faq-item.open .q .ic { transform: rotate(45deg); background: var(--accent); color: #02281f; }
.faq-item .a {
  max-height: 0; overflow: hidden;
  transition: max-height var(--t-base) var(--ease-spring);
}
.faq-item.open .a { max-height: 640px; }
.faq-item .a-inner {
  padding: 0 24px 22px;
  color: var(--text-body); font-size: 15.5px; line-height: 1.7;
}
.faq-empty { text-align: center; color: var(--text-muted); padding: 28px; }

/* --------------------------------------------------------------------------
   22. FINAL CTA
-------------------------------------------------------------------------- */
.final-cta {
  background: linear-gradient(135deg, #0A0E1A 0%, #131A2D 50%, #1B2440 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
  padding: 120px 0;
}
.final-cta::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(50vw 50vw at 80% 30%, var(--accent-glow), transparent 60%),
    radial-gradient(50vw 50vw at 15% 80%, var(--accent-2-glow), transparent 60%);
  animation: meshDrift 18s ease-in-out infinite;
}
.final-cta .inner { position: relative; text-align: center; max-width: 920px; margin: 0 auto; }
.final-cta h2 { color: #fff; font-size: clamp(40px, 6vw, 80px); letter-spacing: -0.04em; }
.final-cta .lede { color: var(--text-on-dark-muted); margin-top: 18px; font-size: 18px; }
.final-cta .ctas { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 32px; }
.final-cta .meta {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
  margin-top: 28px; color: var(--text-on-dark-muted);
  font-family: var(--font-mono); font-size: 13px;
}
.final-cta .meta .pill {
  background: rgba(255,255,255,0.06); padding: 8px 14px; border-radius: 999px;
  border: 1px solid var(--border-dark-2);
  display: inline-flex; align-items: center; gap: 8px;
}
.final-cta .meta .pill .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--accent); animation: pulse 2.4s var(--ease-spring) infinite; }
.final-cta .marquee {
  margin-top: 56px; padding-top: 28px;
  border-top: 1px solid var(--border-dark);
  font-family: var(--font-mono); color: var(--text-on-dark-muted);
  font-size: 13px; letter-spacing: 0.06em;
  overflow: hidden;
}
.final-cta .marquee-track { display: inline-flex; gap: 56px; animation: tickerScroll 30s linear infinite; white-space: nowrap; }

/* --------------------------------------------------------------------------
   23. INNER PAGE (page.php)
-------------------------------------------------------------------------- */
.page-hero {
  background: var(--bg-dark);
  color: #fff;
  padding: calc(var(--header-h) + 80px) 0 80px;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(40vw 40vw at 90% 10%, var(--accent-glow), transparent 70%),
    radial-gradient(40vw 40vw at 0% 90%, var(--accent-2-glow), transparent 70%);
}
.page-hero .grid-overlay { opacity: 0.7; }
.page-hero .inner { position: relative; display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: flex-end; }
@media (max-width: 900px) { .page-hero .inner { grid-template-columns: 1fr; } }

.breadcrumbs { font-family: var(--font-mono); font-size: 12.5px; color: var(--text-on-dark-muted); margin-bottom: 18px; letter-spacing: 0.04em; }
.breadcrumbs a { color: var(--text-on-dark-muted); }
.breadcrumbs a:hover { color: var(--accent-light); }
.breadcrumbs .sep { margin: 0 8px; color: var(--accent); }

.page-hero h1 { color: #fff; font-size: clamp(36px, 5.2vw, 60px); }
.page-hero .lede { color: var(--text-on-dark-muted); font-size: 19px; margin-top: 18px; max-width: 620px; }
.page-hero .ctas { margin-top: 28px; }

.service-info-card {
  background: rgba(255,255,255,0.04);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border-dark-2);
  border-radius: var(--r-lg);
  padding: 22px;
  font-size: 13.5px;
  display: grid; gap: 14px;
}
.service-info-card .row { display: flex; justify-content: space-between; align-items: center; padding-bottom: 12px; border-bottom: 1px dashed var(--border-dark); }
.service-info-card .row:last-child { border-bottom: 0; padding-bottom: 0; }
.service-info-card .l { color: var(--text-on-dark-muted); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; }
.service-info-card .v { color: #fff; font-weight: 600; }
.service-info-card .badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px; background: var(--accent-glow); color: var(--accent-light);
  border-radius: 999px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.04em;
}
.service-info-card .badge .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--accent); animation: pulse 2.4s var(--ease-spring) infinite; }

.page-body { padding: 80px 0 120px; }
.page-body .inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 64px;
  align-items: flex-start;
}
@media (max-width: 1024px) { .page-body .inner { grid-template-columns: 1fr; gap: 48px; } }

.entry-content {
  font-size: 17px; line-height: 1.78; color: var(--text-body);
}
.entry-content > * + * { margin-top: 1.1em; }
.entry-content h2 {
  position: relative;
  padding-left: 18px;
  font-size: clamp(28px, 3.4vw, 40px);
  margin-top: 2.2em;
  margin-bottom: 0.4em;
  color: var(--text-primary);
}
.entry-content h2::before {
  content: ''; position: absolute; left: 0; top: 6px; bottom: 6px;
  width: 4px; background: var(--accent); border-radius: 2px;
}
.entry-content h3 { color: var(--text-primary); margin-top: 1.6em; font-size: 22px; }
.entry-content h4 { color: var(--text-primary); margin-top: 1.4em; font-size: 18px; }
.entry-content p { margin: 0 0 1.2em; }
.entry-content a { color: var(--accent-dark); border-bottom: 1.5px solid var(--accent-glow); transition: border-color var(--t-micro), color var(--t-micro); }
.entry-content a:hover { color: var(--accent); border-bottom-color: var(--accent); }
.entry-content strong { color: var(--text-primary); font-weight: 600; }
.entry-content ul, .entry-content ol { padding-left: 0; margin: 1.1em 0; }
.entry-content ul li, .entry-content ol li { margin: 10px 0; padding-left: 28px; position: relative; line-height: 1.65; }
.entry-content ul li::before {
  content: ''; position: absolute; left: 0; top: 12px;
  width: 12px; height: 2px; background: var(--accent); border-radius: 2px;
  transition: width var(--t-micro);
}
.entry-content ul li:hover::before { width: 18px; }
.entry-content ol { counter-reset: ol; }
.entry-content ol li { counter-increment: ol; padding-left: 44px; }
.entry-content ol li::before {
  content: counter(ol, decimal-leading-zero);
  position: absolute; left: 0; top: 0;
  font-family: var(--font-mono); font-weight: 500;
  color: var(--accent-dark); font-size: 14px; letter-spacing: -0.02em;
  background: var(--accent-surface);
  border-radius: 6px;
  padding: 1px 6px;
}
.entry-content blockquote {
  margin: 28px 0;
  padding: 22px 28px;
  border-left: 3px solid var(--accent);
  background: var(--accent-surface);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  font-family: var(--font-serif); font-style: italic; font-size: 22px;
  color: var(--text-primary); line-height: 1.5;
  position: relative;
}
.entry-content blockquote::before {
  content: '“'; position: absolute; top: -10px; left: 16px;
  font-size: 60px; color: var(--accent); line-height: 1; font-family: var(--font-serif);
}
.entry-content .pullquote {
  font-family: var(--font-serif); font-style: italic;
  font-size: clamp(26px, 3.6vw, 38px);
  color: var(--accent-dark); text-align: center;
  margin: 56px auto; max-width: 720px; line-height: 1.35;
  padding: 32px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
.entry-content table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden;
  margin: 24px 0;
  font-size: 14.5px;
}
.entry-content table thead th {
  background: var(--bg-dark); color: #fff;
  padding: 14px 18px; text-align: left;
  font-family: var(--font-mono); font-size: 12.5px;
  letter-spacing: 0.06em; text-transform: uppercase;
  font-weight: 500;
}
.entry-content table tbody td {
  padding: 14px 18px; border-top: 1px solid var(--border); color: var(--text-body);
}
.entry-content table tbody tr:hover td { background: var(--bg-light); }
.entry-content code {
  font-family: var(--font-mono); font-size: 0.92em;
  background: var(--bg-light); padding: 2px 6px; border-radius: 6px;
  color: var(--accent-dark); border: 1px solid var(--border);
}
.entry-content pre {
  background: var(--bg-dark); color: #fff;
  padding: 20px 22px; border-radius: var(--r-md);
  font-family: var(--font-mono); font-size: 13.5px; line-height: 1.65;
  overflow-x: auto;
}
.entry-content pre code { background: transparent; color: #fff; border: 0; padding: 0; }

/* Embedded blocks */
.feature-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px;
  margin: 32px 0;
}
@media (max-width: 600px) { .feature-grid { grid-template-columns: 1fr; } }
.feature-grid .fi {
  border: 1px solid var(--border); border-radius: var(--r-md);
  padding: 20px; background: var(--bg-pure);
  transition: border-color var(--t-micro), transform var(--t-micro);
}
.feature-grid .fi:hover { border-color: var(--accent); transform: translateY(-2px); }
.feature-grid .fi .ico {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--accent-surface); color: var(--accent-dark);
  display: grid; place-items: center; margin-bottom: 12px;
}
.feature-grid .fi .t { font-family: var(--font-display); font-weight: 600; color: var(--text-primary); margin-bottom: 4px; font-size: 16px; }
.feature-grid .fi .d { font-size: 14px; color: var(--text-body); line-height: 1.5; }

.stat-callout {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; padding: 28px;
  background: var(--bg-dark); color: #fff;
  border-radius: var(--r-lg);
  margin: 32px 0;
}
@media (max-width: 600px) { .stat-callout { grid-template-columns: 1fr; gap: 18px; } }
.stat-callout .s .v { font-family: var(--font-mono); font-size: 32px; color: var(--accent-light); font-weight: 500; letter-spacing: -0.02em; }
.stat-callout .s .l { color: var(--text-on-dark-muted); font-size: 13.5px; margin-top: 6px; }

/* --------------------------------------------------------------------------
   24. SIDEBAR
-------------------------------------------------------------------------- */
.sidebar { position: sticky; top: calc(var(--header-h) + 24px); display: flex; flex-direction: column; gap: 20px; }
.side-card {
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 22px;
}
.side-card h5 {
  font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-muted); margin-bottom: 14px;
  font-weight: 500;
}
.side-card ul li a {
  display: flex; align-items: center; gap: 8px; padding: 8px 0;
  color: var(--text-body); font-size: 14.5px;
  border-left: 2px solid transparent; padding-left: 10px; margin-left: -10px;
  transition: color var(--t-micro), border-color var(--t-micro);
}
.side-card ul li a:hover, .side-card ul li.current a { color: var(--accent-dark); border-left-color: var(--accent); }
.side-card.cta {
  background: linear-gradient(160deg, var(--accent) 0%, var(--accent-dark) 100%);
  color: #02281f;
  border: 0;
}
.side-card.cta h5, .side-card.cta p { color: #02281f; }
.side-card.cta .btn.primary { background: #02281f; color: var(--accent-light); box-shadow: none; }
.side-card.cta .btn.primary:hover { background: #001a14; }
.side-card .contact-list a {
  display: grid; grid-template-columns: 32px 1fr; gap: 10px; padding: 8px 0;
  align-items: center;
}
.side-card .contact-list .ico { width: 32px; height: 32px; border-radius: 8px; background: var(--accent-surface); color: var(--accent-dark); display: grid; place-items: center; }
.side-card .trust { font-size: 13px; color: var(--text-body); line-height: 1.5; }
.side-card .trust strong { color: var(--text-primary); }

.related-posts { display: grid; gap: 12px; }
.related-posts .p {
  display: grid; grid-template-columns: 48px 1fr; gap: 12px;
  padding: 10px; border-radius: 10px; border: 1px solid var(--border);
  transition: border-color var(--t-micro);
}
.related-posts .p:hover { border-color: var(--accent); }
.related-posts .p .thumb { width: 48px; height: 48px; border-radius: 8px; background: var(--bg-light); display: grid; place-items: center; color: var(--accent-dark); }
.related-posts .p .t { font-family: var(--font-display); font-weight: 600; font-size: 13.5px; color: var(--text-primary); line-height: 1.35; }
.related-posts .p .m { font-size: 11.5px; color: var(--text-muted); font-family: var(--font-mono); margin-top: 4px; }

@media (max-width: 1024px) {
  .sidebar { position: static; }
}

/* Below content sections */
.siblings-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
  margin-top: 24px;
}
@media (max-width: 900px) { .siblings-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .siblings-grid { grid-template-columns: 1fr; } }
.sibling-card {
  display: block;
  background: var(--bg-pure); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 22px;
  transition: border-color var(--t-micro), transform var(--t-micro);
  color: var(--text-primary);
}
.sibling-card:hover { border-color: var(--accent); transform: translateY(-3px); color: var(--text-primary); }
.sibling-card h4 { font-size: 17px; margin-bottom: 8px; }
.sibling-card p { font-size: 14px; color: var(--text-body); }
.sibling-card .arrow { color: var(--accent-dark); font-weight: 600; font-size: 13.5px; margin-top: 12px; display: inline-flex; align-items: center; gap: 6px; }

/* --------------------------------------------------------------------------
   25. SINGLE POST / CASE STUDY
-------------------------------------------------------------------------- */
.reading-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px; z-index: 99;
  background: transparent;
}
.reading-progress .bar {
  height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-2));
  transform-origin: left; transform: scaleX(0);
  transition: transform 80ms linear;
}

.post-hero {
  background: var(--bg-dark);
  color: #fff;
  padding: calc(var(--header-h) + 80px) 0 80px;
  position: relative; overflow: hidden;
}
.post-hero::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(40vw 40vw at 90% 10%, var(--accent-glow), transparent 70%);
}
.post-hero .tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 18px; }
.post-hero h1 { color: #fff; max-width: 14ch; }
.post-hero .meta { display: flex; gap: 18px; flex-wrap: wrap; align-items: center; color: var(--text-on-dark-muted); font-family: var(--font-mono); font-size: 13px; margin-top: 22px; }
.post-hero .meta .av { width: 30px; height: 30px; border-radius: 999px; background: var(--accent); color: #02281f; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 12px; }

.featured-image-wrap {
  margin: -40px auto 40px;
  max-width: var(--container);
  padding: 0 var(--container-px);
  position: relative; z-index: 2;
}
.featured-image-wrap img {
  border-radius: var(--r-xl);
  box-shadow: var(--sh-xl);
  width: 100%;
}

.cs-metrics-bar {
  background: var(--bg-pure);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 28px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  margin: 0 auto 48px;
  max-width: 920px;
  box-shadow: var(--sh-md);
  transform: translateY(-32px);
}
@media (max-width: 720px) { .cs-metrics-bar { grid-template-columns: 1fr; gap: 18px; } }
.cs-metrics-bar .m { text-align: center; }
.cs-metrics-bar .v { font-family: var(--font-mono); font-size: clamp(28px, 4vw, 44px); color: var(--accent-dark); font-weight: 600; letter-spacing: -0.02em; line-height: 1; }
.cs-metrics-bar .l { color: var(--text-muted); font-size: 13px; margin-top: 8px; font-family: var(--font-mono); }

.post-body .inner {
  display: grid; grid-template-columns: minmax(0,1fr) 260px;
  gap: 56px; align-items: flex-start;
}
@media (max-width: 1024px) { .post-body .inner { grid-template-columns: 1fr; } }

.toc {
  position: sticky; top: calc(var(--header-h) + 24px);
  background: var(--bg-pure); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 22px;
}
.toc h5 { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 12px; }
.toc ul li a {
  display: block; padding: 6px 0 6px 12px; border-left: 2px solid transparent;
  color: var(--text-body); font-size: 13.5px; transition: color var(--t-micro), border-color var(--t-micro);
}
.toc ul li a.active, .toc ul li a:hover { color: var(--accent-dark); border-left-color: var(--accent); }

.share-rail {
  position: fixed; left: 24px; top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 8px; z-index: 30;
}
.share-rail a {
  width: 40px; height: 40px; border-radius: 999px; background: var(--bg-pure);
  border: 1px solid var(--border); display: grid; place-items: center;
  color: var(--text-body); transition: color var(--t-micro), border-color var(--t-micro), transform var(--t-micro);
  box-shadow: var(--sh-sm);
}
.share-rail a:hover { color: var(--accent-dark); border-color: var(--accent); transform: translateY(-2px); }
@media (max-width: 1300px) { .share-rail { display: none; } }

/* --------------------------------------------------------------------------
   26. ARCHIVE / BLOG INDEX
-------------------------------------------------------------------------- */
.archive-hero { background: var(--bg-dark); color: #fff; padding: calc(var(--header-h) + 80px) 0 64px; position: relative; overflow: hidden; }
.archive-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(40vw 40vw at 80% 30%, var(--accent-glow), transparent 70%); pointer-events: none; }
.archive-hero h1 { color: #fff; max-width: 18ch; }
.archive-hero .lede { color: var(--text-on-dark-muted); font-size: 18px; margin-top: 14px; max-width: 640px; }
.archive-hero .filters { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.archive-hero .filters .chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: 999px;
  background: rgba(255,255,255,0.06); border: 1px solid var(--border-dark-2);
  color: #fff; font-size: 13px; font-family: var(--font-mono);
  cursor: pointer; transition: background var(--t-micro), border-color var(--t-micro);
}
.archive-hero .filters .chip:hover, .archive-hero .filters .chip.active { background: var(--accent); color: #02281f; border-color: var(--accent); }

.posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
@media (max-width: 1024px) { .posts-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .posts-grid { grid-template-columns: 1fr; } }

.post-card {
  background: var(--bg-pure); border: 1px solid var(--border); border-radius: var(--r-lg);
  overflow: hidden; display: flex; flex-direction: column;
  transition: transform var(--t-micro), box-shadow var(--t-micro), border-color var(--t-micro);
}
.post-card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); border-color: var(--border-strong); }
.post-card .thumb {
  aspect-ratio: 16/10;
  background: linear-gradient(135deg, var(--bg-dark), var(--bg-dark-2));
  position: relative; overflow: hidden;
}
.post-card .thumb img { width: 100%; height: 100%; object-fit: cover; }
.post-card .thumb .ph {
  position: absolute; inset: 0; display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700; font-size: 24px;
  color: rgba(255,255,255,0.6); letter-spacing: -0.02em;
}
.post-card .body { padding: 22px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.post-card .cat { font-family: var(--font-mono); font-size: 11.5px; color: var(--accent-dark); letter-spacing: 0.08em; text-transform: uppercase; }
.post-card h3 { font-size: 19px; margin-top: 8px; line-height: 1.3; }
.post-card .excerpt { color: var(--text-body); font-size: 14px; margin-top: 8px; flex: 1; line-height: 1.55; }
.post-card .meta { display: flex; justify-content: space-between; align-items: center; margin-top: 18px; color: var(--text-muted); font-size: 12.5px; font-family: var(--font-mono); }

.post-card.featured { grid-column: span 3; display: grid; grid-template-columns: 1.2fr 1fr; }
@media (max-width: 1024px) { .post-card.featured { grid-column: span 2; grid-template-columns: 1fr; } }
@media (max-width: 600px)  { .post-card.featured { grid-column: span 1; } }
.post-card.featured .thumb { aspect-ratio: auto; height: 100%; min-height: 240px; }
.post-card.featured .body { padding: 36px; }

.pagination { margin-top: 48px; display: flex; gap: 8px; justify-content: center; }
.pagination a, .pagination span {
  padding: 10px 14px; border-radius: 10px; background: var(--bg-pure);
  border: 1px solid var(--border); color: var(--text-primary); font-weight: 500;
  font-size: 14px; transition: border-color var(--t-micro), background var(--t-micro);
}
.pagination a:hover { border-color: var(--accent); }
.pagination .current { background: var(--accent); color: #02281f; border-color: var(--accent); }

/* Case study archive cards (premium) */
.cs-archive-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (max-width: 900px) { .cs-archive-grid { grid-template-columns: 1fr; } }

.cs-archive-card {
  background: var(--bg-pure); border: 1px solid var(--border); border-radius: var(--r-xl);
  padding: 32px; transition: border-color var(--t-micro), transform var(--t-micro), box-shadow var(--t-micro);
  position: relative; overflow: hidden;
}
.cs-archive-card:hover { transform: translateY(-3px); border-color: var(--accent); box-shadow: var(--sh-md); }
.cs-archive-card .tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 14px; }
.cs-archive-card h3 { font-size: 24px; margin-bottom: 10px; }
.cs-archive-card .sum { color: var(--text-body); font-size: 15px; line-height: 1.55; }
.cs-archive-card .row { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 22px; padding-top: 20px; border-top: 1px dashed var(--border); }
.cs-archive-card .hero-m { font-family: var(--font-mono); font-size: 24px; color: var(--accent-dark); font-weight: 600; letter-spacing: -0.02em; }

/* --------------------------------------------------------------------------
   27. 404
-------------------------------------------------------------------------- */
.err-page { min-height: calc(100vh - var(--header-h)); display: grid; place-items: center; background: var(--bg-dark); color: #fff; text-align: center; padding: 80px 24px; position: relative; overflow: hidden; }
.err-page::before { content: ''; position: absolute; inset: 0; background: radial-gradient(40vw 40vw at 50% 30%, var(--accent-glow), transparent 70%); pointer-events: none; }
.err-page .big { font-family: var(--font-display); font-size: clamp(120px, 24vw, 280px); font-weight: 700; line-height: 0.85; letter-spacing: -0.06em; background: linear-gradient(135deg, var(--accent), var(--accent-2)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.err-page h1 { color: #fff; margin: 20px 0 10px; }
.err-page p { color: var(--text-on-dark-muted); max-width: 540px; margin: 0 auto 24px; }

/* --------------------------------------------------------------------------
   28. WHATSAPP FLOAT & BACK TO TOP
-------------------------------------------------------------------------- */
.wa-float {
  position: fixed; right: 24px; bottom: 24px; z-index: 80;
  width: 56px; height: 56px; border-radius: 999px;
  background: #25D366; color: #fff;
  display: grid; place-items: center;
  box-shadow: 0 12px 30px rgba(37,211,102,0.45);
  transition: transform var(--t-micro) var(--ease-spring);
  animation: waPulse 2.6s ease-in-out 1s 3;
}
.wa-float:hover { transform: scale(1.08); }
@keyframes waPulse {
  0%, 100% { box-shadow: 0 12px 30px rgba(37,211,102,0.45), 0 0 0 0 rgba(37,211,102,0.6); }
  50%      { box-shadow: 0 12px 30px rgba(37,211,102,0.45), 0 0 0 16px rgba(37,211,102,0); }
}

.back-to-top {
  position: fixed; left: 24px; bottom: 24px; z-index: 80;
  width: 44px; height: 44px; border-radius: 999px;
  background: var(--bg-dark); color: #fff;
  border: 1px solid var(--accent);
  display: grid; place-items: center;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-micro), transform var(--t-micro) var(--ease-spring);
  transform: scale(0.9);
}
.back-to-top.show { opacity: 1; pointer-events: auto; transform: scale(1); }
.back-to-top:hover { transform: scale(1.08); }

@media (max-width: 600px) {
  .wa-float { right: 16px; bottom: 16px; width: 52px; height: 52px; }
  .back-to-top { left: 16px; bottom: 16px; width: 40px; height: 40px; }
}

/* --------------------------------------------------------------------------
   29. UTILITY / REVEAL / MOTION
-------------------------------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity var(--t-reveal) var(--ease-spring), transform var(--t-reveal) var(--ease-spring); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal[data-delay="1"] { transition-delay: 80ms; }
.reveal[data-delay="2"] { transition-delay: 160ms; }
.reveal[data-delay="3"] { transition-delay: 240ms; }
.reveal[data-delay="4"] { transition-delay: 320ms; }
.reveal[data-delay="5"] { transition-delay: 400ms; }
.reveal[data-delay="6"] { transition-delay: 480ms; }

.hidden { display: none !important; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

/* --------------------------------------------------------------------------
   30. RESPONSIVE TWEAKS
-------------------------------------------------------------------------- */
@media (max-width: 1024px) {
  .hero-stats .hero-stat .num { font-size: 28px; }
  .cs-row .metric .v { font-size: 22px; }
}
@media (max-width: 720px) {
  .hero { min-height: auto; }
  .hero-grid { gap: 48px; }
  .portrait-wrap { max-width: 320px; }
  .badge-card { font-size: 12px; padding: 10px 12px; }
  .cs-row { padding: 24px; }
  .cs-row h3 { font-size: 22px; }
  .cs-row .metric-row { gap: 20px; }
  .cs-row .metric .v { font-size: 20px; }
  .footer-cta { padding: 60px 0; }
  .final-cta { padding: 80px 0; }
}

/* Tag pill base for entry content references */
.entry-content .tag-pill { display: inline-flex; padding: 4px 10px; border-radius: 999px; font-size: 12px; font-family: var(--font-mono); background: var(--accent-surface); color: var(--accent-dark); border: 1px solid var(--accent-glow); }

/* ==========================================================================
   31. EDITORIAL POLISH — what was missing
   These styles layer on top of the existing system to add the kind of
   visual depth and imperfection a senior designer adds last.
========================================================================== */

/* --- Film-grain overlay: kills the "too perfect" digital feel --- */
body::before {
	content: "";
	position: fixed; inset: 0;
	pointer-events: none;
	z-index: 1;
	opacity: 0.04;
	mix-blend-mode: overlay;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	background-size: 180px 180px;
}
.site-header, .mobile-drawer, .mega, .wa-float, .back-to-top, .reading-progress {
	z-index: 90; /* keep UI above the grain layer */
}

/* --- Drop cap on long-form articles --- */
.entry-content > p:first-of-type::first-letter,
.entry-content .article-body > p:first-of-type::first-letter {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 4em;
	float: left;
	line-height: 0.85;
	margin: 0.08em 0.12em 0 -0.04em;
	color: var(--accent-dark);
}

/* H2 left-bar styling is in section 23 — keep that intact. */

/* --- Hero workspace card (replaces the simple portrait blob) --- */
.workspace {
	position: relative;
	width: min(440px, 100%);
	margin: 0 auto;
}
.workspace .frame {
	position: relative;
	background: linear-gradient(180deg, #1B2440 0%, #0A0E1A 100%);
	border: 1px solid var(--border-dark-2);
	border-radius: 22px;
	padding: 22px;
	box-shadow: 0 30px 80px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.06);
	transform: rotate(-1deg);
	transition: transform 600ms var(--ease-spring);
}
.workspace:hover .frame { transform: rotate(0deg); }
.workspace .frame::before {
	content: "";
	position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
	background-size: 24px 24px;
	border-radius: 22px;
	pointer-events: none;
}
.workspace .frame > * { position: relative; }

.workspace-head {
	display: flex; align-items: center; gap: 10px;
	padding-bottom: 14px; margin-bottom: 16px;
	border-bottom: 1px solid var(--border-dark);
}
.workspace-head .dots { display: flex; gap: 5px; }
.workspace-head .dots span { width: 9px; height: 9px; border-radius: 999px; background: rgba(255,255,255,0.16); }
.workspace-head .dots span:nth-child(1) { background: #FF5F57; }
.workspace-head .dots span:nth-child(2) { background: #FEBC2E; }
.workspace-head .dots span:nth-child(3) { background: #28C840; }
.workspace-head .label {
	margin-left: auto;
	font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em;
	text-transform: uppercase; color: var(--text-on-dark-muted);
}

.workspace-row {
	display: flex; justify-content: space-between; align-items: baseline;
	font-family: var(--font-mono);
	padding: 9px 0;
	border-bottom: 1px dashed rgba(255,255,255,0.06);
}
.workspace-row:last-child { border-bottom: 0; }
.workspace-row .k { color: var(--text-on-dark-muted); font-size: 12px; letter-spacing: 0.02em; }
.workspace-row .v { color: #fff; font-size: 15px; font-weight: 500; letter-spacing: -0.01em; }
.workspace-row .delta { color: var(--accent-light); font-size: 11px; margin-left: 8px; }
.workspace-row .delta.down { color: #f87171; }

.workspace-chart {
	margin-top: 14px;
	height: 64px;
	background: rgba(0,212,161,0.06);
	border-radius: 10px;
	border: 1px solid rgba(0,212,161,0.18);
	padding: 8px;
	position: relative;
}
.workspace-chart svg { width: 100%; height: 100%; }
.workspace-chart .legend {
	position: absolute; top: 8px; right: 12px;
	font-family: var(--font-mono); font-size: 10px; color: var(--accent-light); letter-spacing: 0.1em;
}

/* Floating tags next to the workspace card */
.ws-float {
	position: absolute;
	background: rgba(255,255,255,0.96);
	color: var(--text-primary);
	border: 1px solid var(--border);
	border-radius: 14px;
	padding: 10px 14px 10px 12px;
	display: flex; align-items: center; gap: 10px;
	font-size: 13px;
	box-shadow: 0 18px 40px rgba(0,0,0,0.18);
	animation: floaty 5.5s ease-in-out infinite;
	z-index: 2;
}
.ws-float .ico {
	width: 30px; height: 30px; border-radius: 8px;
	background: var(--accent-surface); color: var(--accent-dark);
	display: grid; place-items: center; flex-shrink: 0;
}
.ws-float .t { font-family: var(--font-display); font-weight: 600; font-size: 13.5px; line-height: 1.1; }
.ws-float .m { font-family: var(--font-mono); font-size: 10.5px; color: var(--text-muted); margin-top: 2px; letter-spacing: 0.04em; }
.ws-float-a { top: -16px; right: -14px; animation-delay: -1s; }
.ws-float-b { bottom: 60px; left: -28px; animation-delay: -2.5s; transform: rotate(-3deg); }
.ws-float-c { bottom: -10px; right: -10px; animation-delay: -4s; }

/* Highlight pill for "live" status */
.live-pill {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 4px 10px;
	background: rgba(0,212,161,0.18); color: var(--accent-light);
	font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
	border-radius: 999px;
}
.live-pill .pulse { width: 6px; height: 6px; border-radius: 999px; background: var(--accent); box-shadow: 0 0 0 0 var(--accent); animation: liveDot 2s var(--ease-spring) infinite; }
@keyframes liveDot {
	0%, 100% { box-shadow: 0 0 0 0 rgba(0,212,161,0.6); }
	50%      { box-shadow: 0 0 0 6px transparent; }
}

/* --- Custom client wordmarks (replaces the bland text-only client cards) --- */
.client-mark {
	font-family: var(--font-display);
	letter-spacing: -0.03em;
	line-height: 0.95;
	color: var(--text-primary);
	display: inline-flex; align-items: baseline; gap: 6px;
}
.client-mark.bank { font-weight: 700; font-size: 22px; letter-spacing: -0.04em; font-feature-settings: 'ss01'; }
.client-mark.bank .accent { color: var(--accent-2-dark); font-weight: 700; }
.client-mark.serif { font-family: var(--font-serif); font-style: italic; font-size: 28px; letter-spacing: -0.01em; color: #5B3A29; }
.client-mark.serif .accent { font-family: var(--font-display); font-style: normal; font-weight: 600; font-size: 20px; letter-spacing: -0.03em; color: #B45309; vertical-align: 4px; }
.client-mark.clinic { font-weight: 600; font-size: 19px; text-transform: uppercase; letter-spacing: 0.16em; color: #166534; }
.client-mark.clinic .accent { color: #B91C1C; font-weight: 700; }
.client-mark.broker { font-weight: 800; font-size: 22px; text-transform: uppercase; letter-spacing: -0.02em; color: #1E3A8A; }
.client-mark.broker .accent { color: var(--accent-dark); }
.client-mark.finance { font-weight: 600; font-size: 20px; color: #0F172A; }
.client-mark.finance .dot { width: 6px; height: 6px; background: var(--accent-2); border-radius: 999px; display: inline-block; margin: 0 4px 4px 0; }
.client-mark.media { font-weight: 700; font-size: 22px; color: #DC2626; letter-spacing: -0.04em; text-transform: lowercase; }
.client-mark.media .accent { color: var(--text-primary); }
.client-mark.remit { font-weight: 700; font-size: 22px; color: #166534; letter-spacing: -0.04em; }
.client-mark.remit .accent { color: #65A30D; font-weight: 600; font-size: 14px; vertical-align: 3px; }

/* --- Refined bento — more visual variety --- */
.bento-card { isolation: isolate; }
.bento-card::after {
	content: ""; position: absolute; inset: 0;
	background: radial-gradient(400px 200px at var(--mx,50%) var(--my,30%), var(--accent-glow), transparent 60%);
	opacity: 0; transition: opacity var(--t-base);
	pointer-events: none;
	z-index: 0;
}
.bento-card:hover::after { opacity: 1; }
.bento-card > * { position: relative; z-index: 1; }

/* Sparkline decoration on cards */
.spark-bg {
	position: absolute; right: 16px; bottom: 16px; opacity: 0.25;
	pointer-events: none;
}

/* --- Editorial pull-quotes (used inside articles & case studies) --- */
.entry-content .editorial-quote {
	margin: 56px -8px;
	padding: 0 24px;
	display: grid; grid-template-columns: 56px 1fr;
	gap: 20px;
	align-items: flex-start;
	position: relative;
}
.entry-content .editorial-quote::before {
	content: """;
	font-family: var(--font-serif); font-style: italic;
	font-size: 120px; line-height: 0.7;
	color: var(--accent);
	grid-row: 1;
}
.entry-content .editorial-quote .body {
	font-family: var(--font-serif); font-style: italic;
	font-size: clamp(22px, 2.6vw, 30px);
	line-height: 1.45;
	color: var(--text-primary);
	letter-spacing: -0.01em;
}
.entry-content .editorial-quote .attribution {
	margin-top: 14px;
	font-family: var(--font-mono); font-size: 12px; color: var(--text-muted);
	letter-spacing: 0.06em; text-transform: uppercase;
	font-style: normal;
}

/* --- "Notebook" annotation style for inline notes --- */
.notebook {
	background: linear-gradient(180deg, #FFFBF1 0%, #FEF6E4 100%);
	border-left: 3px solid #F59E0B;
	border-radius: 6px 14px 14px 6px;
	padding: 18px 22px;
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 17px;
	color: #78350F;
	margin: 28px 0;
	position: relative;
}
.notebook::before {
	content: "Note";
	position: absolute; top: -10px; left: 18px;
	background: #F59E0B; color: #fff;
	font-family: var(--font-mono); font-style: normal;
	font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
	padding: 3px 8px; border-radius: 4px;
}

/* --- Tighter, more typographic case-study row --- */
.cs-row h3 {
	font-family: var(--font-display);
	letter-spacing: -0.025em;
}
.cs-row h3 .accent {
	font-family: var(--font-serif); font-style: italic; font-weight: 400;
	color: var(--accent-dark);
}

/* --- Asymmetric section heads (less centered = less templated) --- */
.section-head.asym {
	max-width: 880px;
	margin: 0 0 64px;
	text-align: left;
}
.section-head.asym .lede {
	max-width: 540px;
	margin-left: auto;
	color: var(--text-body);
	font-size: 17px;
	margin-top: 16px;
	text-align: right;
	border-right: 2px solid var(--accent);
	padding-right: 18px;
}
.dark .section-head.asym .lede { color: var(--text-on-dark-muted); }

/* --- Hand-drawn arrow accent --- */
.draw-arrow {
	position: absolute;
	width: 80px; height: 60px;
	opacity: 0.5;
}
.draw-arrow svg { width: 100%; height: 100%; }

/* --- Better hero subtitle treatment --- */
.hero-left .h-sub {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: clamp(20px, 2.2vw, 26px);
	color: var(--accent-light);
	letter-spacing: -0.01em;
	margin-bottom: 6px;
	display: block;
}

/* --- Refined proof-card layout (visible without hover) --- */
.proof-card {
	display: flex; flex-direction: column;
	gap: 14px;
}
.proof-card .logo-row {
	min-height: 36px;
	display: flex; align-items: center;
}
.proof-card .row-meta {
	display: flex; align-items: center; gap: 8px;
	font-family: var(--font-mono); font-size: 11px;
	color: var(--text-muted); letter-spacing: 0.04em;
	text-transform: uppercase;
}
.proof-card .row-meta .sep { color: var(--border); }

/* --- Better focus styles for keyboard users --- */
.btn:focus-visible {
	outline: 2px solid var(--accent);
	outline-offset: 3px;
}

/* --- Subtle section dividers --- */
.section + .section:not(.dark):not(.industries):not(.results):not(.final-cta) {
	border-top: 1px solid var(--border);
}

/* --- Mobile spacing refinements --- */
@media (max-width: 720px) {
	body::before { opacity: 0.03; } /* lighter grain on mobile */
	.workspace .frame { transform: none; }
	.ws-float-a, .ws-float-b, .ws-float-c { display: none; } /* avoid clutter on mobile */
	.entry-content > p:first-of-type::first-letter { font-size: 3em; }
	.section-head.asym .lede { text-align: left; border-right: 0; border-left: 2px solid var(--accent); padding-right: 0; padding-left: 14px; margin-left: 0; }
}



/* ==========================================================================
   32. WORKFLOW-DESIGNED HUB STYLES — bespoke, per-page (ga-, seo-, ma-, ab-, ep-)
========================================================================== */

/* --- gads hub --- */
.ga-hero{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}
.ga-hero-copy h1{font-family:var(--font-display);font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.05;margin:16px 0 20px}
.ga-lede{color:var(--text-body);font-size:1.1rem;margin-bottom:28px;max-width:54ch}
.ga-dash{background:var(--bg-dark);color:var(--text-on-dark);border-radius:var(--r-xl);padding:20px;box-shadow:var(--sh-xl);border:1px solid var(--border-dark)}
.ga-dash-head{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border-dark);font-size:.78rem;color:var(--text-on-dark-muted)}
.ga-dash-dots{display:flex;gap:6px}
.ga-dash-dots span{width:10px;height:10px;border-radius:50%;background:#3a4255}
.ga-dash-dots span:nth-child(1){background:#ff5f57}.ga-dash-dots span:nth-child(2){background:#febc2e}.ga-dash-dots span:nth-child(3){background:#28c840}
.ga-dash-head .live-pill{margin-left:auto}
.ga-dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:18px 0}
.ga-metric{background:var(--bg-dark-2);border-radius:var(--r-md);padding:14px;border:1px solid var(--border-dark)}
.ga-metric-wide{grid-column:1/-1}
.ga-metric-label{display:block;font-size:.7rem;color:var(--text-on-dark-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.ga-metric strong{font-family:var(--font-display);font-size:1.8rem;display:block;color:var(--accent-light)}
.ga-metric-sub{font-size:.78rem;color:var(--text-on-dark-muted)}
.ga-arrow{color:var(--accent);font-weight:400}
.ga-spark{width:100%;height:50px;margin:6px 0 4px}
.ga-dash-foot{font-size:.72rem;color:var(--text-on-dark-muted);padding-top:14px;border-top:1px solid var(--border-dark)}
.ga-section-sub{color:var(--text-body);max-width:68ch;margin-bottom:40px;font-size:1.05rem}
.ga-on-dark{color:var(--text-on-dark-muted)}
.ga-leaks{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.ga-leak{display:flex;gap:16px;padding:18px;background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-md);transition:transform .2s,box-shadow .2s}
.ga-leak:hover{transform:translateY(-2px);box-shadow:var(--sh-card-hover);border-color:var(--accent)}
.ga-leak-num{color:var(--accent);font-size:.95rem;flex-shrink:0}
.ga-leak strong{display:block;font-family:var(--font-display);margin-bottom:6px;color:var(--text-primary)}
.ga-leak p{color:var(--text-body);font-size:.92rem;margin:0}
.ga-timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative}
.ga-phase{background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;border-top:3px solid var(--accent)}
.ga-phase-head{margin-bottom:18px;padding-bottom:16px;border-bottom:1px dashed var(--border)}
.ga-phase-head .mono{color:var(--accent-dark);font-size:.8rem;display:block;margin-bottom:6px}
.ga-phase-head h3{font-family:var(--font-display);margin:0;font-size:1.3rem}
.ga-phase ul{list-style:none;padding:0;margin:0}
.ga-phase li{padding:10px 0 10px 22px;position:relative;color:var(--text-body);font-size:.95rem;border-bottom:1px solid var(--border)}
.ga-phase li:last-child{border-bottom:0}
.ga-phase li:before{content:"";position:absolute;left:0;top:16px;width:10px;height:10px;border-radius:50%;background:var(--accent-surface);border:2px solid var(--accent)}
.ga-campaigns{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ga-camp{background:rgba(255,255,255,0.04);border:1px solid var(--border-dark);border-radius:var(--r-lg);padding:24px;transition:border-color .2s}
.ga-camp:hover{border-color:var(--accent)}
.ga-camp:nth-child(4),.ga-camp:nth-child(5){grid-column:span 1}
.ga-camp h3{font-family:var(--font-display);margin:14px 0 10px;color:var(--text-on-dark)}
.ga-camp p{color:var(--text-on-dark-muted);font-size:.95rem;margin:0}
.ga-cases{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.ga-case{background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-lg);padding:32px;box-shadow:var(--sh-md)}
.ga-case header{margin-bottom:16px}
.ga-case h3{font-family:var(--font-display);margin:10px 0 0;font-size:1.5rem}
.ga-case-brief{color:var(--text-body);margin:0 0 20px}
.ga-case-stats{list-style:none;padding:18px;margin:0 0 16px;background:var(--accent-surface);border-radius:var(--r-md);display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ga-case-stats li{text-align:center}
.ga-case-stats strong{display:block;font-family:var(--font-display);font-size:1.4rem;color:var(--accent-dark)}
.ga-case-stats span{font-size:.78rem;color:var(--text-body)}
.ga-case-note{font-size:.85rem;color:var(--text-muted);padding-top:14px;border-top:1px dashed var(--border)}
.ga-faq{max-width:780px}
.ga-faq details{background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 22px;margin-bottom:10px}
.ga-faq summary{font-family:var(--font-display);font-weight:600;cursor:pointer;color:var(--text-primary);list-style:none}
.ga-faq summary::-webkit-details-marker{display:none}
.ga-faq summary:after{content:"+";float:right;color:var(--accent);font-weight:400;font-size:1.4rem;line-height:1}
.ga-faq details[open] summary:after{content:"\2212"}
.ga-faq p{margin:14px 0 0;color:var(--text-body)}
.ga-final{text-align:center;max-width:760px;margin:0 auto}
.ga-final h2{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:16px;color:var(--text-on-dark)}
.ga-final p{color:var(--text-on-dark-muted);font-size:1.05rem;margin-bottom:28px}
.ga-final .cta-row{justify-content:center}
.ga-final-sig{margin-top:24px;color:var(--text-on-dark-muted);font-size:.8rem}
@media(max-width:900px){.ga-hero,.ga-leaks,.ga-timeline,.ga-campaigns,.ga-cases{grid-template-columns:1fr}.ga-campaigns{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.ga-campaigns{grid-template-columns:1fr}.ga-case-stats{grid-template-columns:1fr}}

/* --- seo hub --- */
.seo-hero{padding:80px 0 40px;background:linear-gradient(180deg,var(--bg-light) 0%,var(--bg-pure) 100%)}
.seo-hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.seo-h1{font-family:var(--font-display);font-size:clamp(36px,4.6vw,60px);line-height:1.05;font-weight:700;color:var(--text-primary);margin:16px 0 20px;letter-spacing:-.02em}
.seo-lede{font-size:18px;color:var(--text-body);line-height:1.6;max-width:560px}
.seo-meta-row{display:flex;gap:20px;margin-top:24px;font-family:var(--font-mono);font-size:12px;color:var(--text-muted);flex-wrap:wrap}
.seo-terminal{background:var(--bg-dark);border-radius:var(--r-lg);box-shadow:var(--sh-xl);overflow:hidden;border:1px solid var(--border-dark)}
.seo-terminal-bar{padding:12px 16px;background:var(--bg-dark-2);font-family:var(--font-mono);font-size:12px;color:var(--text-on-dark-muted);display:flex;align-items:center;gap:6px}
.seo-terminal-bar span{width:10px;height:10px;border-radius:50%;background:#3a4358;display:inline-block;margin-right:2px}
.seo-terminal-bar span:first-child{background:#ff5f57}
.seo-terminal-body{padding:24px;color:var(--accent-light);font-family:var(--font-mono);font-size:13px;line-height:1.8;margin:0;white-space:pre-wrap}
.seo-section{padding:80px 0}
.seo-section-head{max-width:720px;margin-bottom:48px}
.seo-section-head h2{font-family:var(--font-display);font-size:clamp(28px,3.2vw,42px);line-height:1.15;margin:12px 0 16px;color:var(--text-primary);letter-spacing:-.02em}
.seo-section-head.light h2,.seo-section-head.light p{color:var(--text-on-dark)}
.seo-section-head p{color:var(--text-body);font-size:17px;line-height:1.6}
.seo-serp-table{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--bg-pure);box-shadow:var(--sh-md);font-family:var(--font-mono);font-size:13px}
.seo-serp-head,.seo-serp-row{display:grid;grid-template-columns:2fr .8fr .8fr .8fr 1fr 1.2fr;gap:12px;padding:14px 20px;align-items:center}
.seo-serp-head{background:var(--bg-dark);color:var(--text-on-dark);font-size:11px;text-transform:uppercase;letter-spacing:.1em}
.seo-serp-row{border-top:1px solid var(--border);color:var(--text-body)}
.seo-serp-row:hover{background:var(--bg-light)}
.seo-kw{font-family:var(--font-body);color:var(--text-primary);font-weight:500;font-size:14px}
.seo-pos{font-weight:700;font-size:14px}
.seo-bad{color:#dc2626}
.seo-mid{color:#d97706}
.seo-good{color:var(--accent-dark)}
.seo-callout-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.seo-stat-card{background:var(--accent-surface);border:1px solid var(--accent-light);border-radius:var(--r-lg);padding:28px;text-align:center}
.seo-stat-n{font-family:var(--font-display);font-size:44px;font-weight:700;color:var(--accent-dark);letter-spacing:-.02em}
.seo-stat-l{color:var(--text-body);font-size:14px;margin-top:4px}
.seo-dark-band{background:var(--bg-dark);padding:96px 0;margin:40px 0}
.seo-stack{display:flex;flex-direction:column;gap:12px;max-width:880px}
.seo-layer{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-left:3px solid var(--accent);border-radius:var(--r-md);padding:24px 28px;position:relative;display:grid;grid-template-columns:80px 1fr;gap:24px;align-items:center}
.seo-layer::before{content:attr(data-n);font-family:var(--font-mono);font-size:32px;color:var(--accent);font-weight:700}
.seo-layer-name{font-family:var(--font-display);font-size:20px;color:var(--text-on-dark);font-weight:600;margin-bottom:6px}
.seo-layer p{color:var(--text-on-dark-muted);font-size:14px;line-height:1.6;margin:0;grid-column:2}
.seo-layer > p{grid-column:2;margin-top:-8px}
.seo-quote{background:var(--bg-light);border-left:4px solid var(--accent);padding:40px 48px;border-radius:var(--r-lg);font-size:24px;line-height:1.5;color:var(--text-primary);font-family:var(--font-display);font-weight:500}
.seo-quote-by{margin-top:20px;font-family:var(--font-mono);font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:400}
.seo-checklist{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.seo-checklist li{display:grid;grid-template-columns:48px 1fr;gap:16px;padding:20px;background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-md);align-items:start}
.seo-check-n{font-family:var(--font-mono);color:var(--accent-dark);font-weight:700;font-size:14px;background:var(--accent-surface);width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}
.seo-checklist li div:last-child{color:var(--text-body);font-size:14px;line-height:1.55}
.seo-checklist strong{color:var(--text-primary);display:block;margin-bottom:2px}
.seo-industries{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.seo-industry{background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;transition:.2s}
.seo-industry:hover{border-color:var(--accent);box-shadow:var(--sh-card-hover)}
.seo-ind-tag{margin-bottom:12px}
.seo-industry h3{font-family:var(--font-display);font-size:18px;color:var(--text-primary);margin:0 0 8px;font-weight:600}
.seo-industry p{color:var(--text-body);font-size:14px;line-height:1.55;margin:0}
.seo-faq{max-width:820px}
.seo-faq details{border-bottom:1px solid var(--border);padding:20px 0}
.seo-faq summary{font-family:var(--font-display);font-size:18px;color:var(--text-primary);cursor:pointer;font-weight:600;list-style:none;position:relative;padding-right:32px}
.seo-faq summary::after{content:"+";position:absolute;right:0;top:0;color:var(--accent);font-size:24px;font-weight:300}
.seo-faq details[open] summary::after{content:"−"}
.seo-faq p{color:var(--text-body);font-size:15px;line-height:1.65;margin:12px 0 0}
.seo-cta{text-align:center;background:var(--accent-surface);border-radius:var(--r-2xl);padding:64px 32px;margin-bottom:40px}
.seo-cta h2{font-family:var(--font-display);font-size:36px;color:var(--text-primary);margin:0 0 12px;letter-spacing:-.02em}
.seo-cta p{color:var(--text-body);font-size:17px;max-width:560px;margin:0 auto 24px}
.seo-cta .cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:860px){.seo-hero-grid,.seo-callout-row,.seo-checklist,.seo-industries{grid-template-columns:1fr}.seo-serp-head,.seo-serp-row{grid-template-columns:1.6fr .8fr .8fr .8fr;font-size:12px}.seo-serp-head>div:nth-child(n+5),.seo-serp-row>div:nth-child(n+5){display:none}.seo-layer{grid-template-columns:60px 1fr}}

/* --- meta hub --- */
.ma-hero{padding:96px 0 64px;background:linear-gradient(180deg,var(--bg-light),var(--bg-pure))}
.ma-hero-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center}
@media(max-width:860px){.ma-hero-grid{grid-template-columns:1fr}}
.ma-h1{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,4.6vw,58px);line-height:1.05;color:var(--text-primary);margin:16px 0 20px}
.ma-h2{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,3vw,40px);line-height:1.15;color:var(--text-primary);margin:8px 0 24px}
.ma-h2.light{color:var(--text-on-dark)}
.ma-lede{font-size:18px;line-height:1.65;color:var(--text-body);max-width:60ch}
.ma-lede-dark{font-size:17px;line-height:1.65;color:var(--text-on-dark-muted);max-width:65ch;margin-bottom:32px}
.ma-hero-card{background:var(--bg-dark);border-radius:var(--r-2xl);padding:32px;color:var(--text-on-dark);box-shadow:var(--sh-xl)}
.ma-card-label{color:var(--accent);font-size:11px;letter-spacing:0.12em;margin-bottom:12px}
.ma-card-title{font-family:var(--font-display);font-size:22px;font-weight:600;margin-bottom:24px;line-height:1.3}
.ma-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:20px 0;border-top:1px solid var(--border-dark);border-bottom:1px solid var(--border-dark);margin-bottom:20px}
.ma-big{font-family:var(--font-display);font-size:26px;font-weight:700;color:var(--accent-light);line-height:1}
.ma-stat-row .mono{font-size:10px;color:var(--text-on-dark-muted);margin-top:6px;letter-spacing:0.08em}
.ma-tagrow{display:flex;gap:8px;flex-wrap:wrap}
.ma-spotlight{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;margin-top:24px}
@media(max-width:860px){.ma-spotlight{grid-template-columns:1fr}}
.ma-spotlight-copy p{font-size:17px;line-height:1.75;color:var(--text-body);margin-bottom:16px}
.ma-spotlight-side{background:var(--accent-surface);border-radius:var(--r-lg);padding:28px;border-left:3px solid var(--accent)}
.ma-numlist{padding-left:20px;margin-top:12px}
.ma-numlist li{margin-bottom:12px;color:var(--text-body);line-height:1.55}
.ma-matrix{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:8px;margin:32px 0 16px}
.ma-matrix-head{font-family:var(--font-mono);font-size:11px;color:var(--accent-light);letter-spacing:0.1em;padding:10px;text-align:center;text-transform:uppercase}
.ma-matrix-row-label{background:rgba(255,255,255,0.04);border-radius:var(--r-md);padding:14px;color:var(--text-on-dark);font-size:14px;line-height:1.4}
.ma-matrix-row-label .mono{display:block;color:var(--text-on-dark-muted);font-size:11px;margin-top:4px}
.ma-cell{background:rgba(255,255,255,0.03);border:1px solid var(--border-dark);border-radius:var(--r-md);padding:14px;color:var(--text-on-dark-muted);font-family:var(--font-mono);font-size:13px;display:flex;align-items:center;justify-content:center;text-align:center}
.ma-win{background:var(--accent);color:var(--bg-dark);border-color:var(--accent);font-weight:600}
.ma-mid{background:rgba(0,212,161,0.12);color:var(--accent-light);border-color:rgba(0,212,161,0.3)}
.ma-kill{background:rgba(255,80,80,0.1);color:#ff8a8a;border-color:rgba(255,80,80,0.25)}
.ma-fineprint{color:var(--text-on-dark-muted);font-size:11px;letter-spacing:0.08em;margin-top:16px}
.ma-fineprint-dark{color:var(--text-on-dark-muted);font-size:11px;letter-spacing:0.08em;margin-top:20px;text-align:center}
.ma-track-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
@media(max-width:860px){.ma-track-grid{grid-template-columns:1fr}}
.ma-track-card{background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px}
.ma-track-card-mid{border-color:var(--accent);box-shadow:var(--sh-glow)}
.ma-track-card h3{font-family:var(--font-display);font-size:22px;margin:8px 0 12px;color:var(--text-primary)}
.ma-track-card p{color:var(--text-body);font-size:15px;line-height:1.6;margin-bottom:16px}
.ma-coverage{height:8px;background:var(--bg-light);border-radius:var(--r-pill);overflow:hidden;margin-bottom:8px}
.ma-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:var(--r-pill)}
.ma-callout{margin-top:32px;padding:24px 28px;background:var(--bg-dark);color:var(--text-on-dark);border-radius:var(--r-lg);border-left:4px solid var(--accent);font-size:16px;line-height:1.65}
.ma-callout strong{color:var(--accent-light)}
.ma-tree{margin-top:24px}
.ma-tree-q{background:var(--bg-dark);color:var(--text-on-dark);padding:20px 28px;border-radius:var(--r-lg);text-align:center;font-size:17px;font-family:var(--font-display);margin-bottom:24px}
.ma-tree-branch{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:860px){.ma-tree-branch{grid-template-columns:1fr}}
.ma-tree-yes,.ma-tree-no{background:var(--bg-light);border-radius:var(--r-lg);padding:20px}
.ma-tree-yes>.mono,.ma-tree-no>.mono{color:var(--accent-dark);font-weight:700;font-size:13px;letter-spacing:0.1em}
.ma-tree-q2{font-family:var(--font-display);font-size:15px;color:var(--text-primary);margin:12px 0 16px;line-height:1.4}
.ma-tree-leaf{background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;margin-bottom:10px;font-size:14px;line-height:1.5;color:var(--text-body)}
.ma-tree-leaf strong{color:var(--text-primary);display:block;margin-bottom:4px}
.ma-leaf-green{border-left:3px solid var(--accent)}
.ma-leaf-amber{border-left:3px solid #f5a623}
.ma-leaf-blue{border-left:3px solid var(--accent-2)}
.ma-freq{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;align-items:end;margin-top:32px;height:280px}
.ma-freq-week{display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}
.ma-freq-week .mono{color:var(--accent-light);font-size:11px;margin-bottom:8px}
.ma-freq-bar{width:100%;background:linear-gradient(180deg,var(--accent-light),var(--accent));border-radius:var(--r-sm) var(--r-sm) 0 0;min-height:20px}
.ma-freq-warn{background:linear-gradient(180deg,#f5a623,#d4881a)}
.ma-freq-kill{background:linear-gradient(180deg,#ff6b6b,#c44545)}
.ma-freq-label{color:var(--text-on-dark-muted);font-size:11px;margin-top:10px;text-align:center;line-height:1.3}
.ma-faq{margin-top:24px;max-width:820px}
.ma-faq details{border:1px solid var(--border);border-radius:var(--r-md);padding:18px 22px;margin-bottom:12px;background:var(--bg-pure)}
.ma-faq summary{font-family:var(--font-display);font-weight:600;font-size:17px;color:var(--text-primary);cursor:pointer;list-style:none}
.ma-faq summary::after{content:"+";float:right;color:var(--accent);font-weight:400}
.ma-faq details[open] summary::after{content:"-"}
.ma-faq p{margin-top:12px;color:var(--text-body);line-height:1.65}
.ma-cta-section{background:var(--accent-surface);text-align:center}
.ma-cta-section .ma-lede{margin:0 auto 28px;text-align:center}
.ma-cta-section .cta-row{justify-content:center}

/* --- about hub --- */
.ab-h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,4.2vw,3.4rem);line-height:1.1;letter-spacing:-0.02em;color:var(--text-primary);margin:16px 0 24px}
.ab-h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,2.6vw,2.1rem);line-height:1.15;letter-spacing:-0.015em;color:var(--text-primary);margin:0 0 20px}
.ab-on-dark{color:var(--text-on-dark)}
.ab-lede{font-size:1.18rem;line-height:1.55;color:var(--text-body);margin:0 0 20px}
.ab-opener{padding:96px 0 64px}
.ab-opener-grid{display:grid;grid-template-columns:1.65fr 1fr;gap:64px;align-items:start}
.ab-card-id{background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-xl);padding:24px;box-shadow:var(--sh-md);position:sticky;top:24px}
.ab-id-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--border);font-size:.92rem;color:var(--text-body)}
.ab-id-row:last-child{border-bottom:0}
.ab-id-row .mono{color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.ab-two-col{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start}
.ab-artefacts{list-style:none;padding:0;margin:0;counter-reset:art}
.ab-artefacts li{counter-increment:art;padding:20px 0 20px 56px;border-top:1px solid var(--border);position:relative;color:var(--text-body);line-height:1.55}
.ab-artefacts li:before{content:counter(art,decimal-leading-zero);position:absolute;left:0;top:20px;font-family:var(--font-mono);color:var(--accent);font-size:.95rem;font-weight:500}
.ab-artefacts li:last-child{border-bottom:1px solid var(--border)}
.ab-artefacts strong{color:var(--text-primary)}
.ab-timeline-section{background:var(--bg-dark)}
.ab-ledger{list-style:none;padding:0;margin:32px 0 0}
.ab-ledger li{display:grid;grid-template-columns:120px 1fr;gap:32px;padding:22px 0;border-top:1px solid var(--border-dark);color:var(--text-on-dark-muted);line-height:1.6}
.ab-ledger li:last-child{border-bottom:1px solid var(--border-dark)}
.ab-ledger .ab-year{color:var(--accent-light);font-size:1.4rem;font-weight:500}
.ab-ledger strong{color:var(--text-on-dark);font-weight:600}
.ab-sub{color:var(--text-body);max-width:640px;margin:0 0 32px}
.ab-sub-dark{color:var(--text-on-dark-muted);max-width:520px;margin:0 0 28px;line-height:1.6}
.ab-clientlist{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:0;border-top:1px solid var(--border)}
.ab-clientlist li{padding:20px 4px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:4px}
.ab-clientlist strong{font-family:var(--font-display);font-size:1.05rem;color:var(--text-primary)}
.ab-clientlist span{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.ab-wontdo{background:var(--bg-light)}
.ab-wontdo-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.ab-refuse{list-style:none;padding:0;margin:0}
.ab-refuse li{display:grid;grid-template-columns:64px 1fr;gap:20px;padding:18px 0;border-top:1px solid var(--border);color:var(--text-body);line-height:1.55}
.ab-refuse li:last-child{border-bottom:1px solid var(--border)}
.ab-refuse strong{color:var(--text-primary);display:block;margin-bottom:2px}
.ab-x{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;background:var(--text-primary);color:var(--bg-pure);padding:4px 10px;border-radius:var(--r-pill);height:fit-content;text-align:center}
.ab-tools-section{background:var(--bg-dark-2)}
.ab-tools-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:start}
.ab-toolblock{padding:18px 0;border-top:1px solid var(--border-dark)}
.ab-toolblock:last-child{border-bottom:1px solid var(--border-dark)}
.ab-toolhead{color:var(--accent-light);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:8px}
.ab-toolblock p{color:var(--text-on-dark);margin:0;line-height:1.55}
.ab-certs{background:rgba(255,255,255,0.03);border:1px solid var(--border-dark);border-radius:var(--r-xl);padding:28px}
.ab-eyebrow-light{color:var(--accent-light)}
.ab-certlist{list-style:none;padding:0;margin:16px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}
.ab-certlist li{color:var(--text-on-dark);font-size:.93rem;padding-left:18px;position:relative}
.ab-certlist li:before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;background:var(--accent);border-radius:50%}
.ab-cert-foot{color:var(--text-on-dark-muted);font-size:.78rem;margin-top:20px}
.ab-geo-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:start}
.ab-geo-copy p{color:var(--text-body);line-height:1.65;margin:0 0 16px}
.ab-clock-card{background:var(--bg-dark);color:var(--text-on-dark);border-radius:var(--r-xl);padding:28px;box-shadow:var(--sh-lg)}
.ab-clock-row{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--border-dark);font-family:var(--font-mono);font-size:1.1rem}
.ab-clock-row .mono{color:var(--accent-light);font-size:.82rem;letter-spacing:.08em}
.ab-clock-foot{color:var(--text-on-dark-muted);font-size:.85rem;margin:16px 0 0;line-height:1.5}
.ab-faq{background:var(--bg-light)}
.ab-faq-list{margin-top:32px;border-top:1px solid var(--border)}
.ab-faq-list details{border-bottom:1px solid var(--border);padding:20px 0}
.ab-faq-list summary{font-family:var(--font-display);font-weight:600;font-size:1.08rem;color:var(--text-primary);cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:24px}
.ab-faq-list summary:after{content:"+";color:var(--accent);font-weight:400;font-size:1.5rem;line-height:1}
.ab-faq-list details[open] summary:after{content:"−"}
.ab-faq-list p{color:var(--text-body);line-height:1.6;margin:12px 0 0;max-width:760px}
.ab-cta-section{background:var(--bg-dark);text-align:center}
.ab-cta-wrap .ab-h2{color:var(--text-on-dark);max-width:760px;margin-left:auto;margin-right:auto}
.ab-cta-sub{color:var(--text-on-dark-muted);font-family:var(--font-mono);font-size:.95rem;margin:0 0 28px}
.ab-cta-wrap .cta-row{justify-content:center}
@media(max-width:880px){.ab-opener-grid,.ab-two-col,.ab-wontdo-grid,.ab-tools-grid,.ab-geo-grid{grid-template-columns:1fr;gap:40px}.ab-card-id{position:static}.ab-ledger li{grid-template-columns:80px 1fr;gap:16px}.ab-refuse li{grid-template-columns:56px 1fr}}

/* --- service_pricing hub --- */
.ep-wrap{padding:96px 0;background:var(--bg-light)}
.ep-intro{max-width:780px;margin-bottom:64px}
.ep-title{font-family:var(--font-display);font-size:clamp(32px,4vw,52px);font-weight:700;line-height:1.1;color:var(--text-primary);margin:12px 0 20px}
.ep-lede{font-family:var(--font-body);font-size:18px;line-height:1.6;color:var(--text-body)}
.ep-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:80px}
@media(max-width:980px){.ep-tiers{grid-template-columns:1fr}}
.ep-tier{position:relative;background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-2xl);padding:32px;display:flex;flex-direction:column;gap:20px;transition:box-shadow .3s}
.ep-tier:hover{box-shadow:var(--sh-card-hover)}
.ep-tier--sprint{background:var(--bg-dark);border-color:transparent;color:var(--text-on-dark);transform:translateY(-12px)}
.ep-tier--sprint .ep-tier-head h3,.ep-tier--sprint .ep-price-npr,.ep-tier--sprint .ep-block-label,.ep-tier--sprint h4{color:#fff}
.ep-tier--sprint .ep-tag-line,.ep-tier--sprint .ep-list li,.ep-tier--sprint .ep-price-fx{color:var(--text-on-dark)}
.ep-tier--sprint .ep-block--neg .ep-list li{color:var(--text-on-dark-muted)}
.ep-popular{position:absolute;top:-12px;right:24px;background:var(--accent);color:var(--bg-dark);font-family:var(--font-mono);font-size:11px;font-weight:600;padding:6px 12px;border-radius:var(--r-pill);letter-spacing:.04em;text-transform:uppercase}
.ep-kicker{font-size:11px;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}
.ep-tier--sprint .ep-kicker{color:var(--accent-light)}
.ep-tier-head h3{font-family:var(--font-display);font-size:28px;font-weight:700;margin:8px 0 6px;color:var(--text-primary)}
.ep-tag-line{font-family:var(--font-serif);font-style:italic;font-size:17px;line-height:1.4;color:var(--text-body)}
.ep-price{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:16px 0}
.ep-tier--sprint .ep-price{border-color:var(--border-dark)}
.ep-price-row{display:flex;flex-direction:column;gap:2px;margin-bottom:6px}
.ep-price-npr{font-family:var(--font-display);font-size:24px;font-weight:700;color:var(--text-primary)}
.ep-price-fx{font-family:var(--font-mono);font-size:13px;color:var(--text-muted)}
.ep-price-meta{font-size:11px;color:var(--text-muted);letter-spacing:.04em}
.ep-block-label{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-primary);margin-bottom:10px}
.ep-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.ep-list li{font-family:var(--font-body);font-size:14.5px;line-height:1.5;color:var(--text-body);padding-left:18px;position:relative}
.ep-list li:before{content:"+";position:absolute;left:0;color:var(--accent);font-weight:700}
.ep-list--neg li:before{content:"−";color:var(--text-muted)}
.ep-block--neg .ep-list li{color:var(--text-muted)}
.ep-timeline-note{margin-top:auto;font-size:12px;color:var(--accent-dark);letter-spacing:.04em;padding-top:8px}
.ep-tier--sprint .ep-timeline-note{color:var(--accent-light)}
.ep-decision{background:var(--bg-pure);border:1px solid var(--border);border-radius:var(--r-2xl);padding:48px;margin-bottom:80px}
.ep-decision-head h3{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--text-primary);margin:8px 0 32px}
.ep-rules{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:780px){.ep-rules{grid-template-columns:1fr}}
.ep-rule{padding:24px;background:var(--accent-surface);border-radius:var(--r-lg);border-left:3px solid var(--accent)}
.ep-rule-num{display:inline-block;font-size:13px;color:var(--accent-dark);margin-bottom:8px;font-weight:600}
.ep-rule p{font-family:var(--font-body);font-size:15px;line-height:1.55;color:var(--text-primary);margin:0}
.ep-process{margin-bottom:64px}
.ep-process-head{max-width:680px;margin-bottom:40px}
.ep-process-head h3{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--text-primary);margin:8px 0 12px}
.ep-process-lede{font-size:16px;color:var(--text-body)}
.ep-steps{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;background:var(--bg-pure)}
@media(max-width:780px){.ep-steps{grid-template-columns:1fr}}
.ep-step{padding:28px;border-right:1px solid var(--border);position:relative}
.ep-step:last-child{border-right:none}
@media(max-width:780px){.ep-step{border-right:none;border-bottom:1px solid var(--border)}.ep-step:last-child{border-bottom:none}}
.ep-step-num{display:block;font-size:11px;color:var(--accent-dark);background:var(--accent-surface);padding:4px 10px;border-radius:var(--r-pill);width:fit-content;margin-bottom:14px;letter-spacing:.04em}
.ep-step h4{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px}
.ep-step p{font-size:14px;line-height:1.5;color:var(--text-body);margin:0}
.ep-note{background:var(--bg-dark);color:var(--text-on-dark);border-radius:var(--r-2xl);padding:40px 48px;margin-bottom:64px;display:grid;grid-template-columns:160px 1fr;gap:32px;align-items:start}
@media(max-width:780px){.ep-note{grid-template-columns:1fr;padding:32px}}
.ep-note-tag{color:var(--accent-light);font-size:12px;letter-spacing:.06em}
.ep-note-body{font-family:var(--font-serif);font-style:italic;font-size:20px;line-height:1.5;color:var(--text-on-dark);margin:0}
.ep-note-body em{color:var(--accent-light);font-style:italic}
.ep-cta{text-align:center;padding:48px 24px}
.ep-cta h3{font-family:var(--font-display);font-size:clamp(28px,3.5vw,40px);font-weight:700;color:var(--text-primary);margin:0 0 12px}
.ep-cta p{font-size:17px;color:var(--text-body);margin:0 0 24px}
.ep-cta .cta-row{justify-content:center;display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.ep-cta-meta{font-size:12px;color:var(--text-muted);letter-spacing:.04em}
