/* ============================================
   OKTOPEAK V5 — WARM LIGHT DESIGN SYSTEM
   ============================================ */

:root {
  /* PRIMARY — Light warm surfaces */
  --bg: #FAF8F4;
  --bg2: #F1EDE7;
  --bg3: #E5E0D8;
  --white: #FFF;

  /* INK — Text hierarchy */
  --ink: #1A1714;
  --ink2: #4A4540;
  --ink3: #7A756E;
  --ink4: #9E9891;

  /* ACCENT — Terracotta */
  --accent: #C4501A;
  --accent-h: #D4611B;
  --accent-bg: rgba(196, 80, 26, 0.06);
  --accent-border: rgba(196, 80, 26, 0.15);

  /* DARK — Contrast sections */
  --dark: #1A1714;
  --dark2: #242119;
  --dark3: #2E2A24;

  /* SEMANTIC */
  --green: #2D8548;
  --green-bg: rgba(45, 133, 72, 0.06);
  --green-border: rgba(45, 133, 72, 0.15);

  --red: #B84040;
  --red-bg: rgba(184, 64, 64, 0.05);
  --red-border: rgba(184, 64, 64, 0.12);

  /* WARM — Social proof */
  --warm: #F5E6D3;
  --warm-deep: #E8CEB0;

  /* BORDERS */
  --border: #DDD8D0;
  --border-h: #CCC6BC;

  /* TYPOGRAPHY */
  --display: 'Fraunces', Georgia, serif;
  --body: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
  --hand: 'Caveat', cursive;

  /* LAYOUT */
  --max: 1160px;

  /* ====== LEGACY COMPATIBILITY ======
     Maps old dark-theme variable names to v5 values.
     Used by blog bodyHtml, service pages, about page, etc.
     that reference var(--text-primary) etc. inline. */

  /* Text */
  --text-primary: var(--ink);
  --text-secondary: var(--ink3);
  --text-tertiary: var(--ink4);
  --text-muted: var(--ink4);

  /* Backgrounds */
  --bg-primary: var(--bg);
  --bg-secondary: var(--bg2);
  --bg-tertiary: var(--bg3);
  --bg-elevated: var(--white);
  --bg-hover: var(--bg3);
  --bg-card: var(--white);

  /* Accents */
  --accent-primary: var(--accent);
  --accent-primary-light: var(--accent-h);
  --accent-primary-dark: #A8430F;
  --accent-warm: var(--accent);
  --accent-warm-light: var(--accent-h);
  --accent-secondary: var(--accent);
  --accent-blue: var(--accent);
  --accent-amber: var(--accent);

  /* Semantic */
  --success: var(--green);
  --error: var(--red);

  /* Borders */
  --border-subtle: var(--border);
  --border-default: var(--border);
  --border-strong: var(--border-h);

  /* Typography */
  --font-display: var(--display);
  --font-body: var(--body);
  --font-mono: 'DM Mono', 'SF Mono', Consolas, monospace;
  --serif: var(--display);
  --sans: var(--body);
  --mono: var(--font-mono);

  /* Spacing */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;

  /* Border Radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-full: 9999px;

  /* Shadows (adapted for light theme) */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.1);
  --shadow-glow: 0 0 60px rgba(196, 80, 26, 0.08);

  /* Transitions */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --duration-fast: 150ms;
  --duration-normal: 300ms;
  --duration-slow: 500ms;
}

/* ============================================
   RESET & BASE
   ============================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--body);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ink);
  background: var(--bg);
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ============================================
   LAYOUT
   ============================================ */
.w { max-width: var(--max); margin: 0 auto; padding: 0 24px; position: relative; }
.sec { padding: 100px 0; }
@media (max-width: 768px) { .sec { padding: 56px 0; } }

/* ============================================
   BUTTONS
   ============================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 28px;
  border-radius: 8px;
  font-family: var(--body);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all 0.25s;
  letter-spacing: 0.01em;
}
.btn-p { background: var(--accent); color: #fff; }
.btn-p:hover { background: var(--accent-h); transform: translateY(-2px); box-shadow: 0 8px 20px rgba(196, 80, 26, 0.18); }
.btn-s { background: var(--white); color: var(--ink); border: 1.5px solid var(--border); box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04); }
.btn-s:hover { border-color: var(--border-h); transform: translateY(-1px); }
.btn-dark { background: var(--white); color: var(--dark); }
.btn-dark:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2); }
.btn-ghost-light { background: transparent; color: rgba(255, 255, 255, 0.8); border: 1.5px solid rgba(255, 255, 255, 0.2); }
.btn-ghost-light:hover { border-color: rgba(255, 255, 255, 0.5); color: #fff; }

/* ============================================
   UTILITIES
   ============================================ */
.label {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
}

/* Reveal animation — JS adds .vis on scroll */
.rv {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(.23, 1, .32, 1), transform 0.6s cubic-bezier(.23, 1, .32, 1);
}
.rv.vis { opacity: 1; transform: translateY(0); }

/* Safety: if JS fails, show content via noscript or after brief delay */
@keyframes rv-fallback { to { opacity: 1; transform: none; } }
.rv { animation: rv-fallback 0s 0.8s forwards; }
.d1 { transition-delay: .08s; }
.d2 { transition-delay: .16s; }
.d3 { transition-delay: .24s; }
.d4 { transition-delay: .32s; }

