/* ============================================================
   site-v2.css — Liquid Glass Design System Layer
   Design contract: T-MP5YCFE44 / Pascal → Boyle
   Load AFTER site.css, BEFORE palette.css
   ============================================================ */

/* ── Spring easing variable ── */
:root {
  --spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ============================================================
   SAFARI MOBILE VIEWPORT — Non-Negotiables
   ============================================================ */
html {
  /* Never overflow:hidden on html */
}

body {
  min-height: 100vh;
  min-height: -webkit-fill-available;
  background: var(--bg, var(--color-surface));
  color: var(--text, var(--color-ink));
}

/* ============================================================
   GLASS UTILITY CLASSES
   ============================================================ */

/* Light mode glass card */
.glass-card {
  background: color-mix(in oklch, var(--g-bg-s, oklch(0.98 0.004 260 / 0.88)), var(--accent-dim, oklch(0.55 0.22 260 / 0.06)) 8%);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  border: 1px solid var(--g-border, oklch(0.45 0.010 260 / 0.16));
  border-radius: var(--radius, 24px);
  box-shadow:
    var(--g-shadow, 0 2px 16px oklch(0.20 0.010 260 / 0.08), 0 1px 3px oklch(0.20 0.010 260 / 0.04)),
    inset 0 1px 0 rgba(255, 255, 255, 0.60);
  transition:
    transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.35s ease;
}

.glass-card:hover {
  transform: translateY(-3px);
  box-shadow:
    var(--g-shadow-l, 0 8px 40px oklch(0.20 0.010 260 / 0.12), 0 2px 8px oklch(0.20 0.010 260 / 0.06)),
    inset 0 1px 0 rgba(255, 255, 255, 0.70);
}

/* Dark mode glass card */
.glass-card-dark {
  background: color-mix(in oklch, var(--g-bg-s, oklch(0.15 0.003 300 / 0.80)), var(--accent-dim, oklch(0.68 0.22 300 / 0.07)) 8%);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  border: 1px solid var(--g-border, oklch(0.35 0.004 300 / 0.22));
  border-radius: var(--radius, 24px);
  box-shadow:
    var(--g-shadow, 0 4px 24px -8px oklch(0.05 0.002 300 / 0.6), 0 1px 4px oklch(0.05 0.002 300 / 0.4)),
    inset 0 1px 0 rgba(255, 255, 255, 0.10);
  transition:
    transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.35s ease;
}

.glass-card-dark:hover {
  transform: translateY(-3px);
  box-shadow:
    0 8px 40px -8px var(--accent-glow, oklch(0.68 0.22 300 / 0.30)),
    var(--g-shadow, 0 4px 24px -8px oklch(0.05 0.002 300 / 0.6), 0 1px 4px oklch(0.05 0.002 300 / 0.4)),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}

/* ============================================================
   NAV SHRINK — Scroll Contracted Glass Pill
   ============================================================ */
.nav-shrink {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 1000;
  padding: 0 8px;
  padding-top: env(safe-area-inset-top, 0px);
}

.nav-shrink__inner {
  margin: 8px auto 0;
  max-width: 72rem;
  padding: 0 24px;
  /* Pre-apply blur(0px) — keeps compositing layer alive, avoids jank */
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  /* NEVER include backdrop-filter in transition — Safari jank */
  transition:
    max-width     0.3s cubic-bezier(0.22, 1, 0.36, 1),
    padding       0.3s cubic-bezier(0.22, 1, 0.36, 1),
    background-color 0.3s,
    border-color  0.3s,
    border-radius 0.3s,
    box-shadow    0.3s;
  border: 1px solid transparent;
}

.nav-shrink__inner.scrolled {
  max-width: 56rem;
  padding: 0 20px;
  border-radius: 16px;
  border-color: var(--g-border, oklch(0.35 0.004 264 / 0.22));
  background-color: var(--g-bg, oklch(0.12 0.003 264 / 0.55));
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 4px 24px -8px oklch(0.05 0.002 264 / 0.6);
}

/* Bar: 3-zone flex row */
.nav-shrink__bar {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 0;
  gap: 16px;
}

/* Logo */
.nav-shrink__logo {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  flex-shrink: 0;
}

.nav-logo-name {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.03em;
  background: linear-gradient(135deg, var(--accent, oklch(0.55 0.22 260)), var(--accent-alt, oklch(0.65 0.18 210)));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  white-space: nowrap;
}

/* Desktop centered links */
.nav-shrink__links {
  display: flex;
  gap: 28px;
  list-style: none;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.nav-shrink__links a {
  color: var(--muted, oklch(0.67 0.005 264));
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  transition: color 0.15s;
  white-space: nowrap;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.nav-shrink__links a:hover {
  color: var(--text, oklch(0.97 0.002 264));
}

/* Right actions */
.nav-shrink__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.nav-actions--default {
  display: flex;
  gap: 8px;
}

.nav-shrink__inner.scrolled .nav-actions--default {
  display: none;
}

.nav-actions--scrolled {
  display: none;
}

.nav-shrink__inner.scrolled .nav-actions--scrolled {
  display: flex;
}

/* Nav buttons */
.nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  padding: 7px 16px;
  border-radius: 9px;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background-color 0.2s, border-color 0.2s, opacity 0.2s;
  white-space: nowrap;
  line-height: 1;
  min-height: 44px;
}

.nav-btn--outline {
  background: transparent;
  border-color: var(--border, oklch(0.30 0.004 264 / 0.25));
  color: var(--text, oklch(0.97 0.002 264));
}

.nav-btn--outline:hover {
  background: var(--surface, oklch(0.22 0.004 264 / 0.08));
}

.nav-btn--solid {
  background: linear-gradient(135deg, var(--accent, oklch(0.55 0.22 260)), var(--accent-alt, oklch(0.65 0.18 210)));
  color: #fff;
  border: none;
}

.nav-btn--solid:hover {
  opacity: 0.88;
}

/* Mobile hamburger toggle */
.nav-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text, oklch(0.97 0.002 264));
  padding: 4px;
  position: relative;
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
}