/* ============================================
   NAV
   ============================================ */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 0; /* reset legacy styles.css padding */
  background: rgba(250, 248, 244, 0.9);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(221, 216, 208, 0.5);
  transition: none; /* reset legacy transition */
}
.nav.scrolled { background: rgba(250, 248, 244, 0.95); } /* override legacy dark scroll bg */
.nav .w { display: flex; align-items: center; justify-content: space-between; height: 60px; }
.nav-logo { display: flex; align-items: center; gap: 9px; font-weight: 700; font-size: 1.0625rem; color: var(--ink); letter-spacing: -0.02em; }
.nav-logo img { width: 26px; height: 26px; }
.nav-links { display: flex; align-items: center; gap: 28px; list-style: none; }
.nav-links a { font-size: 0.8125rem; font-weight: 500; color: var(--ink3); transition: color 0.2s; }
.nav-links a:hover { color: var(--ink); }
.nav-cta {
  padding: 8px 18px;
  background: var(--ink);
  color: var(--bg) !important;
  border-radius: 6px;
  font-size: 0.8125rem;
  font-weight: 600;
  transition: all 0.2s;
}
.nav-cta:hover { background: var(--accent); }
.nav-mob { display: none; background: none; border: none; cursor: pointer; width: 32px; height: 32px; position: relative; }
.nav-mob span { position: absolute; left: 4px; width: 24px; height: 1.5px; background: var(--ink); transition: 0.3s; }
.nav-mob span:nth-child(1) { top: 10px; }
.nav-mob span:nth-child(2) { top: 16px; }
.nav-mob span:nth-child(3) { top: 22px; }
@media (max-width: 768px) {
  .nav-links { display: none; }
  .nav-mob { display: block; }
  .nav-links.open {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 60px;
    left: 0;
    right: 0;
    background: var(--white);
    padding: 20px 24px;
    border-bottom: 1px solid var(--border);
    gap: 14px;
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.06);
  }
}

/* ============================================
   HERO
   ============================================ */
.hero { padding-top: calc(60px + 72px); padding-bottom: 0; }
.hero-top { display: grid; grid-template-columns: 1fr 460px; gap: 40px; align-items: center; margin-bottom: 48px; }
@media (max-width: 960px) { .hero-top { grid-template-columns: 1fr; } }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 24px; }
.hero-eyebrow .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); animation: blink 2.4s infinite; }
@keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: .3; } }
.hero-eyebrow span:last-child { font-size: 0.8125rem; font-weight: 500; color: var(--green); }
.hero-title {
  font-family: var(--display);
  font-size: clamp(2.75rem, 5.8vw, 4.5rem);
  line-height: 1.06;
  font-weight: 300;
  letter-spacing: -0.03em;
  margin-bottom: 18px;
}
.hero-title em { font-style: italic; color: var(--accent); }
.hero-sub { font-size: 1.125rem; color: var(--ink2); font-weight: 400; max-width: 520px; margin-bottom: 14px; line-height: 1.7; }
.hero-rescue {
  margin-bottom: 24px;
  padding: 12px 18px;
  background: var(--red-bg);
  border: 1px solid var(--red-border);
  border-radius: 8px;
  font-size: 0.875rem;
  color: var(--ink2);
  max-width: 520px;
}
.hero-rescue strong { color: var(--ink); font-weight: 600; }
.hero-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 8px; }
.hero-micro { font-size: 0.8125rem; color: var(--ink4); }

/* Hero visual — mock with team photos */
.hero-vis { position: relative; }
@media (max-width: 960px) { .hero-vis { max-width: 500px; margin-top: 16px; } }
.mock { background: var(--white); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.07), 0 2px 12px rgba(0, 0, 0, 0.03); }
.mock-bar { height: 36px; background: var(--bg2); border-bottom: 1px solid var(--border); display: flex; align-items: center; padding: 0 13px; gap: 6px; }
.mock-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--bg3); }
.mock-sidebar { display: grid; grid-template-columns: 140px 1fr; min-height: 240px; }
.mock-nav { padding: 14px; border-right: 1px solid var(--bg2); display: flex; flex-direction: column; gap: 3px; }
.mock-nav-i { padding: 5px 9px; border-radius: 5px; font-size: 0.5625rem; font-weight: 500; color: var(--ink4); }
.mock-nav-i.active { background: var(--accent-bg); color: var(--accent); font-weight: 600; }
.mock-main { padding: 14px; }
.mock-main h4 { font-size: 0.5625rem; font-weight: 700; color: var(--ink3); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 10px; }
.mock-tbl { width: 100%; }
.mock-r { display: grid; grid-template-columns: 2fr 1.2fr 1fr 0.8fr; gap: 6px; padding: 6px 0; border-bottom: 1px solid var(--bg2); font-size: 0.5rem; color: var(--ink3); align-items: center; }
.mock-r:first-child { font-weight: 700; color: var(--ink4); letter-spacing: 0.05em; text-transform: uppercase; font-size: 0.45rem; }
.badge { display: inline-block; padding: 2px 6px; border-radius: 3px; font-size: 0.4375rem; font-weight: 700; }
.badge-g { background: var(--green-bg); color: var(--green); }
.badge-a { background: var(--accent-bg); color: var(--accent); }

/* Floating team photos */
.hero-team-float {
  position: absolute;
  bottom: -16px;
  left: -20px;
  display: flex;
  align-items: center;
  gap: -8px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 48px;
  padding: 6px 16px 6px 6px;
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.1);
  z-index: 2;
}
.hero-team-float img { width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--white); object-fit: cover; margin-left: -6px; }
.hero-team-float img:first-child { margin-left: 0; }
.hero-team-float span { font-size: 0.6875rem; font-weight: 600; color: var(--ink); margin-left: 6px; white-space: nowrap; }

/* ============================================
   STATS BAR
   ============================================ */
.stats { padding: 28px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); background: var(--white); }
.stats-row { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 20px; }
.stat { display: flex; align-items: baseline; gap: 8px; }
.stat-v { font-family: var(--display); font-size: 1.5rem; font-weight: 300; color: var(--ink); }
.stat-l { font-size: 0.75rem; color: var(--ink4); }
@media (max-width: 600px) { .stats-row { justify-content: center; } }

/* ============================================
   SOCIAL PROOF — WARM SECTION
   ============================================ */
.proof { padding: 60px 0; background: var(--warm); border-bottom: 1px solid var(--warm-deep); }
.proof-inner { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 32px; align-items: start; }
@media (max-width: 768px) { .proof-inner { grid-template-columns: 1fr; gap: 24px; } }
.proof-card { background: var(--white); border-radius: 12px; padding: 28px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04); }
.proof-stars { display: flex; gap: 3px; margin-bottom: 12px; }
.proof-star { width: 16px; height: 16px; fill: var(--accent); stroke: none; }
.proof-quote { font-size: 0.9375rem; color: var(--ink); line-height: 1.65; margin-bottom: 16px; font-style: italic; }
.proof-author { display: flex; align-items: center; gap: 10px; }
.proof-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; background: var(--bg3); }
.proof-name { font-size: 0.8125rem; font-weight: 600; color: var(--ink); }
.proof-role { font-size: 0.6875rem; color: var(--ink3); }
.proof-badges { display: flex; align-items: center; justify-content: center; gap: 32px; margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--warm-deep); }
.proof-badge { display: flex; align-items: center; gap: 8px; font-size: 0.8125rem; font-weight: 500; color: var(--ink2); }
.proof-badge-icon { font-size: 1.25rem; }

/* ============================================
   PAIN POINTS
   ============================================ */
.pain-layout { display: grid; grid-template-columns: 340px 1fr; gap: 48px; align-items: start; margin-top: 48px; }
@media (max-width: 860px) { .pain-layout { grid-template-columns: 1fr; } }
.pain-sticky { position: sticky; top: 100px; }
@media (max-width: 860px) { .pain-sticky { position: static; } }
.pain-cards { display: flex; flex-direction: column; gap: 12px; }
.pc { padding: 28px; background: var(--white); border: 1px solid var(--border); border-radius: 12px; transition: all 0.3s; display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start; }
.pc:hover { border-color: var(--border-h); box-shadow: 0 8px 28px rgba(0, 0, 0, 0.05); }
.pc-icon { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pc-icon svg { width: 20px; height: 20px; stroke-width: 1.8; fill: none; }
.pc h3 { font-size: 0.9375rem; font-weight: 600; color: var(--ink); margin-bottom: 4px; }
.pc p { font-size: 0.8125rem; color: var(--ink2); line-height: 1.6; }
.pc-tags { margin-top: 8px; display: flex; gap: 4px; flex-wrap: wrap; }
.pc-tags span { padding: 2px 7px; background: var(--bg2); border-radius: 3px; font-size: 0.5625rem; font-weight: 600; color: var(--ink4); }

/* ============================================
   BRIDGE (Before/After)
   ============================================ */
.bridge-bar { margin-top: 48px; display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: stretch; }
@media (max-width: 768px) { .bridge-bar { grid-template-columns: 1fr; } .bridge-arr { display: none !important; } }
.bridge-side { padding: 28px; border-radius: 12px; border: 1px solid var(--border); }
.bridge-before { background: var(--red-bg); border-color: var(--red-border); }
.bridge-after { background: var(--green-bg); border-color: var(--green-border); }
.bridge-side h3 { font-family: var(--display); font-size: 1.125rem; margin-bottom: 12px; font-weight: 300; }
.bridge-side ul { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.bridge-side li { font-size: 0.8125rem; color: var(--ink2); display: flex; gap: 8px; align-items: flex-start; }
.bridge-side li svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 3px; stroke-width: 2.5; fill: none; }
.bridge-before li svg { stroke: var(--red); }
.bridge-after li svg { stroke: var(--green); }
.bridge-arr { display: flex; align-items: center; justify-content: center; }
.bridge-arr svg { width: 28px; height: 28px; stroke: var(--accent); fill: none; stroke-width: 1.5; }

/* ============================================
   TCO — DARK SECTION
   ============================================ */
.tco { background: var(--dark); color: var(--bg); padding: 80px 0; position: relative; overflow: hidden; }
.tco::before { content: ''; position: absolute; top: -100px; right: -100px; width: 400px; height: 400px; background: radial-gradient(circle, rgba(196, 80, 26, 0.08), transparent 70%); pointer-events: none; }
.tco-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 768px) { .tco-grid { grid-template-columns: 1fr; gap: 40px; } }
.tco .label { color: rgba(196, 80, 26, 0.8); }
.tco h2 { font-family: var(--display); font-size: clamp(2rem, 3.5vw, 2.75rem); font-weight: 300; line-height: 1.15; margin-top: 12px; color: var(--bg); }
.tco-body { font-size: 0.9375rem; color: rgba(250, 248, 244, 0.55); margin-top: 14px; line-height: 1.7; }
.tco-big { display: flex; gap: 32px; margin-top: 28px; flex-wrap: wrap; }
.tco-big-item { text-align: center; }
.tco-big-val { font-family: var(--display); font-size: 3rem; font-weight: 300; line-height: 1; }
.tco-big-label { font-size: 0.6875rem; color: rgba(250, 248, 244, 0.4); margin-top: 6px; }
.tco-table { border: 1px solid var(--dark3); border-radius: 10px; overflow: hidden; }
.tco-row { display: grid; grid-template-columns: 1fr 1fr 1fr; border-bottom: 1px solid var(--dark3); }
.tco-row:last-child { border-bottom: none; }
.tco-cell { padding: 10px 14px; font-size: 0.8125rem; color: rgba(250, 248, 244, 0.5); }
.tco-hd .tco-cell { background: var(--dark3); font-size: 0.5625rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(250, 248, 244, 0.35); padding: 8px 14px; }
.tco-cell.dim { color: var(--red); }
.tco-cell.good { color: var(--green); font-weight: 600; }
.tco-cell.hl { color: var(--accent); font-weight: 600; }
.tco-fn { font-size: 0.6875rem; color: rgba(250, 248, 244, 0.3); margin-top: 8px; font-style: italic; }

/* ============================================
   PACKAGES
   ============================================ */