.nav-toggle svg {
  position: absolute;
  inset: 10px;
  transition: opacity 0.2s, transform 0.2s;
}

.icon-menu  { opacity: 1; transform: rotate(0deg);    }
.icon-close { opacity: 0; transform: rotate(-180deg); }

.nav-shrink[data-open="true"] .icon-menu  { opacity: 0; transform: rotate(180deg); }
.nav-shrink[data-open="true"] .icon-close { opacity: 1; transform: rotate(0deg);   }

/* Mobile dropdown */
.nav-mobile {
  display: none;
  flex-direction: column;
  gap: 0;
  padding: 0 0 16px;
  border-top: 1px solid var(--border, oklch(0.30 0.004 264 / 0.25));
  margin-top: 4px;
}

.nav-mobile.open {
  display: flex;
}

.nav-mobile ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  padding: 12px 0 16px;
  gap: 2px;
}

.nav-mobile ul a {
  display: block;
  color: var(--muted, oklch(0.67 0.005 264));
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  padding: 10px 4px;
  transition: color 0.15s;
  min-height: 44px;
  display: flex;
  align-items: center;
}

.nav-mobile ul a:hover {
  color: var(--text, oklch(0.97 0.002 264));
}

.nav-mobile__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.nav-mobile__actions .nav-btn {
  width: 100%;
  padding: 11px 16px;
  font-size: 14px;
  border-radius: 10px;
}

/* Responsive breakpoints */
@media (max-width: 1024px) {
  .nav-shrink__links { display: none; }
  .nav-toggle { display: flex; }
  .nav-actions--default,
  .nav-actions--scrolled { display: none !important; }
}

@media (min-width: 1025px) {
  .nav-mobile { display: none !important; }
  .nav-toggle { display: none; }
}

/* ============================================================
   HERO — Staggered Spring Entrance
   ============================================================ */
.hero {
  padding-top: 5rem; /* Offset for fixed nav */
  background: var(--bg, var(--color-surface));
}

/* Hero overrides for v2 */
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  border-radius: 100px;
  background: var(--accent-soft, oklch(0.55 0.22 260 / 0.10));
  border: 1px solid var(--accent-border, oklch(0.55 0.22 260 / 0.20));
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--accent, oklch(0.55 0.22 260));
  margin-bottom: 24px;
  width: fit-content;
}

/* Spring entrance animations — gated on prefers-reduced-motion */
@media (prefers-reduced-motion: no-preference) {
  @keyframes dropIn {
    from { opacity: 0; transform: translateY(-50px); }
    to   { opacity: 1; transform: translateY(0);     }
  }

  @keyframes riseIn {
    from { opacity: 0; transform: translateY(30px); }
    to   { opacity: 1; transform: translateY(0);    }
  }

  .hero-badge {
    animation: riseIn 0.6s var(--spring) both;
    animation-delay: 0ms;
  }

  .hero h1 {
    animation: riseIn 0.6s var(--spring) both;
    animation-delay: 200ms;
  }

  .hero-blurb {
    animation: riseIn 0.6s var(--spring) both;
    animation-delay: 250ms;
  }

  .hero-actions {
    animation: riseIn 0.6s var(--spring) both;
    animation-delay: 300ms;
  }
}

/* ============================================================
   GRADIENT SHINE BUTTON
   ============================================================ */
.btn-gradient-shine {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 32px;
  border-radius: 16px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  color: #fff;
  text-decoration: none;
  min-height: 44px;
  background: linear-gradient(135deg, var(--accent, oklch(0.55 0.22 260)), var(--accent-alt, oklch(0.65 0.18 210)));
  box-shadow:
    inset 0px 2.4px 1.2px 0px rgba(255,255,255,0.25),
    inset 0px 1.2px 1.2px 0px rgba(0,0,0,0.10),
    inset 0px -2.4px 0px 0px rgba(0,0,0,0.10),
    inset 0px 0px 9.6px 4.8px rgba(255,255,255,0.16),
    0px 8px 20px -4px var(--accent-glow, oklch(0.55 0.22 260 / 0.28));
  transition:
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.35s;
}

.btn-gradient-shine::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -80%;
  width: 60%;
  height: 200%;
  background: rgba(255,255,255,0.20);
  filter: blur(6px);
  transform: rotate(-30deg);
  mix-blend-mode: screen;
  transition: left 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
}

.btn-gradient-shine:hover {
  transform: translateY(-2px);
  box-shadow:
    inset 0px 2.4px 1.2px 0px rgba(255,255,255,0.25),
    inset 0px 1.2px 1.2px 0px rgba(0,0,0,0.10),
    inset 0px -2.4px 0px 0px rgba(0,0,0,0.10),
    inset 0px 0px 9.6px 4.8px rgba(255,255,255,0.16),
    0px 14px 32px -4px var(--accent-glow, oklch(0.55 0.22 260 / 0.28));
}

.btn-gradient-shine:hover::after {
  left: 120%;
}

.btn-gradient-shine:active {
  transform: translateY(0) scale(0.98);
}

/* Outline secondary button */
.btn-outline-v2 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 16px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  border: 2px solid var(--border, oklch(0.30 0.004 264 / 0.25));
  background: transparent;
  color: var(--text, oklch(0.97 0.002 264));
  text-decoration: none;
  min-height: 44px;
  cursor: pointer;
  transition:
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    background-color 0.2s,
    border-color 0.2s;
}

.btn-outline-v2:hover {
  transform: translateY(-2px);
  background: var(--accent-soft, oklch(0.55 0.22 260 / 0.10));
  border-color: var(--accent-border, oklch(0.55 0.22 260 / 0.20));
}

/* ============================================================
   SCROLL REVEAL — viewport-spring-reveal
   ============================================================ */