.pkg-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 48px; }
@media (max-width: 768px) { .pkg-grid { grid-template-columns: 1fr; } }
.pkg { padding: 28px; background: var(--white); border: 1px solid var(--border); border-radius: 12px; display: flex; flex-direction: column; transition: all 0.3s; }
.pkg:hover { border-color: var(--border-h); box-shadow: 0 10px 36px rgba(0, 0, 0, 0.06); transform: translateY(-3px); }
.pkg-ind { font-size: 0.5625rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.pkg h3 { font-family: var(--display); font-size: 1.25rem; font-weight: 300; color: var(--ink); margin-bottom: 4px; }
.pkg-desc { font-size: 0.8125rem; color: var(--ink2); margin-bottom: 16px; flex: 1; line-height: 1.6; }
.pkg-prices { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 2px; }
.pkg-price { font-size: 1.125rem; font-weight: 700; color: var(--ink); }
.pkg-vs { font-size: 0.75rem; color: var(--ink4); text-decoration: line-through; }
.pkg-time { font-size: 0.75rem; color: var(--ink3); margin-bottom: 14px; }
.pkg-tags { display: flex; gap: 4px; flex-wrap: wrap; padding-top: 14px; border-top: 1px solid var(--bg2); }
.pkg-tag { padding: 3px 8px; background: var(--bg2); border-radius: 4px; font-size: 0.5625rem; font-weight: 600; color: var(--ink4); }
.pkg-note { text-align: center; margin-top: 20px; font-size: 0.875rem; color: var(--ink3); }
.pkg-note a { color: var(--accent); }

/* ============================================
   CASE STUDIES
   ============================================ */
.cases { display: flex; flex-direction: column; gap: 20px; margin-top: 48px; }
.case { display: grid; grid-template-columns: 1fr 400px; gap: 32px; align-items: center; padding: 36px; background: var(--white); border: 1px solid var(--border); border-radius: 14px; transition: all 0.3s; }
.case:hover { box-shadow: 0 10px 40px rgba(0, 0, 0, 0.06); }
.case:nth-child(even) { grid-template-columns: 400px 1fr; }
.case:nth-child(even) .case-vis { order: -1; }
@media (max-width: 860px) { .case, .case:nth-child(even) { grid-template-columns: 1fr; } .case-vis { order: 0 !important; } }
.case-tag { display: inline-block; padding: 3px 8px; background: var(--bg2); border-radius: 4px; font-size: 0.5625rem; font-weight: 600; color: var(--ink4); margin-right: 4px; margin-bottom: 8px; }
.case h3 { font-family: var(--display); font-size: 1.25rem; font-weight: 300; margin-bottom: 6px; }
.case-desc { font-size: 0.8125rem; color: var(--ink2); margin-bottom: 16px; line-height: 1.65; }
.case-metrics { display: flex; gap: 20px; flex-wrap: wrap; }
.case-mv { font-family: var(--display); font-size: 1.125rem; color: var(--ink); line-height: 1.2; font-weight: 300; }
.case-ml { font-size: 0.5625rem; color: var(--ink4); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
.case-vis { border-radius: 10px; overflow: hidden; border: 1px solid var(--border); background: var(--bg2); }
.case-vis .mock-bar { height: 30px; }
.case-vis .mock-body { padding: 12px; }

/* ============================================
   VERIFY — DARK TRUST SECTION
   ============================================ */
.verify { padding: 100px 0; background: var(--dark); color: var(--bg); position: relative; overflow: hidden; }
.verify::before { content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 800px; height: 400px; background: radial-gradient(ellipse, rgba(196, 80, 26, 0.1) 0%, transparent 60%); pointer-events: none; }
.verify-inner { display: grid; grid-template-columns: 1fr 300px; gap: 64px; align-items: center; }
@media (max-width: 860px) { .verify-inner { grid-template-columns: 1fr; } }
.verify-q { font-family: var(--display); font-size: clamp(2rem, 4vw, 3rem); font-weight: 300; font-style: italic; line-height: 1.15; color: rgba(250, 248, 244, 0.9); margin-bottom: 20px; }
.verify-q em { color: var(--accent); }
.verify-body { font-size: 0.9375rem; color: rgba(250, 248, 244, 0.45); line-height: 1.7; margin-bottom: 24px; }
.verify-team { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.verify-team-photos { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.verify-team-photos img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 10px; filter: grayscale(30%); transition: filter 0.3s; }
.verify-team-photos img:hover { filter: grayscale(0%); }
.verify-team-caption { font-family: var(--hand); font-size: 1.25rem; color: rgba(250, 248, 244, 0.5); text-align: center; }

/* ============================================
   FOUNDER NOTE
   ============================================ */
.founder { padding: 60px 0; background: var(--warm); border-top: 1px solid var(--warm-deep); border-bottom: 1px solid var(--warm-deep); }
.founder-inner { display: grid; grid-template-columns: 80px 1fr; gap: 24px; max-width: 700px; margin: 0 auto; align-items: start; }
@media (max-width: 600px) { .founder-inner { grid-template-columns: 1fr; } .founder-photo { display: none; } }
.founder-photo img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; border: 3px solid var(--white); }
.founder-note { font-size: 0.9375rem; color: var(--ink2); line-height: 1.75; }
.founder-note .hand { font-family: var(--hand); font-size: 1.5rem; color: var(--accent); display: block; margin-top: 12px; }
.founder-name { font-size: 0.8125rem; font-weight: 600; color: var(--ink); margin-top: 4px; }
.founder-title { font-size: 0.6875rem; color: var(--ink3); }
.founder-secondary { margin-top: 32px; padding-top: 32px; border-top: 1px solid var(--warm-deep); }

/* ============================================
   EDGE (AI)
   ============================================ */
.edge-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 48px; align-items: start; }
@media (max-width: 768px) { .edge-grid { grid-template-columns: 1fr; gap: 32px; } }
.edge-point { display: flex; gap: 12px; padding: 16px 18px; background: var(--white); border: 1px solid var(--border); border-radius: 10px; margin-bottom: 8px; transition: border-color 0.3s; }
.edge-point:hover { border-color: var(--border-h); }
.edge-point-i { width: 34px; height: 34px; flex-shrink: 0; border-radius: 8px; display: flex; align-items: center; justify-content: center; }
.edge-point-i svg { width: 16px; height: 16px; stroke-width: 1.8; fill: none; }
.edge-point h4 { font-size: 0.8125rem; font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.edge-point p { font-size: 0.75rem; color: var(--ink3); line-height: 1.55; }

/* Risk reversal */
.risk { margin-top: 40px; padding: 24px 28px; background: var(--green-bg); border: 1px solid var(--green-border); border-radius: 12px; display: flex; gap: 16px; align-items: start; }
@media (max-width: 600px) { .risk { flex-direction: column; } }
.risk-i { width: 40px; height: 40px; flex-shrink: 0; background: rgba(45, 133, 72, 0.1); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.risk-i svg { width: 20px; height: 20px; stroke: var(--green); fill: none; stroke-width: 1.8; }
.risk h3 { font-size: 0.875rem; font-weight: 600; color: var(--ink); margin-bottom: 3px; }
.risk p { font-size: 0.8125rem; color: var(--ink2); line-height: 1.6; }

/* ============================================
   PROCESS
   ============================================ */
.proc-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 40px; }
@media (max-width: 768px) { .proc-steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .proc-steps { grid-template-columns: 1fr; } }
.proc-s { padding: 24px; background: var(--white); border: 1px solid var(--border); border-radius: 10px; }
.proc-n { font-family: var(--display); font-size: 2.25rem; color: var(--bg3); line-height: 1; margin-bottom: 12px; font-weight: 300; }
.proc-s h3 { font-size: 0.875rem; font-weight: 600; color: var(--ink); margin-bottom: 4px; }
.proc-s p { font-size: 0.75rem; color: var(--ink3); line-height: 1.6; }

/* ============================================
   TEAM
   ============================================ */
.team-hero { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
@media (max-width: 768px) { .team-hero { grid-template-columns: 1fr; gap: 32px; } }
.team-photos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.team-photo-card { border-radius: 10px; overflow: hidden; background: var(--bg3); position: relative; transition: transform 0.3s; }
.team-photo-card:hover { transform: translateY(-4px); }
.team-photo-card img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; }
.team-photo-card .team-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 8px 10px; background: linear-gradient(transparent, rgba(0, 0, 0, 0.6)); color: #fff; }
.team-overlay .tn { font-size: 0.75rem; font-weight: 600; }
.team-overlay .tr { font-size: 0.5625rem; opacity: 0.7; }
.team-adv { margin-top: 20px; padding: 16px 20px; background: var(--accent-bg); border: 1px solid var(--accent-border); border-radius: 10px; }
.team-adv h4 { font-size: 0.8125rem; font-weight: 600; color: var(--accent); margin-bottom: 2px; }
.team-adv p { font-size: 0.75rem; color: var(--ink2); }

/* ============================================
   BOUNDARIES
   ============================================ */
.bounds-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 32px; }
@media (max-width: 768px) { .bounds-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .bounds-grid { grid-template-columns: 1fr; } }
.bounds-i { padding: 14px 18px; background: var(--white); border: 1px solid var(--border); border-radius: 8px; font-size: 0.8125rem; color: var(--ink2); display: flex; gap: 8px; align-items: flex-start; }
.bounds-x { color: var(--red); font-weight: 700; font-size: 0.75rem; flex-shrink: 0; margin-top: 2px; }
.bounds-i strong { color: var(--ink); font-weight: 600; }

/* ============================================
   FAQ
   ============================================ */
.faq-list { max-width: 700px; margin: 40px auto 0; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q {
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  padding: 16px 0;
  font-family: var(--body);
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  transition: color 0.2s;
}
.faq-q:hover { color: var(--accent); }
.faq-q svg { width: 18px; height: 18px; flex-shrink: 0; stroke: var(--ink3); fill: none; stroke-width: 2; transition: transform 0.3s; }
.faq-item.open .faq-q svg { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.4s; }
.faq-item.open .faq-a { max-height: 260px; padding-bottom: 16px; }
.faq-a p { font-size: 0.8125rem; color: var(--ink2); line-height: 1.7; }

/* ============================================
   LEAD MAGNET
   ============================================ */
.magnet { max-width: 580px; margin: 0 auto; padding: 36px; background: var(--white); border: 1px solid var(--border); border-radius: 14px; text-align: center; }
.magnet-icon { width: 44px; height: 44px; margin: 0 auto 16px; background: var(--accent-bg); border: 1px solid var(--accent-border); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.magnet-icon svg { width: 20px; height: 20px; stroke: var(--accent); fill: none; stroke-width: 1.8; }

/* ============================================
   CTA END
   ============================================ */
.cta-end { text-align: center; }

/* ============================================
   FOOTER
   ============================================ */
.v5-footer { padding: 48px 0 24px; border-top: 1px solid var(--border); }
.v5-footer-grid { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 32px; margin-bottom: 32px; }
@media (max-width: 768px) { .v5-footer-grid { grid-template-columns: 1fr 1fr; gap: 24px; } }
@media (max-width: 480px) { .v5-footer-grid { grid-template-columns: 1fr; } }
.v5-footer-col h4 { font-size: 0.6875rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink3); margin-bottom: 12px; }
.v5-footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.v5-footer-col a { font-size: 0.8125rem; color: var(--ink3); transition: color 0.2s; }
.v5-footer-col a:hover { color: var(--ink); }
.v5-footer-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; padding-top: 24px; border-top: 1px solid var(--border); }
.v5-footer-brand { display: flex; align-items: center; gap: 8px; font-weight: 600; font-size: 0.8125rem; color: var(--ink3); }
.v5-footer-brand img { width: 20px; height: 20px; opacity: 0.5; }

/* ============================================
   BLOG / ARTICLE STYLES
   ============================================ */

/* Article content typography */
.article-content {
  font-family: var(--body) !important;
  font-size: 1.0625rem;
  line-height: 1.8;
  color: var(--ink2);
}
.article-content h2 {
  font-family: var(--display) !important;
  font-size: 1.75rem;
  font-weight: 300;
  color: var(--ink);
  margin: 2.5rem 0 1rem;
  line-height: 1.2;
}
.article-content h3 {
  font-family: var(--display) !important;
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--ink);
  margin: 2rem 0 0.75rem;
}
.article-content p { margin-bottom: 1.25rem; }
.article-content a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.article-content a:hover { color: var(--accent-h); }
.article-content strong { color: var(--ink); font-weight: 600; }
.article-content ul, .article-content ol { margin-bottom: 1.25rem; padding-left: 1.5rem; }
.article-content li { margin-bottom: 0.5rem; }
.article-content hr { border: none; border-top: 1px solid var(--border); margin: 2rem 0; }
.article-content blockquote {
  border-left: 3px solid var(--accent);
  padding: 0.75rem 1.25rem;
  margin: 1.5rem 0;
  color: var(--ink3);
  font-style: italic;
}
.article-content code {
  font-family: 'DM Mono', monospace;
  font-size: 0.875em;
  background: var(--bg2);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--ink);
}
.article-content pre {
  background: var(--dark) !important;
  color: var(--bg) !important;
  padding: 1.25rem;
  border-radius: 10px;
  overflow-x: auto;
  margin: 1.5rem 0;
  font-size: 0.875rem;
  line-height: 1.6;
}
.article-content pre code { background: none; padding: 0; color: inherit; }
.article-content img { border-radius: 10px; margin: 1.5rem 0; }
.article-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  font-size: 0.9375rem;
}
.article-content th, .article-content td {
  padding: 10px 14px;
  border: 1px solid var(--border);
  text-align: left;
}
.article-content th { background: var(--bg2); color: var(--ink); font-weight: 600; font-size: 0.8125rem; }