@media (prefers-reduced-motion: no-preference) {
  [data-reveal] {
    opacity: 0;
    transform: translateY(28px);
    transition:
      opacity  0.55s cubic-bezier(0.22, 1, 0.36, 1),
      transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
  }

  [data-reveal].revealed {
    opacity: 1;
    transform: translateY(0);
  }

  /* Stagger children */
  [data-stagger] > * {
    opacity: 0;
    transform: translateY(20px);
    transition:
      opacity  0.45s cubic-bezier(0.22, 1, 0.36, 1),
      transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  }

  [data-stagger].revealed > *:nth-child(1)  { transition-delay: 0.06s; }
  [data-stagger].revealed > *:nth-child(2)  { transition-delay: 0.12s; }
  [data-stagger].revealed > *:nth-child(3)  { transition-delay: 0.18s; }
  [data-stagger].revealed > *:nth-child(4)  { transition-delay: 0.24s; }
  [data-stagger].revealed > *:nth-child(5)  { transition-delay: 0.30s; }
  [data-stagger].revealed > *:nth-child(6)  { transition-delay: 0.36s; }

  [data-stagger].revealed > * {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Always visible under reduced motion */
@media (prefers-reduced-motion: reduce) {
  [data-reveal],
  [data-stagger] > * {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
  }

  .hero-badge,
  .hero h1,
  .hero-blurb,
  .hero-actions {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .live-dot {
    animation: none;
  }
}

/* ============================================================
   EYEBROW LABEL
   ============================================================ */
.eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--accent, oklch(0.55 0.22 260));
  margin-bottom: 12px;
}

.eyebrow::after {
  content: '';
  display: block;
  width: 24px;
  height: 2px;
  background: var(--accent, oklch(0.55 0.22 260));
  margin-top: 6px;
  border-radius: 2px;
}

/* ============================================================
   LIVE DOT
   ============================================================ */
.live-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent, oklch(0.55 0.22 260));
  box-shadow: 0 0 0 0 var(--accent-glow, oklch(0.55 0.22 260 / 0.28));
  animation: livePulse 2s ease-in-out infinite;
  flex-shrink: 0;
  vertical-align: middle;
}

/* Override live-dot to green for Marietta Diner "open" semantics */
.live-dot--green {
  background: oklch(0.72 0.16 145);
  box-shadow: 0 0 0 0 oklch(0.72 0.16 145 / 0.30);
}

@keyframes livePulse {
  0%   { box-shadow: 0 0 0 0px var(--accent-glow, oklch(0.55 0.22 260 / 0.28)); }
  70%  { box-shadow: 0 0 0 8px rgba(0,0,0,0); }
  100% { box-shadow: 0 0 0 0px rgba(0,0,0,0); }
}

/* ============================================================
   GRADIENT CTA BANNER
   ============================================================ */
.cta-banner {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  padding: 4rem 2rem;
  background: linear-gradient(100deg, var(--accent, oklch(0.55 0.22 260)) 0%, var(--accent-alt, oklch(0.65 0.18 210)) 100%);
  text-align: center;
  margin-block: var(--space-16, 4rem);
}

/* Concentric circle SVG texture overlay */
.cta-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='28' fill='none' stroke='%23ffffff' stroke-width='1'/%3E%3Ccircle cx='30' cy='30' r='20' fill='none' stroke='%23ffffff' stroke-width='0.5'/%3E%3C/svg%3E");
  background-size: 60px 60px;
  opacity: 0.04;
  pointer-events: none;
}

/* Radial glow for dark pages */
.cta-banner--dark::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 50% at 20% 50%, rgba(255,255,255,0.06), transparent 70%);
  pointer-events: none;
}

.cta-banner__content {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin-inline: auto;
}

.cta-banner__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.80);
  margin-bottom: 16px;
  background: rgba(255,255,255,0.14);
  padding: 5px 14px;
  border-radius: 100px;
  border: 1px solid rgba(255,255,255,0.20);
}

.cta-banner h2 {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 12px;
  line-height: 1.2;
}

.cta-banner p {
  font-size: var(--text-lg, 1.125rem);
  color: rgba(255,255,255,0.88);
  margin-bottom: 28px;
  line-height: 1.6;
}

/* Floating icon badges inside CTA banner */
.cta-floating-badges {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.cta-float-icon {
  position: absolute;
  font-size: 2rem;
  opacity: 0.18;
}

.cta-float-icon:nth-child(1) { top: 15%; left: 8%;  animation: floatBadge 6s ease-in-out infinite; }
.cta-float-icon:nth-child(2) { top: 55%; left: 85%; animation: floatBadge 6s ease-in-out infinite 2s; }
.cta-float-icon:nth-child(3) { top: 70%; left: 15%; animation: floatBadge 6s ease-in-out infinite 4s; }

@keyframes floatBadge {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-12px); }
}