/* Blog listing cards */
.blog-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 28px;
  transition: all 0.3s;
}
.blog-card:hover { border-color: var(--border-h); box-shadow: 0 8px 28px rgba(0,0,0,0.05); transform: translateY(-2px); }
.blog-card { display: flex; flex-direction: column; }
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }

/* ============================================
   LEGACY CLASS OVERRIDES FOR V5 LIGHT THEME
   These override dark-theme visuals from styles.css
   ============================================ */

/* Kill dark decorative elements */
.grain-overlay { display: none !important; }
.hero-grid-pattern,
.cta-grid-pattern {
  background-image:
    linear-gradient(rgba(0, 0, 0, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 0, 0, 0.03) 1px, transparent 1px) !important;
}
.hero-gradient-orb { opacity: 0.3 !important; }
.hero-ekg-line { display: none !important; }

/* Section backgrounds — already mapped via compat vars, but ensure light */
.hero { background: var(--bg) !important; }
.hero-bg { background: var(--bg) !important; }

/* Fix white-on-dark borders for light theme */
.service-card,
.industry-card,
.testimonial-block,
.founder-card,
.pillar,
.work-showcase {
  border-color: var(--border) !important;
  background: var(--white) !important;
}

/* Fix proof strip */
.proof-strip {
  background: var(--bg2) !important;
  border-top: 1px solid var(--border) !important;
  border-bottom: 1px solid var(--border) !important;
}
.proof-item { color: var(--ink2) !important; }
.proof-icon { color: var(--accent) !important; }

/* Fix testimonial */
.quick-testimonial { background: var(--warm) !important; }
.testimonial-block {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
}
.quote-decoration { color: var(--accent) !important; }
.testimonial-quote { color: var(--ink) !important; }
.author-name { color: var(--ink) !important; }
.author-role { color: var(--ink3) !important; }
.metric-value { color: var(--accent) !important; }
.metric-label { color: var(--ink4) !important; }

/* Fix section headers */
.section-label { color: var(--accent) !important; }
.section-title { color: var(--ink) !important; font-family: var(--display) !important; }
.title-accent { color: var(--accent) !important; }
.section-description { color: var(--ink2) !important; }

/* Fix industries/cards sections */
.industries { background: var(--bg) !important; }
.industry-card {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
}
.industry-card:hover { border-color: var(--border-h) !important; box-shadow: 0 8px 28px rgba(0,0,0,0.05) !important; }
.industry-title { color: var(--ink) !important; }
.industry-description { color: var(--ink2) !important; }
.industry-link { color: var(--accent) !important; }
.industry-icon { color: var(--ink3) !important; }

/* Fix featured work */
.featured-work { background: var(--bg2) !important; }
.work-badge, .work-timeline, .work-stack { color: var(--ink4) !important; background: var(--bg2) !important; border-color: var(--border) !important; }
.work-description { color: var(--ink2) !important; }
.outcome-value { color: var(--ink) !important; }
.outcome-label { color: var(--ink4) !important; }
.tech-tag { color: var(--ink3) !important; background: var(--bg2) !important; border-color: var(--border) !important; }
.browser-frame { border: 1px solid var(--border) !important; background: var(--white) !important; }
.browser-bar { background: var(--bg2) !important; border-bottom: 1px solid var(--border) !important; }
.browser-dots span { background: var(--bg3) !important; }
.browser-address { color: var(--ink4) !important; }
.browser-content, .placeholder-screen { background: var(--bg) !important; }
.screen-sidebar { background: var(--bg2) !important; }
.screen-nav-item { background: var(--bg3) !important; }
.screen-nav-item.active { background: var(--accent) !important; }
.screen-header, .screen-card, .table-row { background: var(--bg2) !important; }