/* Hide floating badges on mobile */
@media (max-width: 640px) {
  .cta-floating-badges { display: none; }
  .cta-banner { padding-bottom: 7rem; } /* Clear Safari toolbar */
}

/* ============================================================
   BRAND WATERMARK FOOTER
   ============================================================ */
.footer-v2 {
  position: relative;
  overflow: hidden;
  background: var(--dark, var(--light, var(--color-surface)));
  padding-block: 4rem;
}

/* Light pages */
.footer-v2--light {
  background: var(--light, oklch(0.96 0.003 260));
}

/* Dark pages */
.footer-v2--dark {
  background: var(--dark, oklch(0.12 0.003 300));
}

.footer-v2__top {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.footer-v2__brand {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text, var(--color-ink));
}

.footer-v2__contact {
  font-style: normal;
  font-size: var(--text-sm, 0.875rem);
  color: var(--muted, var(--color-ink-muted));
  line-height: 1.8;
  text-align: right;
}

.footer-v2__contact a {
  color: var(--text, var(--color-ink));
  text-decoration: none;
  min-height: 44px;
  display: inline-block;
  padding-block: 4px;
}

.footer-v2__divider {
  border: none;
  border-top: 1px solid var(--border, oklch(0.20 0.005 260 / 0.12));
  margin-bottom: 1.5rem;
}

.footer-v2__bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  font-size: var(--text-xs, 0.75rem);
  color: var(--muted, var(--color-ink-muted));
}

/* Giant wordmark watermark */
.footer-wordmark {
  position: absolute;
  bottom: -0.5rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-display);
  font-size: clamp(4rem, 15vw, 10rem);
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: -0.04em;
  color: var(--accent, oklch(0.55 0.22 260));
  opacity: 0.06;
  pointer-events: none;
  user-select: none;
  aria-hidden: true;
}

.footer-v2--dark .footer-wordmark {
  opacity: 0.08;
}

/* ============================================================
   V2 HERO OVERRIDE — preserve background gradient properly
   ============================================================ */

/* Dark body background fix — prevent white bleed */
body[data-mode="dark"] {
  background: var(--bg, oklch(0.09 0.002 300));
}

body[data-mode="dark"] .hero {
  background: var(--bg, oklch(0.09 0.002 300));
}

body[data-mode="dark"] .trust {
  background: var(--dark, oklch(0.12 0.003 300));
}

body[data-mode="dark"] .services {
  background: var(--dark, oklch(0.12 0.003 300));
}

body[data-mode="dark"] .about {
  background: var(--bg, oklch(0.09 0.002 300));
}

body[data-mode="dark"] .testimonials {
  background: var(--dark, oklch(0.12 0.003 300));
}

body[data-mode="dark"] .contact {
  background: var(--bg, oklch(0.09 0.002 300));
}

/* Light body background */
body[data-mode="light"] {
  background: var(--bg, oklch(0.98 0.002 260));
}

body[data-mode="light"] .hero {
  background: linear-gradient(135deg, var(--bg, oklch(0.98 0.002 260)) 0%, var(--light, oklch(0.96 0.003 260)) 100%);
}

body[data-mode="light"] .services {
  background: var(--light, oklch(0.96 0.003 260));
}

body[data-mode="light"] .testimonials {
  background: var(--light, oklch(0.96 0.003 260));
}

/* ============================================================
   TRUST PILLS — V2 Glass variant
   ============================================================ */
.trust-pill-v2 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--g-bg-s, oklch(0.98 0.004 260 / 0.88));
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--g-border, oklch(0.45 0.010 260 / 0.16));
  border-radius: var(--radius-pill, 9999px);
  padding: 8px 18px;
  font-size: var(--text-sm, 0.875rem);
  font-weight: 600;
  color: var(--text, var(--color-ink));
  white-space: nowrap;
  flex-shrink: 0;
  box-shadow: var(--g-shadow, 0 2px 16px oklch(0.20 0.010 260 / 0.08), 0 1px 3px oklch(0.20 0.010 260 / 0.04));
}