/* Fix services grid */
.services { background: var(--bg) !important; }
.service-card {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
}
.service-card:hover { border-color: var(--border-h) !important; box-shadow: 0 8px 28px rgba(0,0,0,0.05) !important; }
.service-featured { border-color: var(--accent) !important; }
.service-badge { background: var(--accent-bg) !important; color: var(--accent) !important; }
.service-number { color: var(--bg3) !important; }
.service-title { color: var(--ink) !important; }
.service-tagline { color: var(--ink2) !important; }
.service-features li { color: var(--ink2) !important; }
.service-cta { color: var(--accent) !important; }

/* Fix why/pillar section */
.why-section { background: var(--bg2) !important; }
.pillar {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
}
.pillar-title { color: var(--ink) !important; }
.pillar-description { color: var(--ink2) !important; }
.pillar-proof li { color: var(--ink3) !important; }
.pillar-icon { color: var(--accent) !important; }

/* Fix team section */
.team { background: var(--bg) !important; }
.founder-card {
  background: var(--white) !important;
  border: 1px solid var(--border) !important;
}
.founder-name { color: var(--ink) !important; }
.founder-role { color: var(--accent) !important; }
.founder-bio { color: var(--ink2) !important; }

/* Fix CTA section */
.cta-section { background: var(--bg2) !important; }
.cta-bg { display: none !important; }
.cta-title { color: var(--ink) !important; font-family: var(--display) !important; }
.cta-description { color: var(--ink2) !important; }
.cta-email { color: var(--ink3) !important; }
.cta-urgency { color: var(--green) !important; }

/* Fix buttons */
.btn-primary {
  background: var(--accent) !important;
  color: #fff !important;
  border: none !important;
}
.btn-primary:hover { background: var(--accent-h) !important; }
.btn-ghost {
  background: transparent !important;
  color: var(--ink) !important;
  border: 1.5px solid var(--border) !important;
}
.btn-ghost:hover { border-color: var(--border-h) !important; }
.btn-outline {
  background: transparent !important;
  color: var(--accent) !important;
  border: 1.5px solid var(--accent) !important;
}

/* Fix breadcrumb */
.breadcrumb { background: var(--bg) !important; padding-top: 80px !important; }
.breadcrumb a { color: var(--ink4) !important; }
.breadcrumb [aria-current="page"] { color: var(--ink3) !important; }

/* Fix page hero */
.page-hero { background: var(--bg) !important; }

/* Fix about page sections */
.about-story, .about-values, .about-team, .about-stack, .about-location { background: var(--bg) !important; }
.value-card { background: var(--white) !important; border: 1px solid var(--border) !important; }
.value-number { color: var(--accent) !important; }
.value-title { color: var(--ink) !important; }
.value-desc { color: var(--ink2) !important; }

/* Fix blog listing */
.grid-3 { gap: 16px !important; }

/* Fix hero scroll indicator for light bg */
.hero-scroll-indicator span { color: var(--ink4) !important; }
.scroll-line { background: var(--border) !important; }

/* ============================================
   SERVICE PAGE COMPONENTS
   ============================================ */

/* Breadcrumb */
.svc-breadcrumb { padding: 80px 0 0; background: var(--bg); }
.svc-breadcrumb ol { list-style: none; display: flex; gap: 8px; align-items: center; font-size: 0.75rem; color: var(--ink4); }
.svc-breadcrumb a { color: var(--ink4); transition: color 0.2s; }
.svc-breadcrumb a:hover { color: var(--ink); }
.svc-breadcrumb li:not(:last-child)::after { content: '/'; margin-left: 8px; color: var(--bg3); }
.svc-breadcrumb [aria-current="page"] { color: var(--ink3); font-weight: 500; }

/* Service Hero */
.svc-hero { padding: 32px 0 0; background: var(--bg); }
.svc-hero-inner { max-width: 680px; }
.svc-hero .label { margin-bottom: 12px; }
.svc-hero h1 { font-family: var(--display); font-size: clamp(2.25rem, 4.5vw, 3.25rem); font-weight: 300; line-height: 1.1; letter-spacing: -0.02em; color: var(--ink); margin-bottom: 16px; }
.svc-hero h1 em { font-style: italic; color: var(--accent); }
.svc-hero-desc { font-size: 1.0625rem; color: var(--ink2); line-height: 1.7; margin-bottom: 24px; max-width: 560px; }
.svc-hero-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 10px; }
.svc-hero-reassurance { font-size: 0.8125rem; color: var(--ink4); }
.svc-hero-stats { display: flex; gap: 32px; margin-top: 40px; padding-top: 28px; border-top: 1px solid var(--border); }
@media (max-width: 600px) { .svc-hero-stats { gap: 20px; flex-wrap: wrap; } }
.svc-stat { text-align: left; }
.svc-stat-num { font-family: var(--display); font-size: 1.75rem; font-weight: 300; color: var(--ink); line-height: 1.2; }
.svc-stat-label { font-size: 0.6875rem; color: var(--ink4); letter-spacing: 0.04em; }

/* Service FAQ */
.svc-faq { padding: 80px 0; background: var(--bg); }
.svc-faq-header { text-align: center; margin-bottom: 40px; }
.svc-faq-header .label { margin-bottom: 12px; display: block; }
.svc-faq-header h2 { font-family: var(--display); font-size: clamp(1.75rem, 3vw, 2.5rem); font-weight: 300; color: var(--ink); }
.svc-faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; max-width: 900px; margin: 0 auto; }
@media (max-width: 768px) { .svc-faq-grid { grid-template-columns: 1fr; } }
.svc-faq-grid .faq-item { background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: 0 20px; }
.svc-faq-grid .faq-q { padding: 16px 0; }

/* Service CTA */
.svc-cta { padding: 80px 0; background: var(--bg2); border-top: 1px solid var(--border); text-align: center; }
.svc-cta-inner { max-width: 580px; margin: 0 auto; }
.svc-cta h2 { font-family: var(--display); font-size: clamp(1.75rem, 3vw, 2.5rem); font-weight: 300; color: var(--ink); margin-bottom: 12px; }
.svc-cta-desc { font-size: 0.9375rem; color: var(--ink2); line-height: 1.7; margin-bottom: 24px; }
.svc-cta-email { font-size: 0.8125rem; color: var(--ink3); margin-top: 12px; }
.svc-cta-email strong { color: var(--ink); }
.svc-cta-avail { font-size: 0.8125rem; color: var(--green); margin-top: 8px; }
.svc-cta-expect { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border); text-align: left; max-width: 400px; margin-left: auto; margin-right: auto; }
.svc-cta-expect h4 { font-size: 0.75rem; font-weight: 600; color: var(--ink3); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 10px; }
.svc-cta-expect-list { display: flex; flex-direction: column; gap: 6px; }
.svc-cta-expect-list span { font-size: 0.8125rem; color: var(--ink2); display: flex; gap: 8px; align-items: center; }
.svc-cta-expect-list .chk { color: var(--green); font-weight: 600; font-size: 0.75rem; }

/* ============================================
   MOBILE RESPONSIVENESS
   ============================================ */

/* --- Small tablets & large phones (max 768px) --- */
@media (max-width: 768px) {
  /* Hero */
  .hero { padding-top: calc(60px + 40px); }
  .hero-top { gap: 24px; margin-bottom: 32px; }
  .hero-title { font-size: clamp(2rem, 8vw, 2.75rem); }
  .hero-sub { font-size: 1rem; }
  .hero-rescue { font-size: 0.8125rem; padding: 10px 14px; }

  /* Mock — hide sidebar on mobile, simplify */
  .mock-sidebar { grid-template-columns: 1fr; }
  .mock-nav { display: none; }

  /* Hero team float — reposition */
  .hero-team-float { position: relative; bottom: auto; left: auto; margin-top: 12px; display: inline-flex; }

  /* Stats */
  .stats { padding: 20px 0; }
  .stats-row { gap: 12px 24px; justify-content: flex-start; }
  .stat-v { font-size: 1.25rem; }

  /* Proof badges */
  .proof-badges { flex-wrap: wrap; gap: 16px; justify-content: center; }

  /* TCO table */
  .tco { padding: 56px 0; }
  .tco-big { gap: 24px; }
  .tco-big-val { font-size: 2rem; }
  .tco-cell { padding: 8px 10px; font-size: 0.75rem; }
  .tco-hd .tco-cell { padding: 6px 10px; font-size: 0.5rem; }

  /* Verify */
  .verify { padding: 56px 0; }
  .verify-inner { gap: 32px; }
  .verify-q { font-size: clamp(1.5rem, 5vw, 2rem); }

  /* Team */
  .team-photos { grid-template-columns: repeat(2, 1fr); gap: 8px; }

  /* Nav mobile links — touch-friendly */
  .nav-links.open a { font-size: 1rem; padding: 8px 0; min-height: 44px; display: flex; align-items: center; }
  .nav-links.open .nav-cta { display: flex !important; padding: 12px 18px; text-align: center; justify-content: center; }

  /* Service breadcrumb */
  .svc-breadcrumb { padding-top: 68px; }
  .breadcrumb { padding-top: 68px !important; }

  /* Service hero */
  .svc-hero { padding: 20px 0 0; }
  .svc-hero h1 { font-size: clamp(1.75rem, 7vw, 2.5rem); }

  /* Blog grid */
  .blog-grid { grid-template-columns: 1fr 1fr !important; }

  /* Footer */
  .v5-footer { padding: 32px 0 20px; }
  .v5-footer-grid { margin-bottom: 24px; }
  .v5-footer-bottom { flex-direction: column; align-items: flex-start; gap: 8px; }
}

/* --- Phones (max 480px) --- */
@media (max-width: 480px) {
  .w { padding: 0 16px; }

  /* Hero */
  .hero { padding-top: calc(60px + 28px); }
  .hero-title { font-size: 2rem; letter-spacing: -0.02em; }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn { width: 100%; justify-content: center; }

  /* Stats — 2 per row */
  .stats-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

  /* Proof cards */
  .proof { padding: 40px 0; }
  .proof-card { padding: 20px; }

  /* TCO */
  .tco-row { grid-template-columns: 1.2fr 1fr 1fr; }
  .tco-cell { padding: 6px 8px; font-size: 0.6875rem; }

  /* Packages */
  .pkg { padding: 20px; }

  /* Case studies */
  .case { padding: 20px; gap: 20px; }
  .case-metrics { gap: 12px; }

  /* Verify */
  .verify-team-photos { grid-template-columns: 1fr 1fr; gap: 6px; }

  /* Founder */
  .founder { padding: 40px 0; }

  /* Process */
  .proc-s { padding: 18px; }
  .proc-n { font-size: 1.75rem; }

  /* Team photos — 2 col on small phones */
  .team-photos { grid-template-columns: repeat(2, 1fr); }

  /* Boundaries */
  .bounds-i { padding: 10px 14px; font-size: 0.75rem; }

  /* FAQ */
  .faq-q { font-size: 0.8125rem; padding: 14px 0; }

  /* Service hero */
  .svc-hero h1 { font-size: 1.75rem; }
  .svc-hero-desc { font-size: 0.9375rem; }
  .svc-hero-stats { flex-direction: column; gap: 16px; }
  .svc-stat-num { font-size: 1.5rem; }

  /* Blog grid */
  .blog-grid { grid-template-columns: 1fr !important; }

  /* CTA buttons full width */
  .svc-cta .btn { width: 100%; justify-content: center; }
  .btn-p, .btn-s { padding: 12px 20px; }
}