/* ============================================================
   SERVICE CARD — V2 Glass variant
   ============================================================ */
.service-card-v2 {
  padding: var(--space-8, 2rem);
}

.service-card-v2 h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg, 1.125rem);
  font-weight: 600;
  color: var(--text, var(--color-ink));
  margin-bottom: var(--space-2, 0.5rem);
}

.service-card-v2 p {
  font-size: var(--text-sm, 0.875rem);
  color: var(--muted, var(--color-ink-muted));
  line-height: 1.6;
}

/* ============================================================
   FORM — Glass input variant
   ============================================================ */
.form-group input,
.form-group textarea {
  font-size: 16px; /* Safari iOS — prevent auto-zoom */
  min-height: 44px;
}

/* ============================================================
   SECTION SPACING — V2 Overrides
   ============================================================ */
.section-v2 {
  padding-block: var(--space-16, 4rem);
}

/* ============================================================
   AMBIENT BACKGROUND BLOBS — Desktop only
   ============================================================ */
.ambient-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}

.ambient-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.25;
}

/* Hide ambient blobs on mobile */
@media (max-width: 1024px) {
  .ambient-bg { display: none; }
}

/* ============================================================
   TESTIMONIAL CARD — V2 left accent bar
   ============================================================ */
.testimonial-card-v2 {
  border-left: 3px solid var(--accent, oklch(0.55 0.22 260));
  padding: var(--space-6, 1.5rem);
}

.testimonial-card-v2 blockquote {
  font-style: italic;
  color: var(--text, var(--color-ink));
  line-height: 1.7;
  margin-bottom: var(--space-4, 1rem);
}

.testimonial-card-v2 .attribution {
  font-style: normal;
  font-weight: 600;
  font-size: var(--text-sm, 0.875rem);
  color: var(--muted, var(--color-ink-muted));
}

/* ============================================================
   INDEX PAGE V2
   ============================================================ */
.index-hero-v2 {
  padding-top: 5rem;
  min-height: 60vh;
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, var(--bg, oklch(0.98 0.002 280)) 0%, var(--light, oklch(0.96 0.003 280)) 100%);
}

.index-hero-v2__content {
  text-align: center;
  padding-block: var(--space-16, 4rem);
}

.index-hero-v2__heading {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  color: var(--text, var(--color-ink));
  max-width: 600px;
  margin-inline: auto;
  margin-bottom: var(--space-4, 1rem);
  line-height: 1.15;
}

.index-hero-v2__blurb {
  font-size: var(--text-lg, 1.125rem);
  color: var(--muted, var(--color-ink-muted));
  max-width: 52ch;
  margin-inline: auto;
  margin-bottom: var(--space-8, 2rem);
  line-height: 1.6;
}

/* Index card V2 */
.index-card-v2 {
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 0.75rem);
  padding: var(--space-6, 1.5rem);
}

.index-card-v2 .category-badge {
  display: inline-block;
  background: var(--accent-soft, oklch(0.55 0.24 280 / 0.10));
  color: var(--accent, oklch(0.55 0.24 280));
  font-size: var(--text-xs, 0.75rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: var(--radius-pill, 9999px);
  padding: 4px 12px;
  width: fit-content;
  border: 1px solid var(--accent-border, oklch(0.55 0.24 280 / 0.20));
}

.index-card-v2 h2 {
  font-family: var(--font-display);
  font-size: var(--text-xl, 1.25rem);
  font-weight: 600;
  color: var(--text, var(--color-ink));
  line-height: 1.3;
}

.index-card-v2 p {
  font-size: var(--text-sm, 0.875rem);
  color: var(--muted, var(--color-ink-muted));
  line-height: 1.6;
  flex: 1;
}

/* ============================================================
   ACCESSIBILITY — Focus rings
   ============================================================ */
.nav-btn:focus-visible,
.btn-gradient-shine:focus-visible,
.btn-outline-v2:focus-visible,
.nav-shrink__logo:focus-visible {
  outline: 2px solid var(--accent, oklch(0.55 0.22 260));
  outline-offset: 3px;
}
