/* ================================================================
 HELODESK v12 COMPLETE PACK
 - Navigation & page centering (via JS)
 - The Standard section refinements
 - Pricing section centering
 - Capabilities bar premium minimalist
 - Timeline comparison minimize & tighten
 - Global desktop alignment
 ================================================================ */

/* ===== GLOBAL DESKTOP ALIGNMENT ===== */
body.home-page section {
 max-width: 1400px;
 margin-left: auto;
 margin-right: auto;
 padding-left: 40px;
 padding-right: 40px;
}

@media (min-width: 1200px) {
 body.home-page section {
  max-width: 1200px;
  padding-left: 60px;
  padding-right: 60px;
 }
}

/* ===== THE STANDARD SECTION ===== */
body.home-page .standard-section {
 max-width: 1200px;
 margin: 80px auto;
 padding: 0 40px;
}

@media (min-width: 768px) {
 body.home-page .standard-section {
  padding: 0 60px;
 }
}

/* The Standard - White container curved edges */
body.home-page .standard-content-wrapper,
body.home-page .standard-container,
body.home-page .standard-box {
 border-radius: 24px;
 max-width: 900px;
 margin: 0 auto;
 padding: 60px 50px;
}

@media (min-width: 768px) {
 body.home-page .standard-content-wrapper,
 body.home-page .standard-container,
 body.home-page .standard-box {
  padding: 80px 70px;
 }
}

/* The Standard - Logo watermark opacity increase */
body.home-page .standard-logo-watermark,
body.home-page .standard-section .watermark-logo,
body.home-page .logo-background {
 opacity: 0.18 !important;
}

/* The Standard - Text color darker */
body.home-page .standard-section p,
body.home-page .standard-content-wrapper p,
body.home-page .standard-description {
 color: #666 !important;
 line-height: 1.7;
}

/* ===== PRICING SECTION ===== */
body.home-page .pricing-section {
 max-width: 1200px;
 margin: 80px auto;
 padding: 60px 40px;
}

@media (min-width: 768px) {
 body.home-page .pricing-section {
  padding: 80px 60px;
 }
}

/* Pricing cards container */
body.home-page .pricing-cards,
body.home-page .pricing-grid,
body.home-page .pricing-container {
 max-width: 1100px;
 margin: 0 auto;
 display: flex;
 justify-content: center;
 gap: 32px;
 padding: 40px 20px;
}

@media (min-width: 768px) {
 body.home-page .pricing-cards,
 body.home-page .pricing-grid,
 body.home-page .pricing-container {
  gap: 40px;
 }
}

/* ===== CAPABILITIES BAR (Premium Minimalist) ===== */
body.home-page .capabilities-bar {
 background: linear-gradient(to bottom, #f5f1ed 0%, #ede9e5 100%);
 padding: 48px 40px;
 margin: 0;
}

@media (min-width: 768px) {
 body.home-page .capabilities-bar {
  padding: 60px 40px;
 }
}

body.home-page .capabilities-container {
 max-width: 1400px;
 margin: 0 auto;
 display: flex;
 justify-content: center;
 align-items: center;
 gap: 64px;
 flex-wrap: wrap;
}

body.home-page .capability-item {
 display: flex;
 align-items: center;
 gap: 12px;
 flex-direction: row;
}

/* Remove dividers */
body.home-page .capability-divider,
body.home-page .capabilities-divider {
 display: none !important;
}

/* Capability text - Title Case, refined typography */
body.home-page .capability-text {
 font-size: 15px;
 font-weight: 500;
 letter-spacing: 0.02em;
 color: #2a2a2a;
 text-transform: none;
}

/* Capability icons - subtle opacity */
body.home-page .capability-icon {
 opacity: 0.85;
 font-size: 20px;
}

/* ===== TIMELINE COMPARISON (Minimize & Tighten) ===== */
body.home-page .timeline-section,
body.home-page .comparison-section {
 max-width: 1200px;
 margin: 60px auto;
 padding: 60px 40px;
}

@media (min-width: 768px) {
 body.home-page .timeline-section,
 body.home-page .comparison-section {
  padding: 80px 60px;
 }
}

/* Timeline headline - shorter, punchier */
body.home-page .timeline-headline,
body.home-page .comparison-headline h2 {
 font-size: 2.5rem;
 line-height: 1.2;
 margin-bottom: 60px;
 text-align: center;
}

@media (min-width: 768px) {
 body.home-page .timeline-headline,
 body.home-page .comparison-headline h2 {
  font-size: 3rem;
 }
}

/* Timeline cards - reduce padding 40% */
body.home-page .timeline-card,
body.home-page .comparison-card {
 padding: 18px 20px !important;
 margin-bottom: 24px;
 border-radius: 12px;
 box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

@media (min-width: 768px) {
 body.home-page .timeline-card,
 body.home-page .comparison-card {
  padding: 24px 28px !important;
 }
}

/* Timeline comparison columns - wider on desktop */
body.home-page .timeline-columns,
body.home-page .comparison-columns {
 display: grid;
 grid-template-columns: 1fr;
 gap: 40px;
 max-width: 1100px;
 margin: 0 auto;
}

@media (min-width: 768px) {
 body.home-page .timeline-columns,
 body.home-page .comparison-columns {
  grid-template-columns: 1fr 1fr;
  gap: 60px;
 }
}

/* Hide bottom taglines */
body.home-page .timeline-tagline,
body.home-page .comparison-footer,
body.home-page .timeline-bottom-text {
 display: none !important;
}

/* Timeline column boxes - softer shadows, rounded corners */
body.home-page .timeline-column,
body.home-page .comparison-column {
 background: white;
 border-radius: 20px;
 padding: 40px 30px;
 box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

@media (min-width: 768px) {
 body.home-page .timeline-column,
 body.home-page .comparison-column {
  padding: 50px 40px;
 }
}

/* ===== RESPONSIVE REFINEMENTS ===== */
@media (max-width: 767px) {
 body.home-page section {
  padding-left: 20px;
  padding-right: 20px;
 }

 body.home-page .capabilities-container {
  gap: 40px;
 }

 body.home-page .capability-text {
  font-size: 14px;
 }
}

/* ===== END v12 COMPLETE PACK ===== */

/* ============================================
 HELODESK v11.2 COMPLETE PACK
 All refinements and critical fixes
 Place this block at the VERY TOP of stylesheet
 ============================================ */


/* ============================================
 PART 1: ROOT ELEMENT FIX (GLOBAL)
 Minimal global reset - only html/body
 Required because scoped CSS can't fix root elements
 ============================================ */

html,
body {
 margin: 0 !important;
 padding: 0 !important;
}


/* ============================================
 PART 2: HOMEPAGE NAV POSITIONING
 Homepage-scoped - nav flush to top
 ============================================ */

body.home-page {
 padding-top: 90px !important;
}

body.home-page .site-header,
body.home-page nav {
 position: fixed !important;
 top: 0 !important;
 left: 0 !important;
 right: 0 !important;
 margin: 0 !important;
 z-index: 9999 !important;
}


/* ============================================
 PART 3: CAPABILITIES BAR ELEGANCE
 Homepage-scoped - premium refinement
 ============================================ */

body.home-page .capabilities-bar {
 background: linear-gradient(180deg, #f5f1ed 0%, #ede9e5 100%) !important;
 padding: 60px 0 !important;
 border-top: 1px solid rgba(90, 157, 157, 0.15) !important;
 border-bottom: 1px solid rgba(90, 157, 157, 0.15) !important;
}

body.home-page .capabilities-container {
 gap: 48px !important;
}

body.home-page .capability-item {
 gap: 12px !important;
 transition: transform 0.2s ease !important;
}

body.home-page .capability-item:hover {
 transform: translateY(-2px) !important;
}

body.home-page .capability-icon {
 font-size: 1.5rem !important;
 opacity: 0.9 !important;
}

body.home-page .capability-text {
 font-size: 0.875rem !important;
 font-weight: 600 !important;
 color: #1a1a1a !important;
 letter-spacing: 0.03em !important;
 text-transform: uppercase !important;
}

body.home-page .capability-divider {
 width: 1px !important;
 height: 32px !important;
 background: linear-gradient(
 180deg,
 transparent 0%,
 rgba(90, 157, 157, 0.3) 50%,
 transparent 100%
 ) !important;
}

@media (min-width: 900px) {
 body.home-page .capabilities-container {
  gap: 56px !important;
 }
}


/* ============================================
 PART 4: PRICING GOLD GLOW INTENSIFICATION
 Homepage-scoped - stronger champagne-gold glow
 ============================================ */

body.home-page .pricing-card.standard {
 box-shadow:
 0 24px 48px rgba(90, 157, 157, 0.25),
 0 0 120px rgba(245, 225, 180, 0.8),
 0 0 60px rgba(245, 225, 180, 0.6),
 inset 0 0 0 2px rgba(245, 225, 180, 0.3) !important;
}

body.home-page .pricing-card.standard:hover {
 box-shadow:
 0 28px 56px rgba(90, 157, 157, 0.3),
 0 0 140px rgba(245, 225, 180, 0.9),
 0 0 80px rgba(245, 225, 180, 0.7),
 inset 0 0 0 2px rgba(245, 225, 180, 0.4) !important;
 transform: translateY(-4px) !important;
}


/* ============================================
 END v11.2 COMPLETE PACK
 ============================================ */

:root {
  --bg: #f6f0e8;
  --bg-soft: #efe6db;
  --surface: #faf7f2;
  --surface-strong: #f2ebe3;
  --panel: rgba(255, 255, 255, 0.8);
  --border: rgba(90, 100, 112, 0.12);
  --border-strong: rgba(90, 100, 112, 0.22);
  --text: #2e2b28;
  --muted: #56524e;
  --accent: #c8b8a8;
  --accent-soft: #e8ddd3;
  --accent-sage: #7aadad;
  --accent-clay: #c8b8a8;
  --ink: #2e2b28;
  --shadow: 0 18px 50px rgba(90, 100, 112, 0.08);
  --brand-primary: #5f8487;
  --brand-primary-deep: #4f7073;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  overflow-x: clip;
  overflow-y: auto;
  width: 100%;
}
body {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: linear-gradient(180deg, #f6f0e8 0%, #eee3d8 100%);
  color: var(--text);
  position: relative;
  overflow-x: hidden;
  overflow-y: auto;
  min-height: 100vh;
  width: 100%;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body.home-page {
  padding-top: 80px;
}

img,
video {
  max-width: 100%;
  height: auto;
  display: block;
}

h1,
h2,
h3,
p,
li,
.section-intro,
.hero-text {
  overflow-wrap: anywhere;
  word-break: normal;
}

body::before,
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

body::before {
  background:
    radial-gradient(28% 24% at -6% 16%, rgba(255,255,255,0.82), rgba(255,255,255,0.16) 56%, transparent 74%),
    radial-gradient(30% 24% at 106% 18%, rgba(255,255,255,0.74), rgba(255,255,255,0.14) 56%, transparent 74%),
    radial-gradient(32% 26% at -10% 76%, rgba(200, 184, 168, 0.18), transparent 72%),
    radial-gradient(30% 24% at 110% 80%, rgba(122, 173, 173, 0.16), transparent 72%),
    radial-gradient(70% 50% at 50% 102%, rgba(255,255,255,0.58), rgba(255,255,255,0.06) 66%, transparent 76%);
  animation: edgeCloudDriftA 28s ease-in-out infinite alternate;
  opacity: 0.72;
  -webkit-mask-image: linear-gradient(90deg, rgba(0,0,0,0.96) 0%, rgba(0,0,0,0.55) 12%, rgba(0,0,0,0.06) 24%, rgba(0,0,0,0) 36%, rgba(0,0,0,0) 64%, rgba(0,0,0,0.06) 76%, rgba(0,0,0,0.55) 88%, rgba(0,0,0,0.96) 100%);
  mask-image: linear-gradient(90deg, rgba(0,0,0,0.96) 0%, rgba(0,0,0,0.55) 12%, rgba(0,0,0,0.06) 24%, rgba(0,0,0,0) 36%, rgba(0,0,0,0) 64%, rgba(0,0,0,0.06) 76%, rgba(0,0,0,0.55) 88%, rgba(0,0,0,0.96) 100%);
}

body::after {
  background:
    radial-gradient(24% 18% at 2% 34%, rgba(255,255,255,0.28), transparent 78%),
    radial-gradient(24% 18% at 98% 30%, rgba(255,255,255,0.24), transparent 78%),
    radial-gradient(38% 24% at 50% 108%, rgba(88, 76, 66, 0.08), transparent 72%),
    radial-gradient(20% 16% at 10% 88%, rgba(255,255,255,0.16), transparent 78%),
    radial-gradient(20% 16% at 92% 86%, rgba(255,255,255,0.14), transparent 78%);
  animation: edgeCloudDriftB 34s ease-in-out infinite alternate;
  opacity: 0.52;
  -webkit-mask-image: linear-gradient(90deg, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.42) 10%, rgba(0,0,0,0.04) 22%, rgba(0,0,0,0) 34%, rgba(0,0,0,0) 66%, rgba(0,0,0,0.04) 78%, rgba(0,0,0,0.42) 90%, rgba(0,0,0,0.9) 100%);
  mask-image: linear-gradient(90deg, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.42) 10%, rgba(0,0,0,0.04) 22%, rgba(0,0,0,0) 34%, rgba(0,0,0,0) 66%, rgba(0,0,0,0.04) 78%, rgba(0,0,0,0.42) 90%, rgba(0,0,0,0.9) 100%);
}

a { color: inherit; text-decoration: none; }

button, a, .surface-card, .info-card, .step-card, .comparison-card, .faq-item, .onboarding-panel, .proof-strip div {
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease, border-color 180ms ease, color 180ms ease;
}

body::selection {
  background: rgba(200, 184, 168, 0.28);
}

.page-shell {
  width: min(1220px, calc(100% - 32px));
  margin: 0 auto;
  padding: 28px 0 96px;
  position: relative;
}

main {
  display: grid;
  gap: 6px;
  position: relative;
}

main > section,
main > footer {
  content-visibility: visible;
  contain-intrinsic-size: auto;
}

main::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.32;
  background:
    linear-gradient(90deg, rgba(122, 173, 173, 0.06) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,0.08) 1px, transparent 1px),
    radial-gradient(34% 22% at 18% 18%, rgba(255,255,255,0.22), transparent 72%),
    radial-gradient(28% 18% at 82% 72%, rgba(122, 173, 173, 0.08), transparent 74%);
  background-size: 34px 34px, 34px 34px, auto, auto;
  background-position: 0 calc(var(--scroll-drift, 0px) * -0.35), calc(var(--scroll-drift, 0px) * 0.18) 0, center, center;
  mask-image: linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.3) 10%, rgba(0,0,0,0.85) 24%, rgba(0,0,0,0.85) 76%, rgba(0,0,0,0.3) 90%, transparent 100%);
}

.page-shell::before,
.page-shell::after {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  pointer-events: none;
}

.page-shell::before {
  width: 380px;
  height: 420px;
  top: 54px;
  left: -210px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 56% 42%, rgba(255,255,255,0.68), rgba(255,255,255,0.16) 48%, transparent 70%),
    radial-gradient(circle at 44% 58%, rgba(200, 184, 168, 0.18), transparent 72%);
  filter: blur(22px);
  opacity: 0.6;
  animation: shellCloudFloatA 22s ease-in-out infinite alternate;
}

.page-shell::after {
  width: 400px;
  height: 430px;
  top: 360px;
  right: -220px;
  left: auto;
  border-radius: 999px;
  background:
    radial-gradient(circle at 48% 46%, rgba(255,255,255,0.6), rgba(255,255,255,0.12) 52%, transparent 72%),
    radial-gradient(circle at 58% 56%, rgba(122, 173, 173, 0.14), transparent 74%);
  filter: blur(18px);
  opacity: 0.56;
  animation: shellCloudFloatB 26s ease-in-out infinite alternate;
}

@keyframes edgeCloudDriftA {
  0% { transform: translate3d(0, 0, 0) scale(1); opacity: 1; }
  100% { transform: translate3d(0, 14px, 0) scale(1.03); opacity: 0.92; }
}

@keyframes edgeCloudDriftB {
  0% { transform: translate3d(0, 0, 0) scale(1); opacity: 0.92; }
  100% { transform: translate3d(0, -12px, 0) scale(1.02); opacity: 1; }
}

@keyframes shellCloudFloatA {
  0% { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(14px, 16px, 0); }
}

@keyframes shellCloudFloatB {
  0% { transform: translate3d(0, 0, 0); }
  100% { transform: translate3d(-16px, 14px, 0); }
}

@media (prefers-reduced-motion: reduce) {
  body::before,
  body::after,
  .page-shell::before,
  .page-shell::after,
  .nav-cta::before,
  .primary::before,
  .hero-panel-orbit,
  .brand-world-section .editorial-image-card::after {
    animation: none;
  }

  main::before {
    background-position: 0 0, 0 0, center, center;
  }
}

.brand-logo,
.proof-chat-shot img,
.editorial-image-card img,
.proof-chat-shot-wide img {
  will-change: auto;
}

.site-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 6px 2px 20px;
  position: relative;
  z-index: 1;
  background: transparent;
  border: none;
  border-radius: 0;
  backdrop-filter: none;
  box-shadow: none;
}

body.home-page .site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  width: 100%;
  padding: 12px 40px;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.04);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body.home-page .site-header.scroll-down {
  transform: translateY(-100%);
}

body.home-page .site-header.scroll-up {
  transform: translateY(0);
}

body.home-page .site-nav.scroll-down {
  transform: translateY(-100%);
}

body.home-page .site-nav.scroll-up {
  transform: translateY(0);
}

body.home-page .brand-logo {
  width: 216px;
}

body.home-page .brand-logo-wrap {
  min-width: 216px;
}

.pattern-section {
  position: relative;
  overflow: hidden;
}

.pattern-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(90, 157, 157, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(90, 157, 157, 0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

.pattern-section > * {
  position: relative;
  z-index: 1;
}

.brand-lockup {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-left: 0;
  position: relative;
  min-width: 0;
}

.brand-logo {
  width: 154px;
  height: auto;
  display: block;
  position: relative;
  z-index: 1;
  background: transparent !important;
}

.brand-logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 154px;
  position: relative;
  padding: 4px 0;
  border-radius: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.brand-logo-wrap::before {
  content: none;
}

nav {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  background: rgba(255,255,255,0.5);
  border: 1px solid rgba(90, 100, 112, 0.08);
  border-radius: 999px;
  padding: 5px;
  min-width: 0;
}

body.home-page .site-nav {
  margin-left: auto;
  gap: 40px;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
}

body.home-page .site-nav .nav-cta {
  margin-left: 24px;
}

.site-nav {
  min-width: 0;
}

body.home-page .site-header,
body.demo-page .site-header {
  justify-content: flex-start;
  gap: clamp(24px, 4vw, 52px);
}

body.home-page .site-nav,
body.demo-page .site-nav {
  align-self: center;
}

body.home-page .site-nav a,
body.demo-page .site-nav a {
  white-space: nowrap;
}

body.home-page .site-nav .nav-cta,
body.demo-page .site-nav .nav-cta {
  margin-left: 6px;
}

.nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex-direction: column;
  min-width: 44px;
  min-height: 44px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(58, 50, 43, 0.08);
  background: rgba(255,255,255,0.66);
  color: var(--ink);
  box-shadow: 0 10px 22px rgba(90, 100, 112, 0.06);
}

.nav-toggle span {
  width: 18px;
  height: 1.5px;
  border-radius: 999px;
  background: currentColor;
  transition: transform 180ms ease, opacity 180ms ease;
}

.nav-toggle[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(5.5px) rotate(45deg);
}

.nav-toggle[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}

.nav-toggle[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-5.5px) rotate(-45deg);
}

nav a {
  padding: 10px 13px;
  border-radius: 999px;
  font-size: 14px;
  letter-spacing: 0.01em;
}

nav a:not(.nav-cta):hover {
  background: rgba(122, 173, 173, 0.05);
}

nav a:hover,
.secondary:hover {
  color: var(--ink);
}

.nav-cta, .primary, .secondary {
  border-radius: 999px;
  padding: 14px 20px;
  transition: 180ms ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  white-space: normal;
}

.nav-cta, .primary {
  background: var(--brand-primary);
  color: #FFFFFF;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.03em;
  border-radius: 100px;
  padding: 14px 32px;
  border: none;
  box-shadow: 0 4px 16px rgba(95,132,135,0.30);
  position: relative;
  overflow: hidden;
}

.nav-cta::before,
.primary::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, transparent 18%, rgba(255,255,255,0.22) 32%, transparent 46%);
  transform: translateX(-135%);
  animation: buttonSheen 6.8s ease-in-out infinite;
}

.nav-cta {
  box-shadow: 0 4px 16px rgba(95,132,135,0.30);
}

@media (min-width: 769px) {
  .book-button {
    position: relative;
    overflow: hidden;
    background: var(--brand-primary) !important;
    color: #fff !important;
    font-weight: 600;
    font-size: 15px;
    letter-spacing: 0.03em;
    border-radius: 100px;
    box-shadow: 0 4px 16px rgba(95,132,135,0.30);
  }

  .nav-cta.book-button,
  .primary.book-button {
    min-height: 46px;
    padding: 14px 32px;
  }

  .book-button::before {
    content: none;
  }

  .book-button::after {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 60%;
    height: 100%;
    background: linear-gradient(120deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.25) 50%, rgba(255,255,255,0) 100%);
    animation: shine 3s ease-in-out infinite;
    pointer-events: none;
  }
}

@keyframes shine {
  0% { left: -100%; }
  40% { left: 150%; }
  100% { left: 150%; }
}

@media (min-width: 769px) {
  .nav-cta.book-button,
  .primary.book-button {
    background: var(--brand-primary) !important;
    box-shadow: 0 4px 16px rgba(95,132,135,0.30) !important;
  }

  .hero::before {
    background: #FAF9F7;
    border: 0;
    box-shadow: none;
  }

  .proof-panel {
    background:
      radial-gradient(58% 52% at 82% 18%, rgba(123, 168, 169, 0.12), transparent 62%),
      radial-gradient(36% 28% at 18% 82%, rgba(200, 184, 168, 0.10), transparent 68%),
      linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,244,239,0.88));
    border-color: rgba(122, 173, 173, 0.16);
    box-shadow: 0 22px 54px rgba(90, 100, 112, 0.08);
  }

  .hero-panel-orbit {
    filter: blur(10px);
    opacity: 0.9;
  }

  .live-flow-card {
    background:
      radial-gradient(54% 44% at 78% 18%, rgba(123, 168, 169, 0.10), transparent 64%),
      linear-gradient(180deg, rgba(255,255,255,0.90), rgba(247,243,238,0.84));
  }

  .live-flow-item {
    background: rgba(255,255,255,0.72);
    border-color: rgba(122, 173, 173, 0.10);
  }

  .flow-step-label,
  .live-flow-metrics span {
    background: rgba(255,255,255,0.84);
    border-color: rgba(122, 173, 173, 0.12);
  }

  .flow-graphic .section-side-shell {
    background:
      radial-gradient(58% 48% at 82% 18%, rgba(123, 168, 169, 0.16), transparent 62%),
      radial-gradient(38% 28% at 18% 82%, rgba(200, 184, 168, 0.12), transparent 70%),
      linear-gradient(180deg, rgba(255,255,255,0.94), rgba(241,247,246,0.78));
    border: 1px solid rgba(122, 173, 173, 0.10);
  }

  .flow-graphic-path-glow {
    stroke: rgba(122, 173, 173, 0.82);
    stroke-width: 3;
    stroke-dasharray: 10 14;
    animation-duration: 5.8s;
  }

  .flow-electron {
    filter: drop-shadow(0 0 10px rgba(122, 173, 173, 0.38));
  }

  .flow-aura {
    opacity: 0.82;
    filter: blur(14px);
    animation-duration: 8.6s;
  }

  .cta-section {
    background:
      radial-gradient(54% 56% at 22% 18%, rgba(255,255,255,0.12), transparent 62%),
      radial-gradient(44% 42% at 78% 82%, rgba(200, 184, 168, 0.12), transparent 60%),
      linear-gradient(135deg, #4d5963 0%, #698d92 56%, #7ba8a9 100%);
    box-shadow: 0 26px 64px rgba(77, 89, 99, 0.16);
  }

  .cta-section::before {
    background: linear-gradient(180deg, rgba(255,255,255,0.08), transparent 28%, rgba(255,255,255,0.03));
  }
}

.secondary {
  border: 1px solid var(--border-strong);
  color: var(--text);
  background: rgba(255,255,255,0.45);
}

.primary:hover,
.nav-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(79, 112, 115, 0.22);
}

.secondary:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,0.72);
  box-shadow: 0 10px 24px rgba(90, 100, 112, 0.08);
}

.hero {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 34px;
  align-items: start;
  padding: 20px 0 34px;
  position: relative;
  isolation: isolate;
}

.hero::before {
  content: "";
  position: absolute;
  inset: -34px -28px -22px -28px;
  border-radius: 56px;
  background:
    radial-gradient(92% 130% at 50% 2%, rgba(58, 50, 43, 0.16), transparent 48%),
    radial-gradient(34% 30% at 24% 28%, rgba(200, 184, 168, 0.14), transparent 70%),
    radial-gradient(34% 30% at 76% 26%, rgba(122, 173, 173, 0.14), transparent 70%),
    radial-gradient(88% 76% at 50% 100%, rgba(255,255,255,0.82), rgba(255,255,255,0.18) 62%, transparent 76%),
    linear-gradient(180deg, rgba(255,255,255,0.34), rgba(255,255,255,0.12));
  border: 1px solid rgba(33, 34, 38, 0.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.5), 0 26px 70px rgba(90, 100, 112, 0.08);
  z-index: 0;
}

.hero-grid {
  align-items: center;
}

.hero-copy,
.hero-panel,
.proof-strip,
.content-section,
.comparison-grid,
.cta-section,
.site-footer {
  position: relative;
  z-index: 1;
  min-width: 0;
}

.capability-section {
  background:
    radial-gradient(36% 28% at 14% 18%, rgba(122, 173, 173, 0.14), transparent 72%),
    radial-gradient(28% 22% at 84% 82%, rgba(200, 184, 168, 0.16), transparent 72%),
    linear-gradient(180deg, rgba(239,248,246,0.74), rgba(251,246,239,0.64));
  position: relative;
  overflow: hidden;
}

body.home-page .five-jobs-section {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 80px calc(50vw - 50% + 40px);
}

.core-pain-section {
  background: linear-gradient(180deg, rgba(255,255,255,0.28), rgba(255,255,255,0.08));
}

.capability-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 22px;
  align-items: stretch;
}

.capability-card {
  min-height: 100%;
  position: relative;
  overflow: hidden;
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,244,238,0.9));
  border: 1px solid rgba(90, 100, 112, 0.1);
  border-top-width: 3px;
  box-shadow: 0 16px 38px rgba(90, 100, 112, 0.06);
}

.capability-card::before,
.capability-card::after {
  content: none;
}

.capability-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 2px;
  position: relative;
  z-index: 1;
}

.capability-card .surface-title {
  margin-bottom: 0;
  position: relative;
  z-index: 1;
}

.capability-pill {
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #6a7074;
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(90, 100, 112, 0.08);
}

.capability-card-icon,
.capability-card h3,
.capability-card p,
.capability-card-foot {
  position: relative;
  z-index: 1;
}

.capability-card-icon {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(244,240,235,0.9));
  border: 1px solid rgba(90, 100, 112, 0.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 10px 24px rgba(90, 100, 112, 0.06);
}

.capability-card-icon svg {
  width: 24px;
  height: 24px;
  stroke: #4b5962;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.capability-card h3 {
  margin-bottom: 0;
  color: #46525b;
}

.capability-card p {
  margin: 0;
}

.capability-card-foot {
  margin-top: auto;
  padding-top: 14px;
  font-size: 13px;
  color: #617078;
  border-top: 1px solid rgba(90, 100, 112, 0.08);
}

.capability-grid .capability-card:nth-child(1) {
  grid-column: 1 / span 4;
}

.capability-grid .capability-card:nth-child(2) {
  grid-column: 5 / span 4;
}

.capability-grid .capability-card:nth-child(3) {
  grid-column: 9 / span 4;
}

.capability-grid .capability-card:nth-child(4) {
  grid-column: 2 / span 5;
}

.capability-grid .capability-card:nth-child(5) {
  grid-column: 7 / span 5;
}

.capability-card-response {
  border-top-color: rgba(184, 155, 121, 0.46);
}

.capability-card-guidance,
.capability-card-feel {
  border-top-color: rgba(122, 173, 173, 0.42);
}

.capability-card-control {
  border-top-color: rgba(90, 100, 112, 0.28);
}

.capability-card-handoff {
  border-top-color: rgba(164, 140, 118, 0.38);
}

.capability-card-response .capability-card-icon,
.capability-card-handoff .capability-card-icon {
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,241,234,0.92));
}

.capability-card-guidance .capability-card-icon,
.capability-card-feel .capability-card-icon {
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(240,247,245,0.92));
}

.capability-card-feel .capability-card-icon svg,
.capability-card-guidance .capability-card-icon svg {
  stroke: #4d7a7d;
}

.symbol-icon {
  width: 54px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  margin-bottom: 18px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.92), rgba(255,255,255,0.54) 45%, rgba(255,255,255,0.18) 100%),
    linear-gradient(135deg, rgba(122, 173, 173, 0.2), rgba(200, 184, 168, 0.18));
  border: 1px solid rgba(90, 100, 112, 0.1);
  box-shadow: 0 10px 28px rgba(90, 100, 112, 0.08), inset 0 1px 0 rgba(255,255,255,0.7);
  position: relative;
}

.symbol-icon::after {
  content: "";
  position: absolute;
  inset: 9px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.34);
  opacity: 0.7;
}

.symbol-icon svg {
  width: 26px;
  height: 26px;
  stroke: var(--ink);
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.symbol-icon-reply {
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.94), rgba(255,255,255,0.58) 44%, rgba(255,255,255,0.18) 100%),
    linear-gradient(135deg, rgba(122, 173, 173, 0.24), rgba(122, 173, 173, 0.08));
}

.symbol-icon-flow {
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.94), rgba(255,255,255,0.56) 44%, rgba(255,255,255,0.18) 100%),
    linear-gradient(135deg, rgba(200, 184, 168, 0.24), rgba(122, 173, 173, 0.12));
}

.symbol-icon-control,
.symbol-icon-trust {
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.94), rgba(255,255,255,0.56) 44%, rgba(255,255,255,0.18) 100%),
    linear-gradient(135deg, rgba(200, 184, 168, 0.26), rgba(200, 184, 168, 0.08));
}

.trust-cards .info-card {
  position: relative;
  overflow: hidden;
}

.trust-cards .info-card::before {
  content: "";
  position: absolute;
  width: 180px;
  height: 120px;
  right: -58px;
  top: -38px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(122, 173, 173, 0.18), rgba(122, 173, 173, 0.03) 54%, transparent 70%);
  filter: blur(2px);
  pointer-events: none;
}

.trust-cards .info-card:nth-child(1) {
  background: linear-gradient(180deg, rgba(255,255,255,0.84), rgba(248,244,238,0.72));
}

.trust-cards .info-card:nth-child(2) {
  background: linear-gradient(180deg, rgba(251,250,247,0.88), rgba(240,247,245,0.76));
}

.trust-cards .info-card:nth-child(3) {
  background: linear-gradient(180deg, rgba(251,249,246,0.9), rgba(246,239,233,0.76));
}

.trust-cards .info-card:nth-child(1)::after,
.trust-cards .info-card:nth-child(2)::after,
.trust-cards .info-card:nth-child(3)::after {
  content: "";
  position: absolute;
  inset: auto 18px 16px auto;
  width: 82px;
  height: 34px;
  border-top: 1.4px solid rgba(122, 173, 173, 0.18);
  border-radius: 999px;
  opacity: 0.9;
  pointer-events: none;
}

.trust-cards .info-card:nth-child(2)::after {
  width: 96px;
  border-top-color: rgba(200, 184, 168, 0.24);
}

.trust-cards .info-card:nth-child(3)::after {
  width: 74px;
  border-top-color: rgba(122, 173, 173, 0.16);
}

.hero-copy {
  max-width: 600px;
}

body.home-page .hero-copy {
  max-width: none;
  padding: 42px 42px 38px;
  border-radius: 30px;
  background:
    radial-gradient(72% 72% at 14% 10%, rgba(255,255,255,0.12), transparent 46%),
    radial-gradient(44% 42% at 82% 18%, rgba(122, 173, 173, 0.20), transparent 54%),
    linear-gradient(160deg, #140f0d 0%, #1e1612 48%, #100c0a 100%);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 38px 88px rgba(20, 15, 12, 0.30);
  position: relative;
  overflow: hidden;
}

body.home-page .hero-copy::after {
  content: "";
  position: absolute;
  inset: auto -8% -28% auto;
  width: 260px;
  height: 220px;
  border-radius: 999px;
  background: radial-gradient(circle at 50% 50%, rgba(122, 173, 173, 0.20), transparent 70%);
  filter: blur(4px);
  pointer-events: none;
}

body.home-page .hero-copy::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), transparent 22%, rgba(0,0,0,0.10) 100%);
}

.hero-copy h1,
.hero-copy .hero-text,
.hero-copy .hero-actions,
.hero-copy .hero-points,
.hero-copy .comfort-note,
.hero-copy .hero-mini-note {
  position: relative;
  z-index: 1;
}


.eyebrow, .section-label, .panel-label, .step-number {
  color: #6f6257;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.60);
  border: 1px solid rgba(200, 184, 168, 0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.72);
  margin-bottom: 16px;
}

h1 {
  font-size: clamp(42px, 6vw, 78px);
  line-height: 0.96;
  margin: 14px 0 18px;
  letter-spacing: -0.045em;
  max-width: 11ch;
  text-wrap: balance;
}

h2 {
  font-size: clamp(32px, 4vw, 58px);
  margin: 12px 0 0;
  line-height: 1.04;
  letter-spacing: -0.04em;
  max-width: 13ch;
}

h3 {
  margin: 0 0 10px;
  font-size: 22px;
  line-height: 1.15;
}

.accent-gold {
  color: #b89b79;
}

.info-card p,
.step-card p,
.comparison-card p,
.editorial-copy-card p,
.onboarding-panel p,
.faq-item p {
  font-size: 16px;
  line-height: 1.6;
}

.hero-text, p, li, .section-intro {
  color: #566168;
  font-size: 18px;
  line-height: 1.62;
}

.hero-text,
.section-intro,
.live-flow-item p,
.proof-showcase-head p,
.action-note {
  color: #465158;
}

body.home-page .hero-copy h1 {
  color: #f7f0e8;
  max-width: 10ch;
}

body.home-page .hero-copy .eyebrow {
  color: rgba(247,240,232,0.72);
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.08);
}

body.home-page .hero-copy .hero-text,
body.home-page .hero-copy .action-note,
body.home-page .hero-copy .hero-mini-note {
  color: rgba(247,240,232,0.88);
}

body.home-page .hero-copy .primary.book-button {
  box-shadow: 0 16px 30px rgba(12, 12, 12, 0.22);
}

body.home-page .proof-showcase {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(38% 40% at 50% 46%, rgba(95, 132, 135, 0.28), transparent 48%),
    radial-gradient(28% 24% at 18% 22%, rgba(255,255,255,0.06), transparent 72%),
    radial-gradient(28% 24% at 82% 78%, rgba(200, 184, 168, 0.12), transparent 74%),
    linear-gradient(180deg, #171b1f 0%, #222931 100%);
  border-color: rgba(255,255,255,0.08);
  box-shadow: 0 26px 64px rgba(14, 17, 20, 0.28);
}

body.home-page .proof-showcase .section-label,
body.home-page .proof-showcase h2,
body.home-page .proof-showcase p,
body.home-page .proof-showcase .phone-float-card strong,
body.home-page .proof-showcase .phone-float-card span {
  color: rgba(247, 240, 232, 0.92);
}

body.home-page .proof-showcase .phone-device.phone-device-proof.phone-frame {
  filter: drop-shadow(0 0 42px rgba(95, 132, 135, 0.34));
}

body.home-page .proof-showcase .phone-device-shadow {
  opacity: 0.92;
  filter: blur(28px);
}

body.home-page .phone-proof-image-wrap {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: #0f1317;
}

body.home-page .phone-proof-image {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: top center;
}

.hero-mini-note {
  margin: 12px 0 0;
  max-width: 46ch;
  font-size: 15px;
  line-height: 1.6;
  color: #5a656c;
}

.hero-text,
.section-intro,
.editorial-copy-card p,
.comfort-note p {
  max-width: 60ch;
}

.action-note {
  margin: 2px 0 0;
  max-width: 60ch;
  font-size: 15px;
  line-height: 1.6;
  color: #516067;
}

.hero-signal-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 20px 0 0;
}

.hero-signal-pill {
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.48);
  border: 1px solid rgba(122, 173, 173, 0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.78);
  color: #485a61;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.01em;
}

body.home-page .hero-signal-pill {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.12);
  color: rgba(247,240,232,0.88);
  backdrop-filter: blur(10px);
}

.hero-signal-pill:hover {
  transform: none;
  box-shadow: none;
  border-color: rgba(122, 173, 173, 0.14);
}

.hero-actions {
  display: flex;
  gap: 14px;
  margin: 24px 0 18px;
  flex-wrap: wrap;
}

.live-flow-card {
  padding: 20px 20px 18px;
  position: relative;
  overflow: hidden;
}

.hero-proof-caption {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(0,0,0,0.08);
  color: rgba(26,26,26,0.68);
  font-size: 14px;
  line-height: 1.55;
}

.live-flow-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, transparent 12%, rgba(255,255,255,0.18) 30%, transparent 46%);
  transform: translateX(calc(var(--scroll-drift, 0px) * 0.06));
}

.live-flow-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.live-flow-track {
  --flow-step-1: 8%;
  --flow-step-2: 50%;
  --flow-step-3: 92%;
  position: relative;
  display: flex;
  align-items: center;
  margin: 0 0 18px;
  height: 28px;
}

.live-flow-track-line {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background-image: repeating-linear-gradient(90deg, rgba(90, 157, 157, 0.18) 0 7px, rgba(90, 157, 157, 0.05) 7px 14px);
  background-size: 18px 2px;
  animation: dashFlow 2s linear infinite;
}

.live-flow-track-ball {
  position: absolute;
  top: 50%;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.95), rgba(122, 173, 173, 0.92) 55%, rgba(95, 132, 135, 1) 100%);
  box-shadow: 0 0 0 5px rgba(95, 132, 135, 0.10), 0 0 16px rgba(95, 132, 135, 0.24);
  left: var(--flow-step-1);
  transform: translate(-50%, -50%);
  opacity: 0;
  animation: flowPath 4s ease-in-out infinite;
}

.live-flow-track-ball-a {
  animation-delay: 0s;
}

.live-flow-track-ball-b {
  animation-delay: 2s;
}

@keyframes flowPath {
  0% {
    left: var(--flow-step-1);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.92);
  }

  10% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }

  33% {
    left: var(--flow-step-2);
    opacity: 1;
  }

  66% {
    left: var(--flow-step-3);
    opacity: 1;
  }

  90% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }

  100% {
    left: var(--flow-step-1);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.92);
  }
}

@keyframes dashFlow {
  to {
    background-position: -18px 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .live-flow-track-line,
  .live-flow-track-ball {
    animation: none !important;
  }

  .live-flow-track-ball {
    opacity: 1;
    transform: translate(-50%, -50%);
  }

  .live-flow-track-ball-a {
    left: 28%;
  }

  .live-flow-track-ball-b {
    left: 66%;
  }
}

.live-flow-pulse {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #667b81;
}

.live-flow-pulse::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, #7aadad, #c8b8a8);
  box-shadow: 0 0 0 6px rgba(122, 173, 173, 0.08);
  animation: livePulse 2.2s ease-in-out infinite;
}

.live-flow-list {
  display: grid;
  gap: 12px;
}

.live-flow-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,0.5);
  border: 1px solid rgba(58, 50, 43, 0.06);
}

.flow-step-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  color: #6d797f;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1px solid rgba(122, 173, 173, 0.10);
}

.live-flow-item strong {
  display: block;
  margin: 2px 0 6px;
  font-size: 16px;
  line-height: 1.2;
}

.live-flow-item p {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
}

.live-flow-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.live-flow-metrics span {
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(58, 50, 43, 0.06);
  font-size: 13px;
  color: #53656c;
}

.hero-points {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 14px;
}

.hero-points li,
.comparison-card li,
.route-card li,
.onboarding-panel li {
  list-style: none;
  position: relative;
  padding-left: 18px;
}

.route-card ul,
.comparison-card ul,
.onboarding-panel ul {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.route-card li {
  padding-left: 22px;
  line-height: 1.45;
}

.hero-points li {
  padding: 14px 16px 14px 32px;
  border-radius: 18px;
  background: rgba(255,255,255,0.58);
  border: 1px solid rgba(33, 34, 38, 0.08);
  box-shadow: 0 10px 22px rgba(33, 34, 38, 0.04);
}

.hero-points li:nth-child(1) {
  background: linear-gradient(180deg, rgba(255,255,255,0.86), rgba(227, 212, 188, 0.34));
}

.hero-points li:nth-child(2) {
  background: linear-gradient(180deg, rgba(255,255,255,0.86), rgba(122, 173, 173, 0.22));
}

.hero-points li:nth-child(3) {
  background: linear-gradient(180deg, rgba(255,255,255,0.86), rgba(200, 184, 168, 0.24));
}

.hero-points li:nth-child(4) {
  background: linear-gradient(180deg, rgba(255,255,255,0.86), rgba(194, 187, 214, 0.22));
}

.hero-points li::before,
.comparison-card li::before,
.route-card li::before,
.onboarding-panel li::before {
  content: "•";
  position: absolute;
  left: 14px;
  top: 13px;
  color: #9e8865;
}

.route-card li::before,
.comparison-card li::before,
.onboarding-panel li::before {
  top: 0;
  left: 0;
}

.hero-panel,
.surface-card,
.info-card,
.step-card,
.faq-item,
.comparison-card,
.onboarding-panel {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 26px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  overflow: hidden;
  min-width: 0;
}

.surface-card::before,
.info-card::before,
.step-card::before,
.comparison-card::before,
.onboarding-panel::before {
  content: "";
  position: absolute;
  inset: auto -42px -54px auto;
  width: 180px;
  height: 120px;
  border-radius: 50%;
  pointer-events: none;
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.18), rgba(255,255,255,0.04) 50%, transparent 68%);
}

.info-card,
.step-card,
.comparison-card,
.faq-item,
.onboarding-panel {
  border-top: 3px solid rgba(200, 184, 168, 0.34);
}

.cards-section .info-card:nth-child(2),
.steps-grid .step-card:nth-child(2),
.comparison-grid .comparison-card:nth-child(2),
.summary-grid div:nth-child(2) {
  border-top-color: rgba(122, 173, 173, 0.42);
}

.cards-section .info-card:nth-child(3),
.steps-grid .step-card:nth-child(3),
.summary-grid div:nth-child(3) {
  border-top-color: rgba(200, 184, 168, 0.46);
}

.hero-panel {
  padding: 24px;
}

.proof-panel {
  background: linear-gradient(180deg, rgba(255,255,255,0.9), rgba(251,248,242,0.8));
  overflow: hidden;
  border: 1px solid rgba(122, 173, 173, 0.14);
  box-shadow: 0 18px 42px rgba(90, 100, 112, 0.08);
  position: relative;
}

body.home-page .proof-panel {
  background:
    radial-gradient(54% 44% at 78% 18%, rgba(123, 168, 169, 0.10), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(247,243,238,0.86));
  border-color: rgba(122, 173, 173, 0.10);
}

.hero-panel-orbit {
  position: absolute;
  width: 170px;
  height: 170px;
  border-radius: 999px;
  top: -38px;
  right: -34px;
  background:
    radial-gradient(circle at 42% 58%, rgba(122, 173, 173, 0.26), rgba(122, 173, 173, 0.08) 46%, transparent 66%),
    radial-gradient(circle at 58% 42%, rgba(200, 184, 168, 0.24), rgba(200, 184, 168, 0.06) 42%, transparent 64%);
  filter: blur(6px);
  pointer-events: none;
}

.proof-panel::after {
  content: "";
  position: absolute;
  width: 132px;
  height: 132px;
  border-radius: 999px;
  top: 22px;
  right: 34px;
  background:
    radial-gradient(circle at 40% 56%, rgba(122, 173, 173, 0.16), rgba(122, 173, 173, 0.04) 48%, transparent 66%),
    radial-gradient(circle at 60% 40%, rgba(200, 184, 168, 0.18), rgba(200, 184, 168, 0.04) 44%, transparent 66%);
  opacity: 0.9;
  pointer-events: none;
}

.hero-stack {
  display: grid;
  gap: 16px;
  margin-top: 14px;
}

.hero-proof-frame {
  display: grid;
  gap: 16px;
  margin-top: 14px;
}

.proof-panel:hover .hero-panel-orbit {
  transform: scale(1.03);
}

.hero-proof-row {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 16px;
}

.surface-card,
.info-card,
.step-card,
.faq-item,
.comparison-card,
.onboarding-panel {
  padding: 24px;
  box-shadow: 0 16px 40px rgba(90, 100, 112, 0.06);
}

.surface-card:hover,
.info-card:hover,
.step-card:hover,
.comparison-card:hover,
.faq-item:hover,
.onboarding-panel:hover,
.proof-strip div:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 44px rgba(90, 100, 112, 0.10);
  border-color: rgba(122, 173, 173, 0.22);
}

.surface-title {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #6e8f93;
  margin-bottom: 12px;
}

.surface-title::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  margin-right: 8px;
  vertical-align: middle;
  background: linear-gradient(135deg, #7aadad, #c8b8a8);
}

.chat-card {
  padding: 15px 16px;
  border-radius: 18px;
  line-height: 1.5;
  font-size: 15px;
  display: grid;
  gap: 8px;
}

.chat-card p {
  margin: 0;
}

.chat-card time {
  font-size: 12px;
  color: rgba(69, 73, 80, 0.58);
  justify-self: end;
}

.chat-card-label {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(69, 73, 80, 0.56);
}

.chat-card + .chat-card {
  margin-top: 12px;
}

.chat-card.user {
  background: rgba(17, 18, 20, 0.05);
  color: var(--text);
}

.chat-card.bot {
  background: linear-gradient(135deg, rgba(200, 184, 168, 0.18), rgba(141, 159, 146, 0.12));
  color: var(--ink);
}

.chat-card.system {
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(90, 100, 112, 0.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.chat-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.chat-chip {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(90, 100, 112, 0.08);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #54646c;
}

.summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.summary-grid div {
  background: rgba(255,255,255,0.64);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px 14px;
  min-height: 96px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.summary-grid div:nth-child(1) {
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(200, 184, 168, 0.3));
}

.summary-grid div:nth-child(2) {
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(122, 173, 173, 0.24));
}

.summary-grid div:nth-child(3) {
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(200, 184, 168, 0.18));
}

.summary-grid div:nth-child(4) {
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(194, 187, 214, 0.18));
}

.summary-grid strong {
  display: block;
  font-size: 30px;
  line-height: 1;
  margin-bottom: 10px;
  color: var(--ink);
}

.summary-grid span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.proof-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 8px 0 36px;
}

.proof-strip div {
  padding: 20px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.66), rgba(255, 255, 255, 0.34));
  border: 1px solid var(--border);
  border-radius: 22px;
  min-height: 116px;
  box-shadow: 0 12px 30px rgba(90, 100, 112, 0.04);
}

.proof-strip div:nth-child(1) {
  border-top: 3px solid rgba(200, 184, 168, 0.72);
  background: linear-gradient(180deg, rgba(255,255,255,0.72), rgba(227, 212, 188, 0.2));
}

.proof-strip div:nth-child(2) {
  border-top: 3px solid rgba(141, 159, 146, 0.72);
  background: linear-gradient(180deg, rgba(255,255,255,0.72), rgba(122, 173, 173, 0.16));
}

.proof-strip div:nth-child(3) {
  border-top: 3px solid rgba(201, 150, 127, 0.72);
  background: linear-gradient(180deg, rgba(255,255,255,0.72), rgba(200, 184, 168, 0.18));
}

.proof-strip div:nth-child(4) {
  border-top: 3px solid rgba(160, 145, 186, 0.58);
  background: linear-gradient(180deg, rgba(255,255,255,0.72), rgba(194, 187, 214, 0.16));
}


.proof-strip strong {
  display: block;
  font-size: 16px;
}

.proof-strip strong::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-right: 8px;
  background: linear-gradient(135deg, var(--accent-sage), var(--accent));
  vertical-align: middle;
}

.proof-strip span {
  display: block;
  color: var(--muted);
  margin-top: 6px;
}

.credibility-band {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 26px;
  align-items: start;
  padding: 28px 0;
}

.credibility-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.credibility-points div {
  padding: 20px 0 0;
  border-top: 1px solid rgba(58, 50, 43, 0.10);
}

.credibility-points strong,
.editorial-list strong {
  display: block;
  font-size: 16px;
  line-height: 1.35;
  color: var(--ink);
  margin-bottom: 8px;
}

.credibility-points span {
  display: block;
  font-size: 15px;
  line-height: 1.6;
  color: var(--muted);
}

.decision-surface {
  align-items: stretch;
}

.editorial-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 14px;
}

.editorial-list li {
  position: relative;
  padding-left: 18px;
  color: var(--muted);
}

.editorial-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: #7aa8a9;
}

.booking-trust-band {
  margin-top: 10px;
}

.booking-faq {
  margin-top: 10px;
}

.authority-strip {
  display: grid;
  gap: 18px;
  padding: 10px 0 4px;
}

.authority-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.authority-grid article {
  padding: 22px 24px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid rgba(58, 50, 43, 0.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.74), 0 14px 34px rgba(90, 100, 112, 0.05);
}

.authority-grid p {
  margin: 8px 0 0;
  color: #56636a;
}

.content-section {
  padding: 58px 0;
}

.service-clarity-section .cards-section {
  margin-top: 24px;
}

.section-split-head {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.95fr);
  gap: 30px;
  align-items: center;
  margin-bottom: 24px;
}

.section-split-copy {
  min-width: 0;
}

.section-side-graphic {
  min-width: 0;
}

.section-side-shell {
  position: relative;
  min-height: 170px;
  border-radius: 30px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,0.72), rgba(244,249,248,0.52));
  border: 1px solid rgba(122, 173, 173, 0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.76), 0 18px 38px rgba(83, 118, 123, 0.06);
}

.core-pain-section .section-intro {
  max-width: 58ch;
}

.pain-graphic .section-side-shell {
  background:
    radial-gradient(54% 44% at 18% 22%, rgba(255,255,255,0.34), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,0.78), rgba(248,242,237,0.60));
}

.pain-chart-shell {
  isolation: isolate;
  overflow: hidden;
  width: 100%;
}

.pain-graphic .section-side-shell::before {
  content: "";
  position: absolute;
  inset: 16px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.66), rgba(255,255,255,0.20)),
    linear-gradient(135deg, rgba(122,173,173,0.08), rgba(184,155,121,0.06));
  border: 1px solid rgba(122, 173, 173, 0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 10px 24px rgba(83, 118, 123, 0.04);
}

.pain-signal-stack,
.pain-signal-glow {
  position: absolute;
}

.pain-signal-stack {
  inset: 24px;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 18px;
}

.pain-signal-bar {
  position: relative;
  height: 18px;
  border-radius: 999px;
  overflow: hidden;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.34),
    0 8px 18px rgba(83, 118, 123, 0.08);
}

.pain-signal-bar::before,
.pain-signal-bar::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
}

.pain-signal-bar::before {
  background: linear-gradient(180deg, rgba(255,255,255,0.14), rgba(255,255,255,0));
}

.pain-signal-bar::after {
  width: 34%;
  inset: -45% auto -45% -42%;
  transform: translateX(-140%) skewX(-24deg);
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,0.12), rgba(255,255,255,0.74), rgba(255,255,255,0.12), rgba(255,255,255,0));
  opacity: 0;
  filter: blur(1px);
}

.pain-signal-bar-ideal {
  width: 85%;
  background: linear-gradient(90deg, rgba(122,173,173,0.96), rgba(162,203,199,0.74));
}

.pain-signal-bar-falloff {
  width: 52%;
  background: linear-gradient(90deg, rgba(184,155,121,0.82), rgba(214,198,176,0.54));
}

.pain-signal-glow {
  border-radius: 999px;
  filter: blur(18px);
  opacity: 0.5;
  z-index: 0;
}

.pain-signal-glow-a {
  inset: auto auto 40px 42px;
  width: 126px;
  height: 30px;
  background: rgba(122,173,173,0.18);
}

.pain-signal-glow-b {
  inset: auto auto 88px 42px;
  width: 110px;
  height: 26px;
  background: rgba(184,155,121,0.14);
}

.pain-signal-bar,
.pain-signal-glow {
  opacity: 0;
  transform: translateY(10px);
  transition:
    opacity 320ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.pain-chart-shell.is-chart-visible .pain-signal-bar,
.pain-chart-shell.is-chart-visible .pain-signal-glow {
  opacity: 1;
  transform: translateY(0);
}

.pain-chart-shell.is-chart-visible .pain-signal-bar::after {
  animation: painSignalFlash 3.4s cubic-bezier(0.22, 1, 0.36, 1) infinite;
}

.pain-chart-shell.is-chart-visible .pain-signal-bar-falloff::after {
  animation-delay: 0.22s;
}

.pain-grid {
  margin-top: 24px;
}

.pain-card {
  min-height: 100%;
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(255,255,255,0.52));
}

.pain-card h3 {
  max-width: 14ch;
}

.flow-graphic .section-side-shell {
  background:
    radial-gradient(48% 40% at 18% 18%, rgba(123, 188, 188, 0.13), transparent 66%),
    radial-gradient(40% 34% at 84% 22%, rgba(196, 168, 130, 0.08), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(244,248,247,0.84));
  border: 1px solid rgba(226, 232, 230, 0.9);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 10px 28px rgba(124, 144, 145, 0.06);
}

.flow-graphic-svg,
.flow-node,
.flow-aura {
  position: absolute;
}

.flow-graphic-dot {
  display: block;
  opacity: 0.95;
}

.flow-graphic-svg {
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.flow-graphic-path {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.flow-graphic-path-base {
  stroke: rgba(123, 188, 188, 0.3);
  stroke-width: 1.6;
}

.flow-graphic-path-glow {
  stroke: #7BBCBC;
  stroke-width: 1.6;
  stroke-dasharray: 6 4;
  animation: flowPathDrift 4.8s linear infinite;
  opacity: 1;
}

.flow-electron {
  fill: rgba(123, 188, 188, 0.96);
  stroke: rgba(255,255,255,0.92);
  stroke-width: 1;
  vector-effect: non-scaling-stroke;
  filter: drop-shadow(0 0 6px rgba(123, 188, 188, 0.28));
}

.flow-electron-b {
  fill: rgba(196, 168, 130, 0.9);
}

.flow-electron-c {
  fill: rgba(123, 188, 188, 0.76);
}

.flow-node {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(229, 234, 233, 0.98);
  box-shadow: 0 8px 20px rgba(124, 144, 145, 0.06);
}

.flow-node::before {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 999px;
  background: rgba(180,200,200,0.35);
  opacity: 1;
}

.flow-node::after {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: 22px;
  border: 1px solid rgba(235,239,238,0.95);
  opacity: 0.96;
  animation: flowNodePulse 4.8s ease-in-out infinite;
}

.flow-node-a { top: 27px; left: 11px; }
.flow-node-b { top: 45px; left: calc(50% - 29px); }
.flow-node-c { top: 81px; right: 9px; }

.flow-graphic-dot-a {
  fill: #7BBCBC;
}

.flow-graphic-dot-b {
  fill: #C4A882;
}

.flow-node-b::after {
  animation-delay: 0.9s;
}

.flow-node-c::after {
  animation-delay: 1.8s;
}

.flow-aura {
  border-radius: 999px;
  background: radial-gradient(circle at 50% 50%, rgba(122, 173, 173, 0.18), transparent 70%);
  filter: blur(10px);
  animation: flowAuraFloat 7.2s ease-in-out infinite;
}

.flow-aura-a {
  width: 120px;
  height: 120px;
  left: 8px;
  top: 8px;
}

.flow-aura-b {
  width: 116px;
  height: 116px;
  right: 6px;
  bottom: 2px;
  animation-delay: 1.4s;
}

.service-clarity-section .info-card {
  position: relative;
  overflow: hidden;
  padding-top: 84px;
  background: linear-gradient(180deg, rgba(255,255,255,0.82), rgba(255,255,255,0.56));
  min-height: 250px;
}

.service-clarity-section .info-card::before {
  content: none;
}

.service-clarity-section .info-card:nth-child(1)::after,
.service-clarity-section .info-card:nth-child(2)::after,
.service-clarity-section .info-card:nth-child(3)::after {
  position: absolute;
  top: 24px;
  left: 24px;
  min-width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(240, 248, 247, 0.96), rgba(255, 248, 241, 0.94));
  border: 1px solid rgba(122, 173, 173, 0.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.92), 0 10px 24px rgba(90, 100, 112, 0.06);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #4f5c66;
}

.service-clarity-section .info-card:nth-child(1)::after { content: "01"; }
.service-clarity-section .info-card:nth-child(2)::after { content: "02"; }
.service-clarity-section .info-card:nth-child(3)::after { content: "03"; }

.comparison-section .comparison-grid {
  margin-top: 24px;
}

.comparison-section {
  padding-top: 22px;
}

.comparison-section h2,
.service-clarity-section h2,
.onboarding-section h2 {
  max-width: 12ch;
}

.comparison-card {
  min-height: 100%;
}

.comparison-card ul {
  margin-top: 14px;
}

.faq-section {
  max-width: 980px;
}

.site-footer {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
  gap: 22px;
  margin-top: 20px;
  padding: 30px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255,255,255,0.48), rgba(255,255,255,0.20));
  border: 1px solid rgba(90, 100, 112, 0.08);
  box-shadow: 0 18px 44px rgba(90, 100, 112, 0.05);
}

.site-footer h3 {
  margin-bottom: 10px;
}

.site-footer p {
  margin: 0;
  max-width: 52ch;
}

.footer-links {
  display: grid;
  gap: 12px;
  align-content: start;
}

.footer-links a,
.footer-links span {
  display: inline-flex;
  align-items: center;
  min-height: 46px;
  padding: 0 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.58);
  border: 1px solid rgba(90, 100, 112, 0.08);
  color: #49555e;
}

.footer-links a:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,0.8);
}

main > section {
  position: relative;
}

main > section + section {
  margin-top: 18px;
}

.editorial-gallery {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 18px;
  margin: 0 0 18px;
  position: relative;
  z-index: 1;
  padding: 18px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255,255,255,0.36), rgba(255,255,255,0.14));
  border: 1px solid rgba(90, 100, 112, 0.08);
  box-shadow: 0 18px 44px rgba(90, 100, 112, 0.05);
}

.proof-chat-gallery {
  grid-template-columns: minmax(430px, 1.12fr) minmax(260px, 0.88fr);
  gap: 32px;
  padding: 28px;
  align-items: center;
}

.proof-showcase {
  display: grid;
  gap: 24px;
  margin: 0 0 18px;
  padding: 34px 28px 30px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255,255,255,0.36), rgba(255,255,255,0.14));
  border: 1px solid rgba(90, 100, 112, 0.08);
  box-shadow: 0 18px 44px rgba(90, 100, 112, 0.05);
}

.proof-showcase-head {
  display: grid;
  gap: 10px;
  justify-items: center;
  text-align: center;
}

.proof-showcase-head h2 {
  max-width: none;
  margin-top: 0;
}

.proof-showcase-head p {
  margin: 0;
  max-width: 34ch;
}

.refined-proof-shot {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(247,242,234,0.78));
}

.refined-proof-shot img {
  object-position: 50% 52%;
}

.proof-caption {
  margin: -6px auto 0;
  font-size: 14px;
  color: #766e68;
  text-align: center;
}

.editorial-image-card,
.editorial-copy-card {
  border-radius: 30px;
  overflow: hidden;
  border: 1px solid rgba(33, 34, 38, 0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.65), rgba(255,255,255,0.34));
  box-shadow: 0 22px 60px rgba(90, 100, 112, 0.08);
}

.editorial-image-card img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 100%;
  transition: transform 600ms ease;
}

.proof-chat-shot {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,0.88), rgba(247,242,234,0.74));
  border-radius: 30px;
  border: 1px solid rgba(33, 34, 38, 0.08);
  box-shadow: 0 22px 60px rgba(90, 100, 112, 0.08);
}

.proof-chat-shot img {
  width: min(100%, 410px);
  height: auto;
  min-height: 0;
  object-fit: contain;
  object-position: 50% 50%;
  border-radius: 28px;
  box-shadow: 0 24px 60px rgba(17, 18, 20, 0.12);
  background: rgba(255,255,255,0.74);
  padding: 8px;
}

.proof-chat-shot-wide {
  padding: 18px;
}

.proof-chat-shot-wide img {
  width: min(100%, 420px);
  height: auto;
  object-position: 50% 50%;
}

.phone-flip-stage {
  perspective: 1800px;
  perspective-origin: 50% 38%;
  overflow: visible;
}

.phone-device {
  position: relative;
  width: min(100%, 402px);
  margin: 0 auto;
  transform-style: preserve-3d;
  opacity: 0;
  transform:
    rotateX(var(--phone-rotate-x-base, 24deg))
    rotateY(var(--phone-rotate-y-base, -14deg))
    translateY(var(--phone-lift-base, 44px))
    scale(var(--phone-scale-base, 0.94));
  transition: transform 920ms cubic-bezier(0.16, 1, 0.3, 1), opacity 620ms ease;
  will-change: transform, opacity;
}

.phone-flip-stage.is-in-view .phone-device,
.phone-flip-stage.animated .phone-device {
  opacity: 1;
  transform:
    rotateX(var(--phone-rotate-x, 0deg))
    rotateY(var(--phone-rotate-y, 0deg))
    translateY(var(--phone-lift, 0px))
    scale(var(--phone-scale, 1));
}

.phone-device-shadow {
  position: absolute;
  inset: auto 8% -30px;
  height: 46px;
  border-radius: 999px;
  background: radial-gradient(circle at 50% 50%, rgba(31, 34, 38, 0.26), transparent 72%);
  filter: blur(16px);
  transform: translateZ(-60px);
  pointer-events: none;
}

.phone-device-frame {
  position: relative;
  padding: 12px;
  border-radius: 38px;
  background: linear-gradient(160deg, #1b1c20 0%, #282a2f 42%, #111214 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    inset 0 -2px 0 rgba(255,255,255,0.06),
    0 30px 58px rgba(17, 18, 20, 0.16);
}

.phone-device-frame::before {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 32px;
  border: 1px solid rgba(255,255,255,0.08);
  pointer-events: none;
}

.phone-device-hardware {
  position: absolute;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  min-width: 108px;
  height: 28px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(10, 11, 12, 0.92);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

.phone-speaker {
  width: 42px;
  height: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,0.18);
}

.phone-signal-dot,
.phone-camera-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(255,255,255,0.16);
}

.phone-camera-dot {
  background: radial-gradient(circle at 35% 35%, rgba(122, 173, 173, 0.85), rgba(37, 49, 61, 0.9));
}

.phone-device-screen {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  background: linear-gradient(180deg, #f7f4ef, #ebe4dc);
  min-height: 590px;
}

.phone-flip-stage .phone-device-screen::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(70% 50% at 50% 18%, rgba(255,255,255,0.06), transparent 52%),
    linear-gradient(180deg, rgba(10,11,12,0.98), rgba(18,20,22,0.95));
  opacity: 1;
  transform: scale(1);
  transition: opacity 380ms ease 220ms, transform 420ms ease 220ms;
  pointer-events: none;
  z-index: 3;
}

.phone-flip-stage.is-in-view .phone-device-screen::after,
.phone-flip-stage.animated .phone-device-screen::after {
  opacity: 0;
  transform: scale(1.015);
}

.phone-device-proof .phone-device-screen {
  min-height: 0;
}

body.home-page .phone-device-proof .phone-device-screen::after {
  opacity: 0 !important;
  transform: none !important;
}

.phone-device-screen-proof {
  padding: 0;
  overflow: hidden;
  isolation: isolate;
  background: #f1ebe3;
}

.phone-proof-image-wrap {
  position: relative;
  width: 100%;
  height: 100%;
}

.phone-proof-image-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0) 20%, rgba(255,255,255,0) 76%, rgba(0,0,0,0.06) 100%),
    radial-gradient(64% 30% at 50% 0%, rgba(255,255,255,0.18), transparent 70%);
}

.phone-proof-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 10%;
  padding: 0 !important;
  border-radius: 0 !important;
  background: none !important;
  filter: saturate(1.06) contrast(1.08);
}

.phone-device-screen img {
  display: block;
  width: 100%;
  height: auto;
  background: rgba(255,255,255,0.96);
  padding: 6px;
  border-radius: 28px;
  box-shadow: none;
}

.phone-device-proof .phone-device-screen::before,
.phone-device-chat .phone-device-screen::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(70% 60% at 50% 0%, rgba(255,255,255,0.28), transparent 62%),
    linear-gradient(180deg, rgba(122, 173, 173, 0.05), transparent 34%);
}

.phone-float-card {
  position: absolute;
  z-index: 3;
  display: grid;
  gap: 4px;
  max-width: 154px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(90, 100, 112, 0.10);
  box-shadow: 0 16px 28px rgba(90, 100, 112, 0.1);
  backdrop-filter: blur(14px);
}

.phone-float-card strong {
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #5e7c7f;
}

.phone-float-card span {
  font-size: 13px;
  line-height: 1.35;
  color: #555d63;
}

.phone-float-card-top {
  top: 86px;
  right: -58px;
}

.phone-float-card-bottom {
  bottom: 52px;
  left: -58px;
}

.iphone-demo-stage {
  padding: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.74), rgba(247,242,234,0.6));
}

.phone-device-chat {
  width: min(100%, 344px);
}

.phone-device-screen-chat {
  padding: 46px 12px 12px;
  aspect-ratio: 1179 / 2556;
  min-height: 0;
  display: flex;
  background:
    radial-gradient(80% 60% at 50% 0%, rgba(255,255,255,0.7), transparent 60%),
    linear-gradient(180deg, #f6f1ea 0%, #ece4da 100%);
}

.dm-thread-shell {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 100%;
  height: 100%;
}

.dm-thread-topbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,0.74);
  border: 1px solid rgba(90, 100, 112, 0.08);
}

.dm-thread-topbar-proof {
  margin: 0 4px 8px;
  background: rgba(255,255,255,0.9);
}

.dm-thread-topbar strong,
.dm-thread-topbar span {
  display: block;
}

.dm-thread-topbar strong {
  font-size: 14px;
}

.dm-thread-topbar span {
  font-size: 12px;
  color: #6a7075;
}

.dm-thread-avatar {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #7aadad, #c8b8a8);
  color: white;
  font-weight: 700;
}

.dm-thread-body {
  display: grid;
  gap: 10px;
  align-content: start;
  flex: 1 1 auto;
}

.dm-thread-body .chat-card.user {
  justify-self: end;
  max-width: 84%;
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(90, 100, 112, 0.08);
}

.dm-thread-body .chat-card.bot,
.dm-thread-body .chat-card.system {
  max-width: 88%;
}

.dm-thread-input {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(90, 100, 112, 0.08);
  color: #7a7f84;
}

.dm-thread-send {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #5a6470, #7aadad);
  color: white;
  font-size: 18px;
  line-height: 1;
}

body.demo-page .phone-device-chat {
  width: min(100%, 352px);
}

body.demo-page .dm-thread-shell {
  gap: 8px;
}

body.demo-page .dm-thread-topbar {
  padding: 9px 11px;
}

body.demo-page .dm-thread-avatar {
  width: 32px;
  height: 32px;
  border-radius: 11px;
}

body.demo-page .chat-card {
  padding: 13px 14px;
  font-size: 14px;
  line-height: 1.42;
  gap: 7px;
}

body.demo-page .chat-card-label,
body.demo-page .dm-thread-topbar span,
body.demo-page .chat-chip {
  font-size: 10px;
}

body.demo-page .chat-chip-row {
  gap: 6px;
}

body.demo-page .chat-chip {
  padding: 6px 9px;
}

body.demo-page .dm-thread-input {
  padding: 10px 12px;
}

body.demo-page .dm-thread-send {
  width: 32px;
  height: 32px;
  font-size: 16px;
}

.hero,
.content-section,
.cta-section,
.proof-showcase,
.editorial-gallery {
  position: relative;
}

.hero::after,
.cta-section::after,
body.landing-page .landing-calm-panel::after,
body.landing-page .landing-final-cta::after,
body.demo-page .content-section::after,
body.book-page .content-section::after {
  content: "";
  position: absolute;
  left: -4%;
  right: -4%;
  bottom: -42px;
  height: 110px;
  pointer-events: none;
  border-radius: 50%;
  background:
    radial-gradient(60% 120% at 50% 0%, rgba(255,255,255,0.24), transparent 62%),
    radial-gradient(42% 70% at 50% 22%, rgba(122, 173, 173, 0.08), transparent 68%);
  opacity: 0.75;
}

.hero::before,
body.landing-page .landing-proof-section::after,
body.demo-page .editorial-gallery::after,
body.book-page .booking-trust-band::after {
  content: "";
  position: absolute;
  width: 280px;
  height: 150px;
  right: -36px;
  top: 16px;
  border-radius: 50%;
  border-top: 1.4px solid rgba(122, 173, 173, 0.16);
  border-bottom: 1.2px solid rgba(200, 184, 168, 0.14);
  transform: rotate(-7deg);
  pointer-events: none;
  opacity: 0.8;
}

.editorial-image-card:hover img {
  transform: scale(1.02);
}

.image-collage-card {
  position: relative;
  overflow: visible;
}

.visual-inset-card {
  position: absolute;
  right: 22px;
  bottom: 22px;
  width: min(42%, 240px);
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(33, 34, 38, 0.08);
  box-shadow: 0 18px 44px rgba(17, 18, 20, 0.18);
  backdrop-filter: blur(10px);
}

.visual-inset-card img {
  width: 100%;
  height: 150px;
  object-fit: cover;
}

.wide-inset-card {
  width: min(46%, 280px);
}

.inset-caption {
  padding: 12px 14px 14px;
  font-size: 13px;
  letter-spacing: 0.02em;
  color: #4c545d;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,242,234,0.92));
}

.editorial-copy-card {
  padding: 30px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.proof-chat-copy {
  padding: 28px 30px;
}

.compact-proof-points {
  gap: 8px;
}

.compact-proof-points li {
  font-size: 14px;
}

.visual-story-band {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
  gap: 24px;
  margin: 16px 0 24px;
  position: relative;
  z-index: 1;
}

.visual-story-side {
  display: grid;
  gap: 24px;
}

.visual-montage-card,
.visual-caption-card {
  position: relative;
  overflow: hidden;
  border-radius: 34px;
  border: 1px solid rgba(33, 34, 38, 0.08);
  background: linear-gradient(180deg, rgba(255,255,255,0.56), rgba(255,255,255,0.18));
  box-shadow: 0 22px 56px rgba(90, 100, 112, 0.08);
}

.visual-montage-card {
  min-height: 280px;
}

.visual-primary-shot {
  min-height: 520px;
}

.visual-secondary-shot {
  min-height: 248px;
}

.portrait-shot img {
  object-position: center top;
}

.visual-montage-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.visual-overlay-copy {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  padding: 20px 22px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(18, 19, 24, 0.18), rgba(18, 19, 24, 0.74));
  color: #f7f2ea;
  backdrop-filter: blur(14px);
}

.visual-overlay-copy span {
  display: block;
  margin-bottom: 10px;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(247, 242, 234, 0.76);
}

.visual-overlay-copy strong {
  display: block;
  font-size: clamp(24px, 3.2vw, 34px);
  line-height: 1.04;
  letter-spacing: -0.03em;
  max-width: 12ch;
}

.compact-overlay strong {
  max-width: 14ch;
  font-size: clamp(22px, 2.8vw, 30px);
}

.visual-overlay-chip {
  position: absolute;
  top: 20px;
  left: 20px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.8);
  border: 1px solid rgba(255,255,255,0.42);
  color: #34424a;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.visual-caption-card {
  padding: 34px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: linear-gradient(180deg, rgba(255,255,255,0.88), rgba(247,242,234,0.74));
}

.visual-caption-card h3 {
  font-size: clamp(28px, 3.2vw, 38px);
  margin: 10px 0 12px;
  line-height: 1.06;
  letter-spacing: -0.04em;
}

.visual-caption-card p {
  margin: 0;
}

.visual-hero-panel .surface-card {
  padding: 0;
  overflow: hidden;
}

.visual-surface-card {
  min-height: 460px;
  position: relative;
}

.visual-surface-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.brand-world-section {
  margin-top: 8px;
}

.brand-world-section .editorial-image-card {
  position: relative;
}

.brand-world-section .editorial-image-card::after {
  content: "";
  position: absolute;
  inset: auto 20px 20px auto;
  width: 110px;
  height: 110px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 38% 58%, rgba(122, 173, 173, 0.20), transparent 54%),
    radial-gradient(circle at 60% 40%, rgba(200, 184, 168, 0.18), transparent 50%);
  filter: blur(2px);
  pointer-events: none;
}

.brand-world-section .editorial-copy-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.84), rgba(247,242,234,0.70));
}

.proof-gallery .editorial-copy-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.82), rgba(242, 235, 225, 0.76));
  border-color: rgba(122, 173, 173, 0.16);
}

.editorial-copy-card h3 {
  font-size: 32px;
  margin: 10px 0 12px;
}

.editorial-copy-card p {
  margin: 0;
}

.split-emphasis {
  border-top: 1px solid rgba(33, 34, 38, 0.08);
  border-bottom: 1px solid rgba(33, 34, 38, 0.08);
}

.split-section {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 28px;
  align-items: start;
}

.comparison-grid,
.cards-section,
.steps-grid {
  display: grid;
  gap: 24px;
}

.comparison-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.comparison-grid.comparison-highlight {
  padding: 18px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255,255,255,0.34), rgba(255,255,255,0.12));
  border: 1px solid rgba(90, 100, 112, 0.08);
  box-shadow: 0 18px 44px rgba(90, 100, 112, 0.05);
}

.cards-section,
.steps-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.book-page .hero-copy {
  max-width: none;
  padding: 42px 42px 38px;
  border-radius: 30px;
  background:
    radial-gradient(72% 72% at 14% 10%, rgba(255,255,255,0.10), transparent 46%),
    radial-gradient(44% 42% at 82% 18%, rgba(122, 173, 173, 0.18), transparent 54%),
    linear-gradient(160deg, #18120f 0%, #221914 50%, #130f0c 100%);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 34px 84px rgba(20, 15, 12, 0.20);
  position: relative;
  overflow: hidden;
}

body.book-page .hero-copy::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), transparent 22%, rgba(0,0,0,0.10) 100%);
}

body.book-page .hero-copy::after {
  content: "";
  position: absolute;
  inset: auto -8% -28% auto;
  width: 260px;
  height: 220px;
  border-radius: 999px;
  background: radial-gradient(circle at 50% 50%, rgba(122, 173, 173, 0.20), transparent 70%);
  filter: blur(4px);
  pointer-events: none;
}

body.book-page .hero-copy .eyebrow,
body.book-page .hero-copy h1,
body.book-page .hero-copy .hero-text,
body.book-page .hero-copy .hero-signal-row,
body.book-page .hero-copy .hero-actions,
body.book-page .hero-copy .action-note {
  position: relative;
  z-index: 1;
}

body.book-page .hero-copy .eyebrow,
body.book-page .hero-copy h1 {
  color: #f7f2ea;
}

body.book-page .hero-copy .hero-text,
body.book-page .hero-copy .action-note {
  color: rgba(247,240,232,0.82);
}

body.book-page .hero-signal-pill {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.12);
  color: rgba(247,240,232,0.88);
  backdrop-filter: blur(10px);
}

body.book-page .booking-hero-panel {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,241,235,0.94));
  border-color: rgba(122, 173, 173, 0.12);
  box-shadow: 0 20px 44px rgba(90, 100, 112, 0.08);
}

body.book-page .booking-hero-panel .panel-label {
  color: #7f6c59;
}

body.book-page .booking-hero-panel-simple .hero-panel-orbit,
body.book-page .booking-hero-panel-simple::after {
  display: none;
}

body.book-page .booking-live-flow-card {
  padding: 22px 22px 20px;
  background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(249,247,243,0.94));
  border: 1px solid rgba(58, 50, 43, 0.05);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 12px 28px rgba(90, 100, 112, 0.05);
}

body.book-page .booking-summary-card {
  display: grid;
  gap: 18px;
}

body.book-page .booking-notification-stack {
  display: grid;
  gap: 12px;
  margin-top: 2px;
}

body.book-page .booking-notification-card {
  position: relative;
  padding: 16px 18px;
  border-radius: 22px;
  background:
    radial-gradient(120% 120% at 14% 8%, rgba(255,255,255,0.92), transparent 42%),
    linear-gradient(180deg, rgba(255,252,248,0.98), rgba(247,238,229,0.94));
  border: 1px solid rgba(192, 170, 145, 0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 16px 34px rgba(90, 88, 80, 0.08);
  overflow: hidden;
}

body.book-page .booking-notification-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.42) 26%, transparent 58%);
  opacity: 0.62;
}

body.book-page .notification-card-request {
  margin-right: 24px;
  transform: rotate(-1.2deg);
}

body.book-page .notification-card-followup {
  margin-left: 16px;
  margin-right: 8px;
  transform: rotate(0.4deg);
  z-index: 2;
}

body.book-page .notification-card-tailored {
  margin-left: 28px;
  transform: rotate(1.2deg);
}

body.book-page .booking-notification-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #927a67;
}

body.book-page .booking-notification-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, #d8b488, #bb8f63);
  box-shadow: 0 0 0 4px rgba(214, 177, 132, 0.14);
}

body.book-page .booking-notification-card strong {
  display: block;
  margin-bottom: 6px;
  font-size: 16px;
  line-height: 1.32;
  color: #2e2926;
}

body.book-page .booking-notification-card p {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: #635d57;
}

body.book-page .booking-live-flow-card .hero-proof-caption {
  margin-top: 6px;
  color: rgba(26,26,26,0.66);
}

body.book-page .booking-proof-showcase {
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,245,241,0.88));
  border-color: rgba(0,0,0,0.06);
  box-shadow: 0 16px 36px rgba(90, 100, 112, 0.06);
}

body.book-page .booking-step-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

body.book-page .booking-step-card {
  padding: 26px 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(249,247,243,0.78));
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: 0 14px 34px rgba(90, 100, 112, 0.05);
}

body.book-page .booking-step-card .step-number {
  margin-bottom: 14px;
}

.booking-process-grid {
  margin-top: 8px;
}

.decision-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-self: stretch;
}

.decision-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  justify-content: space-between;
}

.decision-card .primary,
.decision-card .secondary {
  align-self: flex-start;
}

.booking-choice-section {
  align-items: stretch;
}

body.book-page .booking-choice-section {
  padding: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,245,241,0.86));
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: 0 16px 36px rgba(90, 100, 112, 0.06);
}

body.book-page .booking-choice-section .editorial-copy-card,
body.book-page .booking-choice-section .decision-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(249,247,243,0.78));
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: 0 14px 34px rgba(90, 100, 112, 0.05);
}

body.book-page .decision-card {
  padding: 28px 24px;
}

.muted-card {
  background: rgba(255,255,255,0.34);
}

.comparison-highlight {
  margin-top: 10px;
}

.trust-cards .info-card,
.framed-section .onboarding-panel {
  background: rgba(255,255,255,0.7);
}

.section-intro {
  max-width: 760px;
  margin-top: 14px;
}

.alt-section {
  background: linear-gradient(180deg, rgba(255,255,255,0.26), rgba(255,255,255,0.05));
  padding: 56px 32px;
  border-radius: 34px;
  border: 1px solid var(--border);
  box-shadow: 0 18px 48px rgba(90, 100, 112, 0.05);
}

.split-emphasis {
  background: linear-gradient(180deg, rgba(255,255,255,0.28), rgba(255,255,255,0.08));
  padding: 34px 34px;
  border-radius: 28px;
}

.split-lead-block,
.split-copy-block {
  min-width: 0;
}

.onboarding-section {
  display: grid;
  grid-template-columns: 1fr 0.8fr;
  gap: 22px;
  align-items: start;
}

.cta-section {
  text-align: center;
  padding: 64px 24px;
  margin: 18px 0 24px;
  background: linear-gradient(135deg, #48606b, #7aadad);
  color: #f7f2ea;
  border-radius: 34px;
  box-shadow: 0 28px 80px rgba(72, 96, 107, 0.24);
}

.cta-section p {
  max-width: 720px;
  margin: 12px auto 0;
  color: rgba(247, 242, 234, 0.78);
}

.center-actions {
  justify-content: center;
}

.cta-section .secondary {
  border-color: rgba(247, 242, 234, 0.2);
  color: #f7f2ea;
  background: transparent;
}

.cta-section .section-label,
.cta-section h2 {
  color: #f7f2ea;
  max-width: none;
}

.faq-section {
  display: grid;
  gap: 16px;
}

.compact-hero {
  padding-top: 18px;
}

.single-column-points {
  grid-template-columns: 1fr;
  max-width: 520px;
}

.flow-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 1100px) {
  body.book-page .booking-step-grid,
  body.demo-page .service-theme-grid {
    grid-template-columns: 1fr;
  }

  .flow-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .capability-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .capability-grid .capability-card:nth-child(1),
  .capability-grid .capability-card:nth-child(2),
  .capability-grid .capability-card:nth-child(3),
  .capability-grid .capability-card:nth-child(4),
  .capability-grid .capability-card:nth-child(5) {
    grid-column: auto;
  }
}

@media (max-width: 960px) {
  body.book-page .hero-copy {
    padding: 34px 28px 30px;
  }

  body.book-page .booking-choice-section {
    padding: 22px;
  }

  body.book-page .booking-summary-card {
    gap: 16px;
  }

  body.demo-page .service-theme-desk-card-main,
  body.demo-page .service-theme-desk-card-side {
    position: relative;
    inset: auto;
    width: 100%;
    min-width: 0;
  }

  body.demo-page .service-theme-shell {
    display: grid;
    gap: 14px;
    padding: 24px;
  }

  body.book-page .notification-card-request,
  body.book-page .notification-card-followup,
  body.book-page .notification-card-tailored,
  .landing-reception-item-top,
  .landing-reception-item-mid,
  .landing-reception-item-bottom {
    margin-left: 0;
    margin-right: 0;
    transform: none;
  }

  .landing-reception-toolbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .landing-reception-toolbar-minimal {
    align-items: flex-end;
  }

  .landing-reception-live-pill {
    white-space: normal;
  }

  .landing-conversion-shell {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .landing-conversion-divider {
    grid-auto-flow: column;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    width: 100%;
  }

  .landing-conversion-divider-line {
    width: 100%;
    height: 1px;
  }

  .landing-conversion-board-pill,
  .landing-conversion-outcome,
  .landing-conversion-path-node {
    justify-content: center;
    text-align: center;
  }

  .site-header,
  .hero,
  .hero-proof-row,
  .credibility-band,
  .split-section,
  .comparison-grid,
  .proof-strip,
  .editorial-gallery,
  .cards-section,
  .decision-grid,
  .credibility-points,
  .authority-grid,
  .steps-grid,
  .flow-grid,
  .onboarding-section,
  .site-footer {
    grid-template-columns: 1fr;
  }

  .site-header {
    align-items: start;
  }

  body.home-page .site-header,
  body.demo-page .site-header {
    gap: 20px;
  }

  .brand-lockup {
    flex-direction: row;
    align-items: center;
  }

  .brand-logo-wrap {
    min-width: 0;
  }

  .brand-logo {
    width: 148px;
  }

  nav {
    width: 100%;
    flex-wrap: wrap;
    gap: 12px;
  }

  .hero-actions {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .hero-actions .primary,
  .hero-actions .secondary,
  .nav-cta {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .hero-signal-row {
    flex-wrap: wrap;
    gap: 10px;
  }

  .hero-points,
  .summary-grid {
    grid-template-columns: 1fr;
  }

  .hero-points li {
    padding-right: 18px;
  }

  .credibility-band {
    gap: 18px;
  }

  h1, h2 {
    max-width: none;
  }
}

/* Page patterns */

body.home-page .hero::before {
  background:
    radial-gradient(18% 16% at 82% 18%, rgba(122, 173, 173, 0.10), transparent 72%),
    radial-gradient(20% 18% at 70% 78%, rgba(200, 184, 168, 0.08), transparent 74%),
    radial-gradient(86% 74% at 50% 100%, rgba(255,255,255,0.72), rgba(255,255,255,0.12) 62%, transparent 76%),
    linear-gradient(180deg, rgba(255,255,255,0.30), rgba(255,255,255,0.10));
}

@media (min-width: 769px) {
  body.home-page .hero::before {
    content: "";
    inset: -34px -28px -22px -28px;
    border-radius: 56px;
    background:
      radial-gradient(18% 16% at 82% 18%, rgba(122, 173, 173, 0.10), transparent 72%),
      radial-gradient(18% 18% at 16% 24%, rgba(200, 184, 168, 0.10), transparent 74%),
      linear-gradient(180deg, rgba(250,249,247,0.96), rgba(247,243,238,0.88));
  }

  body.home-page .proof-chat-shot-wide {
    padding: 22px;
    overflow: visible;
  }

  body.home-page .phone-device-proof {
    width: min(100%, 418px);
    opacity: 1;
    transform: none;
    transition: transform 600ms cubic-bezier(0.22, 1, 0.36, 1), opacity 600ms ease-out;
    will-change: transform, opacity;
  }

  body.home-page .phone-device-proof .phone-device-screen {
    min-height: 0;
  }

  body.home-page .phone-device-screen-proof {
    padding: 0;
    position: relative;
  }

  body.home-page .phone-float-card {
    opacity: 1;
    will-change: transform, opacity;
    backface-visibility: hidden;
  }

  body.home-page .phone-float-card-top {
    transform: none;
    transition: transform 400ms ease, opacity 400ms ease;
  }

  body.home-page .phone-float-card-bottom {
    transform: none;
    transition: transform 400ms ease, opacity 400ms ease;
  }

  body.home-page .faq-section {
    width: min(100%, 680px);
    max-width: 680px;
    margin: 72px auto 0;
    padding-top: 0;
  }

  body.home-page .faq-divider-row {
    width: 100%;
    gap: 24px;
    margin: 0 auto 40px;
  }

  body.home-page .faq-divider-row::before,
  body.home-page .faq-divider-row::after {
    background: linear-gradient(90deg, rgba(0,0,0,0.03), rgba(0,0,0,0.08));
    opacity: 1;
    animation: none;
  }

  body.home-page .faq-section .section-label {
    min-width: 160px;
    max-width: none;
    min-height: auto;
    padding: 10px 32px;
    background: rgba(250,249,247,1);
    color: #5e8b8c;
    border: 1px solid rgba(0,0,0,0.12);
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    font-weight: 500;
    letter-spacing: 0.12em;
  }

  body.home-page .faq-item {
    padding: 0 0 32px;
    margin: 0;
    background: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
  }

  body.home-page .faq-item:first-of-type {
    border-top: none;
  }

  body.home-page .faq-item + .faq-item {
    margin-top: 32px;
  }

  body.home-page .faq-question {
    padding: 0;
    font-size: 22px;
    font-weight: 600;
    line-height: 1.18;
    color: #2f3338;
  }

  body.home-page .faq-answer {
    padding: 8px 0 0;
  }

  body.home-page .faq-answer p {
    margin: 0;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.6;
    color: rgba(0,0,0,0.55);
  }
}

body.demo-page {
  background: linear-gradient(180deg, #f4efe8 0%, #e9f0ef 100%);
}

body.demo-page::before {
  background:
    radial-gradient(34% 28% at 16% 18%, rgba(122, 173, 173, 0.14), transparent 72%),
    radial-gradient(26% 22% at 84% 18%, rgba(200, 184, 168, 0.14), transparent 70%),
    radial-gradient(44% 26% at 50% 86%, rgba(255,255,255,0.60), transparent 70%);
}

body.demo-page .hero::before,
body.demo-page .alt-section,
body.demo-page .proof-gallery .editorial-copy-card {
  background:
    radial-gradient(34% 28% at 78% 24%, rgba(122, 173, 173, 0.16), transparent 68%),
    linear-gradient(180deg, rgba(255,255,255,0.44), rgba(255,255,255,0.14));
}

body.demo-page .surface-title,
body.demo-page .section-label,
body.demo-page .panel-label {
  color: #5f8f92;
}

body.demo-page .hero-copy {
  padding: 34px 34px 30px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(248,245,241,0.68));
  border: 1px solid rgba(58, 50, 43, 0.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 18px 38px rgba(90, 100, 112, 0.05);
}

body.demo-page .hero-copy .eyebrow {
  color: #6e6258;
  background: rgba(255,255,255,0.72);
  border-color: rgba(200, 184, 168, 0.18);
}

body.demo-page .hero-copy .hero-text {
  color: #455159;
}

body.demo-page .hero-copy .hero-mini-note {
  margin-top: 10px;
  color: #566169;
}

body.demo-page .demo-hero-explainer {
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,245,241,0.88));
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: 0 18px 38px rgba(90, 100, 112, 0.06);
}

body.demo-page .demo-hero-explainer-card {
  background:
    radial-gradient(54% 44% at 82% 18%, rgba(123, 168, 169, 0.12), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,245,241,0.88));
  border: 1px solid rgba(122, 173, 173, 0.10);
}

body.demo-page .demo-hero-explainer-card ul {
  display: grid;
  gap: 12px;
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
}

body.demo-page .demo-hero-explainer-card li {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(58, 50, 43, 0.05);
  color: var(--text);
}

body.demo-page .service-theme-section {
  padding-top: 52px;
}

body.demo-page .service-theme-shell {
  background:
    radial-gradient(58% 48% at 78% 18%, rgba(123, 168, 169, 0.16), transparent 62%),
    radial-gradient(42% 32% at 22% 84%, rgba(200, 184, 168, 0.14), transparent 68%),
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(244,249,248,0.76));
  border-color: rgba(122, 173, 173, 0.12);
  min-height: 220px;
}

body.demo-page .service-theme-orb {
  position: absolute;
  border-radius: 999px;
  filter: blur(4px);
}

body.demo-page .service-theme-orb-a {
  width: 128px;
  height: 128px;
  top: 18px;
  right: 24px;
  background: radial-gradient(circle at 50% 50%, rgba(122, 173, 173, 0.22), transparent 72%);
}

body.demo-page .service-theme-orb-b {
  width: 110px;
  height: 110px;
  left: 34px;
  bottom: 18px;
  background: radial-gradient(circle at 50% 50%, rgba(200, 184, 168, 0.24), transparent 72%);
}

body.demo-page .service-theme-desk-card {
  position: absolute;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(249,247,243,0.84));
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: 0 18px 36px rgba(90, 100, 112, 0.07);
}

body.demo-page .service-theme-desk-card-main {
  left: 24px;
  top: 26px;
  width: min(240px, calc(100% - 104px));
  padding: 20px 20px 18px;
}

body.demo-page .service-theme-kicker {
  display: inline-flex;
  margin-bottom: 10px;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #7c8b92;
}

body.demo-page .service-theme-desk-card-main strong {
  display: block;
  font-size: 22px;
  line-height: 1.12;
  color: var(--ink);
}

body.demo-page .service-theme-desk-card-side {
  right: 24px;
  bottom: 26px;
  display: grid;
  gap: 10px;
  padding: 18px;
  min-width: 158px;
}

body.demo-page .service-theme-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(122, 173, 173, 0.10);
  border: 1px solid rgba(122, 173, 173, 0.14);
  color: #5a6d73;
  font-size: 13px;
  letter-spacing: 0.04em;
}

body.demo-page .service-theme-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

body.demo-page .service-theme-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(249,247,243,0.80));
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: 0 14px 34px rgba(90, 100, 112, 0.05);
}

body.demo-page .demo-proof-showcase {
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,245,241,0.88));
  border-color: rgba(0,0,0,0.06);
  box-shadow: 0 16px 36px rgba(90, 100, 112, 0.06);
}

body.demo-page .demo-proof-showcase .proof-chat-shot {
  padding: 48px 28px 64px;
  background: #FCFBF9;
  border: 0;
  box-shadow: none;
}

body.demo-page .demo-proof-showcase .proof-showcase-head p {
  max-width: 38ch;
  color: #5a6167;
}

body.landing-page {
  background: linear-gradient(180deg, #f6f0e8 0%, #eadfd4 100%);
}

body.landing-page::after {
  background:
    radial-gradient(24% 20% at 18% 24%, rgba(200, 184, 168, 0.14), transparent 76%),
    radial-gradient(22% 18% at 82% 30%, rgba(122, 173, 173, 0.12), transparent 76%),
    radial-gradient(62% 30% at 50% 98%, rgba(255,255,255,0.42), transparent 76%);
}

body.landing-page .hero::before {
  background:
    radial-gradient(96% 136% at 50% 0%, rgba(58, 50, 43, 0.18), transparent 48%),
    radial-gradient(30% 24% at 22% 26%, rgba(200, 184, 168, 0.18), transparent 72%),
    radial-gradient(24% 22% at 78% 22%, rgba(122, 173, 173, 0.12), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,0.34), rgba(255,255,255,0.10));
}

body.landing-page .hero-copy h1 {
  max-width: 10ch;
}

body.landing-page .landing-hero {
  padding-bottom: 28px;
}

body.landing-page .landing-signal-panel .panel-label {
  color: #8f7961;
}

body.landing-page .landing-signal-panel-themed {
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,245,241,0.88));
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: 0 18px 40px rgba(90, 100, 112, 0.07);
}

.landing-live-card {
  position: relative;
  overflow: hidden;
  padding: 24px;
  background:
    radial-gradient(110% 100% at 100% 0%, rgba(184, 155, 121, 0.18), transparent 44%),
    radial-gradient(80% 70% at 0% 100%, rgba(122, 173, 173, 0.16), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,0.78), rgba(250,245,239,0.58));
  border: 1px solid rgba(184, 155, 121, 0.18);
  box-shadow: 0 24px 64px rgba(90, 100, 112, 0.10);
}

.landing-live-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(120deg, transparent 18%, rgba(255,255,255,0.22) 34%, transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,0.12), transparent 42%);
  transform: translateX(calc(var(--scroll-drift, 0px) * 0.18));
}

.landing-live-head,
.landing-live-core,
.landing-live-points,
.landing-reception-stack,
.landing-reception-caption {
  position: relative;
  z-index: 1;
}

.landing-live-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.landing-live-badge,
.landing-live-note,
.footer-trust-title {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.landing-live-badge {
  color: #f7f2ea;
  background: linear-gradient(135deg, #7aadad, #5a6470);
  box-shadow: 0 8px 20px rgba(90, 100, 112, 0.16);
}

.landing-reception-card {
  background:
    radial-gradient(74% 52% at 84% 16%, rgba(184, 155, 121, 0.18), transparent 54%),
    radial-gradient(64% 54% at 16% 88%, rgba(122, 173, 173, 0.18), transparent 56%),
    linear-gradient(180deg, rgba(255,255,255,0.94), rgba(248,244,238,0.82));
  border: 1px solid rgba(184, 155, 121, 0.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.86), 0 20px 46px rgba(90, 100, 112, 0.08);
}

.landing-reception-head {
  margin-bottom: 16px;
}

.landing-reception-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.landing-reception-toolbar-simple {
  align-items: center;
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(184, 155, 121, 0.10);
}

.landing-reception-toolbar-minimal {
  justify-content: flex-end;
  margin-bottom: 14px;
}

.landing-graphic-title {
  display: block;
  font-size: 19px;
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: #2e2926;
}

.landing-reception-live-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 13px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(116, 214, 150, 0.28), rgba(116, 214, 150, 0.18));
  border: 1px solid rgba(86, 191, 122, 0.42);
  color: #2f6a43;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 0 0 1px rgba(128, 228, 162, 0.10), 0 10px 24px rgba(80, 192, 118, 0.18), 0 0 18px rgba(112, 214, 145, 0.16);
}

.landing-reception-live-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, #98f1ae, #56c874);
  box-shadow: 0 0 0 4px rgba(115, 224, 151, 0.22), 0 0 12px rgba(107, 220, 145, 0.42);
}

.landing-reception-stack {
  display: grid;
  gap: 13px;
}

.landing-reception-item {
  padding: 17px 18px;
  border-radius: 22px;
  background:
    radial-gradient(120% 120% at 14% 8%, rgba(255,255,255,0.80), transparent 42%),
    linear-gradient(180deg, rgba(228, 247, 245, 0.99), rgba(211, 239, 236, 0.94));
  border: 1px solid rgba(122, 173, 173, 0.24);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.84), 0 16px 32px rgba(78, 88, 99, 0.08);
}

.landing-reception-item-top {
  margin-right: 26px;
  transform: rotate(-1.7deg);
}

.landing-reception-item-mid {
  margin-left: 16px;
  margin-right: 10px;
  transform: rotate(0.9deg);
}

.landing-reception-item-bottom {
  margin-left: 32px;
  transform: rotate(1.9deg);
}

.landing-reception-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #71878e;
}

.landing-reception-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, #88bbbb, #6f9ca2);
  box-shadow: 0 0 0 4px rgba(122, 173, 173, 0.12);
}

.landing-reception-item strong {
  display: block;
  margin-bottom: 6px;
  font-size: 16px;
  line-height: 1.3;
  color: #272320;
}

.landing-reception-item p {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: #5c686e;
}

.landing-reception-caption {
  margin-top: 16px;
  color: rgba(26,26,26,0.58);
  font-size: 13px;
}

.landing-signal-panel-conversion {
  background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(248,244,238,0.88));
}

.landing-conversion-card {
  background:
    radial-gradient(64% 52% at 82% 18%, rgba(122, 173, 173, 0.14), transparent 58%),
    radial-gradient(52% 40% at 18% 84%, rgba(200, 184, 168, 0.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(247,243,238,0.88));
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.84), 0 20px 46px rgba(90, 100, 112, 0.08);
}

.landing-conversion-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}

.landing-conversion-column {
  display: grid;
  gap: 14px;
}

.landing-conversion-column > strong {
  font-size: 24px;
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: #2f2925;
}

.landing-conversion-emblem {
  position: relative;
  width: 72px;
  height: 72px;
  border-radius: 999px;
}

.landing-conversion-emblem-negative {
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.66), rgba(244,236,229,0.28) 56%, transparent 72%);
}

.landing-conversion-emblem-positive {
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.72), rgba(220,241,238,0.30) 56%, transparent 72%);
}

.landing-conversion-emblem-orbit,
.landing-conversion-emblem-dot,
.landing-conversion-emblem-trail {
  position: absolute;
  inset: 0;
  margin: auto;
}

.landing-conversion-emblem-orbit {
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: 1.5px solid rgba(0,0,0,0.08);
}

.landing-conversion-emblem-orbit-faint {
  border-color: rgba(196, 166, 144, 0.42);
}

.landing-conversion-emblem-orbit-strong {
  border-color: rgba(122, 173, 173, 0.44);
}

.landing-conversion-emblem-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  top: 9px;
  left: 42px;
  right: auto;
  bottom: auto;
}

.landing-conversion-emblem-dot-negative {
  background: linear-gradient(180deg, #ddb3a0, #c98672);
  box-shadow: 0 0 0 4px rgba(214, 151, 126, 0.14);
}

.landing-conversion-emblem-dot-positive {
  background: linear-gradient(180deg, #97efae, #56c874);
  box-shadow: 0 0 0 4px rgba(114, 224, 150, 0.18), 0 0 10px rgba(107, 220, 145, 0.28);
}

.landing-conversion-emblem-trail {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border-top: 2px solid transparent;
  border-left: 2px solid transparent;
  transform: rotate(38deg);
  top: 12px;
  left: 14px;
  right: auto;
  bottom: auto;
}

.landing-conversion-emblem-trail-negative {
  border-right: 2px dashed rgba(201, 134, 114, 0.62);
  border-bottom: 2px dashed rgba(201, 134, 114, 0.18);
  opacity: 0.78;
}

.landing-conversion-emblem-trail-positive {
  border-right: 2px solid rgba(86, 200, 116, 0.82);
  border-bottom: 2px solid rgba(86, 200, 116, 0.42);
}

.landing-conversion-kicker {
  display: inline-flex;
  align-items: center;
  align-self: start;
  gap: 8px;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(184, 155, 121, 0.16);
  color: #8d7866;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.landing-conversion-signal-light {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  flex: 0 0 auto;
}

.landing-conversion-signal-light-negative {
  background: linear-gradient(180deg, #ef9a92, #d96d61);
  box-shadow: 0 0 0 4px rgba(223, 120, 108, 0.16), 0 0 10px rgba(223, 120, 108, 0.28);
}

.landing-conversion-kicker-negative {
  background: linear-gradient(180deg, rgba(252,246,240,0.94), rgba(244,234,226,0.88));
  border-color: rgba(184, 155, 121, 0.22);
  color: #8c725f;
}

.landing-conversion-kicker-live {
  gap: 8px;
  background: linear-gradient(180deg, rgba(118, 214, 151, 0.24), rgba(118, 214, 151, 0.14));
  border-color: rgba(86, 191, 122, 0.30);
  color: #366c48;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.78), 0 0 16px rgba(112, 214, 145, 0.12);
}

.landing-conversion-signal-light-positive {
  background: linear-gradient(180deg, #97efae, #56c874);
  box-shadow: 0 0 0 4px rgba(114, 224, 150, 0.18), 0 0 10px rgba(107, 220, 145, 0.34);
}

.landing-conversion-stack {
  display: grid;
  gap: 12px;
}

.landing-conversion-item {
  position: relative;
  padding: 16px 16px 15px;
  border-radius: 20px;
  border: 1px solid rgba(58, 50, 43, 0.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.80), 0 14px 28px rgba(90, 100, 112, 0.06);
}

.landing-conversion-item-label {
  display: inline-flex;
  margin-bottom: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.landing-conversion-item p {
  margin: 0;
  font-size: 14px;
  line-height: 1.52;
}

.landing-conversion-item-muted {
  background: linear-gradient(180deg, rgba(251,248,244,0.94), rgba(242,235,228,0.90));
  border-color: rgba(198, 180, 163, 0.18);
}

.landing-conversion-item-muted .landing-conversion-item-label {
  color: #9a8573;
}

.landing-conversion-item-muted p {
  color: #746a63;
}

.landing-conversion-item-active {
  background:
    radial-gradient(120% 120% at 14% 8%, rgba(255,255,255,0.80), transparent 42%),
    linear-gradient(180deg, rgba(230,247,245,0.98), rgba(211,239,236,0.94));
  border-color: rgba(122, 173, 173, 0.22);
}

.landing-conversion-item-active .landing-conversion-item-label {
  color: #628188;
}

.landing-conversion-item-active p {
  color: #526268;
}

.landing-conversion-divider {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 10px;
  padding: 6px 0;
}

.landing-conversion-divider-line {
  width: 1px;
  height: 48px;
  background: linear-gradient(180deg, rgba(184, 155, 121, 0.06), rgba(122, 173, 173, 0.18), rgba(184, 155, 121, 0.06));
}

.landing-conversion-divider-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(122, 173, 173, 0.16);
  color: #5d787f;
  font-size: 20px;
  box-shadow: 0 10px 20px rgba(90, 100, 112, 0.06);
}

.landing-conversion-caption {
  color: rgba(26,26,26,0.62);
}

.home-balance-bridge {
  background: linear-gradient(180deg, rgba(250,249,247,0.72), rgba(245,241,235,0.46));
}

.home-balance-conversion-section {
  display: grid;
  gap: 18px;
  justify-items: stretch;
}

.home-balance-conversion-section > h2,
.home-balance-conversion-section > .section-label {
  text-align: left;
}

.home-balance-conversion-card {
  padding: 24px;
}

.landing-conversion-board {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 24px;
  border: 1px solid rgba(58, 50, 43, 0.07);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 16px 32px rgba(90, 100, 112, 0.06);
}

.landing-conversion-board-before {
  background: linear-gradient(180deg, rgba(250,246,241,0.96), rgba(243,236,229,0.92));
  border-color: rgba(193, 173, 156, 0.18);
}

.landing-conversion-board-after {
  background: linear-gradient(180deg, rgba(236,248,246,0.98), rgba(220,241,238,0.94));
  border-color: rgba(122, 173, 173, 0.22);
}

.landing-conversion-board-top {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 20px;
}

.landing-conversion-board-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(177, 156, 139, 0.62);
}

.landing-conversion-board-top-live {
  justify-content: flex-start;
  flex-wrap: wrap;
}

.landing-conversion-board-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.70);
  border: 1px solid rgba(122, 173, 173, 0.18);
  color: #5c787f;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.landing-conversion-board-screen {
  display: grid;
  gap: 12px;
}

.landing-conversion-status-card {
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(58, 50, 43, 0.07);
}

.landing-conversion-status-card-muted {
  background: rgba(255,255,255,0.58);
}

.landing-conversion-status-label {
  display: inline-flex;
  margin-bottom: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #9a8573;
}

.landing-conversion-status-card strong {
  display: block;
  font-size: 18px;
  line-height: 1.2;
  color: #524740;
}

.landing-conversion-rails {
  display: grid;
  gap: 10px;
}

.landing-conversion-rail {
  display: block;
  height: 10px;
  border-radius: 999px;
}

.landing-conversion-rail-fade {
  background: linear-gradient(90deg, rgba(189, 170, 154, 0.56), rgba(189, 170, 154, 0.12));
}

.landing-conversion-rail.short {
  width: 72%;
}

.landing-conversion-outcome {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.landing-conversion-outcome-negative {
  background: rgba(255,255,255,0.60);
  border: 1px solid rgba(193, 173, 156, 0.20);
  color: #9b7d68;
}

.landing-conversion-outcome-positive {
  background: rgba(255,255,255,0.68);
  border: 1px solid rgba(122, 173, 173, 0.20);
  color: #56757c;
}

.landing-conversion-path-card {
  display: grid;
  gap: 10px;
}

.landing-conversion-path-node {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 16px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(122, 173, 173, 0.18);
  color: #486066;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.landing-conversion-path-node.active {
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 10px 20px rgba(122, 173, 173, 0.10);
}

.landing-conversion-path-link {
  width: 2px;
  height: 18px;
  margin: 0 auto;
  background: linear-gradient(180deg, rgba(122, 173, 173, 0.16), rgba(122, 173, 173, 0.54), rgba(122, 173, 173, 0.16));
  border-radius: 999px;
}

.landing-live-note,
.footer-trust-title {
  color: #8f7961;
  background: rgba(255,255,255,0.62);
  border: 1px solid rgba(184, 155, 121, 0.18);
}

.landing-live-core strong {
  display: block;
  font-size: 28px;
  line-height: 1.08;
  letter-spacing: -0.03em;
  max-width: 11ch;
}

.landing-live-core p {
  margin: 12px 0 0;
  max-width: 34ch;
}

.landing-live-points {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.landing-live-points span {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.66);
  border: 1px solid rgba(184, 155, 121, 0.14);
  color: #4f5c66;
  font-size: 14px;
}

body.landing-page .landing-proof-section,
body.landing-page .landing-calm-panel,
body.landing-page .landing-card-band,
body.landing-page .landing-final-cta {
  position: relative;
  overflow: hidden;
}

body.landing-page .landing-proof-section::before,
body.landing-page .landing-calm-panel::before,
body.landing-page .landing-card-band::before,
body.landing-page .landing-final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(34% 26% at 18% 22%, rgba(255,255,255,0.22), transparent 72%),
    radial-gradient(26% 20% at 82% 24%, rgba(122, 173, 173, 0.10), transparent 72%),
    radial-gradient(36% 24% at 50% 92%, rgba(200, 184, 168, 0.10), transparent 74%);
  opacity: 0.9;
}

body.landing-page .landing-calm-warm::before {
  background:
    radial-gradient(34% 30% at 18% 22%, rgba(200, 184, 168, 0.16), transparent 72%),
    radial-gradient(22% 18% at 80% 26%, rgba(255,255,255,0.26), transparent 72%),
    radial-gradient(42% 22% at 50% 100%, rgba(122, 173, 173, 0.08), transparent 74%);
}

body.landing-page .landing-calm-soft::before {
  background:
    radial-gradient(30% 24% at 16% 26%, rgba(255,255,255,0.24), transparent 72%),
    radial-gradient(24% 18% at 84% 22%, rgba(122, 173, 173, 0.08), transparent 70%),
    radial-gradient(44% 26% at 50% 96%, rgba(200, 184, 168, 0.08), transparent 74%);
}

body.landing-page .landing-calm-teal::before {
  background:
    radial-gradient(26% 22% at 18% 20%, rgba(122, 173, 173, 0.14), transparent 70%),
    radial-gradient(24% 18% at 82% 24%, rgba(255,255,255,0.18), transparent 70%),
    radial-gradient(44% 24% at 50% 100%, rgba(200, 184, 168, 0.08), transparent 74%);
}

body.landing-page .landing-calm-orbit::before {
  background:
    radial-gradient(22% 18% at 16% 24%, rgba(255,255,255,0.24), transparent 72%),
    radial-gradient(20% 16% at 84% 22%, rgba(122, 173, 173, 0.12), transparent 70%),
    radial-gradient(48% 26% at 50% 100%, rgba(122, 173, 173, 0.08), transparent 74%);
}

body.landing-page .landing-calm-grid::before {
  background:
    linear-gradient(90deg, rgba(255,255,255,0.08) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,0.06) 1px, transparent 1px),
    radial-gradient(28% 22% at 18% 22%, rgba(122, 173, 173, 0.10), transparent 70%),
    radial-gradient(40% 26% at 50% 100%, rgba(200, 184, 168, 0.08), transparent 74%);
  background-size: 32px 32px, 32px 32px, auto, auto;
}

body.landing-page .landing-calm-panel > *,
body.landing-page .landing-card-band > *,
body.landing-page .landing-proof-section > *,
body.landing-page .landing-final-cta > * {
  position: relative;
  z-index: 1;
}

body.landing-page .landing-card-band {
  padding: 24px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255,255,255,0.28), rgba(255,255,255,0.10));
  border: 1px solid rgba(90, 100, 112, 0.08);
  box-shadow: 0 18px 46px rgba(90, 100, 112, 0.05);
}

body.landing-page .landing-proof-section {
  margin-top: 8px;
}

body.landing-page .landing-proof-phone-section {
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,245,241,0.88));
  border-color: rgba(0,0,0,0.06);
  box-shadow: 0 16px 36px rgba(90, 100, 112, 0.06);
}

body.landing-page .landing-proof-phone-section .proof-showcase-head p {
  color: #5a6167;
}

body.landing-page .landing-proof-phone-section .proof-chat-shot {
  padding: 72px 190px;
  background: #FCFBF9;
  border: 0;
  box-shadow: none;
}

body.landing-page .landing-proof-phone-section .phone-device.phone-device-proof {
  width: 308px;
  max-width: 308px;
}

body.landing-page .landing-proof-phone-section .phone-device-screen,
body.landing-page .landing-proof-phone-section .phone-device-screen-proof {
  aspect-ratio: 1179 / 2556;
  min-height: 0;
  padding: 0;
  background: #000;
}

body.landing-page .landing-proof-phone-section .phone-proof-image-wrap::after,
body.landing-page .landing-proof-phone-section .phone-device-proof .phone-device-screen::before,
body.landing-page .landing-proof-phone-section .phone-device-proof .phone-device-screen::after {
  content: none;
  display: none;
}

body.landing-page .landing-proof-phone-section .phone-proof-image {
  object-position: 40% 38%;
  filter: saturate(1.02) contrast(1.03);
}

body.landing-page .landing-proof-phone-section .phone-float-card-top {
  top: 22%;
  left: calc(50% + 136px);
  right: auto;
  bottom: auto;
}

body.landing-page .landing-proof-phone-section .phone-float-card-bottom {
  top: 72%;
  left: calc(50% - 344px);
  right: auto;
  bottom: auto;
}

.proof-points {
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.proof-points li {
  position: relative;
  padding-left: 20px;
}

.proof-points li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: #7a908f;
}

.proof-note {
  margin-top: 16px;
  font-size: 14px;
  color: #66727a;
}

.real-proof-shot {
  background: linear-gradient(180deg, rgba(17, 15, 24, 0.94), rgba(38, 24, 58, 0.92));
}

.real-proof-shot img {
  object-fit: cover;
  object-position: center top;
}

@media (max-width: 980px) {
  body.landing-page .landing-proof-phone-section .proof-chat-shot {
    padding: 42px 24px 68px;
  }

  body.landing-page .landing-proof-phone-section .phone-device.phone-device-proof {
    width: min(100%, 286px);
    max-width: 286px;
  }

  body.landing-page .landing-proof-phone-section .phone-float-card-top {
    top: auto;
    bottom: -22px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
  }

  body.landing-page .landing-proof-phone-section .phone-float-card-bottom {
    display: none;
  }

  .visual-story-band {
    grid-template-columns: 1fr;
  }

  .visual-primary-shot,
  .visual-surface-card {
    min-height: 380px;
  }

  .visual-secondary-shot {
    min-height: 220px;
  }

  .visual-inset-card,
  .wide-inset-card {
    width: min(56%, 250px);
    right: 16px;
    bottom: 16px;
  }

  .visual-caption-card {
    padding: 28px;
  }

  .visual-overlay-copy {
    left: 16px;
    right: 16px;
    bottom: 16px;
    padding: 18px;
  }
}

.cta-proof-note {
  color: rgba(247, 242, 234, 0.72);
}

body.book-page {
  background: linear-gradient(180deg, #f7f2ea 0%, #efe7db 100%);
}

body.book-page::before {
  background:
    radial-gradient(24% 20% at 20% 20%, rgba(122, 173, 173, 0.10), transparent 74%),
    radial-gradient(18% 16% at 80% 22%, rgba(200, 184, 168, 0.10), transparent 72%),
    radial-gradient(60% 26% at 50% 92%, rgba(255,255,255,0.48), transparent 74%);
}

body.book-page .hero::before,
body.book-page .cta-section {
  background:
    radial-gradient(28% 26% at 72% 24%, rgba(122, 173, 173, 0.10), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,0.34), rgba(255,255,255,0.12));
}

body.book-page .cta-section {
  color: var(--text);
  box-shadow: 0 20px 52px rgba(90, 100, 112, 0.08);
}

body.book-page .cta-section p,
body.book-page .cta-section .section-label,
body.book-page .cta-section h2,
body.book-page .cta-section .secondary {
  color: var(--text);
}

body.book-page .cta-section .secondary {
  border-color: rgba(90, 100, 112, 0.14);
}

html {
  scroll-behavior: smooth;
}

body {
  transition: background 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

main {
  transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

body.is-transitioning main {
  opacity: 0.76;
  transform: translateY(8px);
}

.page-transition-layer {
  position: fixed;
  inset: 0;
  z-index: 60;
  pointer-events: none;
  transform: translateZ(0) scaleY(0);
  transform-origin: bottom;
  transition: transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
  background:
    radial-gradient(54% 44% at 50% 20%, rgba(122, 173, 173, 0.16), transparent 60%),
    radial-gradient(42% 32% at 60% 82%, rgba(200, 184, 168, 0.16), transparent 62%),
    linear-gradient(180deg, rgba(247, 242, 236, 0.92), rgba(239, 232, 223, 0.94));
}

body.is-transitioning .page-transition-layer {
  transform: translateZ(0) scaleY(1);
  transform-origin: top;
}

.page-shell {
  padding-top: 122px;
  max-width: 100%;
  overflow-x: clip;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 280ms cubic-bezier(0.22, 1, 0.36, 1), transform 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

body.is-ready .page-shell {
  opacity: 1;
  transform: translateY(0);
}

.site-loader {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  background:
    radial-gradient(44% 34% at 50% 40%, rgba(255,255,255,0.78), transparent 72%),
    linear-gradient(180deg, rgba(247, 242, 236, 0.96), rgba(239, 232, 223, 0.98));
  transition: opacity 260ms cubic-bezier(0.22, 1, 0.36, 1), visibility 0s linear 260ms;
}

body.is-ready .site-loader {
  opacity: 0;
  visibility: hidden;
}

.site-loader-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 212px;
  min-height: 84px;
  padding: 20px 26px;
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(58, 50, 43, 0.06);
  box-shadow: 0 14px 34px rgba(90, 100, 112, 0.08);
  backdrop-filter: blur(14px);
}

.site-loader-mark img {
  width: 168px;
  height: auto;
}

.site-header {
  position: fixed;
  top: 18px;
  left: 50%;
  width: min(1220px, calc(100% - 32px));
  padding: 14px 18px;
  border-radius: 26px;
  transform: translate3d(-50%, 0, 0);
  background: rgba(250, 245, 239, 0.74);
  border: 1px solid rgba(58, 50, 43, 0.06);
  backdrop-filter: blur(18px) saturate(1.04);
  box-shadow: 0 14px 34px rgba(90, 100, 112, 0.08);
  will-change: transform;
  backface-visibility: hidden;
  transition: transform 240ms cubic-bezier(0.22, 1, 0.36, 1), opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1), background 220ms cubic-bezier(0.22, 1, 0.36, 1);
  max-width: calc(100vw - 16px);
  overflow: clip;
  isolation: isolate;
  z-index: 48;
}

body.header-at-top .site-header {
  background: rgba(252, 248, 243, 0.98);
  box-shadow: 0 12px 28px rgba(90, 100, 112, 0.08);
}

body.header-scrolled .site-header {
  background: rgba(252, 248, 243, 0.82);
  box-shadow: 0 18px 40px rgba(90, 100, 112, 0.11);
}

body.header-hidden .site-header {
  opacity: 0;
  transform: translate3d(-50%, -140%, 0);
}

.brand-lockup {
  gap: 0;
}

.brand-logo {
  width: 148px;
}

.brand-logo-wrap {
  min-width: 148px;
  padding: 2px 0;
}

.brand-logo-wrap::before {
  inset: -8px -12px;
  opacity: 0.64;
}

nav {
  gap: 18px;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
}

nav a {
  padding: 8px 0;
  border-radius: 0;
  font-size: 14px;
  letter-spacing: 0.01em;
  position: relative;
}

nav a:not(.nav-cta)::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -3px;
  height: 1px;
  background: linear-gradient(90deg, rgba(122, 173, 173, 0), rgba(122, 173, 173, 0.6), rgba(122, 173, 173, 0));
  opacity: 0;
  transform: translateY(3px);
  transition: opacity 180ms ease, transform 180ms ease;
}

nav a:not(.nav-cta):hover {
  background: transparent;
}

nav a:not(.nav-cta):hover::after {
  opacity: 1;
  transform: translateY(0);
}

.nav-cta,
.primary,
.secondary {
  padding: 13px 20px;
}

.nav-cta,
.primary {
  background: linear-gradient(135deg, #4d5963, #7ba8a9);
  box-shadow: 0 12px 26px rgba(77, 89, 99, 0.14);
}

.secondary {
  border: none;
  background: transparent;
  color: #46525b;
  padding-left: 4px;
  padding-right: 4px;
}

.secondary::after {
  content: "↗";
  margin-left: 8px;
  font-size: 13px;
  opacity: 0.7;
}

.secondary:hover {
  background: transparent;
  box-shadow: none;
}

.hero-signal-pill {
  padding: 0 18px 0 0;
  border: none;
  border-radius: 0;
  background: transparent;
  color: #53656c;
  position: relative;
}

.hero-signal-pill::before {
  content: "";
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-right: 10px;
  border-radius: 999px;
  vertical-align: middle;
  background: linear-gradient(135deg, rgba(122, 173, 173, 0.95), rgba(200, 184, 168, 0.95));
}

.hero-points {
  gap: 10px 22px;
}

.hero-points li {
  padding: 0 0 0 18px;
  border: none;
  border-radius: 0;
  background: transparent !important;
  box-shadow: none;
}

.hero-points li::before {
  left: 0;
  top: 10px;
}

.hero::before {
  border-radius: 64px;
}

.hero-panel,
.surface-card,
.info-card,
.step-card,
.faq-item,
.comparison-card,
.onboarding-panel {
  background: rgba(255, 255, 255, 0.46);
  border: 1px solid rgba(58, 50, 43, 0.07);
  border-radius: 22px;
  box-shadow: 0 14px 34px rgba(90, 100, 112, 0.05);
}

.info-card,
.step-card,
.comparison-card,
.faq-item,
.onboarding-panel {
  border-top: none;
}

.surface-card,
.info-card,
.step-card,
.faq-item,
.comparison-card,
.onboarding-panel {
  padding: 26px;
}

.surface-card:hover,
.info-card:hover,
.step-card:hover,
.comparison-card:hover,
.faq-item:hover,
.onboarding-panel:hover,
.proof-strip div:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 42px rgba(90, 100, 112, 0.08);
  border-color: rgba(122, 173, 173, 0.16);
}

.summary-grid div,
.proof-strip div {
  border-radius: 18px;
  box-shadow: 0 12px 28px rgba(90, 100, 112, 0.04);
}

.reveal-on-scroll {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 300ms cubic-bezier(0.22, 1, 0.36, 1), transform 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 960px) {
  .page-shell {
    padding-top: 150px;
  }

  .site-header {
    top: 12px;
    width: min(1220px, calc(100% - 20px));
    padding: 14px;
    border-radius: 22px;
  }

  nav {
    width: 100%;
    justify-content: space-between;
    gap: 12px;
  }

  nav a {
    padding: 6px 0;
  }

  .nav-cta {
    padding: 11px 16px;
  }
}

@media (max-width: 720px) {
  .page-shell {
    width: min(100% - 20px, 1220px);
    padding-top: 152px;
    padding-bottom: 78px;
  }

  .site-header {
    background: linear-gradient(180deg, rgba(255,255,255,0.82), rgba(247,242,234,0.72));
    box-shadow: 0 18px 34px rgba(90, 100, 112, 0.08);
  }

  .phone-device,
  .phone-flip-stage.is-in-view .phone-device {
    opacity: 1;
    transform: none;
  }

  .phone-float-card {
    position: static;
    max-width: none;
    margin-top: 12px;
  }

  .phone-device-frame {
    padding: 12px;
    border-radius: 34px;
  }

  .phone-device-frame::before {
    border-radius: 28px;
  }

  .phone-device-screen {
    border-radius: 26px;
    min-height: 520px;
  }

  .phone-device-screen-chat {
    min-height: 0;
    aspect-ratio: 1179 / 2556;
  }

  .phone-device-screen img {
    border-radius: 26px;
  }

  .iphone-demo-stage {
    padding: 18px;
  }

  body::before,
  body::after,
  .page-shell::before,
  .page-shell::after,
  .hero::before,
  .hero::after,
  .cta-section::after,
  body.landing-page .landing-calm-panel::after,
  body.landing-page .landing-final-cta::after,
  body.demo-page .content-section::after,
  body.book-page .content-section::after {
    animation: none;
    opacity: 0.4;
  }

  body.landing-page .landing-card-band {
    padding: 18px;
  }

  .proof-note {
    font-size: 13px;
  }

  .proof-chat-shot,
  .proof-chat-shot-wide {
    padding: 12px;
  }

  .site-header {
    padding: 12px;
    border-radius: 20px;
    gap: 12px;
  }

  .brand-logo {
    width: 128px;
  }

  .capability-grid {
    grid-template-columns: 1fr;
  }

  .split-emphasis {
    padding: 28px 22px;
  }

  nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
    gap: 8px;
  }

  nav a {
    font-size: 13px;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 11px 12px;
    border-radius: 14px;
    background: rgba(255,255,255,0.48);
    border: 1px solid rgba(58, 50, 43, 0.08);
  }

  nav a:not(.nav-cta)::after {
    display: none;
  }

  .nav-cta {
    grid-column: 1 / -1;
    width: 100%;
  }

  .page-shell {
    width: min(100% - 18px, 1220px);
    padding-bottom: 74px;
  }

  h1 {
    font-size: clamp(1.9rem, 8.4vw, 2.75rem);
    line-height: 1.03;
    text-wrap: pretty;
    max-width: none;
  }

  h2 {
    font-size: clamp(1.48rem, 6.2vw, 2rem);
    line-height: 1.08;
    text-wrap: pretty;
    max-width: none;
  }

  h3 {
    font-size: 20px;
  }

  .hero,
  .content-section,
  .editorial-gallery,
  .cta-section,
  .comparison-grid,
  .split-section,
  .alt-section {
    gap: 16px;
  }

  .hero-proof-row,
  .cards-section,
  .steps-grid,
  .comparison-grid,
  .proof-strip,
  .section-split-head {
    gap: 14px;
  }

  .hero {
    padding-top: 6px;
    padding-bottom: 18px;
  }

  .hero-copy .eyebrow {
    display: none;
  }

  .hero::before {
    inset: -10px -10px -6px;
    border-radius: 30px;
  }

  .hero::before,
  .editorial-image-card,
  .editorial-copy-card,
  .hero-panel,
  .surface-card,
  .info-card,
  .step-card,
  .comparison-card,
  .onboarding-panel,
  .authority-grid article {
    border-radius: 20px;
  }

  .surface-card,
  .info-card,
  .step-card,
  .comparison-card,
  .onboarding-panel,
  .authority-grid article {
    padding: 18px;
  }

  .editorial-copy-card {
    padding: 22px;
  }

  .content-section {
    padding: 36px 0;
  }

  .section-side-shell {
    min-height: 136px;
    border-radius: 24px;
  }

  .hero-text, p, li, .section-intro {
    font-size: 15.5px;
  }

  .hero-signal-row {
    gap: 8px;
  }

  .hero-signal-pill {
    font-size: 13px;
  }

  .hero-actions {
    gap: 10px;
  }

  .hero-actions .secondary,
  .cta-section .secondary {
    padding: 13px 16px;
    border: 1px solid rgba(58, 50, 43, 0.12);
    border-radius: 999px;
    background: rgba(255,255,255,0.4);
  }

  .secondary::after {
    margin-left: 6px;
  }
}

@media (max-width: 560px) {
  .page-shell {
    width: calc(100% - 14px);
    padding-top: 14px;
    padding-bottom: 64px;
  }

  .hero-copy {
    gap: 0;
  }

  .phone-device,
  .phone-device-chat {
    width: 100%;
  }

  .phone-device-screen {
    min-height: 430px;
  }

  .phone-device-screen-proof {
    padding: 18px 6px 6px;
  }

  .phone-device-screen-chat {
    padding: 44px 12px 12px;
    min-height: 0;
    aspect-ratio: 1179 / 2556;
  }

  .dm-thread-shell {
    min-height: 100%;
  }

  .split-emphasis {
    padding: 24px 18px;
  }

  .dm-thread-topbar,
  .dm-thread-input {
    padding: 12px 14px;
  }

  .chat-card {
    padding: 14px 15px;
  }

  html,
  body,
  .page-shell,
  main,
  .site-header,
  .brand-lockup,
  .brand-logo-wrap,
  nav,
  nav a,
  .hero,
  .hero-copy,
  .hero-panel,
  .content-section,
  .editorial-gallery,
  .comparison-grid,
  .split-section,
  .cards-section,
  .proof-showcase,
  .proof-chat-shot,
  .proof-chat-shot-wide,
  .surface-card,
  .info-card,
  .step-card,
  .comparison-card,
  .faq-item,
  .onboarding-panel,
  .cta-section {
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  body.book-page h1 {
    font-size: clamp(28px, 8.6vw, 34px);
  }

  main {
    gap: 2px;
  }

  body.landing-page .landing-proof-section,
  body.landing-page .landing-card-band,
  body.landing-page .landing-calm-panel,
  body.landing-page .landing-final-cta {
    border-radius: 24px;
  }

  .site-header {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    padding: 10px;
    margin-bottom: 10px;
    transform: none;
    border-radius: 20px;
    display: grid;
    grid-template-columns: 1fr;
    justify-items: stretch;
    gap: 8px;
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(246,239,230,0.86));
    border: 1px solid rgba(184, 155, 121, 0.12);
    box-shadow: 0 16px 34px rgba(90, 100, 112, 0.08);
    z-index: 48;
    transition: box-shadow 180ms ease, background 180ms ease;
  }

  body.header-at-top .site-header,
  body.header-scrolled .site-header,
  body.header-hidden .site-header {
    opacity: 1;
    transform: none;
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(246,239,230,0.86));
  }

  .brand-lockup {
    justify-content: center;
    width: 100%;
  }

  .brand-logo {
    width: 122px;
  }

  .brand-logo-wrap {
    min-width: 0;
    width: 100%;
    justify-content: center;
    padding: 6px 0 2px;
  }

  nav {
    grid-template-columns: 1fr;
    width: 100%;
  }

  nav a {
    min-height: 44px;
    padding: 10px 14px;
    font-size: 12px;
    border-radius: 16px;
    background: rgba(255,255,255,0.76);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 8px 18px rgba(90, 100, 112, 0.04);
  }

  .site-header::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    background: linear-gradient(120deg, transparent 12%, rgba(255,255,255,0.24) 28%, transparent 42%);
    opacity: 0.45;
    transform: translateX(calc(var(--scroll-drift, 0px) * 0.08));
  }

  .hero-signal-pill {
    width: 100%;
    padding-right: 0;
  }

  .summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero-proof-row {
    gap: 14px;
  }

  .hero-actions .primary,
  .hero-actions .secondary,
  .cta-section .primary,
  .cta-section .secondary {
    width: 100%;
    padding-left: 16px;
    padding-right: 16px;
    font-size: 15px;
  }

  .hero-points li {
    padding: 12px 14px 12px 28px;
  }

  .surface-card,
  .info-card,
  .step-card,
  .comparison-card,
  .onboarding-panel,
  .authority-grid article {
    padding: 18px;
  }

  .editorial-copy-card {
    padding: 20px;
  }

  .proof-chat-gallery {
    gap: 12px;
    padding: 0;
    background: transparent;
    border: none;
    box-shadow: none;
  }

  .proof-showcase {
    gap: 12px;
    padding: 18px 0 0;
    background: transparent;
    border: none;
    box-shadow: none;
  }

  .proof-showcase-head {
    justify-items: start;
    text-align: left;
  }

  .landing-live-card {
    padding: 18px;
  }

  .landing-live-core strong {
    font-size: 24px;
    max-width: none;
  }

  .proof-chat-shot {
    padding: 10px;
    border-radius: 24px;
  }

  .capability-section {
    background:
      radial-gradient(38% 28% at 14% 20%, rgba(122, 173, 173, 0.12), transparent 72%),
      radial-gradient(34% 24% at 86% 80%, rgba(200, 184, 168, 0.14), transparent 72%),
      linear-gradient(180deg, rgba(240,248,247,0.82), rgba(251,246,239,0.72));
  }

  .capability-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(240,248,247,0.7));
    border-color: rgba(122, 173, 173, 0.12);
    transform: none;
  }

  .capability-card::after {
    opacity: 0.72;
  }

  .capability-card.reveal-on-scroll,
  .capability-grid .capability-card.reveal-on-scroll {
    transform: translateY(18px) scale(0.985);
  }

  .capability-card.reveal-on-scroll.is-visible,
  .capability-grid .capability-card.reveal-on-scroll.is-visible {
    transform: translateY(0) scale(1);
  }

  .proof-chat-shot,
  .proof-chat-shot-wide {
    padding: 12px;
    border-radius: 22px;
    overflow: hidden;
  }

  .phone-flip-stage {
    overflow: hidden;
  }

  .phone-device,
  .phone-device-chat {
    width: min(100%, 320px);
  }

  .phone-device-frame {
    padding: 10px;
    border-radius: 28px;
  }

  .phone-device-screen {
    min-height: 380px;
    border-radius: 20px;
  }

  .phone-device-screen-proof {
    padding: 14px 4px 4px;
  }

  .phone-device-screen img,
  .proof-chat-shot img,
  .proof-chat-shot-wide img {
    width: 100%;
    max-width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: 50% 50%;
    border-radius: 18px;
    background: rgba(255,255,255,0.88);
    padding: 0;
    box-shadow: none;
  }

  .phone-float-card {
    display: none;
  }

  .proof-chat-copy {
    padding: 18px 4px 4px;
  }

  .hero,
  .compact-hero,
  .content-section,
  .alt-section,
  .split-emphasis,
  .cta-section,
  .editorial-gallery {
    margin-top: 0;
    margin-bottom: 10px;
  }

  .hero {
    gap: 12px;
    padding-bottom: 14px;
  }

  .core-pain-section {
    background: linear-gradient(180deg, rgba(255,255,255,0.34), rgba(255,255,255,0.1));
  }

  .hero-copy,
  .editorial-copy-card,
  .surface-card,
  .info-card,
  .step-card,
  .onboarding-panel,
  .faq-item {
    text-align: left;
  }

  .hero-panel,
  .editorial-image-card:not(.essential-proof-shot) {
    display: none;
  }

  .hero-signal-row {
    gap: 6px;
  }

  .hero-signal-pill {
    font-size: 13px;
  }

  h1 {
    font-size: clamp(30px, 9.2vw, 38px);
    line-height: 1.06;
    text-wrap: pretty;
  }

  h2 {
    font-size: clamp(24px, 7.2vw, 30px);
    line-height: 1.1;
    text-wrap: pretty;
  }

  .action-note,
  .credibility-points span,
  .authority-grid p {
    font-size: 14px;
  }

  .hero-text,
  p,
  li,
  .section-intro {
    font-size: 15px;
    line-height: 1.55;
  }

  html,
  body {
    position: relative;
    max-width: 100%;
    overflow-x: clip;
  }
}

@keyframes orbitFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(-4px, 6px, 0) scale(1.025); }
}

@keyframes softPulse {
  0%, 100% { opacity: 0.55; transform: scale(1); }
  50% { opacity: 0.82; transform: scale(1.06); }
}

@keyframes livePulse {
  0%, 100% { box-shadow: 0 0 0 6px rgba(122, 173, 173, 0.06); opacity: 0.94; }
  50% { box-shadow: 0 0 0 10px rgba(122, 173, 173, 0.12); opacity: 1; }
}

@keyframes buttonSheen {
  0%, 72%, 100% { transform: translateX(-135%); }
  84% { transform: translateX(135%); }
}

.hero-panel-orbit,
.brand-world-section .editorial-image-card::after {
  animation: orbitFloat 8s ease-in-out infinite;
}

.brand-logo-wrap::before {
  content: none !important;
  animation: none !important;
}

.editorial-gallery {
  gap: 26px;
  padding: 8px 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.editorial-image-card,
.editorial-copy-card {
  border-radius: 32px;
  background: rgba(255,255,255,0.38);
  border-color: rgba(58, 50, 43, 0.06);
  box-shadow: 0 18px 50px rgba(90, 100, 112, 0.06);
}

.editorial-copy-card {
  padding: 40px;
}

.comparison-grid.comparison-highlight,
.alt-section,
.split-emphasis {
  border-radius: 30px;
  border-color: rgba(58, 50, 43, 0.06);
  box-shadow: 0 16px 42px rgba(90, 100, 112, 0.05);
}

.comparison-grid.comparison-highlight {
  padding: 10px 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.comparison-card {
  min-height: 100%;
}

.faq-section {
  position: relative;
  gap: 0;
  padding-top: 76px;
}

.faq-divider-row {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(82%, 920px);
  margin: 0 auto 36px;
  gap: 24px;
}

.faq-divider-row::before,
.faq-divider-row::after {
  content: "";
  flex: 1 1 auto;
  height: 1px;
  background: linear-gradient(90deg, rgba(122, 173, 173, 0), rgba(122, 173, 173, 0.18) 22%, rgba(122, 173, 173, 0.36) 100%);
  opacity: 0.8;
  transform-origin: center;
  animation: faqSideBloom 4.8s ease-in-out infinite;
}

.faq-divider-row::after {
  transform: scaleX(-1);
}

.faq-section .section-label {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-width: 180px;
  max-width: 220px;
  padding: 0 28px;
  margin: 0;
  background: rgba(250, 246, 240, 0.92);
  border-color: rgba(200, 184, 168, 0.18);
  box-shadow: none;
}

.faq-item {
  padding-left: 0;
  padding-right: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
  border-bottom: 1px solid rgba(58, 50, 43, 0.08);
}

.faq-item:first-of-type {
  border-top: 1px solid rgba(58, 50, 43, 0.08);
}

.faq-item:hover {
  transform: none;
  box-shadow: none;
  border-color: rgba(122, 173, 173, 0.22);
}

.faq-question {
  display: block;
  width: 100%;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.15;
  text-align: left;
  cursor: default;
}

.faq-question-icon {
  display: none;
}

.faq-answer {
  display: block;
}

.cta-section {
  overflow: hidden;
  position: relative;
  background:
    radial-gradient(62% 68% at 18% 18%, rgba(255,255,255,0.16), transparent 62%),
    radial-gradient(42% 42% at 82% 78%, rgba(123,188,188,0.18), transparent 62%),
    linear-gradient(135deg, #5b7c85 0%, #6a97a0 54%, #79b2b8 100%);
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.16), 0 22px 52px rgba(92, 121, 129, 0.18);
}

.cta-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.06), transparent 28%, rgba(255,255,255,0.02));
  pointer-events: none;
}

.cta-section .hero-actions {
  position: relative;
  z-index: 1;
}

.cta-section .primary.book-button {
  min-width: min(100%, 520px);
  justify-content: center;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.02) 26%, rgba(0,0,0,0.16) 100%),
    linear-gradient(135deg, #4b5d69 0%, #445862 100%) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.10), 0 14px 26px rgba(54, 70, 81, 0.22) !important;
}

.cta-section .primary.book-button::before {
  opacity: 0.42 !important;
}

.cta-section .section-label {
  background: rgba(255,255,255,0.18) !important;
  border-color: rgba(255,255,255,0.18) !important;
  color: rgba(255,255,255,0.92) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.14);
}

.cta-section .secondary {
  padding-left: 0;
  padding-right: 0;
}

.cta-section .secondary::after {
  color: rgba(247, 242, 234, 0.8);
}

@media (min-width: 1180px) {
  .hero {
    gap: 54px;
  }

  .hero-copy {
    max-width: 600px;
  }

  .hero-panel {
    align-self: center;
  }
}

@media (max-width: 960px) {
  .editorial-copy-card {
    padding: 28px;
  }
}

.capability-section {
  background:
    radial-gradient(42% 34% at 16% 16%, rgba(122, 173, 173, 0.24), transparent 70%),
    radial-gradient(36% 28% at 84% 20%, rgba(149, 202, 199, 0.16), transparent 74%),
    radial-gradient(42% 30% at 78% 84%, rgba(200, 184, 168, 0.16), transparent 74%),
    linear-gradient(180deg, rgba(230, 245, 243, 0.94), rgba(246, 250, 248, 0.88) 48%, rgba(251, 246, 239, 0.82));
  border: 1px solid rgba(122, 173, 173, 0.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.58), 0 24px 56px rgba(83, 118, 123, 0.08);
  isolation: isolate;
}

.capability-section::before,
.capability-section::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.capability-section::before {
  inset: 14px;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,0.42);
  opacity: 0.72;
}

.capability-section::after {
  inset: auto -10% -26% 42%;
  height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(122, 173, 173, 0.14), transparent 70%);
  filter: blur(18px);
  animation: sectionAuraFloat 12s ease-in-out infinite;
  z-index: 0;
}

.capability-section > * {
  position: relative;
  z-index: 1;
}

.capability-head {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
  gap: 42px;
  align-items: center;
  margin-bottom: 34px;
}

.capability-copy {
  min-width: 0;
  max-width: 640px;
}

.capability-copy h2 {
  max-width: 10ch;
}

.capability-section .section-intro {
  max-width: 56ch;
  margin-top: 18px;
  color: #50666c;
}

.capability-visual {
  min-width: 0;
}

.capability-visual-shell {
  position: relative;
  min-height: 244px;
  padding: 26px;
  border-radius: 34px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,0.46), rgba(255,255,255,0.18));
  border: 1px solid rgba(122, 173, 173, 0.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.62), 0 20px 40px rgba(83, 118, 123, 0.07);
}

.capability-visual-shell-abstract {
  min-height: 228px;
}

.capability-visual-glow {
  position: absolute;
  inset: auto -10% -24% 24%;
  height: 170px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(122, 173, 173, 0.24), transparent 68%);
  filter: blur(12px);
}

.capability-visual-panel {
  position: absolute;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(244,249,248,0.82));
  border: 1px solid rgba(122, 173, 173, 0.12);
  box-shadow: 0 16px 34px rgba(83, 118, 123, 0.08);
}

.capability-visual-panel-main {
  inset: 34px 54px 30px 26px;
  padding: 22px;
}

.capability-visual-panel-top {
  top: 18px;
  right: 18px;
  width: 136px;
  height: 60px;
  display: grid;
  place-items: center;
}

.capability-visual-panel-side {
  right: 26px;
  top: 86px;
  width: 150px;
  padding: 14px;
  display: grid;
  gap: 10px;
}

.capability-visual-panel-head {
  display: flex;
  gap: 8px;
  margin-bottom: 22px;
}

.capability-visual-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(122, 173, 173, 0.92), rgba(184, 155, 121, 0.78));
}

.capability-visual-dot-soft {
  opacity: 0.5;
}

.capability-visual-tracks {
  display: grid;
  gap: 14px;
}

.capability-visual-track {
  display: block;
  height: 14px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(122, 173, 173, 0.24), rgba(255,255,255,0.82));
}

.capability-visual-track-strong { width: 72%; }
.capability-visual-track-mid { width: 54%; }
.capability-visual-track-short { width: 38%; }

.capability-visual-ring {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: 6px solid rgba(122, 173, 173, 0.2);
  border-top-color: rgba(122, 173, 173, 0.78);
  border-right-color: rgba(184, 155, 121, 0.58);
}

.capability-visual-pill {
  display: block;
  height: 16px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,255,255,0.96), rgba(238,247,246,0.84));
}

.capability-visual-pill-mid { width: 82%; }
.capability-visual-pill-short { width: 64%; }

.capability-visual-orbit {
  position: absolute;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.46);
  opacity: 0.68;
}

.capability-visual-orbit-a {
  width: 230px;
  height: 230px;
  right: -20px;
  top: -26px;
  animation: orbitFloat 9s ease-in-out infinite;
}

.capability-visual-orbit-b {
  width: 150px;
  height: 150px;
  left: -10px;
  bottom: 2px;
  animation: orbitFloat 11s ease-in-out infinite reverse;
}

.capability-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 24px;
  align-items: stretch;
}

.capability-card {
  grid-column: span 4;
  min-width: 0;
  min-height: 276px;
  padding: 30px;
  gap: 14px;
  border-radius: 30px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,249,0.9)),
    linear-gradient(135deg, rgba(122, 173, 173, 0.06), rgba(255,255,255,0));
  border: 1px solid rgba(109, 150, 153, 0.12);
  border-top-width: 4px;
  box-shadow: 0 18px 40px rgba(83, 118, 123, 0.08);
  transition: transform 240ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 240ms cubic-bezier(0.22, 1, 0.36, 1), border-color 220ms ease;
}

.capability-grid .capability-card:nth-child(1),
.capability-grid .capability-card:nth-child(2),
.capability-grid .capability-card:nth-child(3) {
  grid-column: span 4;
}

.capability-grid .capability-card:nth-child(4) {
  grid-column: 2 / span 5;
}

.capability-grid .capability-card:nth-child(5) {
  grid-column: 7 / span 5;
}

.capability-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 50px rgba(83, 118, 123, 0.12);
  border-color: rgba(122, 173, 173, 0.22);
}

.capability-card-top {
  margin-bottom: 4px;
}

.capability-card .surface-title {
  color: #6a8d8f;
}

.capability-pill {
  color: #5f6e73;
  background: rgba(255,255,255,0.86);
}

.capability-card-icon {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 12px 26px rgba(83, 118, 123, 0.08);
  transition: transform 240ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 240ms cubic-bezier(0.22, 1, 0.36, 1);
}

.capability-card:hover .capability-card-icon {
  transform: translateY(-2px) scale(1.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), 0 16px 30px rgba(83, 118, 123, 0.12);
}

.capability-card-foot {
  color: #55727a;
}

.trust-cards .info-card {
  transition: transform 240ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 240ms cubic-bezier(0.22, 1, 0.36, 1), border-color 220ms ease;
}

.trust-cards .info-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 48px rgba(83, 118, 123, 0.1);
  border-color: rgba(122, 173, 173, 0.18);
}

.trust-cards .info-card::after {
  animation: trustArcDrift 11s ease-in-out infinite;
}

.site-footer {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(44% 46% at 10% 10%, rgba(122, 173, 173, 0.18), transparent 68%),
    radial-gradient(34% 34% at 88% 18%, rgba(255,255,255,0.28), transparent 68%),
    linear-gradient(180deg, rgba(240,248,247,0.9), rgba(251,246,239,0.82));
  border: 1px solid rgba(122, 173, 173, 0.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.58), 0 22px 54px rgba(83, 118, 123, 0.08);
}

.site-footer::before {
  content: "";
  position: absolute;
  inset: 16px;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,0.42);
  pointer-events: none;
}

.footer-block {
  position: relative;
  display: grid;
  gap: 14px;
  align-content: start;
  min-height: 100%;
  padding: 18px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255,255,255,0.7), rgba(255,255,255,0.44));
  border: 1px solid rgba(122, 173, 173, 0.08);
  box-shadow: 0 14px 34px rgba(83, 118, 123, 0.05);
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1), border-color 220ms ease;
}

.footer-block::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(120deg, transparent 20%, rgba(255,255,255,0.28) 46%, transparent 62%);
  transform: translateX(-130%);
  opacity: 0;
  transition: transform 480ms cubic-bezier(0.22, 1, 0.36, 1), opacity 240ms ease;
}

.footer-block:hover {
  transform: translateY(-3px);
  border-color: rgba(122, 173, 173, 0.18);
  box-shadow: 0 18px 40px rgba(83, 118, 123, 0.08);
}

.footer-block:hover::before {
  transform: translateX(120%);
  opacity: 1;
}

.footer-note {
  margin-top: auto;
  padding-top: 12px;
  font-size: 14px;
  color: #5d7075;
  border-top: 1px solid rgba(90, 100, 112, 0.08);
}

.footer-trust-title {
  width: fit-content;
}

.footer-links {
  gap: 12px;
}

.footer-links a,
.footer-links span {
  position: relative;
}

.footer-links a span {
  min-height: 0;
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.footer-links a {
  display: grid;
  width: 100%;
  grid-template-columns: 48px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  min-height: 74px;
  text-decoration: none;
  color: inherit;
  background: linear-gradient(180deg, rgba(255,255,255,0.88), rgba(244,249,248,0.8));
  border-color: rgba(122, 173, 173, 0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.84), 0 10px 22px rgba(83, 118, 123, 0.05);
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1), border-color 220ms ease;
}

.footer-link-icon {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: transparent;
  border: none;
  box-shadow: none;
  color: #5f8487;
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.footer-link-icon svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.footer-link-copy {
  min-width: 0;
  display: grid;
}

.footer-links a::after {
  content: "↗";
  color: #6d8d90;
  font-size: 14px;
  opacity: 0.72;
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1), opacity 220ms ease;
}

.footer-links a:hover {
  transform: translateY(-2px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.88), 0 14px 28px rgba(83, 118, 123, 0.08);
  border-color: rgba(122, 173, 173, 0.2);
}

.footer-links a:hover::after {
  transform: translate(2px, -1px);
  opacity: 1;
}

.footer-links a:hover .footer-link-icon {
  transform: translateY(-1px);
  box-shadow: none;
}

.email-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1198;
  background: rgba(0,0,0,0.3);
}

.email-modal {
  position: fixed;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  z-index: 1199;
  display: flex;
  width: min(calc(100vw - 32px), 480px);
  max-width: 480px;
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.12);
}

.email-modal[hidden],
.email-modal-overlay[hidden] {
  display: none !important;
}

.email-modal-body {
  width: 100%;
  display: grid;
  gap: 12px;
  padding: 28px 24px 24px;
}

.email-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 999px;
  background: rgba(244, 239, 230, 0.96);
  color: #5f8487;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}

.email-modal-label {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #7c858a;
}

.email-modal-value {
  color: #2f3338;
  font-size: 15px;
  line-height: 1.4;
}

.email-modal-draft {
  width: 100%;
  min-height: 170px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(122, 173, 173, 0.16);
  background: rgba(250, 249, 247, 0.92);
  color: #3e474d;
  font: inherit;
  line-height: 1.55;
  resize: vertical;
  box-sizing: border-box;
}

.email-modal-mail,
.email-modal-copy {
  width: 100%;
  justify-content: center;
  text-align: center;
}

.email-modal-mail {
  display: inline-flex;
}

.email-modal-copy {
  background: rgba(244, 239, 230, 0.96);
  color: #5f8487;
  border: 1px solid rgba(122, 173, 173, 0.12);
}

.footer-link-text {
  font-weight: 600;
}

.footer-link-meta {
  min-width: fit-content;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(122, 173, 173, 0.1);
  color: #638184;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

@keyframes sectionAuraFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); opacity: 0.84; }
  50% { transform: translate3d(-18px, -10px, 0) scale(1.06); opacity: 1; }
}

@keyframes trustArcDrift {
  0%, 100% { transform: translate3d(0, 0, 0); opacity: 0.72; }
  50% { transform: translate3d(-6px, 4px, 0); opacity: 1; }
}

@keyframes faqSideBloom {
  0%, 100% { opacity: 0.46; width: 26px; }
  50% { opacity: 0.9; width: 44px; }
}

@keyframes painShellSweep {
  0%, 100% { transform: translate3d(-12px, 0, 0); opacity: 0.24; }
  50% { transform: translate3d(14px, -2px, 0); opacity: 0.52; }
}

@keyframes signalChargeRun {
  0% { transform: translateX(-32px); opacity: 0; }
  16% { opacity: 0.9; }
  84% { opacity: 0.9; }
  100% { transform: translateX(calc(100% + 32px)); opacity: 0; }
}

@keyframes signalNodePulse {
  0%, 100% { transform: scale(1); opacity: 0.46; }
  50% { transform: scale(1.08); opacity: 0.92; }
}

@keyframes flowPathDrift {
  0% { stroke-dashoffset: 0; }
  100% { stroke-dashoffset: -52; }
}

@keyframes flowNodePulse {
  0%, 100% { transform: scale(1); opacity: 0.3; }
  50% { transform: scale(1.06); opacity: 0.72; }
}

@keyframes flowAuraFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); opacity: 0.5; }
  50% { transform: translate3d(4px, -6px, 0) scale(1.05); opacity: 0.86; }
}

@keyframes painSignalFlash {
  0%, 18% { transform: translateX(-140%) skewX(-24deg); opacity: 0; }
  28% { opacity: 0.92; }
  54% { transform: translateX(345%) skewX(-24deg); opacity: 0.18; }
  100% { transform: translateX(345%) skewX(-24deg); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .capability-section::after,
  .trust-cards .info-card::after,
  .capability-visual-orbit,
  .faq-section .section-label::before,
  .faq-section .section-label::after,
  .pain-graphic .section-side-shell::before,
  .pain-signal-bar::after,
  .flow-graphic-path-glow,
  .flow-node::after,
  .flow-aura {
    animation: none;
  }

  .capability-card,
  .capability-card-icon,
  .trust-cards .info-card,
  .footer-block,
  .footer-links a,
  .footer-links a::after,
  .phone-flip-stage .phone-device-screen::after,
  .pain-signal-bar,
  .pain-signal-glow {
    transition: none;
  }
}

@media (max-width: 1100px) {
  .capability-head,
  .section-split-head {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .capability-visual-panel-main {
    inset: 28px 42px 24px 22px;
  }

  .capability-visual-panel-side {
    right: 22px;
    width: 138px;
  }

  .capability-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .capability-grid .capability-card,
  .capability-grid .capability-card:nth-child(1),
  .capability-grid .capability-card:nth-child(2),
  .capability-grid .capability-card:nth-child(3),
  .capability-grid .capability-card:nth-child(4),
  .capability-grid .capability-card:nth-child(5) {
    grid-column: auto;
    min-height: 250px;
  }

  .capability-visual-shell {
    min-height: 200px;
  }
}

@media (max-width: 960px) {
  .site-footer {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .footer-block {
    padding: 16px;
    border-radius: 22px;
  }

  .footer-links a {
    grid-template-columns: 44px minmax(0, 1fr) auto auto;
    min-height: 68px;
  }

  .capability-section::before {
    inset: 10px;
  }
}

@media (max-width: 720px) {
  .capability-grid {
    grid-template-columns: 1fr;
  }

  .section-side-shell {
    min-height: 144px;
  }

  .faq-section {
    order: 12;
    padding-top: 66px;
  }

  .cta-section {
    order: 11;
  }

  main > footer {
    order: 13;
  }

  .faq-divider-row {
    width: min(86%, 680px);
    gap: 16px;
    margin: 0 auto 30px;
  }

  .faq-section .section-label {
    min-width: 180px;
    max-width: 200px;
    padding: 0 22px;
  }

  .faq-item {
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .flow-node {
    width: 48px;
    height: 48px;
  }

  .flow-node::before {
    inset: 12px;
  }

  .flow-graphic-path-base {
    stroke-width: 2.2;
  }

  .flow-graphic-path-glow {
    stroke-width: 2.4;
  }

  .capability-grid .capability-card,
  .capability-grid .capability-card:nth-child(1),
  .capability-grid .capability-card:nth-child(2),
  .capability-grid .capability-card:nth-child(3),
  .capability-grid .capability-card:nth-child(4),
  .capability-grid .capability-card:nth-child(5) {
    grid-column: auto;
    min-height: 0;
  }

  .capability-visual-shell {
    min-height: 174px;
    padding: 18px;
  }

  .capability-visual-panel-main {
    inset: 24px 34px 18px 18px;
    padding: 16px;
  }

  .capability-visual-panel-top {
    top: 14px;
    right: 14px;
    width: 104px;
    height: 48px;
  }

  .capability-visual-panel-side {
    right: 18px;
    top: 76px;
    width: 104px;
    padding: 10px;
    gap: 8px;
  }

  .capability-visual-panel-head {
    margin-bottom: 14px;
  }

  .capability-visual-track {
    height: 12px;
  }

  .capability-visual-pill {
    height: 12px;
  }

  .footer-links a {
    grid-template-columns: 42px minmax(0, 1fr) auto;
    gap: 10px;
  }

.footer-link-meta {
  display: none;
}
}

@media (max-width: 768px) {
  body {
    font-size: 16px;
    line-height: 1.6;
  }

  .page-shell {
    padding-top: 28px;
  }

  .flex-row,
  [class*="grid"],
  [class*="columns"] {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  a,
  button {
    min-height: 44px;
    padding: 12px 16px;
  }

  section,
  .container,
  .wrapper {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }

  .page-shell {
    width: 100%;
    max-width: 100%;
    padding-inline: 0;
    padding-bottom: clamp(16px, 4vw, 40px);
  }

  .site-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-inline: 12px;
    width: auto;
    padding: 10px 12px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255,255,255,0.95), rgba(246,239,230,0.88));
    border: 1px solid rgba(184, 155, 121, 0.12);
    box-shadow: 0 12px 28px rgba(90, 100, 112, 0.08);
  }

  .brand-lockup,
  .brand-logo-wrap {
    width: auto;
    min-width: 0;
    justify-content: flex-start;
  }

  .nav-toggle {
    display: inline-flex;
    flex: 0 0 auto;
  }

  .site-nav {
    display: none;
    width: 100%;
    order: 3;
    padding: 8px;
    border-radius: 18px;
    background: rgba(255,255,255,0.96);
    border: 1px solid rgba(184, 155, 121, 0.14);
    box-shadow: 0 14px 28px rgba(90, 100, 112, 0.10);
  }

  .site-nav.is-open {
    display: flex;
    flex-direction: column;
  }

  .site-nav a,
  .site-nav .nav-cta {
    width: 100%;
    justify-content: flex-start;
    text-align: left;
    font-size: 0.95rem;
    border-radius: 14px;
    background: rgba(255,255,255,0.82);
  }

  .hero,
  .content-section,
  .editorial-gallery,
  .cta-section,
  .comparison-grid,
  .split-section,
  .alt-section,
  .proof-showcase,
  .site-footer {
    gap: 14px;
    padding-top: clamp(16px, 4vw, 34px);
    padding-bottom: clamp(16px, 4vw, 34px);
  }

  .hero {
    padding-top: 8px;
    padding-bottom: 16px;
  }

  .hero-copy {
    max-width: 100%;
  }

  .proof-showcase {
    gap: 12px;
    padding-top: 24px;
    padding-bottom: 24px;
  }

  .proof-showcase-head {
    gap: 8px;
  }

  .hero-text,
  .section-intro,
  .action-note,
  .proof-showcase-head p {
    color: #4f565c;
  }

  .surface-card,
  .info-card,
  .step-card,
  .comparison-card,
  .onboarding-panel,
  .faq-item {
    padding: clamp(16px, 4vw, 24px);
  }

  .faq-divider-row {
    width: 100%;
    justify-content: center;
    margin: 0 auto 16px;
  }

  .faq-divider-row::before,
  .faq-divider-row::after {
    display: none;
  }

  .faq-section .section-label {
    min-width: 180px;
    max-width: 220px;
  }

  .faq-section {
    max-width: 100%;
  }

  .faq-item {
    width: 100%;
    margin: 0;
    padding-top: 0;
    padding-bottom: 0;
    border: 1px solid rgba(0,0,0,0.07);
    border-radius: 16px;
    background: #faf9f7;
    box-shadow: none;
    overflow: hidden;
  }

  .faq-item:first-of-type {
    border-top: 1px solid rgba(0,0,0,0.07);
  }

  .faq-item + .faq-item {
    margin-top: 8px;
  }

  .faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    min-height: 0;
    padding: 16px;
    cursor: pointer;
    font-size: 18px;
    line-height: 1.2;
  }

  .faq-question-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    line-height: 1;
    flex: 0 0 auto;
    transition: transform 180ms ease;
  }

  .faq-item.is-open .faq-question-icon {
    transform: rotate(45deg);
  }

  .faq-answer {
    padding: 0 16px 16px;
  }

  .faq-answer p {
    margin: 0;
    font-size: 14px;
    line-height: 1.45;
    color: rgba(0,0,0,0.55);
  }
}

.mobile-header-cta {
  display: none;
}

@media (max-width: 768px) {
  body.home-page {
    padding-top: 0;
  }

  body.home-page .brand-logo {
    width: 168px;
  }

  body.home-page .brand-logo-wrap {
    min-width: 168px;
  }

  .page-shell {
    padding-top: 98px;
    padding-bottom: 52px;
    width: 100%;
  }

  .site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    margin: 0;
    padding: 4px 6px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 6px;
    transform: translateY(0);
    border-radius: 0;
    background: rgba(250, 249, 247, 0.85);
    border: 0;
    border-bottom: 1px solid rgba(0,0,0,0.07);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    z-index: 9999;
    will-change: transform;
    backface-visibility: hidden;
    transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  }

  body.header-hidden .site-header {
    pointer-events: none;
    transform: translateX(-50%) translateY(calc(-100% - 12px));
    box-shadow: 0 18px 40px rgba(90, 100, 112, 0.11);
  }

  body.nav-open .site-header,
  body.header-at-top .site-header,
  body.header-scrolled .site-header {
    pointer-events: auto;
  }

  .site-header::before {
    opacity: 0.28;
  }

  .brand-lockup,
  .brand-logo-wrap {
    width: auto;
    justify-content: flex-start;
  }

  .brand-logo-wrap {
    padding: 2px 0;
  }

  .brand-logo {
    width: 60px;
  }

  .mobile-header-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 10px 16px;
    border-radius: 999px;
    background: linear-gradient(135deg, #4d5963, #7ba8a9);
    color: #f7f3ee;
    box-shadow: 0 5px 10px rgba(77, 89, 99, 0.08);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
  }

  body.home-page .hero-copy h1,
  body.home-page h2,
  body.home-page h3,
  body.home-page .surface-title {
    color: #1A1A1A !important;
  }

  body.home-page .hero-copy h1 {
    color: #141414 !important;
  }

  body.home-page .hero-copy .hero-text,
  body.home-page .section-intro,
  body.home-page .action-note,
  body.home-page .info-card p,
  body.home-page .step-card p,
  body.home-page .faq-answer p,
  body.home-page li {
    color: #3F444A !important;
    opacity: 1 !important;
  }

  body.home-page .site-header {
    background: rgba(250,249,247,0.96) !important;
  }

  body.home-page .brand-logo {
    filter: saturate(1.08) contrast(1.16);
  }

  body.home-page .hero {
    background: linear-gradient(180deg, #FAF9F7 0%, #F7F3EE 100%);
  }

  body.home-page .section-label,
  body.home-page .panel-label,
  body.home-page .hero .eyebrow {
    background: rgba(255,255,255,0.94);
    border-color: rgba(0,0,0,0.08);
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    color: #4A8C8C;
  }

  .nav-toggle {
    min-width: 28px;
    min-height: 28px;
    padding: 4px;
    border-radius: 11px;
    background: rgba(255,255,255,0.82);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 5px 10px rgba(90, 100, 112, 0.04);
  }

  .site-nav {
    grid-column: 1 / -1;
    margin-top: 4px;
    padding: 8px;
    border-radius: 18px;
    background: rgba(255,255,255,0.98);
    box-shadow: 0 14px 28px rgba(90, 100, 112, 0.09);
  }

  .site-nav a,
  .site-nav .nav-cta {
    min-height: 48px;
    padding: 12px 14px;
    font-size: 14px;
    border-radius: 14px;
    box-shadow: none;
  }

  .site-nav .nav-cta {
    display: none;
  }

  .hero,
  .compact-hero,
  .content-section,
  .alt-section,
  .split-emphasis,
  .cta-section,
  .editorial-gallery,
  .proof-showcase,
  .site-footer {
    margin-bottom: 4px;
    padding-top: 16px;
    padding-bottom: 16px;
  }

  .hero {
    gap: 6px;
    padding-top: 4px;
    padding-bottom: 4px;
  }

  body.home-page .hero::before {
    content: none;
  }

  body.home-page .hero .eyebrow,
  body.home-page .hero-panel {
    display: none;
  }

  body.home-page .hero {
    grid-template-columns: 1fr;
  }

  body.home-page .hero-copy {
    padding-top: 2px;
  }

  h1 {
    font-size: clamp(17px, 5vw, 21px);
    line-height: 1.05;
  }

  h2 {
    font-size: clamp(20px, 5.9vw, 25px);
    line-height: 1.05;
  }

  .hero-text,
  p,
  li,
  .section-intro,
  .action-note,
  .credibility-points span,
  .authority-grid p {
    font-size: 13.5px;
    line-height: 1.4;
  }

  .surface-card,
  .info-card,
  .step-card,
  .comparison-card,
  .onboarding-panel,
  .faq-item,
  .footer-block {
    padding: 15px;
    border-radius: 22px;
  }

  .faq-item {
    padding: 0;
    border-radius: 16px;
  }

  .hero-copy {
    gap: 0;
  }

  .hero-copy h1 {
    margin: 6px 0 10px;
    padding-left: 2px;
    letter-spacing: -0.03em;
  }

  .hero-copy .hero-text {
    margin-bottom: 6px;
    max-width: 25ch;
    font-size: 12px;
  }

  .hero-signal-row {
    display: none;
  }

  .hero-signal-pill {
    width: 100%;
    padding: 8px 8px;
    font-size: 10.5px;
    letter-spacing: 0.02em;
    text-align: center;
    justify-content: center;
  }

  .hero .action-note {
    display: none;
  }

  .action-note {
    margin-top: 4px;
  }

  .section-side-shell {
    min-height: 98px;
    border-radius: 22px;
  }

  .section-split-head {
    gap: 12px;
    margin-bottom: 12px;
  }

  .core-pain-section {
    padding-top: 20px;
    padding-bottom: 10px;
  }

  .section-split-head-pain {
    gap: 12px;
    margin-bottom: 0;
  }

  .core-pain-section .section-label {
    margin-top: 2px;
    margin-bottom: 8px;
    padding: 0 14px;
    min-height: 34px;
  }

  .core-pain-section h2 {
    font-size: clamp(18px, 5.4vw, 22px);
    line-height: 1.04;
    margin-bottom: 8px;
  }

  .core-pain-section .section-intro {
    font-size: 12.5px;
    line-height: 1.34;
    max-width: 34ch;
  }

  .pain-graphic .section-side-shell {
    min-height: 132px;
    border-radius: 16px;
    overflow: visible;
  }

  .pain-chart-shell {
    aspect-ratio: 320 / 170;
    padding: 18px 20px 8px;
  }

  .pain-grid {
    margin-top: 16px;
    gap: 12px;
    grid-template-columns: minmax(0, 1fr);
  }

  .pain-card {
    min-height: 0;
    padding: 20px;
    background: #FFFFFF;
    border: none;
    border-radius: 16px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
  }

  .pain-card h3 {
    max-width: none;
    line-height: 1.08;
    margin-bottom: 8px;
  }

  .pain-card p {
    font-size: 13px;
    line-height: 1.34;
    margin: 0;
  }

  .pain-signal-stack {
    inset: 32px 24px 28px;
    gap: 14px;
  }

  .pain-signal-bar {
    height: 16px;
  }

  .pain-signal-glow-a {
    inset: auto auto 32px 28px;
    width: 110px;
    height: 26px;
  }

  .pain-signal-glow-b {
    inset: auto auto 72px 28px;
    width: 96px;
    height: 22px;
  }

  .flow-graphic .section-side-shell {
    overflow: hidden;
    border-radius: 20px;
    background:
      radial-gradient(54% 44% at 18% 18%, rgba(122, 173, 173, 0.18), transparent 62%),
      linear-gradient(180deg, rgba(255,255,255,0.90), rgba(242,247,246,0.76));
  }

  .flow-graphic-svg {
    inset: 10px 14px 12px;
    width: calc(100% - 28px);
    height: calc(100% - 22px);
  }

  .flow-graphic-path-base {
    stroke-width: 2.2;
    stroke: rgba(122, 173, 173, 0.4);
  }

  .flow-graphic-path-glow {
    stroke-width: 2.5;
    stroke-dasharray: 9 14;
  }

  .flow-node {
    width: 36px;
    height: 36px;
    border-radius: 13px;
    box-shadow: 0 8px 16px rgba(83, 118, 123, 0.06);
  }

  .flow-node::before {
    inset: 9px;
  }

  .flow-node::after {
    inset: -5px;
    border-radius: 16px;
  }

  .flow-node-a {
    top: calc(50% - 29px);
    left: 16px;
  }

  .flow-node-b {
    top: calc(50% - 29px);
    left: calc(50% - 29px);
  }

  .flow-node-c {
    top: calc(50% - 29px);
    right: 18px;
  }

  .flow-aura {
    filter: blur(7px);
    opacity: 0.58;
  }

  .proof-showcase {
    gap: 10px;
    margin-top: 18px;
    padding-top: 24px;
    padding-bottom: 22px;
  }

  .proof-showcase-head {
    gap: 6px;
  }

  .proof-showcase .section-label {
    min-height: 34px;
    margin-bottom: 8px;
    padding: 0 13px;
  }

  .proof-showcase + .content-section {
    margin-top: 28px;
  }

  .capability-section {
    padding-top: 14px;
    padding-bottom: 14px;
    border-radius: 20px;
    box-shadow: 0 10px 22px rgba(83, 118, 123, 0.05);
  }

  .capability-section::before,
  .capability-section::after,
  .capability-visual {
    display: none;
  }

  .capability-head {
    gap: 8px;
    margin-bottom: 10px;
  }

  .capability-copy .section-label {
    margin-bottom: 6px;
  }

  .capability-copy h2 {
    max-width: none;
    font-size: clamp(18px, 5.7vw, 22px);
    line-height: 1.08;
  }

  .capability-section .section-intro {
    margin-top: 8px;
    max-width: none;
    font-size: 11.5px;
    line-height: 1.32;
  }

  .capability-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .capability-grid .capability-card,
  .capability-grid .capability-card:nth-child(1),
  .capability-grid .capability-card:nth-child(2),
  .capability-grid .capability-card:nth-child(3),
  .capability-grid .capability-card:nth-child(4),
  .capability-grid .capability-card:nth-child(5) {
    grid-column: auto;
    min-height: 0;
  }

  .capability-card {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    grid-template-areas:
      "icon top"
      "icon title"
      "copy copy";
    column-gap: 9px;
    row-gap: 5px;
    padding: 10px;
    border-radius: 15px;
    box-shadow: 0 7px 16px rgba(83, 118, 123, 0.04);
  }

  .capability-card-top {
    grid-area: top;
    gap: 7px;
    align-items: center;
  }

  .capability-card .surface-title {
    min-width: 24px;
    height: 24px;
    font-size: 9px;
  }

  .capability-pill {
    padding: 4px 7px;
    font-size: 8.8px;
    letter-spacing: 0.04em;
  }

  .capability-card-icon {
    grid-area: icon;
    width: 34px;
    height: 34px;
    border-radius: 10px;
    margin-top: 1px;
  }

  .capability-card-icon svg {
    width: 15px;
    height: 15px;
  }

  .capability-card h3 {
    grid-area: title;
    font-size: 13.5px;
    line-height: 1.12;
    margin: 0;
    align-self: center;
  }

  .capability-card p {
    grid-area: copy;
    font-size: 11px;
    line-height: 1.28;
    margin: 0;
  }

  .capability-card-foot {
    display: none;
  }

  .steps-grid {
    gap: 12px;
  }

  .step-card .step-number {
    min-width: 30px;
    height: 30px;
    padding: 0 9px;
    margin-bottom: 8px;
    font-size: 10.5px;
  }

  .step-card,
  .steps-grid .step-card {
    padding: 11px;
  }

  .step-card h3,
  .info-card h3,
  .footer-link-text {
    font-size: clamp(15px, 4.6vw, 17px);
  }

  .step-card h3 {
    margin-bottom: 6px;
  }

  .step-card p,
  .info-card p {
    font-size: 14px;
    line-height: 1.42;
  }

  .cta-section .hero-actions,
  .hero-actions {
    gap: 8px;
  }

  .hero-actions {
    margin: 12px 0 6px;
  }

  body.home-page .hero .hero-actions {
    display: none;
  }

  .hero-actions .primary,
  .hero-actions .secondary,
  .cta-section .primary,
  .cta-section .secondary {
    min-height: 38px;
    padding: 8px 13px;
    font-size: 12px;
    box-shadow: 0 6px 12px rgba(77, 89, 99, 0.08);
  }

  body.home-page .cta-section {
    padding: 24px 18px 22px;
    border-radius: 36px;
  }

  body.home-page .cta-section p,
  body.home-page .cta-section .action-note {
    display: none;
  }

  body.home-page .cta-section h2 {
    margin-bottom: 16px;
    font-size: clamp(30px, 9vw, 42px);
    line-height: 0.98;
    letter-spacing: -0.04em;
  }

  body.home-page .cta-section .hero-actions {
    width: 100%;
    margin-top: 10px;
  }

  body.home-page .cta-section .primary.book-button {
    width: 100%;
    min-height: 58px;
    font-size: 15px;
  }

  .hero .hero-actions .primary {
    width: auto;
    min-width: 0;
  }

  body.book-page h1 {
    font-size: clamp(25px, 7.6vw, 31px);
  }

  body.book-page .hero-actions {
    position: sticky;
    bottom: 10px;
    z-index: 9;
    padding: 8px;
    border-radius: 20px;
    background: rgba(246, 240, 232, 0.88);
    backdrop-filter: blur(10px);
    box-shadow: 0 12px 24px rgba(90, 100, 112, 0.08);
  }

  body.book-page .hero-actions .secondary {
    background: rgba(255,255,255,0.82);
  }

  .faq-section {
    padding-top: 34px;
  }

  .site-footer {
    display: block;
    gap: 4px;
    padding: 2px 0 28px;
    margin-top: 4px;
    border-radius: 0;
    background: transparent;
    border: none;
    box-shadow: none;
  }

  .site-footer::before {
    display: none;
  }

  .footer-block {
    gap: 4px;
    padding: 5px;
    border-radius: 12px;
    background: rgba(255,255,255,0.40);
    box-shadow: 0 5px 10px rgba(83, 118, 123, 0.03);
  }

  .footer-note,
  .footer-trust-title,
  .footer-link-meta {
    display: none;
  }

  .footer-intro {
    display: none;
  }

  .footer-links {
    gap: 6px;
  }

  .footer-links a {
    grid-template-columns: 30px minmax(0, 1fr);
    align-items: center;
    min-height: 32px;
    gap: 6px;
    padding: 4px 6px;
    border-radius: 10px;
  }

  .footer-link-icon {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    align-self: center;
  }

  .footer-link-icon svg {
    width: 13px;
    height: 13px;
  }

  .footer-link-copy {
    gap: 0;
    align-self: center;
    min-width: 0;
  }

  .footer-link-text {
    font-size: 10.5px;
    white-space: nowrap;
    line-height: 1;
  }

  .footer-links a::after {
    display: none !important;
  }
}

@media (max-width: 560px) {
  .page-shell {
    padding-top: 78px;
    width: 100%;
  }

  .site-header {
    width: calc(100% - 16px);
    margin: 0;
    padding: 3px 5px;
    gap: 5px;
    border-radius: 14px;
  }

  .brand-logo {
    width: 60px;
  }

  .mobile-header-cta {
    min-height: 25px;
    padding: 0 7px;
    font-size: 8.5px;
  }

  .nav-toggle {
    min-width: 25px;
    min-height: 25px;
    padding: 3px;
  }

  .hero,
  .compact-hero,
  .content-section,
  .alt-section,
  .split-emphasis,
  .cta-section,
  .editorial-gallery,
  .proof-showcase,
  .site-footer {
    padding-left: 20px;
    padding-right: 20px;
    padding-top: 18px;
    padding-bottom: 18px;
  }

  body.book-page .hero-actions {
    bottom: 8px;
    padding: 8px;
  }
}

@media (max-width: 768px) {
  .site-header {
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    min-height: 60px;
    margin: 0;
    padding: 12px 12px;
    border-radius: 0;
    background: rgba(250, 249, 247, 0.85);
    border: 0;
    border-bottom: 1px solid rgba(0,0,0,0.07);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    backface-visibility: hidden;
  }

  body.header-hidden .site-header {
    transform: translateY(-100%);
    box-shadow: 0 18px 40px rgba(90, 100, 112, 0.11);
  }

  body.nav-open .site-header,
  body.header-at-top .site-header,
  body.header-scrolled .site-header {
    opacity: 1;
    pointer-events: auto;
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(246,239,230,0.86));
  }

  body.header-at-top .site-header {
    box-shadow: 0 12px 28px rgba(90, 100, 112, 0.08);
  }

  body.header-scrolled .site-header,
  body.nav-open .site-header {
    box-shadow: 0 18px 40px rgba(90, 100, 112, 0.11);
  }

  .brand-lockup,
  .brand-logo-wrap {
    min-width: 0;
  }

  .brand-logo-wrap {
    padding: 0;
    background: transparent;
    border: none;
    box-shadow: none;
  }

  .site-header::before,
  .brand-logo-wrap::before {
    content: none;
    display: none;
  }

  .hero::before,
  body.demo-page .hero::before,
  body.landing-page .hero::before,
  body.book-page .hero::before {
    content: none;
  }

  .hero-copy h1,
  .hero-copy .hero-text,
  .hero-copy .hero-actions {
    width: 100%;
    max-width: none;
  }

  main > section:not(.hero),
  main > footer {
    content-visibility: auto;
    contain-intrinsic-size: 720px;
  }

  body::before,
  body::after,
  .site-header,
  .page-transition-layer,
  .reveal-on-scroll,
  .phone-device,
  .phone-float-card,
  .hero-panel-orbit,
  .pain-signal-bar,
  .pain-signal-glow,
  .faq-question-icon {
    will-change: transform, opacity;
  }

  body.home-page .site-header {
    display: grid;
    align-items: center;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    min-height: 60px;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 6px;
    padding: 10px 16px;
    border-radius: 0;
    background: rgba(250, 249, 247, 0.85);
    border: 0;
    border-bottom: 1px solid rgba(0,0,0,0.07);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    backface-visibility: hidden;
  }

  body.home-page .brand-lockup {
    display: flex;
    width: auto;
    justify-content: flex-start;
    align-items: center;
  }

  body.home-page.header-at-top .site-header {
    opacity: 1;
    pointer-events: auto;
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(246,239,230,0.86));
    box-shadow: 0 12px 28px rgba(90, 100, 112, 0.08);
  }

  body.home-page.header-scrolled .site-header {
    opacity: 1;
    pointer-events: auto;
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(246,239,230,0.86));
    box-shadow: 0 18px 40px rgba(90, 100, 112, 0.11);
  }

  body.home-page.header-hidden .site-header {
    opacity: 1;
    pointer-events: none;
    transform: translateY(-100%);
    background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(246,239,230,0.86));
    box-shadow: 0 18px 40px rgba(90, 100, 112, 0.11);
  }

  body.home-page .site-header::before {
    display: none;
  }

  .site-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    z-index: 9999 !important;
    min-height: 60px;
    transition: transform 0.28s ease;
    will-change: transform;
    transform: translateY(0);
    background: rgba(250, 249, 247, 0.85);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(0,0,0,0.07);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  }

  body.home-page .brand-logo-wrap {
    padding: 0;
    min-width: 112px;
  }

  body.home-page .brand-logo {
    width: 112px;
  }

  body.home-page .mobile-header-cta {
    min-height: 44px;
    padding: 0 16px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 999px;
    box-shadow: 0 6px 14px rgba(77, 89, 99, 0.12);
  }

  body.home-page .nav-toggle {
    min-width: 44px;
    min-height: 44px;
    padding: 8px;
  }

  .service-clarity-section .trust-cards .info-card {
    display: grid;
    grid-template-columns: auto auto;
    align-items: center;
    align-content: start;
    justify-content: start;
    row-gap: 12px;
    column-gap: 10px;
    padding-top: 18px;
    min-height: 0;
  }

  .service-clarity-section .trust-cards .info-card:nth-child(1)::after,
  .service-clarity-section .trust-cards .info-card:nth-child(2)::after,
  .service-clarity-section .trust-cards .info-card:nth-child(3)::after {
    position: static;
    inset: auto;
    width: auto;
    min-width: 0;
    height: auto;
    padding: 4px 12px;
    justify-self: start;
    align-self: center;
  }

  .service-clarity-section .trust-cards .info-card .symbol-icon {
    margin-bottom: 0;
    grid-column: 2;
    grid-row: 1;
  }

  .service-clarity-section .trust-cards .info-card h3,
  .service-clarity-section .trust-cards .info-card p {
    grid-column: 1 / -1;
  }

  .service-clarity-section .trust-cards .info-card h3 {
    margin-bottom: 0;
  }

  .service-clarity-section .trust-cards .info-card p {
    margin-top: -2px;
  }

  body.home-page .hero .eyebrow {
    display: inline-flex;
    margin-bottom: 12px;
  }

  body.home-page .hero {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    min-height: 100svh;
    grid-template-columns: 1fr;
    gap: 28px;
    padding-top: 18px;
    padding-bottom: 24px;
    background:
      radial-gradient(56% 38% at 50% 24%, rgba(122, 173, 173, 0.06), rgba(122, 173, 173, 0.02) 34%, rgba(250, 249, 247, 0) 72%);
    border-bottom: 1px solid rgba(0,0,0,0.06);
  }

  body.home-page .hero-panel {
    display: block;
    padding: 20px;
    margin-top: 0;
    border-radius: 22px;
    box-shadow: 0 12px 28px rgba(90, 100, 112, 0.08);
  }

  body.home-page .hero-copy {
    width: 100%;
    min-height: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
  }

  body.home-page .hero-copy h1 {
    max-width: none;
    width: 100%;
    margin: 0 0 14px;
    padding-left: 0;
    font-size: clamp(36px, 10vw, 40px);
    line-height: 0.96;
    letter-spacing: -0.04em;
  }

  body.home-page .hero-copy .hero-text {
    width: 100%;
    max-width: none;
    margin: 0;
    font-size: 15px;
    line-height: 1.5;
    color: #5b676f;
  }

  body.home-page .hero-signal-row {
    display: grid;
    width: 100%;
    justify-items: start;
    gap: 10px;
    margin: 18px 0 0;
  }

  body.home-page .hero-signal-pill {
    width: auto;
    padding: 0;
    justify-content: flex-start;
    text-align: left;
    font-size: 13px;
  }

  body.home-page .hero .hero-actions {
    display: flex;
    width: 100%;
    margin: 16px 0 0;
    padding-top: 0;
  }

  body.home-page .hero .hero-actions .primary {
    width: 100%;
    min-height: 52px;
    padding: 0 18px;
    font-size: 14px;
    border-radius: 999px;
    justify-content: center;
  }

  .proof-showcase-head {
    justify-items: center;
    text-align: center;
  }

  body.demo-page .hero {
    gap: 16px;
    padding-top: 18px;
    min-height: auto;
    padding-bottom: 32px;
    background:
      radial-gradient(54% 36% at 50% 24%, rgba(122, 173, 173, 0.06), rgba(122, 173, 173, 0.02) 36%, rgba(250, 249, 247, 0) 74%);
    border-bottom: 1px solid rgba(0,0,0,0.06);
  }

  body.demo-page .hero-copy {
    width: 100%;
    min-height: 0;
    text-align: left;
  }

  body.demo-page .hero-copy .eyebrow {
    display: inline-flex;
    margin-bottom: 12px;
  }

  body.demo-page .hero-copy h1 {
    width: 100%;
    margin: 0 0 12px;
    padding-left: 0;
  }

  body.demo-page .hero-copy .hero-text {
    width: 100%;
    max-width: none;
    margin: 0;
  }

  body.demo-page .hero .hero-actions {
    width: 100%;
    margin: 20px 0 0;
  }

  body.demo-page .hero .hero-actions .primary {
    width: 100%;
    min-height: 52px;
    padding: 0 18px;
    font-size: 14px;
    border-radius: 999px;
    justify-content: center;
  }

  body.demo-page #steps {
    padding-top: 0;
    padding-bottom: 56px;
  }

  body.demo-page #steps .section-label {
    margin-bottom: 12px;
  }

  body.demo-page #steps h2 {
    margin: 0 0 24px;
  }

  body.demo-page #steps .steps-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  body.demo-page #steps .step-card {
    padding: 20px;
  }

  body.demo-page #steps .step-card .step-number {
    width: auto;
    min-width: 0;
    height: auto;
    padding: 4px 10px;
    margin-bottom: 8px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-variant-numeric: tabular-nums;
    line-height: 1;
  }

  body.demo-page #steps .step-card h3 {
    margin-bottom: 8px;
  }

  body.demo-page .surface-card:not(.conversation-card),
  body.demo-page .info-card,
  body.demo-page .comparison-card,
  body.demo-page .authority-grid article {
    min-height: 0;
    height: auto;
  }

  body.demo-page .comparison-grid.comparison-highlight {
    gap: 12px;
    padding: 0;
  }

  body.demo-page .comparison-card {
    padding: 20px;
    align-self: start;
  }

  body.demo-page .comparison-card ul {
    margin-top: 12px;
    gap: 8px;
  }

  .proof-showcase-head p {
    max-width: 34ch;
  }

  .proof-showcase .section-label,
  .core-pain-section .section-label,
  #how .section-label {
    min-height: 38px;
  }

  body.home-page #core-problem {
    padding-bottom: 10px;
  }

  .section-side-shell {
    min-height: 170px;
    border-radius: 30px;
  }

  .pain-graphic .section-side-shell {
    min-height: 0;
    overflow: hidden;
  }

  .pain-graphic,
  .pain-graphic .section-side-shell,
  .pain-chart-shell {
    width: 100%;
    max-width: none;
  }

  .pain-chart-shell {
    aspect-ratio: auto;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 18px;
  }

  .pain-signal-stack {
    position: relative;
    inset: auto;
    width: 100%;
    max-width: none;
    gap: 18px;
  }

  .pain-signal-bar {
    width: 100%;
    max-width: none;
    height: 16px;
  }

  .pain-signal-bar-ideal {
    width: 96%;
  }

  .pain-signal-bar-falloff {
    width: 72%;
  }

  .pain-signal-glow-a {
    inset: auto auto 14px 28px;
    width: min(38%, 128px);
    height: 24px;
  }

  .pain-signal-glow-b {
    inset: auto auto 38px 28px;
    width: min(32%, 108px);
    height: 20px;
  }

  .flow-graphic .section-side-shell {
    background:
      radial-gradient(52% 40% at 18% 18%, rgba(122, 173, 173, 0.14), transparent 64%),
      linear-gradient(180deg, rgba(255,255,255,0.78), rgba(241,247,246,0.56));
  }

  .flow-graphic-svg {
    inset: 0;
    width: 100%;
    height: 100%;
  }

  .flow-graphic-path-base {
    stroke: rgba(122, 173, 173, 0.34);
    stroke-width: 2.6;
  }

  .flow-graphic-path-glow {
    stroke: rgba(122, 173, 173, 0.74);
    stroke-width: 2.8;
    stroke-dasharray: 10 16;
    opacity: 0.96;
  }

  .flow-node {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    box-shadow: 0 12px 24px rgba(83, 118, 123, 0.06);
  }

  .flow-node::before {
    inset: 15px;
  }

  .flow-node::after {
    inset: -10px;
    border-radius: 24px;
    opacity: 0.52;
  }

  .flow-node-a { top: calc(50% - 29px); left: 11px; }
  .flow-node-b { top: calc(50% - 29px); left: calc(50% - 29px); }
  .flow-node-c { top: calc(50% - 29px); right: 9px; }

  .flow-aura {
    filter: blur(10px);
    opacity: 1;
  }

  .capability-section::before,
  .capability-section::after {
    display: block;
  }

  .capability-visual {
    display: block;
  }

  .capability-section {
    padding-top: 18px;
    padding-bottom: 18px;
    border-radius: 24px;
  }

  .capability-head {
    gap: 18px;
    margin-bottom: 18px;
  }

  .capability-visual-shell {
    min-height: 200px;
    padding: 18px;
  }

  .phone-flip-stage {
    perspective: 1800px;
    perspective-origin: 50% 38%;
    overflow: visible;
  }

  .phone-device {
    width: min(100%, 402px);
    opacity: 0;
    transform:
      rotateX(var(--phone-rotate-x-base, 24deg))
      rotateY(var(--phone-rotate-y-base, -14deg))
      translateY(var(--phone-lift-base, 44px))
      scale(var(--phone-scale-base, 0.94));
  }

  .phone-flip-stage.is-in-view .phone-device,
  .phone-flip-stage.animated .phone-device {
    opacity: 1;
    transform:
      rotateX(var(--phone-rotate-x, 0deg))
      rotateY(var(--phone-rotate-y, 0deg))
      translateY(var(--phone-lift, 0px))
      scale(var(--phone-scale, 1));
  }

  .phone-device-frame {
    padding: 12px;
    border-radius: 38px;
  }

  .phone-device-frame::before {
    border-radius: 32px;
  }

  .phone-device-screen {
    min-height: 590px;
    border-radius: 30px;
  }

  .phone-device-proof .phone-device-screen {
    min-height: 0;
  }

  .phone-device-screen-proof {
    padding: 18px 8px 8px;
    background: linear-gradient(180deg, #f5efe7 0%, #e9e2d8 100%);
  }

  .phone-device-screen img,
  .proof-chat-shot img,
  .proof-chat-shot-wide img {
    width: 100%;
    height: auto;
    object-fit: contain;
    object-position: 50% 50%;
    border-radius: 28px;
    background: rgba(255,255,255,0.96);
    padding: 6px;
    box-shadow: none;
  }

  .proof-chat-shot,
  .proof-chat-shot-wide {
    padding: 18px;
    border-radius: 30px;
    overflow: visible;
  }

  .phone-float-card {
    position: absolute;
    z-index: 3;
    display: grid;
    gap: 4px;
    max-width: 150px;
    margin-top: 0;
    padding: 10px 12px;
    border-radius: 15px;
  }

  .phone-float-card strong {
    font-size: 11px;
  }

  .phone-float-card span {
    font-size: 12px;
  }

  .phone-float-card-top {
    top: 76px;
    right: -12px;
  }

  .phone-float-card-bottom {
    bottom: 40px;
    left: -10px;
  }
}

@media (max-width: 560px) {
  body.home-page .site-header {
    min-height: 60px;
    padding: 10px 16px;
    gap: 5px;
  }

  body.home-page .brand-logo {
    width: 112px;
  }

  body.home-page .hero-panel {
    margin-top: 0;
    padding: 18px;
    border-radius: 20px;
  }

  body.home-page .hero-signal-row {
    margin-top: 18px;
    gap: 6px;
  }

  body.home-page .hero-signal-pill {
    font-size: 12.5px;
  }

  .pain-graphic .section-side-shell {
    min-height: 0;
  }

  .pain-chart-shell {
    aspect-ratio: auto;
    padding: 16px 20px 8px;
  }

  .core-pain-section h2 {
    font-size: clamp(17px, 5.2vw, 20px);
  }

  .core-pain-section .section-intro {
    font-size: 12px;
    line-height: 1.3;
    max-width: none;
  }

  .pain-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 12px;
  }

  .pain-card {
    padding: 20px;
  }

  .pain-card h3 {
    font-size: 13.5px;
    margin-bottom: 8px;
  }

  .pain-card p {
    font-size: 12px;
    line-height: 1.28;
  }

  .pain-signal-stack {
    gap: 8px;
  }

  .pain-signal-bar {
    height: 14px;
  }

  .pain-signal-bar-ideal {
    width: 100%;
  }

  .pain-signal-bar-falloff {
    width: 72%;
  }

  .pain-signal-glow-a {
    inset: auto auto 12px 22px;
    width: min(36%, 104px);
    height: 20px;
  }

  .pain-signal-glow-b {
    inset: auto auto 32px 22px;
    width: min(30%, 86px);
    height: 18px;
  }

  .phone-device {
    width: min(100%, 350px);
  }

  .phone-device-screen {
    min-height: 520px;
  }

  .phone-float-card {
    max-width: 132px;
    padding: 8px 10px;
  }

  .phone-float-card strong {
    font-size: 10px;
  }

  .phone-float-card span {
    font-size: 11px;
    line-height: 1.28;
  }

  .phone-float-card-top {
    top: 70px;
    right: -4px;
  }

.phone-float-card-bottom {
  left: -2px;
  bottom: 34px;
}
}


.mobile-flow-title,
.mobile-flow-copy,
.landing-flow-cta {
  display: none;
}

.desktop-flow-title,
.desktop-flow-copy {
  display: inline;
}

@media (max-width: 768px) {
  .page-shell {
    padding-top: 78px;
  }

  .site-header {
    position: fixed;
    top: max(0px, env(safe-area-inset-top));
    left: 0;
    right: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 6px;
    width: 100%;
    max-width: none;
    min-height: 60px;
    transform: translate3d(0, 0, 0);
    padding: 10px 16px;
    z-index: 1000;
  }

  .brand-lockup {
    width: auto;
    justify-content: flex-start;
    align-items: center;
  }

  .brand-logo-wrap {
    min-width: 112px;
    padding: 0;
    justify-content: flex-start;
  }

  .brand-logo {
    width: 112px;
  }

  .mobile-header-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0 14px;
    font-size: 10px;
    font-weight: 600;
    border-radius: 999px;
    background: #4A8C8C;
    color: #ffffff;
    box-shadow: 0 4px 16px rgba(74,140,140,0.22);
    white-space: nowrap;
  }

  .nav-toggle {
    min-width: 44px;
    min-height: 44px;
    padding: 8px;
  }

  body.header-hidden .site-header {
    transform: translate3d(0, -100%, 0);
  }

  .eyebrow,
  .section-label,
  .panel-label {
    font-size: 12px;
    letter-spacing: 0.18em;
    min-width: 38px;
    height: 38px;
    padding: 0 10px;
    border-radius: 999px;
    margin-bottom: 12px;
  }

  main > section:not(.hero),
  main > footer {
    padding-left: 20px;
    padding-right: 20px;
  }

  .hero {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    grid-template-columns: 1fr;
    min-height: 100svh;
    gap: 16px;
    padding: 18px 20px 24px;
  }

  .hero-panel {
    display: none;
  }

  .hero-copy {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    min-height: calc(100svh - 132px);
    text-align: left;
  }

  .hero-copy .eyebrow {
    display: inline-flex;
  }

  .hero-copy h1,
  .hero-copy .hero-text,
  .hero-copy .hero-actions,
  .hero-copy .action-note,
  .hero-copy .hero-signal-row {
    width: 100%;
    max-width: none;
  }

  body.home-page .faq-section {
    padding-top: 32px;
    padding-bottom: 32px;
    gap: 0;
  }

  body.home-page .faq-divider-row {
    margin: 0 auto 12px;
  }

  body.home-page .faq-item {
    padding: 0;
    border-radius: 14px;
    background: rgba(250,249,247,0.84);
    border-color: rgba(0,0,0,0.05);
  }

  body.home-page .faq-question {
    padding: 14px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.2;
  }

  body.home-page .faq-answer {
    padding: 0 14px 14px;
  }

  body.home-page .faq-answer p {
    font-size: 12px;
    line-height: 1.4;
    color: rgba(0,0,0,0.50);
  }

  body.home-page .proof-showcase {
    gap: 24px;
    margin: 48px 0;
    padding: 0 24px;
  }

  body.home-page .proof-showcase-head {
    gap: 10px;
    width: 100%;
    justify-items: start;
    text-align: left;
  }

  body.home-page .proof-showcase-head h2 {
    width: 100%;
    max-width: none;
  }

  body.home-page .proof-chat-shot,
  body.home-page .proof-chat-shot-wide {
    width: 100%;
    max-width: 100%;
    padding: 20px;
    overflow: hidden;
    border-radius: 22px;
    box-sizing: border-box;
  }

  body.home-page .phone-flip-stage {
    display: flex;
    justify-content: center;
    width: 100%;
    overflow: hidden;
  }

  body.home-page .phone-device,
  body.home-page .phone-device-chat,
  body.home-page .phone-device-proof {
    width: min(100%, 296px);
    max-width: 100%;
    transform: none;
    opacity: 1;
  }

  body.home-page .proof-showcase .phone-device-shadow {
    inset: auto 12% -12px;
    height: 30px;
    filter: blur(12px);
  }

  body.home-page .phone-device-screen img,
  body.home-page .proof-chat-shot img,
  body.home-page .proof-chat-shot-wide img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }

  .hero-copy h1 {
    margin: 0 0 12px;
    padding-left: 0;
  }

  .hero-copy .hero-text {
    margin: 0;
    max-width: none;
    font-size: 15px;
    line-height: 1.5;
    color: rgba(26,26,26,0.78);
  }

  body.home-page .hero,
  body.home-page .proof-showcase {
    background: #FAF9F7;
  }

  body.home-page {
    background: #FAF9F7;
  }

  body.home-page::before,
  body.home-page::after {
    content: none;
    display: none;
  }

  body.home-page .hero-copy h1 {
    color: #1A1A1A !important;
    font-weight: 700;
  }

  body.home-page .hero-copy .action-note,
  body.home-page .proof-showcase-head p,
  body.home-page .section-intro {
    color: #4A4F55 !important;
  }

  body.home-page .hero-copy .hero-text,
  body.home-page .info-card p,
  body.home-page .step-card p,
  body.home-page .faq-answer p,
  body.home-page .section-intro,
  body.home-page .proof-showcase-head p {
    color: #4A4F55 !important;
    opacity: 1 !important;
  }

  body.home-page h2,
  body.home-page h3,
  body.home-page .surface-title {
    color: #1A1A1A;
  }

  body.home-page .section-label,
  body.home-page .panel-label,
  body.home-page .hero .eyebrow {
    background: #FAF9F7;
    border-color: rgba(0,0,0,0.08);
    color: #4A8C8C;
  }

  body.home-page .hero-signal-pill {
    background: rgba(255,255,255,0.88);
    color: rgba(26,26,26,0.78);
    border: 1px solid rgba(0,0,0,0.06);
  }

  .hero .hero-actions {
    display: flex;
    width: 100%;
    margin: auto 0 0;
    padding-top: 24px;
  }

  .hero .hero-actions .primary,
  .hero .hero-actions .secondary,
  .cta-section .primary,
  .cta-section .secondary {
    width: 100%;
    min-height: 52px;
    padding: 0 18px;
    font-size: 14px;
    justify-content: center;
    border-radius: 999px;
  }

  .surface-card,
  .info-card,
  .step-card,
  .comparison-card,
  .onboarding-panel,
  .faq-item,
  .authority-grid article,
  .capability-card,
  .editorial-copy-card,
  .editorial-image-card,
  .footer-block {
    min-height: 0;
    height: auto;
    padding: 20px;
  }

  body.landing-page .landing-hero {
    padding-bottom: 24px;
  }

  body.landing-page .landing-hero .hero-copy {
    min-height: calc(100svh - 132px);
  }

  body.landing-page .landing-hero .hero-signal-row {
    margin-top: auto;
  }

  body.landing-page .landing-hero .hero-actions {
    margin: 16px 0 0;
    padding-top: 0;
  }

  body.landing-page .landing-hero .action-note {
    margin-top: 12px;
  }

  body.landing-page .landing-proof-section .proof-showcase-head p,
  body.landing-page #flow h2,
  body.landing-page #flow .landing-flow-extended-card {
    display: none;
  }

  body.landing-page #flow {
    padding-top: 18px;
    padding-bottom: 24px;
  }

  body.landing-page #flow .flow-grid {
    gap: 12px;
  }

  body.landing-page #flow .step-card {
    padding: 20px;
  }

  body.landing-page #flow .step-card h3 {
    margin-bottom: 8px;
  }

  body.landing-page #flow .step-card p {
    margin: 0;
  }

  body.landing-page #flow .desktop-flow-title,
  body.landing-page #flow .desktop-flow-copy {
    display: none;
  }

  body.landing-page #flow .mobile-flow-title,
  body.landing-page #flow .mobile-flow-copy,
  body.landing-page #flow .landing-flow-cta {
    display: inline;
  }

  body.landing-page #flow .landing-flow-cta {
    display: flex;
    width: 100%;
    margin: 8px 0 0;
  }
}

@media (max-width: 560px) {
  .page-shell {
    width: 100%;
  }

  .site-header {
    min-height: 60px;
    padding: 10px 10px;
  }

  .brand-logo-wrap {
    min-width: 108px;
  }

  .brand-logo {
    width: 108px;
  }

  .hero {
    padding-left: 20px;
    padding-right: 20px;
  }

.hero-copy .hero-text,
.hero-copy .action-note,
.hero-copy .hero-actions {
  max-width: none;
}
}

@media (min-width: 1024px) {
  body {
    padding-top: 76px;
  }

  .page-shell {
    padding-top: 50px;
  }

  .hero::before,
  body.demo-page .hero::before,
  body.landing-page .hero::before,
  body.book-page .hero::before {
    content: none !important;
    display: none !important;
    background: none !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  body.home-page {
    overflow-x: clip;
  }

  body.home-page .site-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100% !important;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin: 0 !important;
    padding: 16px 32px !important;
    min-height: 76px !important;
    box-sizing: border-box;
    transform: translateY(0) !important;
    border-radius: 0 !important;
    background: rgba(250, 249, 247, 0.92);
    border: 0 !important;
    border-bottom: 1px solid rgba(0,0,0,0.07);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 1px 0 rgba(0,0,0,0.05) !important;
  }

  body.home-page .hero,
  body.home-page .proof-showcase {
    background: #FAF9F7;
  }

  body.home-page .hero::after {
    content: none !important;
    display: none !important;
    background: none !important;
    box-shadow: none !important;
  }

  body.home-page.header-at-top .site-header,
  body.home-page.header-scrolled .site-header,
  body.home-page.nav-open .site-header {
    transform: translateY(0) !important;
  }

  body.home-page.header-hidden .site-header {
    transform: translateY(-100%) !important;
  }

  body.home-page .brand-lockup {
    position: relative;
    display: flex !important;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    flex: 0 0 auto;
    width: auto;
    min-width: 0;
    height: 40px;
    margin: 0;
    padding: 0;
  }

  body.home-page .brand-logo-wrap {
    display: flex !important;
    align-items: center;
    justify-content: flex-start;
    width: auto;
    min-width: 0;
    height: 40px;
    padding: 0;
  }

  body.home-page .brand-logo {
    display: block !important;
    width: auto !important;
    height: 40px !important;
    opacity: 1 !important;
    visibility: visible !important;
    object-fit: contain;
  }

  body.home-page .mobile-header-cta,
  body.home-page .nav-toggle,
  body.home-page .hero .eyebrow {
    display: none !important;
  }

  body.home-page .site-header::before,
  body.home-page .site-header::after {
    content: none !important;
    display: none !important;
  }

  body.home-page .site-header > * {
    position: relative;
    z-index: 2;
  }

  body.home-page nav,
  body.home-page .site-nav {
    display: flex !important;
    align-items: center;
    justify-content: flex-end;
    gap: 24px;
    margin-left: auto;
    min-height: 76px !important;
    padding: 16px 0 !important;
    width: auto;
    box-sizing: border-box;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  body.home-page nav a:not(.nav-cta),
  body.home-page .site-nav a:not(.nav-cta) {
    padding: 0;
  }

  body.home-page .nav-cta.book-button,
  body.home-page .primary.book-button {
    background: #4A8C8C !important;
    color: #fff !important;
    font-size: 15px !important;
    letter-spacing: 0.03em !important;
    padding: 14px 32px !important;
    box-shadow: 0 4px 16px rgba(74,140,140,0.30) !important;
  }

  body.home-page .proof-chat-shot-wide {
    position: relative;
    padding: 28px 32px;
    overflow: visible;
    border-radius: 30px;
    background:
      radial-gradient(56% 42% at 16% 18%, rgba(122, 188, 188, 0.12), transparent 68%),
      linear-gradient(180deg, rgba(255,255,255,0.66), rgba(240,244,244,0.58));
  }

  body.home-page .phone-flip-stage {
    display: flex;
    justify-content: center;
    width: 100%;
    overflow: visible;
  }

  body.home-page .phone-device,
  body.home-page .phone-device-chat,
  body.home-page .phone-device-proof {
    width: min(100%, 320px) !important;
    max-width: 320px !important;
  }

  body.home-page .phone-device-screen,
  body.home-page .phone-device-screen-proof,
  body.home-page .phone-proof-image-wrap {
    min-height: 0;
    overflow: hidden;
  }

  body.home-page .phone-device-screen-proof {
    border-radius: 34px;
  }

  body.home-page .phone-device-proof {
    opacity: 1 !important;
    transform: none !important;
  }

  body.home-page .phone-device-shadow {
    inset: auto 11% -18px;
    height: 32px;
    background: radial-gradient(circle at 50% 50%, rgba(0,0,0,0.22), transparent 74%);
    filter: blur(14px);
  }

  body.home-page .phone-device-frame {
    padding: 12px;
    border-radius: 42px;
    background: linear-gradient(180deg, #18191d 0%, #0f1013 100%);
    box-shadow: 0 24px 60px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.09);
  }

  body.home-page .phone-device-frame::before {
    inset: 7px;
    border-radius: 34px;
    border-color: rgba(255,255,255,0.07);
  }

  body.home-page .phone-device-screen {
    border-radius: 32px;
    background: linear-gradient(180deg, #f8f5ef 0%, #eee6db 100%);
  }

  body.home-page .phone-device-hardware {
    top: 14px;
    min-width: 118px;
    height: 30px;
    padding: 0 16px;
    border-radius: 18px;
    background: rgba(5,6,8,0.96);
  }

  body.home-page .pain-graphic .section-side-shell,
  body.home-page .pain-chart-shell {
    width: 100%;
    overflow: hidden;
  }

  body.home-page .pain-signal-stack {
    inset: 24px;
  }

  body.home-page .pain-signal-bar {
    width: 0;
    max-width: none;
  }

  body.home-page .pain-signal-bar-ideal {
    transition: width 1.4s ease-out;
  }

  body.home-page .pain-signal-bar-falloff {
    transition: width 1.4s ease-out 0.25s;
  }

  body.home-page .pain-signal-bar-ideal.animated {
    width: 92%;
  }

  body.home-page .pain-signal-bar-falloff.animated {
    width: 58%;
  }

  body.home-page .flow-graphic .section-side-shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    width: 100%;
    min-height: 136px;
    padding: 28px 36px;
    border-radius: 24px;
    overflow: hidden;
    background:
      radial-gradient(48% 40% at 18% 18%, rgba(123, 188, 188, 0.13), transparent 66%),
      radial-gradient(40% 34% at 84% 22%, rgba(196, 168, 130, 0.08), transparent 72%),
      linear-gradient(180deg, rgba(255,255,255,0.94), rgba(244,248,247,0.84));
    border: 1px solid rgba(226, 232, 230, 0.9);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 10px 28px rgba(124, 144, 145, 0.06);
  }

  body.home-page .flow-graphic-svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }

  body.home-page .flow-graphic-path-base {
    display: block;
    stroke: rgba(123, 188, 188, 0.3);
    stroke-width: 1.6px;
  }

  body.home-page .flow-graphic-path-glow {
    stroke: #7BBCBC;
    stroke-width: 1.6px;
    stroke-dasharray: 6 4;
    opacity: 1;
    animation: flowPathDrift 4.8s linear infinite;
  }

  body.home-page .flow-graphic-dot {
    display: block;
    opacity: 0.95;
    r: 5px;
  }

  body.home-page .flow-graphic-dot-a {
    fill: #7BBCBC;
    transition-delay: 260ms;
  }

  body.home-page .flow-graphic-dot-b {
    fill: #C4A882;
    transition-delay: 760ms;
  }

  body.home-page .flow-node {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 76px;
    width: 76px;
    height: 76px;
    margin: 0;
    border-radius: 20px;
    background: rgba(255,255,255,0.9);
    border: 1px solid rgba(229, 234, 233, 0.98);
    box-shadow: 0 8px 20px rgba(124, 144, 145, 0.06);
    opacity: 1;
    transform: none;
    transition: opacity 420ms ease-out, transform 420ms ease-out;
  }

  body.home-page .flow-node::before {
    inset: auto;
    width: 38px;
    height: 38px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: rgba(180,200,200,0.35);
    opacity: 1;
  }

  body.home-page .flow-node::after {
    content: "";
    inset: -8px;
    border-radius: 22px;
    border: 1px solid rgba(235,239,238,0.95);
    opacity: 0.96;
  }

  body.home-page .flow-electron,
  body.home-page .flow-aura {
    display: block;
  }

  body.home-page .phone-proof-image {
    object-position: center 10%;
  }

  body.home-page .phone-float-card {
    display: none;
  }
}

@media (min-width: 1024px) {
  body.home-page,
  body.home-page .page-shell,
  body.home-page main,
  body.home-page .hero,
  body.home-page .proof-showcase,
  body.home-page .split-section,
  body.home-page .content-section,
  body.home-page .capability-section,
  body.home-page .core-pain-section,
  body.home-page .cta-section,
  body.home-page .site-footer {
    background: #FAF9F7 !important;
  }

  body.home-page {
    color: #1A1A1A;
  }

  body.home-page .site-header {
    background: rgba(250,249,247,0.92) !important;
    border-bottom: 1px solid rgba(0,0,0,0.08) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: none !important;
  }

  body.home-page nav a:not(.nav-cta),
  body.home-page .site-nav a:not(.nav-cta) {
    color: rgba(26,26,26,0.72) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    letter-spacing: 0.01em !important;
  }

  body.home-page .nav-cta.book-button,
  body.home-page .primary.book-button {
    background: #4A8B8C !important;
    color: #FFFFFF !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    letter-spacing: 0.01em !important;
    border-radius: 100px !important;
    padding: 12px 28px !important;
    box-shadow: none !important;
    min-height: 0 !important;
  }

  body.home-page .nav-cta.book-button::before,
  body.home-page .primary.book-button::before,
  body.home-page .nav-cta.book-button::after,
  body.home-page .primary.book-button::after {
    content: none !important;
    display: none !important;
  }

  body.home-page .hero {
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr) !important;
    align-items: start !important;
    gap: 44px !important;
    padding: 28px 0 34px !important;
    min-height: 0 !important;
    background: #FAF9F7 !important;
  }

  body.home-page .hero::before,
  body.home-page .hero::after,
  body.home-page .hero-panel-orbit {
    content: none !important;
    display: none !important;
  }

  body.home-page .hero-copy {
    width: 100% !important;
    max-width: none !important;
    min-height: 0 !important;
    display: block !important;
    text-align: left !important;
  }

  body.home-page .hero-copy h1,
  body.home-page .hero-copy .hero-text,
  body.home-page .hero-copy .hero-actions,
  body.home-page .hero-copy .action-note,
  body.home-page .hero-copy .hero-signal-row {
    width: 100% !important;
    max-width: none !important;
  }

  body.home-page .hero-copy h1 {
    color: #F7F0E8 !important;
    font-size: clamp(52px, 5.8vw, 76px) !important;
    line-height: 0.96 !important;
    letter-spacing: -0.05em !important;
    margin: 0 0 18px !important;
  }

  body.home-page .hero-copy .hero-text,
  body.home-page .hero-copy .action-note,
  body.home-page .hero-copy p,
  body.home-page .split-copy-block p {
    color: rgba(247,240,232,0.72) !important;
  }

  body.home-page .hero-copy .hero-text {
    font-size: 18px !important;
    line-height: 1.58 !important;
    margin-bottom: 18px !important;
  }

  body.home-page .hero-signal-row {
    display: grid !important;
    gap: 10px !important;
    margin: 0 0 24px !important;
  }

  body.home-page .hero-signal-pill {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    width: fit-content !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    color: rgba(247,240,232,0.84) !important;
    font-size: 15px !important;
  }

  body.home-page .hero-signal-pill::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #7BBCBC;
    flex: 0 0 8px;
  }

  body.home-page .hero-actions {
    margin: 0 0 18px !important;
  }

  body.home-page .hero-panel {
    display: block !important;
    align-self: start !important;
    justify-self: end !important;
    width: 100% !important;
    max-width: 420px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
  }

  body.home-page .panel-label {
    display: none !important;
  }

  body.home-page .live-flow-card,
  body.home-page .surface-card.live-flow-card {
    background: #FFFFFF !important;
    border: 0 !important;
    border-radius: 16px !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06) !important;
    padding: 22px !important;
    overflow: visible !important;
    min-height: 0 !important;
  }

  body.home-page .live-flow-card::after {
    content: none !important;
    display: none !important;
  }

  body.home-page .live-flow-head {
    margin-bottom: 16px !important;
  }

  body.home-page .live-flow-head .surface-title {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    color: #1A1A1A !important;
    font-size: 12px !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
  }

  body.home-page .live-flow-head .surface-title::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #7BBCBC;
    flex: 0 0 8px;
  }

  body.home-page .live-flow-pulse {
    color: rgba(26,26,26,0.55) !important;
    font-size: 12px !important;
    letter-spacing: 0.14em !important;
  }

  body.home-page .live-flow-pulse::before {
    width: 8px !important;
    height: 8px !important;
    background: rgba(26,26,26,0.25) !important;
    box-shadow: none !important;
    animation: none !important;
  }

  body.home-page .live-flow-list {
    gap: 12px !important;
  }

  body.home-page .live-flow-item {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 10px 0 !important;
    grid-template-columns: 44px minmax(0, 1fr) !important;
    gap: 14px !important;
    box-shadow: none !important;
  }

  body.home-page .live-flow-item + .live-flow-item {
    border-top: 1px solid rgba(0,0,0,0.06) !important;
  }

  body.home-page .flow-step-label {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    background: #FAF9F7 !important;
    border: 1px solid rgba(0,0,0,0.08) !important;
    color: rgba(26,26,26,0.72) !important;
    box-shadow: none !important;
  }

  body.home-page .live-flow-item strong {
    color: #1A1A1A !important;
  }

  body.home-page .live-flow-item p {
    color: rgba(26,26,26,0.55) !important;
  }

  body.home-page .live-flow-metrics {
    display: none !important;
  }

  body.home-page .split-section.split-emphasis {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr) !important;
    gap: 44px !important;
    align-items: start !important;
    padding-top: 28px !important;
    border-top: 1px solid rgba(0,0,0,0.08) !important;
    background: transparent !important;
  }

  body.home-page .split-lead-block h2,
  body.home-page .split-copy-block h2,
  body.home-page .proof-showcase-head h2,
  body.home-page .content-section h2 {
    color: #1A1A1A !important;
  }

  body.home-page .proof-showcase,
  body.home-page .capability-section,
  body.home-page .core-pain-section,
  body.home-page .cta-section,
  body.home-page .site-footer {
    border: 0 !important;
    box-shadow: none !important;
  }
}

body.home-page .proof-showcase.proof-gallery {
  background: #FAF9F7 !important;
}

body.home-page .proof-chat-shot.proof-chat-shot-wide.phone-container {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 72px 190px;
  background: #FAF9F7 !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

body.home-page .proof-chat-shot.proof-chat-shot-wide.phone-container img {
  padding: 0 !important;
  background: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body.home-page .proof-showcase .phone-device.phone-device-proof.phone-frame {
  width: 308px !important;
  max-width: 308px !important;
  opacity: 0;
  transform: translate3d(0, 24px, 0);
  transform-style: flat;
  transition: opacity 600ms ease-out, transform 600ms ease-out !important;
}

body.home-page .proof-showcase .phone-device-shadow {
  inset: auto 4% -30px;
  height: 58px;
  background: radial-gradient(circle at 50% 50%, rgba(0,0,0,0.20), transparent 72%);
  filter: blur(18px);
}

body.home-page .proof-showcase .phone-device-frame {
  padding: 10px;
  border-radius: 42px;
  background: #050608;
  box-shadow: 0 32px 80px rgba(0,0,0,0.20);
}

body.home-page .proof-showcase .phone-device-frame::before {
  inset: 5px;
  border-radius: 36px;
  border: 1px solid rgba(255,255,255,0.08);
}

body.home-page .proof-showcase .phone-device-hardware {
  top: 8px;
  min-width: 92px;
  height: 22px;
  padding: 0 12px;
  border-radius: 16px;
  background: rgba(5,6,8,0.98);
}

body.home-page .proof-showcase .phone-device-screen,
body.home-page .proof-showcase .phone-device-screen-proof {
  width: 100%;
  min-height: 0 !important;
  aspect-ratio: 1179 / 2556;
  padding: 0 !important;
  border-radius: 34px;
  overflow: hidden;
  background: #000 !important;
  isolation: isolate;
}

body.home-page .proof-showcase .phone-device-proof .phone-device-screen::before,
body.home-page .proof-showcase .phone-device-proof .phone-device-screen::after,
body.home-page .proof-showcase .phone-proof-image-wrap::after {
  content: none !important;
  display: none !important;
}

body.home-page .proof-showcase .phone-proof-image-wrap {
  display: flex;
  align-items: stretch;
  justify-content: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: inherit;
  background: #000;
}

body.home-page .proof-showcase .phone-proof-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 40% 38%;
  display: block;
  filter: saturate(1.02) contrast(1.03);
}

body.home-page .proof-showcase .phone-float-card {
  display: grid !important;
  gap: 4px;
  max-width: 200px;
  padding: 14px 18px;
  border-radius: 14px;
  background: rgba(255,255,255,0.96);
  border: 0;
  box-shadow: 0 6px 24px rgba(0,0,0,0.10);
  backdrop-filter: none;
  opacity: 0;
  transition: opacity 500ms ease-out, transform 500ms ease-out;
  will-change: transform, opacity;
}

body.home-page .proof-showcase .phone-float-card strong {
  margin-bottom: 4px;
  color: #4A8B8C;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.home-page .proof-showcase .phone-float-card span {
  color: rgba(26,26,26,0.60);
  font-size: 13px;
  line-height: 1.4;
}

body.home-page .proof-showcase .phone-float-card-top {
  top: 22%;
  left: calc(50% + 136px);
  right: auto;
  bottom: auto;
  transform: translateX(40px);
}

body.home-page .proof-showcase .phone-float-card-bottom {
  top: 72%;
  left: calc(50% - 344px);
  right: auto;
  bottom: auto;
  transform: translateX(-40px);
}

@media (max-width: 768px) {
  body.home-page .proof-chat-shot.proof-chat-shot-wide.phone-container {
    padding-left: 80px;
    padding-right: 80px;
    padding-top: 56px;
    padding-bottom: 56px;
  }

  body.home-page .proof-showcase .phone-device.phone-device-proof.phone-frame {
    width: 240px !important;
    max-width: 240px !important;
  }

  body.home-page .proof-showcase .phone-device-screen,
  body.home-page .proof-showcase .phone-device-screen-proof {
    aspect-ratio: 240 / 420;
  }

  body.home-page .proof-showcase .phone-float-card {
    max-width: 160px;
    padding: 10px 14px;
  }

  body.home-page .proof-showcase .phone-float-card span {
    font-size: 12px;
  }

  body.home-page .proof-showcase .phone-float-card-top {
    top: 24%;
    left: calc(50% + 92px);
  }

  body.home-page .proof-showcase .phone-float-card-bottom {
    top: 72%;
    left: calc(50% - 252px);
  }
}

body.modal-open {
  overflow: hidden;
}

.founder-section {
  padding-top: 10px;
}

.founder-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  padding: 30px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(250,249,247,0.90), rgba(244,239,230,0.84));
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}

.background-logo {
  position: absolute;
  right: 10%;
  top: 50%;
  width: min(520px, 68%);
  height: min(320px, 65%);
  transform: translateY(-50%);
  background-image: url('/assets/helodesk-logo.svg?v=20260515-logo1');
  background-repeat: no-repeat;
  background-position: center right;
  background-size: contain;
  opacity: 0;
  pointer-events: none;
  transition: opacity 1.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.background-logo.visible {
  opacity: 0.12;
}

.founder-avatar {
  width: 64px;
  height: 64px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 2px solid rgba(123,188,188,0.7);
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  color: #4A8B8C;
  font-size: 28px;
  font-weight: 700;
  background: rgba(255,255,255,0.9);
}

.founder-copy h2 {
  max-width: 12ch;
}

.founder-copy {
  position: relative;
  z-index: 1;
}

.core-problem-commercial-note {
  margin-top: 14px;
  color: #3f4b52;
  font-weight: 600;
}

.founder-copy p {
  max-width: 62ch;
}

.founder-signoff {
  margin-top: 6px;
  font-style: normal;
  color: rgba(26,26,26,0.6);
}

.footer-enquiry-line {
  margin-top: 12px;
  color: rgba(26,26,26,0.62);
  font-size: 14px;
  line-height: 1.6;
}

.footer-legal-links {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 8px;
}

.footer-legal-links a {
  font-size: 13px;
  color: rgba(26,26,26,0.58);
}

.faq-item a {
  color: var(--brand-primary);
  text-decoration-color: rgba(95, 132, 135, 0.42);
  text-underline-offset: 0.18em;
}

.journey-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1400;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.journey-modal-shell {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1401;
  width: min(calc(100vw - 32px), 520px);
  max-width: 520px;
  padding: 40px 36px;
  border-radius: 24px;
  background: #FAF9F7;
  box-shadow: 0 24px 80px rgba(0,0,0,0.18);
}

.journey-modal-shell[hidden],
.journey-modal-overlay[hidden] {
  display: none !important;
}

.journey-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 0;
  background: rgba(26,26,26,0.06);
  color: rgba(26,26,26,0.5);
  font-size: 22px;
  cursor: pointer;
}

.journey-modal-content {
  display: grid;
  gap: 16px;
}

.journey-progress {
  display: flex;
  gap: 8px;
}

.journey-progress-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(26,26,26,0.12);
}

.journey-progress-dot.is-active {
  background: #4A8B8C;
}

.journey-modal-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #4A8B8C;
}

.journey-modal-title {
  margin: 0;
  color: #1A1A1A;
  font-size: clamp(30px, 4vw, 42px);
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.journey-modal-copy {
  margin: 0;
  color: rgba(26,26,26,0.55);
  font-size: 16px;
  line-height: 1.6;
}

.journey-options {
  display: grid;
  gap: 10px;
}

.journey-option,
.journey-back,
.journey-inline-link {
  font: inherit;
}

.journey-option {
  width: 100%;
  text-align: left;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(74,139,140,0.16);
  background: rgba(255,255,255,0.88);
  color: #1A1A1A;
}

.journey-option:hover,
.journey-option.is-selected {
  border-color: rgba(74,139,140,0.42);
  background: rgba(123,188,188,0.1);
}

.journey-modal-actions {
  display: grid;
  gap: 12px;
}

.journey-modal-actions.stacked > * {
  width: 100%;
  justify-content: center;
  text-align: center;
}

.journey-modal-divider {
  height: 1px;
  background: rgba(0,0,0,0.08);
}

.journey-inline-link,
.journey-back {
  width: fit-content;
  border: 0;
  background: transparent;
  color: #4A8B8C;
  padding: 0;
}

.journey-email-card {
  display: grid;
  gap: 10px;
  padding: 18px;
  border-radius: 18px;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(0,0,0,0.06);
}

.journey-email-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 14px;
  color: rgba(26,26,26,0.6);
}

.journey-email-row strong,
.journey-email-label {
  color: #1A1A1A;
}

.journey-email-draft {
  width: 100%;
  min-height: 170px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(74,139,140,0.16);
  background: rgba(250,249,247,0.96);
  color: #1A1A1A;
  font: inherit;
  line-height: 1.55;
  resize: vertical;
  box-sizing: border-box;
}

.journey-fit-message {
  display: grid;
  gap: 14px;
}

@media (max-width: 768px) {
  .founder-card {
    grid-template-columns: 1fr;
    padding: 22px;
  }

  .journey-modal-shell {
    width: min(calc(100vw - 20px), 520px);
    padding: 28px 20px;
  }

  .journey-modal-title {
    font-size: clamp(26px, 7vw, 34px);
  }
}

body.home-page {
  background: #FAF9F7;
}

body.home-page .hero,
body.home-page #core-problem,
body.home-page #how,
body.home-page .process-section,
body.home-page .cta-section,
body.home-page #faq,
body.home-page .site-footer {
  background: #FAF9F7 !important;
}

body.home-page .proof-showcase,
body.home-page #handles,
body.home-page .proof-results-section,
body.home-page #pricing,
body.home-page .founder-section,
body.home-page .lead-capture-section {
  background: #F2EEEA !important;
}

@media (min-width: 1024px) {
  body.home-page h1,
  body.home-page .hero-copy h1 {
    font-size: 72px !important;
    font-weight: 800 !important;
    line-height: 1.05 !important;
    letter-spacing: -0.03em !important;
  }

  body.home-page h2,
  body.home-page .section-split-copy h2,
  body.home-page .content-section h2 {
    font-size: 52px !important;
    font-weight: 700 !important;
    line-height: 1.1 !important;
    letter-spacing: -0.02em !important;
  }

  body.home-page h3 {
    font-size: 24px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
  }

  body.home-page p,
  body.home-page .hero-text,
  body.home-page .section-intro,
  body.home-page li {
    font-size: 17px !important;
    line-height: 1.65 !important;
  }
}

body.home-page .section-label,
body.home-page .surface-title {
  color: #4A8B8C;
}

.hero-urgency-pill {
  display: inline-flex;
  align-items: center;
  margin-top: 4px;
  padding: 8px 18px;
  border-radius: 999px;
  background: rgba(74,139,140,0.08);
  border: 1px solid rgba(74,139,140,0.20);
  color: #4A8B8C;
  font-size: 13px;
  font-weight: 500;
}

.proof-results-section {
  padding-top: 34px;
}

.proof-results-section h2 {
  max-width: 12ch;
}

.proof-results-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-top: 28px;
}

.proof-result-card {
  display: grid;
  gap: 14px;
  padding: 28px 24px;
  border-radius: 20px;
  background: #FFFFFF;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}

.proof-result-card h3 {
  margin: 0;
}

.proof-result-card p {
  margin: 0;
}

.proof-result-visual {
  overflow: hidden;
  border-radius: 18px;
  background: rgba(250,249,247,0.9);
  border: 1px solid rgba(0,0,0,0.06);
}

.proof-result-image img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  object-position: top center;
  display: block;
}

.proof-quote {
  margin: 0;
  padding: 20px;
  border-radius: 18px;
  background: #1A1A1A;
  color: rgba(255,255,255,0.86);
  font-size: 16px;
  line-height: 1.6;
}

.proof-status-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.proof-status-row span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(74,139,140,0.08);
  color: #4A8B8C;
  font-size: 13px;
  font-weight: 600;
}

@media (max-width: 860px) {
  .proof-results-grid {
    grid-template-columns: 1fr;
  }
}

.process-section {
  padding-top: 24px;
}

.process-stack {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}

.process-step-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px 24px;
  border-left: 2px solid #7BBCBC;
  border-radius: 12px;
  background: #FFFFFF;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}

.process-step-number {
  flex: 0 0 auto;
  min-width: 32px;
  color: #4A8B8C;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.process-step-card h3,
.process-step-card p {
  margin: 0;
}

.pricing-section-refined .section-intro {
  max-width: 54ch;
}

.pricing-grid-refined {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 28px;
}

.pricing-card-refined {
  display: grid;
  gap: 10px;
  padding: 30px 26px;
  border-radius: 20px;
  background: #FFFFFF;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  cursor: pointer;
}

.pricing-card-refined:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
}

.pricing-card-refined.standard {
  transform: translateY(-6px);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
}

.pricing-card-refined.standard:hover {
  transform: translateY(-8px);
}

.pricing-card-refined p {
  margin: 0;
}

.pricing-card-refined ul {
  display: none;
}

.pricing-card-highlight {
  background: linear-gradient(180deg, rgba(74,139,140,0.96), rgba(91,163,163,0.96));
}

.pricing-card-highlight,
.pricing-card-highlight h3,
.pricing-card-highlight p,
.pricing-card-highlight li,
.pricing-card-highlight .surface-title {
  color: #FFFFFF !important;
}

.phone-flip-stage .iphone-mockup {
  opacity: 0;
  transform: translateY(30px) !important;
  transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.phone-flip-stage .iphone-mockup.reveal {
  opacity: 1;
  transform: translateY(0) !important;
}

.lead-capture-section {
  display: grid;
  gap: 14px;
  justify-items: center;
  text-align: center;
  padding-top: 34px;
}

.pre-faq-section {
  background: linear-gradient(180deg, #f8f8f8 0%, #ffffff 100%);
  padding: 80px 0;
  text-align: center;
  justify-items: center;
}

.pre-faq-section h2 {
  color: #1a1a1a;
  font-size: 2.5rem;
  margin-bottom: 24px;
}

.pre-faq-cta-button {
  background: var(--brand-primary) !important;
  padding: 16px 48px !important;
  border-radius: 40px !important;
  font-weight: 600;
  transition: all 0.3s ease;
}

.pre-faq-cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 16px rgba(90, 157, 157, 0.2);
}

.lead-capture-section h2 {
  max-width: 13ch;
}

.lead-capture-section .section-intro {
  max-width: 38ch;
}

.lead-capture-form {
  width: min(100%, 620px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
}

.lead-capture-input {
  min-height: 54px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(74,139,140,0.18);
  background: rgba(250,249,247,0.96);
  color: #1A1A1A;
  font: inherit;
}

.lead-capture-input:focus {
  outline: 2px solid rgba(74,139,140,0.25);
  border-color: #4A8B8C;
}

.lead-capture-button {
  min-height: 54px;
}

.lead-capture-note,
.lead-capture-success {
  margin: 0;
  font-size: 12px;
  color: rgba(26,26,26,0.55);
}

.lead-capture-note a,
.lead-capture-success a {
  color: #4A8B8C;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.lead-capture-success {
  color: #4A8B8C;
}

.footer-legal-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.footer-legal-links a {
  background: transparent !important;
  border: none !important;
  min-height: 0 !important;
  padding: 0 !important;
}

body.home-page .site-footer {
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: none;
}

@media (max-width: 960px) {
  .proof-results-grid,
  .pricing-grid-refined {
    grid-template-columns: 1fr;
  }

  .lead-capture-form {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .hero-urgency-pill {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .proof-result-image img {
    height: 220px;
  }

  .process-step-card {
    padding: 18px 18px 18px 20px;
  }

  .pricing-card-refined,
  .proof-result-card {
    padding: 22px 18px;
  }
}

@media (max-width: 960px) {
  body.home-page .hero-copy {
    padding: 32px 26px 28px;
    border-radius: 24px;
  }

  body.home-page .hero-signal-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin: 8px 0 22px !important;
  }

  body.home-page .hero-signal-pill {
    padding: 9px 12px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,0.08) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    font-size: 13px !important;
    line-height: 1 !important;
  }

  body.home-page .hero-signal-pill::before {
    content: none !important;
  }

  body.home-page .proof-chat-shot.proof-chat-shot-wide.phone-container {
    padding: 42px 24px 68px;
  }

  body.home-page .proof-showcase .phone-device.phone-device-proof.phone-frame {
    width: min(100%, 286px) !important;
    max-width: 286px !important;
  }

  body.home-page .proof-showcase .phone-float-card-top {
    top: auto;
    bottom: -22px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
  }

  body.home-page .proof-showcase .phone-float-card-bottom {
    display: none !important;
  }
}

body.home-page .hero-copy h1 {
  color: #F7F0E8 !important;
}

body.home-page .hero-copy .hero-text,
body.home-page .hero-copy .action-note,
body.home-page .hero-copy .hero-mini-note,
body.home-page .hero-copy p,
body.home-page .hero-signal-pill {
  color: rgba(247,240,232,0.74) !important;
}

body.home-page .pre-faq-section {
  position: relative;
  padding: 100px 0;
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  overflow: hidden;
  text-align: center;
  justify-items: center;
}

body.home-page .pre-faq-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(90, 157, 157, 0.08) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(90, 157, 157, 0.06) 0%, transparent 50%);
  animation: breathe 8s ease-in-out infinite;
}

body.home-page .pre-faq-section > * {
  position: relative;
  z-index: 1;
}

@keyframes breathe {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

body.home-page .pre-faq-section .eyebrow {
  color: #5a9d9d;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 16px;
}

body.home-page .pre-faq-section h2 {
  color: #1a1a1a;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 24px;
}

body.home-page .pre-faq-section p {
  color: #4a4a4a;
  font-size: 1.125rem;
  line-height: 1.6;
  max-width: 700px;
  margin: 0 auto 40px;
}

body.home-page .pre-faq-section .subtext {
  color: #6a6a6a;
  font-size: 0.9375rem;
  margin-top: 24px;
  margin-bottom: 0;
}

body.home-page .book-walkthrough-btn {
  background: #5a9d9d !important;
  color: white !important;
  padding: 16px 48px !important;
  border-radius: 40px !important;
  font-weight: 600;
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

body.home-page .book-walkthrough-btn::before {
  content: '' !important;
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  animation: flash 3s ease-in-out infinite;
}

body.home-page .book-walkthrough-btn::after {
  content: none !important;
  display: none !important;
}

@keyframes flash {
  0%, 100% { left: -100%; }
  50% { left: 100%; }
}

body.home-page .book-walkthrough-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(90, 157, 157, 0.3) !important;
}

body.home-page .book-walkthrough-btn:hover::before {
  animation-play-state: paused;
}

body.home-page .pre-faq-cta-button {
  background: #5a9d9d !important;
  color: white !important;
  padding: 18px 56px !important;
  border-radius: 50px !important;
  font-weight: 600;
  font-size: 1.125rem;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(90, 157, 157, 0.25);
  position: relative;
  z-index: 1;
}

body.home-page .pre-faq-cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(90, 157, 157, 0.35) !important;
}

body.home-page .pricing-card-refined,
body.home-page .five-jobs-section .capability-card {
  background: white;
  border-radius: 16px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: default;
}

body.home-page .pricing-card-refined:hover,
body.home-page .five-jobs-section .capability-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.12);
}

body.home-page .pricing-card-refined.standard {
  transform: translateY(-8px);
  box-shadow: 0 16px 32px rgba(90, 157, 157, 0.15);
}

body.home-page .pricing-card-refined.standard:hover {
  transform: translateY(-12px);
  box-shadow: 0 20px 40px rgba(90, 157, 157, 0.2);
}

@media (prefers-reduced-motion: reduce) {
  body.home-page .pre-faq-section::before,
  body.home-page .book-walkthrough-btn::before {
    animation: none !important;
  }
}

body.home-page {
  padding-top: 70px !important;
}

body.home-page .page-shell {
  padding-top: 0 !important;
}

body.home-page .site-header {
  padding: 8px 40px !important;
}

body.home-page .site-header,
body.home-page nav {
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

body.home-page nav.scroll-down,
body.home-page .site-header.scroll-down {
  transform: translateY(-100%) !important;
}

body.home-page nav.scroll-up,
body.home-page .site-header.scroll-up {
  transform: translateY(0) !important;
}

body.home-page .brand-lockup,
body.home-page .brand-logo-wrap {
  min-height: 48px;
}

body.home-page .brand-logo {
  height: 48px !important;
  width: auto !important;
}

body.home-page .five-jobs-section,
body.home-page #pricing,
body.home-page .standard-section {
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding-left: calc(50vw - 50% + 40px) !important;
  padding-right: calc(50vw - 50% + 40px) !important;
}

body.home-page .standard-section {
  position: relative;
  overflow: hidden;
}

body.home-page .background-logo {
  position: absolute;
  right: 8%;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0;
  transition: opacity 2s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: none;
  z-index: 0;
}

body.home-page .background-logo.visible {
  opacity: 0.12 !important;
}

@media (max-width: 768px) {
  body.home-page {
    padding-top: 70px !important;
  }

  body.home-page .page-shell {
    padding-top: 0 !important;
  }

  body.home-page .site-header {
    padding: 8px 20px !important;
  }

  body.home-page .brand-logo {
    height: 40px !important;
  }

  body.home-page .five-jobs-section,
  body.home-page #pricing,
  body.home-page .standard-section {
    padding-left: calc(50vw - 50% + 20px) !important;
    padding-right: calc(50vw - 50% + 20px) !important;
  }
}

body.home-page .weak-zone-section {
  background: #f8f9fa;
  padding: 100px 40px;
}

body.home-page .weak-zone-section .eyebrow {
  color: #5a9d9d;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 16px;
}

body.home-page .weak-zone-section h2 {
  color: #1a1a1a !important;
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 32px;
}

body.home-page .weak-zone-section p {
  color: #4a4a4a;
  font-size: 1.125rem;
  line-height: 1.6;
  max-width: 760px;
  margin: 0;
}

body.home-page .weak-zone-section .controlled-momentum {
  color: #5a9d9d;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 48px;
}

body.home-page .comparison-section {
  padding-top: 44px;
}

body.home-page .comparison-section h2 {
  color: #1a1a1a !important;
}

body.home-page .comparison-grid-premium {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-top: 60px;
}

body.home-page .comparison-side {
  background: white;
  border-radius: 16px;
  padding: 48px 40px;
  position: relative;
}

body.home-page .comparison-side.problem {
  background: #fef5f5;
  border: 2px solid #f5e5e5;
}

body.home-page .comparison-side.solution {
  background: #f0faf5;
  border: 2px solid #e0f5ea;
}

body.home-page .side-label {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 32px;
}

body.home-page .side-label .icon {
  font-size: 1.25rem;
}

body.home-page .problem .side-label {
  color: #c73e3a;
}

body.home-page .solution .side-label {
  color: #2d7a54;
}

body.home-page .flow-visual {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 32px;
  min-height: 280px;
}

body.home-page .step {
  background: white;
  padding: 16px 20px;
  border-radius: 8px;
  text-align: center;
  font-weight: 500;
}

body.home-page .step-label {
  display: block;
}

body.home-page .step.faded {
  opacity: 0.4;
  border: 1px dashed #ddd;
}

body.home-page .step.active {
  background: #5a9d9d;
  color: white;
  box-shadow: 0 2px 8px rgba(90, 157, 157, 0.2);
}

body.home-page .gap-zone {
  background: #fff;
  border: 2px dashed #e5a5a1;
  padding: 24px 20px;
  border-radius: 8px;
  text-align: center;
  margin: 12px 0;
}

body.home-page .gap-text {
  display: block;
  font-weight: 700;
  color: #c73e3a;
  font-size: 1.125rem;
  margin-bottom: 8px;
}

body.home-page .time-loss {
  display: block;
  font-size: 0.875rem;
  color: #999;
  font-style: italic;
}

body.home-page .arrow-flow {
  text-align: center;
  font-size: 1.5rem;
  color: #5a9d9d;
  font-weight: bold;
}

body.home-page .outcome {
  padding: 20px;
  border-radius: 8px;
  text-align: center;
}

body.home-page .outcome.negative {
  background: #fef0f0;
  border: 1px solid #f5d5d5;
}

body.home-page .outcome.positive {
  background: #e8f5f0;
  border: 1px solid #d0e8e0;
}

body.home-page .outcome strong {
  display: block;
  font-size: 1.125rem;
  margin-bottom: 8px;
}

body.home-page .outcome.negative strong {
  color: #c73e3a;
}

body.home-page .outcome.positive strong {
  color: #2d7a54;
}

body.home-page .outcome p {
  font-size: 0.9375rem;
  color: #666;
  margin: 0;
}

body.home-page .timeline-stack {
  display: grid;
  gap: 18px;
}

body.home-page .timeline-row {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 18px 18px;
  border-radius: 12px;
  background: rgba(255,255,255,0.86);
}

body.home-page .timeline-time {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.92);
  font-size: 0.875rem;
  font-weight: 700;
  color: #1a1a1a;
}

body.home-page .timeline-copy strong {
  display: block;
  color: #1a1a1a;
  margin-bottom: 6px;
}

body.home-page .timeline-copy p {
  margin: 0;
  font-size: 0.9375rem;
  color: #666;
}

body.home-page .gap-row {
  border: 1px dashed #e5a5a1;
  background: rgba(255,255,255,0.78);
}

body.home-page .success-row {
  border: 1px solid #c5e5d5;
  background: rgba(255,255,255,0.92);
}

body.home-page .timeline-impact {
  padding: 22px 20px;
  border-radius: 12px;
  text-align: center;
}

body.home-page .negative-impact {
  background: #fef0f0;
  border: 1px solid #f5d5d5;
}

body.home-page .positive-impact {
  background: #e8f5f0;
  border: 1px solid #d0e8e0;
}

body.home-page .impact-value {
  display: block;
  margin-bottom: 8px;
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

body.home-page .negative-impact .impact-value {
  color: #c73e3a;
}

body.home-page .positive-impact .impact-value {
  color: #2d7a54;
}

body.home-page .timeline-impact p {
  margin: 0;
  font-size: 0.9375rem;
  color: #666;
}

body.home-page .phone-flip-stage .iphone-mockup {
  opacity: 0;
  transform: translateY(20px) !important;
  transition: opacity 1s cubic-bezier(0.4, 0, 0.2, 1), transform 1s cubic-bezier(0.4, 0, 0.2, 1);
}

body.home-page .phone-flip-stage .iphone-mockup.reveal {
  opacity: 1;
  transform: translateY(0) !important;
}

@media (max-width: 860px) {
  body.home-page .comparison-grid-premium {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  body.home-page .comparison-side {
    padding: 30px 24px;
  }

  body.home-page .weak-zone-section {
    padding: 72px 20px;
  }

  body.home-page .weak-zone-section h2 {
    font-size: 2.4rem;
  }
}

@media (min-width: 768px) {
  body.home-page {
    padding-top: 70px !important;
  }

  body.home-page .site-header {
    background: rgba(255, 255, 255, 0.72) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    padding: 8px 40px !important;
  }

  body.home-page .brand-logo {
    height: 48px !important;
    width: auto !important;
  }

  body.home-page nav.scroll-down,
  body.home-page .site-header.scroll-down {
    transform: translateY(-100%) !important;
  }

  body.home-page nav.scroll-up,
  body.home-page .site-header.scroll-up {
    transform: translateY(0) !important;
  }

  body.home-page .background-logo {
    display: block;
  }

  body.home-page .phone-flip-stage .iphone-mockup {
    transform: translateY(20px) !important;
  }

  body.home-page .phone-flip-stage .iphone-mockup.reveal {
    transform: translateY(0) !important;
  }

  body.home-page .comparison-grid-premium {
    grid-template-columns: 1fr 1fr;
    gap: 40px;
  }

  body.home-page .five-jobs-section,
  body.home-page #pricing,
  body.home-page .standard-section {
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  body.home-page .content-section {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}

@media (max-width: 767px) {
  body.home-page {
    padding-top: 70px !important;
  }

  body.home-page .page-shell {
    padding-top: 0 !important;
    width: 100% !important;
  }

  body.home-page .site-header,
  body.home-page nav {
    transform: translateY(0) !important;
  }

  body.home-page .site-header {
    background: rgba(250, 249, 247, 0.94) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    padding: 8px 16px !important;
  }

  body.home-page .site-nav.scroll-down,
  body.home-page .site-nav.scroll-up,
  body.home-page .site-header.scroll-down,
  body.home-page .site-header.scroll-up {
    transform: translateY(0) !important;
  }

  body.home-page .brand-logo {
    height: 36px !important;
    width: auto !important;
  }

  body.home-page .background-logo {
    display: none !important;
  }

  body.home-page .phone-flip-stage .iphone-mockup,
  body.home-page .phone-flip-stage .iphone-mockup.reveal {
    transform: none !important;
  }

  body.home-page .live-flow-track-line,
  body.home-page .live-flow-track-ball {
    animation: none !important;
  }

  body.home-page .live-flow-track-ball {
    display: none !important;
  }

  body.home-page .comparison-grid-premium {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }

  body.home-page .five-jobs-section,
  body.home-page #pricing,
  body.home-page .standard-section {
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding-top: 48px !important;
    padding-bottom: 48px !important;
    padding-left: calc(50vw - 50% + 20px) !important;
    padding-right: calc(50vw - 50% + 20px) !important;
  }

  body.home-page .content-section {
    padding-top: 48px;
    padding-bottom: 48px;
  }

  body.home-page .comparison-side,
  body.home-page .pricing-card-refined,
  body.home-page .five-jobs-section .capability-card {
    padding: 24px !important;
  }
}

body.home-page .proof-section {
  padding: 100px 0;
  background: white;
}

body.home-page .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

body.home-page .proof-section > h2 {
  text-align: center;
  max-width: 12ch;
  margin-left: auto;
  margin-right: auto;
}

body.home-page .metrics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin: 60px 0;
}

body.home-page .metric-card {
  background: #fafafa;
  border: 2px solid #e5e5e5;
  border-radius: 16px;
  padding: 40px 32px;
  text-align: center;
  transition: all 0.3s ease;
}

body.home-page .metric-card.highlight {
  background: linear-gradient(135deg, #f0faf5 0%, #e8f5f0 100%);
  border-color: #c5e5d5;
  transform: translateY(-6px);
  box-shadow: 0 12px 28px rgba(90, 157, 157, 0.12);
}

body.home-page .metric-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08);
}

body.home-page .metric-card.highlight:hover {
  transform: translateY(-8px);
}

body.home-page .metric-value {
  font-size: 3.5rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 12px;
  line-height: 1;
}

body.home-page .metric-card.highlight .metric-value {
  color: #2d7a54;
}

body.home-page .metric-label {
  font-size: 1.125rem;
  font-weight: 500;
  color: #333;
  margin-bottom: 8px;
}

body.home-page .metric-compare {
  font-size: 0.875rem;
  color: #999;
  font-style: italic;
}

body.home-page .proof-visual-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 40px;
  margin-top: 60px;
}

body.home-page .dashboard-mockup {
  background: white;
  border: 2px solid #e5e5e5;
  border-radius: 16px;
  overflow: hidden;
}

body.home-page .dashboard-header {
  background: #5a9d9d;
  color: white;
  padding: 16px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

body.home-page .dashboard-title {
  font-weight: 600;
  font-size: 0.9375rem;
}

body.home-page .live-indicator {
  font-size: 0.875rem;
  opacity: 0.9;
  animation: pulse 2s ease-in-out infinite;
}

body.home-page .dashboard-content {
  padding: 24px;
}

body.home-page .status-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  background: #fafafa;
  border-radius: 8px;
  margin-bottom: 12px;
}

body.home-page .status-row:last-child {
  margin-bottom: 0;
}

body.home-page .status-label {
  font-size: 0.9375rem;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 8px;
}

body.home-page .status-label::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}

body.home-page .status-label.handled::before {
  background: #5a9d9d;
}

body.home-page .status-label.waiting::before {
  background: #f5a623;
}

body.home-page .status-label.booked::before {
  background: #2d7a54;
}

body.home-page .status-label.needs-attention::before {
  background: #c73e3a;
}

body.home-page .status-count {
  font-size: 1.25rem;
  font-weight: 700;
  color: #1a1a1a;
}

body.home-page .chat-proof {
  display: flex;
  flex-direction: column;
}

body.home-page .proof-label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #5a9d9d;
  margin-bottom: 16px;
}

body.home-page .chat-screenshot {
  background: #fafafa;
  border: 2px solid #e5e5e5;
  border-radius: 16px;
  overflow: hidden;
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

body.home-page .chat-screenshot img {
  max-width: 100%;
  height: auto;
}

body.home-page .workflow-panel {
  padding: 40px 28px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(229, 229, 229, 0.9);
  border-radius: 24px;
  box-shadow: 0 18px 42px rgba(16, 22, 28, 0.08);
}

body.home-page .workflow-section {
  padding: 80px 0;
  background: white;
}

body.home-page .workflow-section .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

body.home-page .workflow-section .section-headline {
  text-align: center;
  font-size: 2.5rem;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 60px;
  max-width: none;
}

body.home-page .workflow-steps {
  display: flex;
  align-items: flex-start;
  gap: 0;
  margin-top: 60px;
  position: relative;
}

body.home-page .workflow-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
}

body.home-page .workflow-section .step-number {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 24px;
  box-shadow: 0 4px 12px rgba(90, 157, 157, 0.25);
}

body.home-page .workflow-section .step-content {
  max-width: 280px;
}

body.home-page .workflow-section .step-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: 12px;
  line-height: 1.4;
}

body.home-page .workflow-section .step-description {
  font-size: 0.9375rem;
  color: #666;
  line-height: 1.6;
  margin: 0;
}

body.home-page .workflow-connector {
  flex: 0 0 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-top: 32px;
}

body.home-page .connector-line {
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #5a9d9d 0%, #4a8d8d 100%);
  position: relative;
}

body.home-page .connector-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #5a9d9d;
  position: absolute;
  animation: travelDot 3s ease-in-out infinite;
  box-shadow: 0 0 8px rgba(90, 157, 157, 0.4);
}

@keyframes travelDotHorizontal {
  0%, 100% {
    left: 0;
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 1;
  }

  100% {
    left: 100%;
    opacity: 0;
  }
}

body.home-page .connector-dot {
  animation-name: travelDotHorizontal;
}

body.home-page .workflow-steps .workflow-connector:nth-of-type(2) .connector-dot {
  animation-delay: 1.5s;
}

@media (max-width: 767px) {
  body.home-page .metrics-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  body.home-page .metric-card.highlight {
    transform: none;
  }

  body.home-page .proof-visual-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  body.home-page .workflow-panel {
    padding: 28px 20px;
  }

  body.home-page .workflow-section .section-headline,
  body.home-page .workflow-section h2 {
    font-size: 1.875rem;
    margin-bottom: 48px;
  }

  body.home-page .workflow-steps {
    flex-direction: column;
    gap: 32px;
    margin-top: 48px;
  }

  body.home-page .workflow-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  body.home-page .workflow-section .step-number {
    width: 56px;
    height: 56px;
    font-size: 1.25rem;
    margin-bottom: 20px;
  }

  body.home-page .workflow-connector {
    flex: 0 0 auto;
    width: 2px;
    height: 60px;
    margin: 0 auto;
  }

  body.home-page .connector-line {
    width: 2px;
    height: 100%;
    background: linear-gradient(180deg, #5a9d9d 0%, #4a8d8d 100%);
  }

  body.home-page .workflow-section .step-content {
    max-width: 100%;
    padding: 0 20px;
  }

  body.home-page .workflow-section .step-title {
    font-size: 1rem;
  }

  body.home-page .workflow-section .step-description {
    font-size: 0.875rem;
  }

  body.home-page .connector-dot {
    left: 50%;
    transform: translateX(-50%);
    box-shadow: 0 0 8px rgba(90, 157, 157, 0.4);
    animation: travelDotVertical 3s ease-in-out infinite;
  }

  @keyframes travelDotVertical {
    0%, 100% {
      top: 0;
      opacity: 0;
    }

    10% {
      opacity: 1;
    }

    90% {
      opacity: 1;
    }

    100% {
      top: 100%;
      opacity: 0;
    }
  }

  body.home-page .connector-dot {
    animation-name: travelDotVertical;
  }

  body.home-page .workflow-steps .workflow-connector:nth-of-type(2) .connector-dot {
    animation-delay: 1.5s;
  }
}

body.home-page .cta-button,
body.home-page .book-walkthrough-btn,
body.home-page .send-playbook-btn {
  position: relative;
  overflow: hidden;
  background: #5a9d9d !important;
  color: white !important;
  padding: 16px 48px;
  border-radius: 40px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
}

body.home-page .cta-button::before,
body.home-page .book-walkthrough-btn::before,
body.home-page .send-playbook-btn::before {
  content: '' !important;
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  animation: ctaFlash 3s ease-in-out infinite;
}

@keyframes ctaFlash {
  0%, 100% {
    left: -100%;
  }

  50% {
    left: 100%;
  }
}

body.home-page .cta-button:hover::before,
body.home-page .book-walkthrough-btn:hover::before,
body.home-page .send-playbook-btn:hover::before {
  animation-play-state: paused;
}

body.home-page .cta-button:hover,
body.home-page .book-walkthrough-btn:hover,
body.home-page .send-playbook-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(90, 157, 157, 0.3) !important;
}

@media (prefers-reduced-motion: reduce) {
  body.home-page .cta-button::before,
  body.home-page .book-walkthrough-btn::before,
  body.home-page .send-playbook-btn::before {
    animation: none !important;
  }
}

body.home-page .hero.hero-section {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 80vh;
  padding: 120px 0;
  background: #2a2a2a;
  border-radius: 32px;
  overflow: hidden;
}

body.home-page .hero.hero-section::before {
  content: none;
}

body.home-page .hero-section .container,
body.home-page .five-jobs-section .container,
body.home-page .pricing-section .container,
body.home-page .pre-faq-booking-section .container,
body.home-page .timeline-comparison-section .container {
  width: min(1200px, calc(100% - 80px));
  margin: 0 auto;
}

body.home-page .hero-content-centered {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

body.home-page .hero-headline {
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1.15;
  margin: 0 0 32px;
  color: white;
  max-width: none;
}

body.home-page .hero-description {
  font-size: 1.25rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.9);
  margin: 0 0 24px;
}

body.home-page .hero-subtext {
  font-size: 1.125rem;
  color: rgba(255, 255, 255, 0.8);
  margin: 0 0 40px;
  font-weight: 500;
}

body.home-page .hero-footnote {
  font-size: 0.9375rem;
  color: rgba(255, 255, 255, 0.6);
  margin: 24px 0 0;
}

body.home-page .five-jobs-section {
  padding: 100px 0;
  background: #f5f5f5;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

body.home-page .five-jobs-section .section-description {
  text-align: center;
  color: #666;
  font-size: 1.125rem;
  max-width: 700px;
  margin: 0 auto 80px;
}

body.home-page .jobs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 32px;
  max-width: 1200px;
  margin: 0 auto;
}

body.home-page .job-card {
  background: white;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body.home-page .job-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

body.home-page .browser-chrome {
  background: linear-gradient(180deg, #f5f5f5 0%, #ebebeb 100%);
  padding: 12px 16px;
  border-bottom: 1px solid #d5d5d5;
  display: flex;
  align-items: center;
  gap: 16px;
}

body.home-page .window-dots {
  display: flex;
  gap: 6px;
}

body.home-page .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

body.home-page .dot.red {
  background: #ff5f56;
}

body.home-page .dot.yellow {
  background: #ffbd2e;
}

body.home-page .dot.green {
  background: #27c93f;
}

body.home-page .chrome-title {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
}

body.home-page .card-number {
  font-size: 0.75rem;
  font-weight: 700;
  color: #5a9d9d;
}

body.home-page .card-category {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #999;
}

body.home-page .card-content {
  padding: 32px 24px;
}

body.home-page .card-icon {
  font-size: 2rem;
  margin-bottom: 16px;
}

body.home-page .card-title {
  font-size: 1.375rem;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 12px;
}

body.home-page .card-description {
  font-size: 0.9375rem;
  color: #666;
  line-height: 1.6;
  margin: 0 0 16px;
}

body.home-page .card-outcome {
  font-size: 0.875rem;
  color: #5a9d9d;
  font-weight: 500;
  padding-top: 16px;
  border-top: 1px solid #e8e8e8;
  margin: 0;
}

body.home-page .pre-faq-booking-section {
  padding: 0;
  margin: 80px 0;
}

body.home-page .dark-container {
  background: #2a2a2a;
  color: white;
  padding: 80px 0;
  border-radius: 24px;
  max-width: 1200px;
  margin: 0 auto;
}

body.home-page .booking-content {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

body.home-page .dark-container .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 16px;
}

body.home-page .dark-container .section-headline {
  font-size: 3rem;
  font-weight: 700;
  color: white;
  margin: 0 0 24px;
  line-height: 1.2;
  max-width: none;
}

body.home-page .dark-container .section-description {
  font-size: 1.125rem;
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.6;
  margin: 0 0 40px;
}

body.home-page .dark-container .section-subtext {
  font-size: 0.9375rem;
  color: rgba(255, 255, 255, 0.7);
  margin-top: 24px;
}

body.home-page .pricing-section {
  padding: 100px 0;
  background: #f5f1ed;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

body.home-page .pricing-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}

body.home-page .pricing-section > .section-label,
body.home-page .pricing-section > h2,
body.home-page .pricing-section > .section-intro,
body.home-page .pricing-section > .cards-section {
  width: min(1200px, calc(100% - 80px));
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 767px) {
  body.home-page .hero.hero-section {
    min-height: auto;
    padding: 88px 0 72px;
    border-radius: 0;
  }

  body.home-page .hero-section .container,
  body.home-page .five-jobs-section .container,
  body.home-page .pricing-section .container,
  body.home-page .pre-faq-booking-section .container,
  body.home-page .timeline-comparison-section .container {
    width: calc(100% - 40px);
  }

  body.home-page .hero-headline {
    font-size: 2.25rem;
  }

  body.home-page .hero-description {
    font-size: 1.125rem;
  }

  body.home-page .jobs-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  body.home-page .five-jobs-section .section-headline,
  body.home-page .five-jobs-section h2 {
    font-size: 1.875rem;
  }

  body.home-page .dark-container {
    border-radius: 0;
    padding: 60px 20px;
  }

  body.home-page .dark-container .section-headline {
    font-size: 2rem;
  }

  body.home-page .pricing-section {
    padding: 80px 0;
  }

  body.home-page .pricing-section > .section-label,
  body.home-page .pricing-section > h2,
  body.home-page .pricing-section > .section-intro,
  body.home-page .pricing-section > .cards-section {
    width: calc(100% - 40px);
  }
}

body.home-page .pricing-card.standard,
body.home-page .pricing-card-refined.standard {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
  color: white;
  transform: translateY(-12px);
  box-shadow: 0 20px 40px rgba(90, 157, 157, 0.25);
  position: relative;
  z-index: 2;
}

body.home-page .pricing-card.standard:hover,
body.home-page .pricing-card-refined.standard:hover {
  transform: translateY(-16px);
  box-shadow: 0 24px 48px rgba(90, 157, 157, 0.3);
}

body.home-page .pricing-card.standard .card-label,
body.home-page .pricing-card-refined.standard .card-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.95);
}

body.home-page .app-icon.message {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

body.home-page .app-icon.message::before {
  content: '💬';
  font-size: 12px;
  filter: grayscale(1) brightness(10);
}

body.home-page .proof-section {
  padding: 100px 0;
  background: #fafafa;
}

body.home-page .proof-section .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

body.home-page .proof-section .section-headline {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 80px;
  color: #1a1a1a;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

body.home-page .proof-section .metrics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  max-width: 1000px;
  margin: 0 auto;
}

body.home-page .proof-section .metric-card {
  background: white;
  border: 2px solid #e8e8e8;
  border-radius: 16px;
  padding: 40px 32px;
  text-align: center;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
  transform: none;
}

body.home-page .proof-section .metric-card.speed {
  background: linear-gradient(180deg, #ffffff 0%, #f0f8ff 100%);
  border-color: #d5e5f5;
}

body.home-page .proof-section .metric-card.conversion {
  background: linear-gradient(180deg, #f0faf5 0%, #ffffff 100%);
  border-color: #d0e8e0;
}

body.home-page .proof-section .metric-card.reliability {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
  border-color: #e8e8e8;
}

body.home-page .proof-section .metric-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
}

body.home-page .metric-icon {
  font-size: 2.5rem;
  margin-bottom: 20px;
  opacity: 0.9;
}

body.home-page .metric-number {
  font-size: 4rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 12px;
  line-height: 1;
}

body.home-page .proof-section .metric-label {
  font-size: 1.125rem;
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: 8px;
}

body.home-page .metric-context {
  font-size: 0.875rem;
  color: #999;
  font-style: italic;
  line-height: 1.5;
}

@media (max-width: 767px) {
  body.home-page .proof-section .metrics-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  body.home-page .proof-section .section-headline {
    font-size: 1.875rem;
  }

  body.home-page .metric-number {
    font-size: 3rem;
  }
}

body.home-page .pricing-section {
  padding: 120px 0;
  background: #f5f1ed;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

body.home-page .pricing-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}

body.home-page .pricing-cards-grid,
body.home-page .pricing-grid-refined.pricing-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 56px;
  max-width: 1200px;
  margin: 0 auto;
}

body.home-page .pricing-card {
  background: white;
  border: 2px solid #e5e5e5;
  border-radius: 20px;
  padding: 48px 36px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}

body.home-page .pricing-card.pilot {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

body.home-page .pricing-card.pilot:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

body.home-page .pricing-card.standard,
body.home-page .pricing-card-refined.standard {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
  color: white;
  transform: translateY(-24px);
  box-shadow: 0 24px 48px rgba(90, 157, 157, 0.3);
  border: 2px solid #5a9d9d;
  z-index: 2;
}

body.home-page .pricing-card.standard .card-label,
body.home-page .pricing-card-refined.standard .card-label {
  color: rgba(255, 255, 255, 0.95);
}

body.home-page .pricing-card.standard .pricing-headline,
body.home-page .pricing-card-refined.standard .pricing-headline {
  font-size: 2rem;
  font-weight: 700;
  margin: 24px 0 16px;
  line-height: 1.2;
  color: white;
}

body.home-page .pricing-card.standard .pricing-description,
body.home-page .pricing-card-refined.standard .pricing-description {
  color: rgba(255, 255, 255, 0.9);
  font-size: 1rem;
}

body.home-page .pricing-card.standard .pricing-features,
body.home-page .pricing-card-refined.standard .pricing-features {
  color: rgba(255, 255, 255, 0.95);
}

body.home-page .pricing-card.standard:hover,
body.home-page .pricing-card-refined.standard:hover {
  transform: translateY(-28px);
  box-shadow: 0 28px 56px rgba(90, 157, 157, 0.35);
}

body.home-page .pricing-card.scoped {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

body.home-page .pricing-card.scoped:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

body.home-page .pricing-card .pricing-headline,
body.home-page .pricing-card-refined .pricing-headline,
body.home-page .pricing-card h3,
body.home-page .pricing-card-refined h3 {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 24px 0 16px;
  line-height: 1.25;
}

body.home-page .pricing-card .pricing-description,
body.home-page .pricing-card-refined .pricing-description,
body.home-page .pricing-card p,
body.home-page .pricing-card-refined p {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: #666;
}

@media (max-width: 767px) {
  body.home-page .pricing-cards-grid,
  body.home-page .pricing-grid-refined.pricing-cards-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  body.home-page .pricing-card.standard,
  body.home-page .pricing-card-refined.standard {
    transform: translateY(0);
  }

  body.home-page .pricing-card.standard:hover,
  body.home-page .pricing-card-refined.standard:hover {
    transform: translateY(-4px);
  }
}

/* ============================================
 HERO SECTION FORCE FIX - v8
 Add at END of CSS file to override conflicts
 ============================================ */

.hero-section {
  background: #2a2a2a !important;
  color: white !important;
  padding: 120px 0 !important;
  min-height: 80vh !important;
  display: flex !important;
  align-items: center !important;
}

.hero-section *,
.hero-section .container,
.hero-section .hero-content-centered {
  background: transparent !important;
}

.hero-section h1,
.hero-section .hero-headline {
  color: white !important;
  font-size: 3.5rem !important;
  font-weight: 700 !important;
  line-height: 1.15 !important;
  margin-bottom: 32px !important;
}

.hero-section p,
.hero-section .hero-description {
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 1.25rem !important;
}

.hero-section .hero-subtext {
  color: rgba(255, 255, 255, 0.8) !important;
  font-size: 1.125rem !important;
}

.hero-section .hero-footnote {
  color: rgba(255, 255, 255, 0.6) !important;
  font-size: 0.9375rem !important;
}

.hero-content-centered {
  max-width: 800px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

/* v8 timeline */
.timeline-comparison-section {
  padding: 100px 0;
  background: #fafafa;
}

.timeline-comparison-section .section-headline {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 60px;
  color: #1a1a1a;
}

.timeline-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  max-width: 1100px;
  margin: 0 auto;
}

.timeline-side {
  background: white;
  border-radius: 20px;
  padding: 48px 36px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.timeline-side.problem {
  background: linear-gradient(180deg, #fef5f5 0%, #fff 100%);
  border: 2px solid #f5d5d5;
}

.timeline-side.solution {
  background: linear-gradient(180deg, #f0faf5 0%, #fff 100%);
  border: 2px solid #d0e8e0;
}

.timeline-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
}

.timeline-label .icon {
  font-size: 1.25rem;
}

.problem .timeline-label {
  color: #c73e3a;
}

.solution .timeline-label {
  color: #2d7a54;
}

.ios-notification {
  background: #ffffff;
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  border: 1px solid #e8e8e8;
}

.ios-notification.unread {
  opacity: 0.6;
}

.notification-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.app-info {
  display: flex;
  align-items: center;
  gap: 8px;
}

.app-icon {
  width: 20px;
  height: 20px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}

.app-icon.message {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
}

.app-icon.message::before {
  content: '💬';
  filter: grayscale(1) brightness(10);
}

.app-icon.message-check {
  background: linear-gradient(135deg, #2d7a54 0%, #257a54 100%);
}

.app-icon.message-check::before {
  content: '✓';
  color: white;
  font-weight: bold;
}

.app-icon.calendar {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
}

.app-icon.calendar::before {
  content: '📅';
  filter: grayscale(0.3);
  font-size: 11px;
}

.app-name {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #1a1a1a;
}

.notification-time {
  font-size: 0.75rem;
  color: #8e8e93;
}

.notification-content {
  margin-left: 28px;
}

.notification-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: #1a1a1a;
  margin-bottom: 4px;
}

.notification-preview {
  font-size: 0.8125rem;
  color: #8e8e93;
  line-height: 1.4;
}

.time-indicator {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
  position: relative;
}

.time-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #5a9d9d;
  flex-shrink: 0;
}

.time-line {
  flex: 1;
  height: 2px;
  background: linear-gradient(90deg, #5a9d9d 0%, transparent 100%);
}

.time-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: #5a9d9d;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.outcome-section {
  margin-top: auto;
  padding-top: 24px;
  border-top: 1px solid #e8e8e8;
}

.outcome-label {
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 12px;
  text-align: center;
}

.outcome-label.problem {
  color: #c73e3a;
}

.outcome-label.success {
  color: #2d7a54;
}

.outcome-value {
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
  padding: 16px;
  border-radius: 10px;
}

.outcome-value.lost {
  background: #fef0f0;
  color: #c73e3a;
  border: 1px solid #f5c5c5;
}

.outcome-value.protected {
  background: #e8f5f0;
  color: #2d7a54;
  border: 1px solid #c5e5d5;
}

/* v8 proof */
.proof-section {
  padding: 100px 0;
  background: #fafafa;
}

.proof-section .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

.proof-section .section-headline {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 80px;
  color: #1a1a1a;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  max-width: 1000px;
  margin: 0 auto;
}

.metric-card {
  background: white;
  border: 2px solid #e8e8e8;
  border-radius: 16px;
  padding: 40px 32px;
  text-align: center;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.metric-card.speed {
  background: linear-gradient(180deg, #ffffff 0%, #f0f8ff 100%);
  border-color: #d5e5f5;
}

.metric-card.conversion {
  background: linear-gradient(180deg, #f0faf5 0%, #ffffff 100%);
  border-color: #d0e8e0;
}

.metric-card.reliability {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
  border-color: #e8e8e8;
}

.metric-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
}

.metric-icon {
  font-size: 2.5rem;
  margin-bottom: 20px;
  opacity: 0.9;
}

.metric-number {
  font-size: 4rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 12px;
  line-height: 1;
}

.metric-card.speed .metric-number {
  font-size: 3rem;
}

.metric-label {
  font-size: 1.125rem;
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: 8px;
}

.metric-context {
  font-size: 0.875rem;
  color: #999;
  font-style: italic;
  line-height: 1.5;
}

/* v8 five jobs */
.five-jobs-section {
  padding: 100px 0;
  background: #f5f5f5;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.five-jobs-section .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

.five-jobs-section .section-headline {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 16px;
  color: #1a1a1a;
}

.five-jobs-section .section-description {
  text-align: center;
  color: #666;
  font-size: 1.125rem;
  max-width: 700px;
  margin: 0 auto 80px;
}

.jobs-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  max-width: 700px;
  margin: 0 auto;
}

.job-card {
  width: 100%;
  max-width: 650px;
  background: white;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.job-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.browser-chrome {
  background: linear-gradient(180deg, #f5f5f5 0%, #ebebeb 100%);
  padding: 12px 16px;
  border-bottom: 1px solid #d5d5d5;
  display: flex;
  align-items: center;
  gap: 16px;
}

.window-dots {
  display: flex;
  gap: 6px;
}

.dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #d0d0d0;
  border: 1px solid #bbb;
}

.chrome-title {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
}

.card-number {
  font-size: 0.75rem;
  font-weight: 700;
  color: #5a9d9d;
}

.card-category {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #999;
}

.card-content {
  padding: 32px 28px;
}

.card-icon {
  font-size: 2rem;
  margin-bottom: 16px;
}

.card-title {
  font-size: 1.375rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 12px;
}

.card-description {
  font-size: 0.9375rem;
  color: #666;
  line-height: 1.6;
  margin-bottom: 16px;
}

.card-outcome {
  font-size: 0.875rem;
  color: #5a9d9d;
  font-weight: 500;
  padding-top: 16px;
  border-top: 1px solid #e8e8e8;
}

/* v8 pricing */
.pricing-section {
  padding: 120px 0;
  background: #f5f1ed;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.pricing-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}

.pricing-section .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

.pricing-section .section-headline {
  font-size: 2.75rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 16px;
  color: #1a1a1a;
}

.pricing-section .section-description {
  text-align: center;
  color: #666;
  font-size: 1.125rem;
  max-width: 700px;
  margin: 0 auto 80px;
  line-height: 1.6;
}

.pricing-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 56px;
  max-width: 1200px;
  margin: 0 auto;
}

.pricing-card {
  background: white;
  border: 2px solid #e5e5e5;
  border-radius: 20px;
  padding: 48px 36px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}

.card-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 24px;
  color: #999;
}

.pricing-card.pilot {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

.pricing-card.pilot:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

.pricing-card.standard {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
  color: white;
  transform: translateY(-24px);
  box-shadow:
    0 24px 48px rgba(90, 157, 157, 0.25),
    0 0 60px rgba(245, 241, 237, 0.4);
  border: 2px solid #5a9d9d;
  z-index: 2;
}

.pricing-card.standard .card-label {
  color: rgba(255, 255, 255, 0.95);
  text-align: center;
}

.pricing-card.standard .pricing-headline {
  font-size: 2rem;
  font-weight: 700;
  margin: 24px 0 16px;
  line-height: 1.2;
  color: white;
  text-align: center;
}

.pricing-card.standard .pricing-description {
  color: rgba(255, 255, 255, 0.9);
  font-size: 1rem;
  text-align: center;
}

.pricing-card.standard:hover {
  transform: translateY(-28px);
  box-shadow:
    0 28px 56px rgba(90, 157, 157, 0.3),
    0 0 80px rgba(245, 241, 237, 0.5);
}

.pricing-card.scoped {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

.pricing-card.scoped:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

.pricing-headline {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 24px 0 16px;
  line-height: 1.25;
  text-align: center;
  color: #1a1a1a;
}

.pricing-description {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: #666;
  text-align: center;
}

@media (max-width: 767px) {
  .hero-section h1,
  .hero-section .hero-headline {
    font-size: 2.25rem !important;
  }

  .timeline-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .timeline-comparison-section .section-headline {
    font-size: 1.875rem;
  }

  .timeline-side {
    padding: 32px 24px;
  }

  .metrics-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .proof-section .section-headline {
    font-size: 1.875rem;
    margin-bottom: 60px;
  }

  .metric-number {
    font-size: 3rem;
  }

  .metric-card.speed .metric-number {
    font-size: 2.5rem;
  }

  .five-jobs-section .section-headline {
    font-size: 1.875rem;
  }

  .jobs-container {
    gap: 24px;
  }

  .pricing-cards-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .pricing-card.standard {
    transform: translateY(0);
  }

  .pricing-card.standard:hover {
    transform: translateY(-4px);
  }

  .pricing-section .section-headline {
    font-size: 2rem;
  }
}

body.home-page .pricing-card.standard .bullet,
body.home-page .pricing-card-refined.standard .bullet {
  font-size: 0.8rem;
}

body.home-page .pricing-card.standard .pricing-headline,
body.home-page .pricing-card-refined.standard .pricing-headline {
  font-size: 1.875rem;
  font-weight: 700;
  margin: 24px 0 16px;
  line-height: 1.2;
  color: white;
}

body.home-page .pricing-card.standard .pricing-description,
body.home-page .pricing-card-refined.standard .pricing-description {
  color: rgba(255, 255, 255, 0.9);
  margin: 0;
}

body.home-page .pricing-card.standard .pricing-features,
body.home-page .pricing-card-refined.standard .pricing-features {
  display: grid;
  gap: 10px;
  margin: 8px 0 0;
  padding-left: 18px;
  color: rgba(255, 255, 255, 0.95);
}

body.home-page .pricing-card.standard .pricing-features li,
body.home-page .pricing-card-refined.standard .pricing-features li {
  display: list-item;
}

body.home-page .timeline-comparison-section {
  padding: 100px 0;
  background: #fafafa;
}

body.home-page .timeline-comparison-section .section-headline {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 60px;
  color: #1a1a1a;
  max-width: none;
}

body.home-page .timeline-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  max-width: 1100px;
  margin: 0 auto;
}

body.home-page .timeline-side {
  background: white;
  border-radius: 20px;
  padding: 48px 36px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

body.home-page .timeline-side.problem {
  background: linear-gradient(180deg, #fef5f5 0%, #fff 100%);
  border: 2px solid #f5d5d5;
}

body.home-page .timeline-side.solution {
  background: linear-gradient(180deg, #f0faf5 0%, #fff 100%);
  border: 2px solid #d0e8e0;
}

body.home-page .timeline-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
}

body.home-page .timeline-label .icon {
  font-size: 1.25rem;
}

body.home-page .problem .timeline-label {
  color: #c73e3a;
}

body.home-page .solution .timeline-label {
  color: #2d7a54;
}

body.home-page .ios-notification {
  background: #ffffff;
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  border: 1px solid #e8e8e8;
}

body.home-page .ios-notification.unread {
  opacity: 0.6;
}

body.home-page .notification-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

body.home-page .app-info {
  display: flex;
  align-items: center;
  gap: 8px;
}

body.home-page .app-icon {
  width: 20px;
  height: 20px;
  border-radius: 5px;
}

body.home-page .app-icon.instagram {
  background: linear-gradient(135deg, #833ab4 0%, #fd1d1d 50%, #fcb045 100%);
}

body.home-page .app-name {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #1a1a1a;
}

body.home-page .notification-time {
  font-size: 0.75rem;
  color: #8e8e93;
}

body.home-page .notification-content {
  margin-left: 28px;
}

body.home-page .notification-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: #1a1a1a;
  margin-bottom: 4px;
}

body.home-page .notification-preview {
  font-size: 0.8125rem;
  color: #8e8e93;
  line-height: 1.4;
}

body.home-page .intervention-badges {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 16px 0;
}

body.home-page .badge {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 10px;
  background: #e8f5f0;
  border: 1px solid #c5e5d5;
}

body.home-page .badge.success {
  background: #e8f5f0;
  border-color: #c5e5d5;
}

body.home-page .badge-icon {
  font-size: 1rem;
  color: #2d7a54;
}

body.home-page .badge-text {
  font-size: 0.875rem;
  font-weight: 500;
  color: #2d7a54;
}

body.home-page .outcome-section {
  margin-top: auto;
  padding-top: 24px;
  border-top: 1px solid #e8e8e8;
}

body.home-page .outcome-label {
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 12px;
  text-align: center;
}

body.home-page .outcome-label.problem {
  color: #c73e3a;
}

body.home-page .outcome-label.success {
  color: #2d7a54;
}

body.home-page .outcome-value {
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
  padding: 16px;
  border-radius: 10px;
}

body.home-page .outcome-value.lost {
  background: #fef0f0;
  color: #c73e3a;
  border: 1px solid #f5c5c5;
}

body.home-page .outcome-value.protected {
  background: #e8f5f0;
  color: #2d7a54;
  border: 1px solid #c5e5d5;
}

@media (max-width: 767px) {
  body.home-page .timeline-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  body.home-page .timeline-comparison-section .section-headline,
  body.home-page .timeline-comparison-section .section-headline.section-headline {
    font-size: 1.875rem;
  }

  body.home-page .timeline-side {
    padding: 32px 24px;
  }
}

/* ============================================
 V8 FINAL EOF OVERRIDE LAYER
 Keep this at the absolute end so legacy home-page rules cannot win.
 ============================================ */

body.home-page .hero.hero-section {
  background: #2a2a2a !important;
  color: white !important;
  padding: 120px 0 !important;
  min-height: 80vh !important;
  display: flex !important;
  align-items: center !important;
}

body.home-page .hero.hero-section *,
body.home-page .hero.hero-section .container,
body.home-page .hero.hero-section .hero-content-centered {
  background: transparent !important;
}

body.home-page .hero.hero-section h1,
body.home-page .hero.hero-section .hero-headline {
  color: white !important;
  font-size: 3.5rem !important;
  font-weight: 700 !important;
  line-height: 1.15 !important;
  margin-bottom: 32px !important;
}

body.home-page .hero.hero-section p,
body.home-page .hero.hero-section .hero-description {
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 1.25rem !important;
}

body.home-page .hero.hero-section .hero-subtext {
  color: rgba(255, 255, 255, 0.8) !important;
  font-size: 1.125rem !important;
}

body.home-page .hero.hero-section .hero-footnote {
  color: rgba(255, 255, 255, 0.6) !important;
  font-size: 0.9375rem !important;
}

body.home-page .hero-content-centered {
  max-width: 800px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

body.home-page .proof-section {
  padding: 100px 0;
  background: #fafafa;
}

body.home-page .proof-section .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

body.home-page .proof-section .section-headline {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 80px;
  color: #1a1a1a;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

body.home-page .metrics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  max-width: 1000px;
  margin: 0 auto;
}

body.home-page .metric-card {
  background: white;
  border: 2px solid #e8e8e8;
  border-radius: 16px;
  padding: 40px 32px;
  text-align: center;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

body.home-page .metric-card.speed {
  background: linear-gradient(180deg, #ffffff 0%, #f0f8ff 100%);
  border-color: #d5e5f5;
}

body.home-page .metric-card.conversion {
  background: linear-gradient(180deg, #f0faf5 0%, #ffffff 100%);
  border-color: #d0e8e0;
}

body.home-page .metric-card.reliability {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
  border-color: #e8e8e8;
}

body.home-page .metric-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
}

body.home-page .metric-icon {
  font-size: 2.5rem;
  margin-bottom: 20px;
  opacity: 0.9;
}

body.home-page .metric-number {
  font-size: 4rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 12px;
  line-height: 1;
}

body.home-page .metric-card.speed .metric-number {
  font-size: 3rem;
}

body.home-page .metric-label {
  font-size: 1.125rem;
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: 8px;
}

body.home-page .metric-context {
  font-size: 0.875rem;
  color: #999;
  font-style: italic;
  line-height: 1.5;
}

body.home-page .five-jobs-section {
  padding: 100px 0;
  background: #f5f5f5;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

body.home-page .five-jobs-section .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

body.home-page .five-jobs-section .section-headline {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 16px;
  color: #1a1a1a;
}

body.home-page .five-jobs-section .section-description {
  text-align: center;
  color: #666;
  font-size: 1.125rem;
  max-width: 700px;
  margin: 0 auto 80px;
}

body.home-page .jobs-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  max-width: 700px;
  margin: 0 auto;
}

body.home-page .job-card {
  width: 100%;
  max-width: 650px;
  background: white;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body.home-page .job-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

body.home-page .browser-chrome {
  background: linear-gradient(180deg, #f5f5f5 0%, #ebebeb 100%);
  padding: 12px 16px;
  border-bottom: 1px solid #d5d5d5;
  display: flex;
  align-items: center;
  gap: 16px;
}

body.home-page .window-dots {
  display: flex;
  gap: 6px;
}

body.home-page .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #d0d0d0;
  border: 1px solid #bbb;
}

body.home-page .chrome-title {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
}

body.home-page .card-number {
  font-size: 0.75rem;
  font-weight: 700;
  color: #5a9d9d;
}

body.home-page .card-category {
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #999;
}

body.home-page .card-content {
  padding: 32px 28px;
}

body.home-page .card-icon {
  font-size: 2rem;
  margin-bottom: 16px;
}

body.home-page .card-title {
  font-size: 1.375rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 12px;
}

body.home-page .card-description {
  font-size: 0.9375rem;
  color: #666;
  line-height: 1.6;
  margin-bottom: 16px;
}

body.home-page .card-outcome {
  font-size: 0.875rem;
  color: #5a9d9d;
  font-weight: 500;
  padding-top: 16px;
  border-top: 1px solid #e8e8e8;
}

body.home-page .timeline-comparison-section {
  padding: 100px 0;
  background: #fafafa;
}

body.home-page .timeline-comparison-section .section-headline {
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 60px;
  color: #1a1a1a;
}

body.home-page .timeline-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  max-width: 1100px;
  margin: 0 auto;
}

body.home-page .timeline-side {
  background: white;
  border-radius: 20px;
  padding: 48px 36px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

body.home-page .timeline-side.problem {
  background: linear-gradient(180deg, #fef5f5 0%, #fff 100%);
  border: 2px solid #f5d5d5;
}

body.home-page .timeline-side.solution {
  background: linear-gradient(180deg, #f0faf5 0%, #fff 100%);
  border: 2px solid #d0e8e0;
}

body.home-page .timeline-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
}

body.home-page .timeline-label .icon {
  font-size: 1.25rem;
}

body.home-page .problem .timeline-label {
  color: #c73e3a;
}

body.home-page .solution .timeline-label {
  color: #2d7a54;
}

body.home-page .ios-notification {
  background: #ffffff;
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  border: 1px solid #e8e8e8;
}

body.home-page .ios-notification.unread {
  opacity: 0.6;
}

body.home-page .notification-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

body.home-page .app-info {
  display: flex;
  align-items: center;
  gap: 8px;
}

body.home-page .app-icon {
  width: 20px;
  height: 20px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}

body.home-page .app-icon.message {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
}

body.home-page .app-icon.message::before {
  content: '💬';
  filter: grayscale(1) brightness(10);
}

body.home-page .app-icon.message-check {
  background: linear-gradient(135deg, #2d7a54 0%, #257a54 100%);
}

body.home-page .app-icon.message-check::before {
  content: '✓';
  color: white;
  font-weight: bold;
}

body.home-page .app-icon.calendar {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
}

body.home-page .app-icon.calendar::before {
  content: '📅';
  filter: grayscale(0.3);
  font-size: 11px;
}

body.home-page .app-name {
  font-size: 0.8125rem;
  font-weight: 600;
  color: #1a1a1a;
}

body.home-page .notification-time {
  font-size: 0.75rem;
  color: #8e8e93;
}

body.home-page .notification-content {
  margin-left: 28px;
}

body.home-page .notification-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: #1a1a1a;
  margin-bottom: 4px;
}

body.home-page .notification-preview {
  font-size: 0.8125rem;
  color: #8e8e93;
  line-height: 1.4;
}

body.home-page .time-indicator {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
  position: relative;
}

body.home-page .time-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #5a9d9d;
  flex-shrink: 0;
}

body.home-page .time-line {
  flex: 1;
  height: 2px;
  background: linear-gradient(90deg, #5a9d9d 0%, transparent 100%);
}

body.home-page .time-label {
  font-size: 0.75rem;
  font-weight: 600;
  color: #5a9d9d;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

body.home-page .outcome-section {
  margin-top: auto;
  padding-top: 24px;
  border-top: 1px solid #e8e8e8;
}

body.home-page .outcome-label {
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 12px;
  text-align: center;
}

body.home-page .outcome-label.problem {
  color: #c73e3a;
}

body.home-page .outcome-label.success {
  color: #2d7a54;
}

body.home-page .outcome-value {
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
  padding: 16px;
  border-radius: 10px;
}

body.home-page .outcome-value.lost {
  background: #fef0f0;
  color: #c73e3a;
  border: 1px solid #f5c5c5;
}

body.home-page .outcome-value.protected {
  background: #e8f5f0;
  color: #2d7a54;
  border: 1px solid #c5e5d5;
}

body.home-page .pricing-section {
  padding: 120px 0;
  background: #f5f1ed;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

body.home-page .pricing-section .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}

body.home-page .pricing-section .section-eyebrow {
  color: #5a9d9d;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 16px;
}

body.home-page .pricing-section .section-headline {
  font-size: 2.75rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 16px;
  color: #1a1a1a;
}

body.home-page .pricing-section .section-description {
  text-align: center;
  color: #666;
  font-size: 1.125rem;
  max-width: 700px;
  margin: 0 auto 80px;
  line-height: 1.6;
}

body.home-page .pricing-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 56px;
  max-width: 1200px;
  margin: 0 auto;
}

body.home-page .pricing-card {
  background: white;
  border: 2px solid #e5e5e5;
  border-radius: 20px;
  padding: 48px 36px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}

body.home-page .card-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 24px;
  color: #999;
}

body.home-page .pricing-card.pilot {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

body.home-page .pricing-card.pilot:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

body.home-page .pricing-card.standard {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%);
  color: white;
  transform: translateY(-24px);
  box-shadow:
    0 24px 48px rgba(90, 157, 157, 0.25),
    0 0 60px rgba(245, 241, 237, 0.4);
  border: 2px solid #5a9d9d;
  z-index: 2;
}

body.home-page .pricing-card.standard .card-label {
  color: rgba(255, 255, 255, 0.95);
  text-align: center;
}

body.home-page .pricing-card.standard .pricing-headline {
  font-size: 2rem;
  font-weight: 700;
  margin: 24px 0 16px;
  line-height: 1.2;
  color: white;
  text-align: center;
}

body.home-page .pricing-card.standard .pricing-description {
  color: rgba(255, 255, 255, 0.9);
  font-size: 1rem;
  text-align: center;
}

body.home-page .pricing-card.standard:hover {
  transform: translateY(-28px);
  box-shadow:
    0 28px 56px rgba(90, 157, 157, 0.3),
    0 0 80px rgba(245, 241, 237, 0.5);
}

body.home-page .pricing-card.scoped {
  background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

body.home-page .pricing-card.scoped:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08);
}

body.home-page .pricing-headline {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 24px 0 16px;
  line-height: 1.25;
  text-align: center;
  color: #1a1a1a;
}

body.home-page .pricing-description {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: #666;
  text-align: center;
}

@media (max-width: 767px) {
  body.home-page .hero.hero-section h1,
  body.home-page .hero.hero-section .hero-headline {
    font-size: 2.25rem !important;
  }

  body.home-page .timeline-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  body.home-page .timeline-comparison-section .section-headline {
    font-size: 1.875rem;
  }

  body.home-page .timeline-side {
    padding: 32px 24px;
  }

  body.home-page .metrics-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  body.home-page .proof-section .section-headline {
    font-size: 1.875rem;
    margin-bottom: 60px;
  }

  body.home-page .metric-number {
    font-size: 3rem;
  }

  body.home-page .metric-card.speed .metric-number {
    font-size: 2.5rem;
  }

  body.home-page .five-jobs-section .section-headline {
    font-size: 1.875rem;
  }

  body.home-page .jobs-container {
    gap: 24px;
  }

  body.home-page .pricing-cards-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  body.home-page .pricing-card.standard {
    transform: translateY(0);
  }

  body.home-page .pricing-card.standard:hover {
    transform: translateY(-4px);
  }

  body.home-page .pricing-section .section-headline {
    font-size: 2rem;
  }
}

/* ============================================
 v9 FINAL EOF OVERRIDE LAYER
 Keep this at the absolute end so it wins cleanly.
 ============================================ */

/* NAVIGATION LOGO SIZE - v9 */
body.home-page .brand-lockup,
body.home-page .brand-logo-wrap {
  width: 185px !important;
  min-width: 185px !important;
  height: 48px !important;
  min-height: 48px !important;
  flex: 0 0 185px !important;
}

body.home-page .brand-logo,
body.home-page .nav-logo,
body.home-page .header-logo,
body.home-page .logo img,
body.home-page header img,
body.home-page nav img {
  width: 185px !important;
  min-width: 185px !important;
  max-width: 185px !important;
  height: 48px !important;
  min-height: 48px !important;
  max-height: 48px !important;
}

body.home-page nav,
body.home-page header,
body.home-page .navigation,
body.home-page .header,
body.home-page .site-header {
  padding-top: 16px !important;
  padding-bottom: 16px !important;
}

/* HERO SECTION FIXES - v9 */
body.home-page .hero.hero-section {
  padding-top: 180px !important;
  padding-bottom: 120px !important;
}

body.home-page .hero.hero-section .cta-button,
body.home-page .hero.hero-section button,
body.home-page .hero.hero-section .primary {
  background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 100%) !important;
  color: #ffffff !important;
  border: none !important;
  padding: 16px 36px !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  border-radius: 50px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 4px 16px rgba(90, 157, 157, 0.3) !important;
}

body.home-page .hero.hero-section .cta-button:hover,
body.home-page .hero.hero-section button:hover,
body.home-page .hero.hero-section .primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(90, 157, 157, 0.4) !important;
}

body.home-page .hero.hero-section .hero-subtext {
  position: relative !important;
  display: inline-block !important;
}

body.home-page .hero.hero-section .hero-subtext::after {
  content: '' !important;
  position: absolute !important;
  bottom: -8px !important;
  left: 0 !important;
  width: 100% !important;
  height: 3px !important;
  background: linear-gradient(90deg, #5a9d9d 0%, transparent 100%) !important;
  border-radius: 2px !important;
}

/* EDGE-TO-EDGE BACKGROUNDS - v9 */
body.home-page main > section {
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}

body.home-page .hero-section .container,
body.home-page .proof-section .container,
body.home-page .timeline-comparison-section .container,
body.home-page .five-jobs-section .container,
body.home-page .pricing-section .container,
body.home-page .standard-section .container,
body.home-page .the-standard-section .container,
body.home-page .pre-faq-booking-section .container,
body.home-page .faq-section .container,
body.home-page main > section .container {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 40px !important;
  padding-right: 40px !important;
}

/* THE STANDARD SECTION TEXT - v9 */
body.home-page .standard-section .section-description,
body.home-page .the-standard-section .section-description,
body.home-page .standard-section p,
body.home-page .the-standard-section p {
  color: #666 !important;
  font-size: 1.125rem !important;
  line-height: 1.6 !important;
  margin-bottom: 40px !important;
}

/* THE STANDARD LOGO FADE - v9 */
body.home-page #standard-logo {
  opacity: 0 !important;
  transition: opacity 1.5s ease-in-out !important;
  background: none !important;
  object-fit: contain !important;
}

body.home-page #standard-logo.visible {
  opacity: 0.12 !important;
}

/* PRICING STANDARD CARD - v9 */
body.home-page .pricing-card.standard .card-label {
  text-align: center !important;
  display: block !important;
  width: 100% !important;
}

body.home-page .pricing-card.standard {
  box-shadow:
    0 24px 48px rgba(90, 157, 157, 0.25),
    0 0 80px rgba(245, 241, 237, 0.6),
    inset 0 0 0 2px rgba(245, 241, 237, 0.2) !important;
}

body.home-page .pricing-card.standard:hover {
  box-shadow:
    0 28px 56px rgba(90, 157, 157, 0.3),
    0 0 100px rgba(245, 241, 237, 0.7),
    inset 0 0 0 2px rgba(245, 241, 237, 0.3) !important;
}

/* FIVE JOBS - OVERLAPPING CARDS - v9 */
body.home-page .five-jobs-section {
  padding: 100px 0 !important;
  background: #f5f5f5 !important;
}

body.home-page .five-jobs-section .section-eyebrow {
  color: #5a9d9d !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  margin-bottom: 16px !important;
}

body.home-page .five-jobs-section .section-headline {
  font-size: 2.5rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  margin-bottom: 16px !important;
  color: #1a1a1a !important;
}

body.home-page .five-jobs-section .section-description {
  text-align: center !important;
  color: #666 !important;
  font-size: 1.125rem !important;
  max-width: 700px !important;
  margin: 0 auto 80px !important;
}

body.home-page .jobs-stack-container {
  position: relative !important;
  max-width: 650px !important;
  margin: 0 auto !important;
  padding-top: 60px !important;
  min-height: 680px !important;
}

body.home-page .jobs-stack-container .job-card {
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 100% !important;
  max-width: 650px !important;
  background: #ffffff !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

body.home-page .jobs-stack-container .job-card[data-index="1"] {
  top: 0 !important;
  z-index: 5 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="2"] {
  top: 30px !important;
  z-index: 4 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="3"] {
  top: 60px !important;
  z-index: 3 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="4"] {
  top: 90px !important;
  z-index: 2 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="5"] {
  top: 120px !important;
  z-index: 1 !important;
}

body.home-page .jobs-stack-container .job-card:hover {
  transform: translateX(-50%) translateY(-4px) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12) !important;
}

@media (max-width: 767px) {
  body.home-page .brand-lockup,
  body.home-page .brand-logo-wrap {
    width: 185px !important;
    min-width: 185px !important;
    height: 48px !important;
    min-height: 48px !important;
    flex: 0 0 185px !important;
  }

  body.home-page .brand-logo {
    width: 185px !important;
    min-width: 185px !important;
    max-width: 185px !important;
    height: 48px !important;
    min-height: 48px !important;
    max-height: 48px !important;
  }

  body.home-page .hero.hero-section {
    padding-top: 140px !important;
  }

  body.home-page main > section .container {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body.home-page .jobs-stack-container {
    position: static !important;
    min-height: auto !important;
    padding-top: 0 !important;
  }

  body.home-page .jobs-stack-container .job-card {
    position: relative !important;
    top: auto !important;
    left: 0 !important;
    transform: none !important;
    margin-bottom: 24px !important;
  }

  body.home-page .jobs-stack-container .job-card:hover {
    transform: translateY(-4px) !important;
  }

  body.home-page .five-jobs-section .section-headline {
    font-size: 1.875rem !important;
  }
}

/* ============================================
 EMERGENCY CONTAINER FIX
 Restores content visibility
 ============================================ */

/* Force safe container behavior */
body {
 overflow-x: hidden !important;
 width: 100% !important;
}

body.home-page * {
 box-sizing: border-box !important;
}

/* Reset all containers to safe state */
body.home-page .container,
body.home-page section .container,
body.home-page .section-container,
body.home-page div[class*="container"] {
 max-width: 1200px !important;
 width: 100% !important;
 margin-left: auto !important;
 margin-right: auto !important;
 padding-left: 40px !important;
 padding-right: 40px !important;
 box-sizing: border-box !important;
 position: relative !important;
}

/* Remove negative margins and viewport-width forcing that break layout */
body.home-page section,
body.home-page main > section {
 width: 100% !important;
 max-width: 100% !important;
 margin-left: 0 !important;
 margin-right: 0 !important;
 left: auto !important;
 right: auto !important;
}

/* Edge-to-edge backgrounds WITHOUT breaking containers */
body.home-page .hero-section,
body.home-page .proof-section,
body.home-page .timeline-comparison-section,
body.home-page .five-jobs-section,
body.home-page .pricing-section,
body.home-page .standard-section,
body.home-page .the-standard-section,
body.home-page .pre-faq-booking-section {
 position: relative !important;
 width: 100% !important;
 left: 0 !important;
 right: 0 !important;
}

/* Add full-width backgrounds via pseudo-element */
body.home-page .hero-section::before,
body.home-page .proof-section::before,
body.home-page .timeline-comparison-section::before,
body.home-page .five-jobs-section::before,
body.home-page .pricing-section::before {
 content: '' !important;
 position: absolute !important;
 top: 0 !important;
 left: 50% !important;
 transform: translateX(-50%) !important;
 width: 100vw !important;
 height: 100% !important;
 z-index: -1 !important;
 background: inherit !important;
}

/* Mobile safe padding */
@media (max-width: 767px) {
 body.home-page .container,
 body.home-page section .container,
 body.home-page main > section .container,
 body.home-page .hero-section .container,
 body.home-page .timeline-comparison-section .container,
 body.home-page .five-jobs-section .container,
 body.home-page .pricing-section .container,
 body.home-page .standard-section .container,
 body.home-page .pre-faq-booking-section .container,
 body.home-page div[class*="container"] {
  padding-left: 20px !important;
  padding-right: 20px !important;
 }
}

/* ============================================
 HELODESK HOMEPAGE v10 COMPLETE UPDATE
 All changes in one block for clean implementation
 ============================================ */

/* ============================================
 1. NAVIGATION - FIXED LUXURY STYLE
 Based on Grandeur USA reference
 ============================================ */

body.home-page nav,
body.home-page header,
body.home-page .navigation,
body.home-page .site-header,
body.home-page .header {
 position: fixed !important;
 top: 0 !important;
 left: 0 !important;
 right: 0 !important;
 width: 100% !important;
 background: white !important;
 box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
 z-index: 1000 !important;
 padding: 16px 40px !important;
 transition: all 0.3s ease !important;
}

/* Logo proper size */
body.home-page nav img,
body.home-page header img,
body.home-page .navigation img,
body.home-page .site-header img,
body.home-page .header img,
body.home-page .logo img,
body.home-page nav .logo,
body.home-page header .logo {
 height: 48px !important;
 width: auto !important;
 max-height: 48px !important;
}

/* Prevent nav from covering content */
body.home-page {
 padding-top: 90px !important;
}

/* Navigation links styling */
body.home-page nav a,
body.home-page header a,
body.home-page .navigation a {
 color: #1a1a1a !important;
 font-weight: 500 !important;
 text-decoration: none !important;
 transition: color 0.2s ease !important;
}

body.home-page nav a:hover,
body.home-page header a:hover {
 color: #5a9d9d !important;
}

/* ============================================
 2. HERO SECTION - CHAMPAGNE TEXT TREATMENT
 Headline WHITE, body CHAMPAGNE, dark bg preserved
 ============================================ */

/* Dark background STAYS */
body.home-page .hero-section {
 background: #2a2a2a !important;
}

/* Headline stays WHITE - maximum pop */
body.home-page .hero-section h1,
body.home-page .hero-section .hero-headline,
body.home-page .hero-section > h1 {
 color: #ffffff !important;
}

/* Main paragraph - CHAMPAGNE */
body.home-page .hero-section > p:first-of-type,
body.home-page .hero-section .hero-description,
body.home-page .hero-section p:nth-of-type(1) {
 color: #f5f1ed !important;
}

/* Tagline/subheading - CHAMPAGNE */
body.home-page .hero-section .hero-tagline,
body.home-page .hero-section > p:nth-of-type(2) {
 color: #f5f1ed !important;
}

/* Small text at bottom - CHAMPAGNE with slight fade */
body.home-page .hero-section .small-text,
body.home-page .hero-section > p:last-of-type {
 color: #f5f1ed !important;
 opacity: 0.9 !important;
}

/* ============================================
 3. THE STANDARD SECTION - STATIC LOGO WATERMARK
 Large centered background, no animation
 ============================================ */

body.home-page .standard-section,
body.home-page .the-standard-section {
 position: relative !important;
}

/* Logo as background watermark - centered and large */
body.home-page .standard-section img,
body.home-page .the-standard-section img,
body.home-page #standard-section-logo {
 position: absolute !important;
 top: 50% !important;
 left: 50% !important;
 transform: translate(-50%, -50%) !important;
 width: 600px !important;
 height: auto !important;
 opacity: 0.08 !important;
 z-index: 0 !important;
 pointer-events: none !important;
}

/* Ensure text content stays on top of logo */
body.home-page .standard-section .container,
body.home-page .the-standard-section .container,
body.home-page .standard-section h2,
body.home-page .the-standard-section h2,
body.home-page .standard-section p,
body.home-page .the-standard-section p,
body.home-page .standard-section .section-eyebrow,
body.home-page .the-standard-section .section-eyebrow {
 position: relative !important;
 z-index: 1 !important;
}

/* ============================================
 4. FIVE JOBS SECTION - HEADLINE SPACING
 Better formatting and breathing room
 ============================================ */

body.home-page .five-jobs-section .section-headline {
 font-size: 3rem !important;
 line-height: 1.25 !important;
 letter-spacing: -0.02em !important;
 max-width: 800px !important;
 margin-left: auto !important;
 margin-right: auto !important;
 margin-bottom: 24px !important;
}

/* ============================================
 5. TIMELINE SECTION - SUBTLE "8 SECONDS"
 Reduce opacity to make it background element
 ============================================ */

body.home-page .time-indicator {
 opacity: 0.4 !important;
}

body.home-page .time-dot {
 opacity: 0.5 !important;
}

body.home-page .time-line {
 opacity: 0.3 !important;
}

body.home-page .time-label,
body.home-page .time-text {
 opacity: 0.5 !important;
 font-size: 0.6875rem !important;
}

/* ============================================
 6. PRICING STANDARD CARD - GOLD GLOW + GRADIENT
 Premium visual treatment
 ============================================ */

/* Deeper teal gradient with dimension */
body.home-page .pricing-card.standard {
 background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 50%, #3a7d7d 100%) !important;

 /* Gold glow around edges */
 box-shadow:
 0 24px 48px rgba(90, 157, 157, 0.25),
 0 0 80px rgba(255, 215, 0, 0.5),
 inset 0 0 0 2px rgba(255, 215, 0, 0.15) !important;
}

body.home-page .pricing-card.standard:hover {
 box-shadow:
 0 28px 56px rgba(90, 157, 157, 0.3),
 0 0 100px rgba(255, 215, 0, 0.6),
 inset 0 0 0 2px rgba(255, 215, 0, 0.2) !important;
}

/* Ensure STANDARD label stays centered */
body.home-page .pricing-card.standard .card-label {
 text-align: center !important;
 width: 100% !important;
 display: block !important;
}

/* ============================================
 MOBILE RESPONSIVE ADJUSTMENTS
 ============================================ */

@media (max-width: 767px) {
 /* Navigation mobile */
 body.home-page nav,
 body.home-page header,
 body.home-page .navigation {
  padding: 12px 20px !important;
 }

 body.home-page {
  padding-top: 70px !important;
 }

 /* Standard section logo mobile */
 body.home-page .standard-section img,
 body.home-page .the-standard-section img,
 body.home-page #standard-section-logo {
  width: 300px !important;
  opacity: 0.06 !important;
 }

 /* Five Jobs headline mobile */
 body.home-page .five-jobs-section .section-headline {
  font-size: 2rem !important;
  line-height: 1.3 !important;
 }
}

body.home-page .site-header,
body.home-page header.site-header,
body.home-page .site-header.scroll-up,
body.home-page .site-header.scroll-down {
 background: #ffffff !important;
 box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
 backdrop-filter: none !important;
 -webkit-backdrop-filter: none !important;
}

body.home-page .hero-section .hero-description,
body.home-page .hero-section .hero-subtext,
body.home-page .hero-section .hero-footnote,
body.home-page .hero-section p {
 color: #f5f1ed !important;
}

body.home-page .hero-section .hero-footnote {
 opacity: 0.9 !important;
}

body.home-page .standard-section #standard-logo,
body.home-page .the-standard-section #standard-logo,
body.home-page .standard-section img.background-logo,
body.home-page .the-standard-section img.background-logo {
 position: absolute !important;
 top: 50% !important;
 left: 50% !important;
 transform: translate(-50%, -50%) !important;
 width: 600px !important;
 height: auto !important;
 opacity: 0.08 !important;
 z-index: 0 !important;
 pointer-events: none !important;
 transition: none !important;
}

body.home-page .standard-section #standard-logo.visible,
body.home-page .the-standard-section #standard-logo.visible,
body.home-page .standard-section img.background-logo.visible,
body.home-page .the-standard-section img.background-logo.visible {
 opacity: 0.08 !important;
}

@media (max-width: 767px) {
 body.home-page .standard-section #standard-logo,
 body.home-page .the-standard-section #standard-logo,
 body.home-page .standard-section img.background-logo,
 body.home-page .the-standard-section img.background-logo {
  width: 300px !important;
  opacity: 0.06 !important;
 }

 body.home-page .standard-section #standard-logo.visible,
 body.home-page .the-standard-section #standard-logo.visible,
 body.home-page .standard-section img.background-logo.visible,
 body.home-page .the-standard-section img.background-logo.visible {
  opacity: 0.06 !important;
 }
}

/* ============================================
 END v10 CSS
 ============================================ */

/* ============================================
 EMERGENCY FIVE JOBS FIX
 Makes all cards visible with proper spacing
 ============================================ */

/* Fix container height to fit all cards */
body.home-page .jobs-stack-container {
 min-height: 1000px !important;
 padding-top: 0 !important;
 position: relative !important;
}

/* Proper spacing so all cards visible */
body.home-page .jobs-stack-container .job-card[data-index="1"] {
 top: 0 !important;
 z-index: 5 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="2"] {
 top: 140px !important;
 z-index: 4 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="3"] {
 top: 280px !important;
 z-index: 3 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="4"] {
 top: 420px !important;
 z-index: 2 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="5"] {
 top: 560px !important;
 z-index: 1 !important;
}

/* Ensure cards don't break on smaller screens */
@media (max-width: 767px) {
 body.home-page .jobs-stack-container {
  min-height: auto !important;
 }

 body.home-page .jobs-stack-container .job-card {
  position: relative !important;
  top: auto !important;
  margin-bottom: 24px !important;
 }
}

/* ============================================
 HELODESK HOMEPAGE v10 FINAL EOF OVERRIDES
 Must remain the true end of file
 ============================================ */

body.home-page .site-header,
body.home-page header.site-header,
body.home-page .site-header.scroll-up,
body.home-page .site-header.scroll-down,
body.home-page.header-at-top .site-header,
body.home-page.header-scrolled .site-header,
body.home-page.nav-open .site-header {
 background: #ffffff !important;
 box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
 backdrop-filter: none !important;
 -webkit-backdrop-filter: none !important;
}

body.home-page .hero.hero-section .hero-content-centered .hero-description,
body.home-page .hero.hero-section .hero-content-centered .hero-subtext,
body.home-page .hero.hero-section .hero-content-centered .hero-footnote,
body.home-page .hero.hero-section .hero-content-centered p {
 color: #f5f1ed !important;
}

body.home-page .hero.hero-section .hero-content-centered .hero-footnote {
 opacity: 0.9 !important;
}

body.home-page .standard-section #standard-logo,
body.home-page .the-standard-section #standard-logo,
body.home-page .standard-section img.background-logo,
body.home-page .the-standard-section img.background-logo,
body.home-page .standard-section #standard-logo.visible,
body.home-page .the-standard-section #standard-logo.visible,
body.home-page .standard-section img.background-logo.visible,
body.home-page .the-standard-section img.background-logo.visible {
 position: absolute !important;
 top: 50% !important;
 left: 50% !important;
 transform: translate(-50%, -50%) !important;
 width: 600px !important;
 height: auto !important;
 opacity: 0.08 !important;
 z-index: 0 !important;
 pointer-events: none !important;
 transition: none !important;
}

body.home-page .five-jobs-section .section-headline {
 font-size: 3rem !important;
 line-height: 1.25 !important;
 letter-spacing: -0.02em !important;
 max-width: 800px !important;
 margin-left: auto !important;
 margin-right: auto !important;
 margin-bottom: 24px !important;
}

body.home-page .timeline-highlight,
body.home-page .time-indicator,
body.home-page .time-dot,
body.home-page .time-line,
body.home-page .time-label,
body.home-page .time-text {
 opacity: 0.4 !important;
}

body.home-page .pricing-card.standard {
 background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 50%, #3a7d7d 100%) !important;
 box-shadow:
 0 24px 48px rgba(90, 157, 157, 0.25),
 0 0 80px rgba(255, 215, 0, 0.5),
 inset 0 0 0 2px rgba(255, 215, 0, 0.15) !important;
}

body.home-page .pricing-card.standard:hover {
 box-shadow:
 0 28px 56px rgba(90, 157, 157, 0.3),
 0 0 100px rgba(255, 215, 0, 0.6),
 inset 0 0 0 2px rgba(255, 215, 0, 0.2) !important;
}

body.home-page .pricing-card.standard .card-label {
 text-align: center !important;
 width: 100% !important;
 display: block !important;
}

@media (max-width: 767px) {
 body.home-page .site-header,
 body.home-page header.site-header,
 body.home-page.header-at-top .site-header,
 body.home-page.header-scrolled .site-header,
 body.home-page.nav-open .site-header {
  padding: 12px 20px !important;
 }

 body.home-page {
  padding-top: 70px !important;
 }

 body.home-page .standard-section #standard-logo,
 body.home-page .the-standard-section #standard-logo,
 body.home-page .standard-section img.background-logo,
 body.home-page .the-standard-section img.background-logo,
 body.home-page .standard-section #standard-logo.visible,
 body.home-page .the-standard-section #standard-logo.visible,
 body.home-page .standard-section img.background-logo.visible,
 body.home-page .the-standard-section img.background-logo.visible {
  width: 300px !important;
  opacity: 0.06 !important;
 }

 body.home-page .five-jobs-section .section-headline {
  font-size: 2rem !important;
  line-height: 1.3 !important;
 }
}

/* ============================================
 HELODESK HOMEPAGE v11 FINAL EOF OVERRIDES
 Smart Five Jobs overlap + champagne glow
 ============================================ */

body.home-page .jobs-stack-container {
 position: relative !important;
 min-height: 1250px !important;
 max-width: 650px !important;
 margin: 0 auto !important;
 padding-top: 60px !important;
}

body.home-page .jobs-stack-container .job-card {
 position: absolute !important;
 left: 50% !important;
 transform: translateX(-50%) !important;
 width: 100% !important;
 max-width: 650px !important;
}

body.home-page .jobs-stack-container .job-card[data-index="1"] {
 top: 0 !important;
 z-index: 5 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="2"] {
 top: 200px !important;
 z-index: 4 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="3"] {
 top: 400px !important;
 z-index: 3 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="4"] {
 top: 600px !important;
 z-index: 2 !important;
}

body.home-page .jobs-stack-container .job-card[data-index="5"] {
 top: 800px !important;
 z-index: 1 !important;
}

body.home-page .job-card .card-content {
 padding: 32px 28px 50px 28px !important;
}

body.home-page .job-card:hover {
 transform: translateX(-50%) translateY(-4px) !important;
 box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12) !important;
 z-index: 10 !important;
}

body.home-page .pricing-card.standard {
 background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 50%, #3a7d7d 100%) !important;
 box-shadow:
 0 24px 48px rgba(90, 157, 157, 0.25),
 0 0 80px rgba(245, 225, 180, 0.6),
 inset 0 0 0 2px rgba(245, 225, 180, 0.2) !important;
}

body.home-page .pricing-card.standard:hover {
 box-shadow:
 0 28px 56px rgba(90, 157, 157, 0.3),
 0 0 100px rgba(245, 225, 180, 0.7),
 inset 0 0 0 2px rgba(245, 225, 180, 0.3) !important;
}

@media (max-width: 767px) {
 body.home-page .site-header,
 body.home-page header.site-header {
  padding: 12px 20px !important;
 }

 body.home-page {
  padding-top: 70px !important;
 }

 body.home-page .container,
 body.home-page section .container {
  max-width: 100% !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
 }

 body.home-page .five-jobs-section .jobs-stack-container {
  position: static !important;
  min-height: auto !important;
  padding-top: 0 !important;
 }

 body.home-page .jobs-stack-container .job-card,
 body.home-page .jobs-stack-container .job-card[data-index="1"],
 body.home-page .jobs-stack-container .job-card[data-index="2"],
 body.home-page .jobs-stack-container .job-card[data-index="3"],
 body.home-page .jobs-stack-container .job-card[data-index="4"],
 body.home-page .jobs-stack-container .job-card[data-index="5"] {
  position: relative !important;
  top: auto !important;
  left: 0 !important;
  transform: none !important;
  margin-bottom: 24px !important;
 }

 body.home-page .jobs-stack-container .job-card:hover {
  transform: translateY(-4px) !important;
 }
}

/* ============================================
 HELODESK HOMEPAGE v11.1 FINAL EOF OVERRIDES
 Wider layout, nuclear hero text, capabilities bar
 ============================================ */

@media (min-width: 1600px) {
 body.home-page .hero-section .container,
 body.home-page .pricing-section .container {
  max-width: 1500px !important;
 }

 body.home-page .container,
 body.home-page section .container {
  max-width: 1300px !important;
 }
}

body.home-page section {
 width: 100% !important;
 margin-left: 0 !important;
 margin-right: 0 !important;
 padding-left: 0 !important;
 padding-right: 0 !important;
}

body.home-page .hero-section,
body.home-page .hero,
body.home-page main > section:first-of-type {
 color: #f5f1ed !important;
}

body.home-page .hero-section p,
body.home-page .hero-section > p,
body.home-page .hero-section div p,
body.home-page .hero-section * p,
body.home-page .hero p,
body.home-page main > section:first-of-type p {
 color: #f5f1ed !important;
 opacity: 1 !important;
}

body.home-page .hero-section span,
body.home-page .hero-section .hero-description,
body.home-page .hero-section .hero-tagline,
body.home-page .hero-section .hero-subtext,
body.home-page .hero-section .small-text,
body.home-page .hero-section .hero-footnote {
 color: #f5f1ed !important;
}

body.home-page .hero-section *:not(h1):not(.headline):not(button):not(.cta-button):not(.primary) {
 color: #f5f1ed !important;
}

body.home-page .hero-section h1,
body.home-page .hero-section h1 *,
body.home-page .hero-section .headline,
body.home-page .hero-section > h1,
body.home-page .hero h1 {
 color: #ffffff !important;
}

body.home-page .hero-section button,
body.home-page .hero-section .cta-button,
body.home-page .hero-section a.button,
body.home-page .hero-section .primary {
 color: #ffffff !important;
}

body.home-page .capabilities-bar {
 background: #f5f1ed !important;
 padding: 50px 0 !important;
 margin: 0 !important;
 width: 100% !important;
}

body.home-page .capabilities-container {
 max-width: 1200px !important;
 margin: 0 auto !important;
 padding: 0 40px !important;
 display: flex !important;
 justify-content: center !important;
 align-items: center !important;
 gap: 40px !important;
 flex-wrap: wrap !important;
}

body.home-page .capability-item {
 display: flex !important;
 align-items: center !important;
 gap: 10px !important;
 white-space: nowrap !important;
}

body.home-page .capability-icon {
 font-size: 1.375rem !important;
 line-height: 1 !important;
}

body.home-page .capability-text {
 font-size: 0.9375rem !important;
 font-weight: 600 !important;
 color: #2a2a2a !important;
 letter-spacing: 0.01em !important;
}

body.home-page .capability-divider {
 width: 1px !important;
 height: 24px !important;
 background: rgba(42, 42, 42, 0.2) !important;
}

body.home-page .pricing-card.standard {
 background: linear-gradient(135deg, #5a9d9d 0%, #4a8d8d 50%, #3a7d7d 100%) !important;
 box-shadow:
 0 24px 48px rgba(90, 157, 157, 0.25),
 0 0 80px rgba(245, 225, 180, 0.6),
 inset 0 0 0 2px rgba(245, 225, 180, 0.2) !important;
}

body.home-page .pricing-card.standard:hover {
 box-shadow:
 0 28px 56px rgba(90, 157, 157, 0.3),
 0 0 100px rgba(245, 225, 180, 0.7),
 inset 0 0 0 2px rgba(245, 225, 180, 0.3) !important;
}

@media (min-width: 900px) {
 body.home-page .capabilities-container {
  flex-wrap: nowrap !important;
  gap: 32px !important;
 }

 body.home-page .capability-divider {
  display: block !important;
 }
}

@media (max-width: 899px) {
 body.home-page .capabilities-container {
  flex-direction: column !important;
  gap: 20px !important;
  padding: 0 20px !important;
 }

 body.home-page .capability-divider {
  display: none !important;
 }

 body.home-page .capability-item {
  justify-content: center !important;
 }

 body.home-page .capabilities-bar {
  padding: 40px 0 !important;
 }
}

/* ===== HELODESK v19 DIRECT SOURCE FIXES ===== */
body.home-page .timeline-pill-section {
  background: #f5f1ed;
  border-radius: 24px;
}

body.home-page .timeline-pill-comparison {
  max-width: 900px;
  margin: 0 auto;
  display: grid;
  gap: 42px;
}

body.home-page .timeline-pill-lane {
  display: grid;
  gap: 18px;
}

body.home-page .timeline-pill-label {
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.05em;
  color: #999;
  font-weight: 600;
}

body.home-page .timeline-pill-label-solution {
  color: #5a9d9d;
}

body.home-page .timeline-pill-bar {
  height: 18px;
  border-radius: 50px;
}

body.home-page .timeline-pill-bar-problem {
  width: 75%;
  background: linear-gradient(90deg, rgba(212,205,199,0.9) 0%, rgba(201,184,176,0.9) 70%, rgba(216,144,144,0.85) 100%);
  filter: blur(0.5px);
  box-shadow: 0 3px 10px rgba(0,0,0,0.06);
}

body.home-page .timeline-pill-bar-solution {
  width: 28%;
  background: linear-gradient(90deg, rgba(90,157,157,0.9) 0%, rgba(74,141,141,0.85) 100%);
  filter: blur(0.5px);
  box-shadow: 0 3px 10px rgba(90,157,157,0.2);
}

body.home-page .timeline-pill-scale {
  width: 75%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  font-size: 0.92rem;
  color: #666;
}

body.home-page .timeline-pill-scale-solution {
  width: 28%;
}

body.home-page .timeline-pill-scale-solution span {
  color: #5a9d9d;
  font-weight: 600;
}

body.home-page .timeline-pill-loss {
  color: #d89090;
  font-weight: 600;
}

body.home-page .core-pain-section {
  position: relative;
  overflow: hidden;
}

body.home-page .what-changes-blobs {
  position: absolute;
  top: 48px;
  right: 48px;
  width: 200px;
  height: 200px;
  pointer-events: none;
  z-index: 1;
}

body.home-page .what-changes-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(1px);
}

body.home-page .what-changes-blob-teal {
  width: 100px;
  height: 100px;
  top: 0;
  right: 0;
  background: radial-gradient(circle, rgba(90,157,157,0.3) 0%, rgba(90,157,157,0.15) 70%, transparent 100%);
}

body.home-page .what-changes-blob-champagne {
  width: 80px;
  height: 80px;
  top: 60px;
  right: 80px;
  background: radial-gradient(circle, rgba(200,184,168,0.25) 0%, rgba(200,184,168,0.12) 70%, transparent 100%);
}

body.home-page .core-pain-section .section-split-head,
body.home-page .core-pain-section .pain-grid {
  position: relative;
  z-index: 2;
}

body.home-page .footer-link-copy {
  gap: 2px;
}

body.home-page .footer-link-subtext {
  font-size: 0.9rem;
  color: #6d8d90;
}

@media (max-width: 767px) {
  body.home-page .timeline-pill-bar-problem,
  body.home-page .timeline-pill-scale {
    width: 100%;
  }

  body.home-page .timeline-pill-bar-solution,
  body.home-page .timeline-pill-scale-solution {
    width: 52%;
  }

  body.home-page .what-changes-blobs {
    top: 24px;
    right: 20px;
    transform: scale(0.8);
    transform-origin: top right;
  }
}

/* ===== HELODESK DESIGN SYSTEM LAYER, 2026-05-22 ===== */
:root {
  --space-xs: 12px;
  --space-sm: 24px;
  --space-md: 40px;
  --space-lg: 60px;
  --space-xl: 80px;
  --space-2xl: 120px;

  --text-xs: 12px;
  --text-sm: 14px;
  --text-base: 16px;
  --text-lg: 18px;
  --text-xl: 20px;
  --text-2xl: 24px;
  --text-3xl: 32px;
  --text-4xl: 40px;
  --text-5xl: 48px;
  --text-6xl: 56px;

  --color-teal: #5a9d9d;
  --color-champagne: #f5f1ed;
  --color-taupe: #C8B8A8;
  --color-dark: #2a2a2a;
  --color-background: #FAF8F5;
  --color-text-primary: #2a2a2a;
  --color-text-secondary: #666;
  --color-text-muted: #999;
  --color-border: rgba(200, 184, 168, 0.2);
}

body.home-page {
  color: var(--color-text-primary);
  background: var(--color-background);
}

body.home-page main > section {
  padding-top: var(--space-xl);
  padding-bottom: var(--space-xl);
}

body.home-page .hero-section {
  padding-top: var(--space-2xl) !important;
  padding-bottom: var(--space-xl) !important;
}

body.home-page h1,
body.home-page .hero-headline {
  font-size: var(--text-5xl);
  line-height: 1.2;
}

body.home-page h2,
body.home-page .section-headline,
body.home-page .proof-showcase-head h2,
body.home-page .section-split-copy h2,
body.home-page .booking-content h2,
body.home-page .lead-capture-section h2 {
  font-size: var(--text-4xl);
  line-height: 1.2;
  margin-bottom: var(--space-sm);
}

body.home-page h3,
body.home-page .metric-number,
body.home-page .pricing-headline,
body.home-page .footer-link-text {
  font-size: var(--text-3xl);
  line-height: 1.3;
}

body.home-page p,
body.home-page .hero-description,
body.home-page .hero-subtext,
body.home-page .section-description,
body.home-page .section-intro,
body.home-page .metric-context,
body.home-page .pricing-description,
body.home-page .footer-note,
body.home-page .footer-enquiry-line,
body.home-page .lead-capture-note {
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-text-secondary);
}

body.home-page .container,
body.home-page .proof-showcase-head,
body.home-page .founder-card,
body.home-page .booking-content,
body.home-page .lead-capture-section,
body.home-page .site-footer {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

body.home-page .proof-showcase,
body.home-page .proof-section,
body.home-page .pricing-section,
body.home-page .standard-section,
body.home-page .lead-capture-section,
body.home-page .pre-faq-booking-section,
body.home-page .core-pain-section,
body.home-page .weak-zone-section,
body.home-page .timeline-pill-section {
  padding-top: var(--space-xl) !important;
  padding-bottom: var(--space-xl) !important;
}

body.home-page .proof-showcase {
  display: grid;
  gap: var(--space-lg);
}

body.home-page .proof-chat-shot,
body.home-page .phone-flip-stage,
body.home-page .phone-container {
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}

body.home-page .iphone-mockup,
body.home-page .phone-device {
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
}

body.home-page .phone-float-card {
  background: #fff;
  border-radius: 8px;
  padding: var(--space-md);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

body.home-page .metrics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  align-items: stretch;
}

body.home-page .metric-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: var(--space-md);
  transition: all 0.2s ease;
  height: 100%;
}

body.home-page .metric-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

body.home-page .proof-section .metric-number {
  font-size: var(--text-3xl) !important;
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: var(--space-sm);
}

body.home-page .proof-section .metric-context {
  font-size: var(--text-base) !important;
  line-height: 1.6;
  color: var(--color-text-secondary) !important;
}

body.home-page .pricing-section {
  padding-top: var(--space-xl) !important;
  padding-bottom: var(--space-xl) !important;
}

body.home-page .pricing-cards-grid {
  margin-bottom: var(--space-md);
  gap: var(--space-md);
}

body.home-page .pricing-cards-grid + .section-description {
  margin-top: 0 !important;
  max-width: 900px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.home-page .standard-section,
body.home-page .founder-section {
  padding-top: var(--space-xl) !important;
  padding-bottom: var(--space-xl) !important;
  background: var(--color-champagne);
}

body.home-page .founder-card {
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

body.home-page .pricing-card,
body.home-page .info-card,
body.home-page .faq-item,
body.home-page .founder-card {
  border: 1px solid var(--color-border);
}

body.home-page .card-label,
body.home-page .timeline-pill-label,
body.home-page .section-label {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
}

@media (max-width: 1024px) {
  body.home-page .metrics-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  body.home-page main > section {
    padding-top: var(--space-lg);
    padding-bottom: var(--space-lg);
  }

  body.home-page h1,
  body.home-page .hero-headline {
    font-size: var(--text-4xl);
  }

  body.home-page h2,
  body.home-page .section-headline,
  body.home-page .proof-showcase-head h2,
  body.home-page .section-split-copy h2,
  body.home-page .booking-content h2,
  body.home-page .lead-capture-section h2 {
    font-size: var(--text-3xl);
  }

  body.home-page h3,
  body.home-page .metric-number,
  body.home-page .pricing-headline,
  body.home-page .footer-link-text {
    font-size: var(--text-2xl);
  }
}

/* ===== HELODESK COMPLETE FIX + VISUAL UPDATE PACK, 2026-05-22 ===== */
body.home-page .page-shell,
body.home-page .site-header,
body.home-page .site-loader {
  position: relative;
  z-index: 1;
}

#helodesk-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: #d4c9bb;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
  transition: opacity 0.6s ease;
}

#helodesk-loader.fade-out {
  opacity: 0;
}

#helodesk-loader .logo-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

#helodesk-loader .logo {
  width: 420px;
  max-width: 90%;
  height: auto;
}

#bubbles-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

#bubbles-background .bubble {
  position: absolute;
  border-radius: 50%;
  opacity: 0.2;
  transition: transform 0.1s ease-out;
}

#bubbles-background .bubble.teal {
  background: radial-gradient(circle, rgba(90,157,157,0.3) 0%, rgba(90,157,157,0.15) 60%, transparent 100%);
}

#bubbles-background .bubble.champagne {
  background: radial-gradient(circle, rgba(200,184,168,0.25) 0%, rgba(200,184,168,0.12) 60%, transparent 100%);
}

body.home-page .footer-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

body.home-page .footer-links a {
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: start;
  min-height: auto;
}

body.home-page .footer-link-copy {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

body.home-page .footer-link-text {
  font-size: var(--text-sm) !important;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.2;
}

body.home-page .footer-link-subtext {
  font-size: var(--text-base) !important;
  color: var(--color-text-primary);
  line-height: 1.4;
}

body.home-page .pricing-section {
  background: var(--color-champagne) !important;
  border-radius: 24px !important;
  padding: var(--space-xl) var(--space-md) !important;
  margin: var(--space-xl) auto !important;
  max-width: 1200px !important;
}

body.home-page .pricing-section .container {
  max-width: 1200px;
}

body.home-page .pricing-section .section-headline {
  font-size: var(--text-5xl) !important;
  line-height: 1.2;
  margin-bottom: var(--space-sm) !important;
  text-align: center;
}

body.home-page .pricing-section > .container > .section-description:first-of-type {
  font-size: var(--text-lg) !important;
  color: var(--color-text-secondary) !important;
  margin-bottom: var(--space-lg) !important;
  text-align: center;
  max-width: 700px;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.home-page .pricing-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md) !important;
  margin-bottom: var(--space-lg) !important;
  max-width: 1000px;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.home-page .pricing-cards-grid + .section-description {
  font-size: var(--text-base) !important;
  line-height: 1.6;
  color: var(--color-text-secondary) !important;
  text-align: center;
  max-width: 900px !important;
  margin: 0 auto !important;
  padding: 0 var(--space-md);
}

body.home-page .pricing-cards-grid + .section-description strong {
  color: var(--color-text-primary);
  font-weight: 600;
}

body.home-page .timeline-pill-section {
  background: var(--color-champagne) !important;
  border-radius: 24px !important;
  padding: var(--space-xl) !important;
  max-width: 1200px !important;
  margin: var(--space-xl) auto !important;
}

body.home-page .timeline-pill-section .section-headline {
  font-size: var(--text-5xl) !important;
  text-align: center;
  margin-bottom: var(--space-xl) !important;
}

body.home-page .timeline-pill-lane {
  margin-bottom: var(--space-lg);
}

body.home-page .timeline-pill-label {
  font-size: var(--text-sm) !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
  margin-bottom: var(--space-sm);
}

body.home-page .timeline-pill-bar-container {
  position: relative;
  padding: 24px 0;
}

body.home-page .what-changes-blobs {
  top: 48px !important;
  right: 48px !important;
  width: 200px !important;
  height: 200px !important;
}

body.home-page .proof-showcase {
  padding-top: var(--space-xl) !important;
  padding-bottom: var(--space-xl) !important;
}

body.home-page .proof-showcase .proof-showcase-head {
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

body.home-page .proof-showcase .phone-device,
body.home-page .proof-showcase .iphone-mockup {
  max-width: 400px !important;
}

@media (max-width: 900px) {
  body.home-page .pricing-cards-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  #helodesk-loader .logo {
    width: 280px;
  }

  body.home-page .pricing-section,
  body.home-page .timeline-pill-section {
    padding: var(--space-lg) var(--space-sm) !important;
  }

  body.home-page .timeline-pill-section .section-headline,
  body.home-page .pricing-section .section-headline {
    font-size: var(--text-4xl) !important;
  }

  body.home-page .footer-links a {
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 12px;
  }
}

/* ===== HELODESK WIDTH / VIEWPORT CORRECTION, 2026-05-23 ===== */
body.home-page main {
  display: block !important;
}

body.home-page main > section,
body.home-page main > footer,
body.home-page .site-footer {
  width: auto !important;
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.home-page .hero-section,
body.home-page .proof-showcase,
body.home-page .weak-zone-section,
body.home-page .timeline-pill-section,
body.home-page .proof-section,
body.home-page .capabilities-bar,
body.home-page .core-pain-section,
body.home-page .pricing-section,
body.home-page .standard-section,
body.home-page .pre-faq-booking-section,
body.home-page .faq-section,
body.home-page .lead-capture-section,
body.home-page .site-footer {
  width: min(1200px, calc(100% - 32px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

@media (max-width: 768px) {
  body.home-page .hero-section,
  body.home-page .proof-showcase,
  body.home-page .weak-zone-section,
  body.home-page .timeline-pill-section,
  body.home-page .proof-section,
  body.home-page .capabilities-bar,
  body.home-page .core-pain-section,
  body.home-page .pricing-section,
  body.home-page .standard-section,
  body.home-page .pre-faq-booking-section,
  body.home-page .faq-section,
  body.home-page .lead-capture-section,
  body.home-page .site-footer {
    width: calc(100% - 24px) !important;
  }

  body.home-page main > section .container,
  body.home-page .proof-showcase-head,
  body.home-page .pricing-section .container,
  body.home-page .booking-content,
  body.home-page .site-footer {
    padding-left: 16px !important;
    padding-right: 16px !important;
    box-sizing: border-box !important;
  }
}

/* ===== HELODESK PRICING RECENTER PATCH, 2026-05-23 ===== */
body.home-page .pricing-section,
body.home-page .pricing-section-refined,
body.home-page .pricing-section.alt-section {
  margin-left: auto !important;
  margin-right: auto !important;
  transform: none !important;
}

@media (max-width: 768px) {
  body.home-page .pricing-section,
  body.home-page .pricing-section-refined,
  body.home-page .pricing-section.alt-section {
    width: calc(100% - 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* ===== HELODESK CLAUDE TRANSLATION PASS, 2026-05-23 ===== */
:root {
  --hd-slate: #3D5A66;
  --hd-teal: #6B9FA3;
  --hd-sage: #7DB5B5;
  --hd-champagne: #C9B5A0;
  --hd-taupe: #B8A89A;
  --hd-cream: #FAF8F5;
  --hd-cream-soft: #F4F0E9;
  --hd-charcoal: #2D3436;
  --hd-charcoal-70: rgba(45, 52, 54, 0.70);
  --hd-slate-12: rgba(61, 90, 102, 0.12);
  --hd-slate-08: rgba(61, 90, 102, 0.08);
}

/* Footer hierarchy */
body.home-page .site-footer {
  background: var(--hd-slate) !important;
  color: rgba(250,248,245,0.78) !important;
  padding: 64px 56px 32px !important;
  box-sizing: border-box !important;
}

body.home-page .site-footer .footer-block.footer-links {
  display: flex !important;
  flex-direction: column !important;
  gap: 28px !important;
  align-items: flex-start !important;
}

body.home-page .site-footer .footer-links > a {
  display: grid !important;
  grid-template-columns: 40px minmax(0, 1fr) !important;
  align-items: flex-start !important;
  gap: 16px !important;
  width: 100% !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  min-height: auto !important;
}

body.home-page .site-footer .footer-link-icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: 12px !important;
  background: rgba(250,248,245,0.08) !important;
  border: 1px solid rgba(250,248,245,0.15) !important;
  display: grid !important;
  place-items: center !important;
  color: #D4A574 !important;
}

body.home-page .site-footer .footer-link-copy {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  align-items: flex-start !important;
  padding-top: 0 !important;
  flex: 1 1 auto !important;
}

body.home-page .site-footer .footer-link-text {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: #D4A574 !important;
  line-height: 1 !important;
  opacity: 0.85 !important;
}

body.home-page .site-footer .footer-link-subtext {
  font-size: 18px !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
  color: #FFFFFF !important;
  line-height: 1.3 !important;
  opacity: 0.95 !important;
}

body.home-page .site-footer .footer-links > a::after {
  color: rgba(250,248,245,0.55) !important;
}

body.home-page .site-footer .footer-links > a:hover .footer-link-subtext,
body.home-page .site-footer .footer-links > a:hover::after {
  color: #D4A574 !important;
  opacity: 1 !important;
}

body.home-page .site-footer .footer-note,
body.home-page .site-footer .footer-enquiry-line,
body.home-page .site-footer p {
  color: rgba(250,248,245,0.78) !important;
}

body.home-page .site-footer .footer-legal-links {
  margin-top: 32px !important;
  padding-top: 24px !important;
  border-top: 1px solid rgba(250,248,245,0.10) !important;
}

body.home-page .site-footer .footer-legal-links a {
  color: rgba(250,248,245,0.55) !important;
}

body.home-page .site-footer .footer-legal-links a:hover {
  color: var(--hd-cream) !important;
}

/* Pricing containment */
body.home-page .pricing-section,
body.home-page .pricing-section-refined,
body.home-page .pricing-section.alt-section {
  background: var(--hd-cream) !important;
  box-sizing: border-box !important;
  width: calc(100% - 64px) !important;
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  left: 0 !important;
  right: 0 !important;
  padding: 96px 64px !important;
}

body.home-page .pricing-section .section-headline {
  font-size: 56px !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  line-height: 1.08 !important;
  color: var(--hd-charcoal) !important;
  max-width: 760px !important;
  margin: 0 auto 20px !important;
  text-wrap: balance !important;
}

body.home-page .pricing-section > .container > .section-description:first-of-type {
  font-size: 18px !important;
  line-height: 1.55 !important;
  color: var(--hd-charcoal-70) !important;
  max-width: 680px !important;
  margin: 0 auto 64px !important;
  text-wrap: pretty !important;
}

body.home-page .pricing-cards-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  max-width: 1000px !important;
  margin: 0 auto 56px !important;
  align-items: stretch !important;
}

body.home-page .pricing-card {
  background: var(--hd-cream-soft) !important;
  border: 1px solid var(--hd-slate-08) !important;
  border-radius: 24px !important;
  padding: 32px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  box-shadow: none !important;
  transform: none !important;
}

body.home-page .pricing-card.standard {
  background: var(--hd-teal) !important;
  border-color: transparent !important;
  box-shadow: 0 12px 32px rgba(61,90,102,0.16) !important;
  transform: translateY(-8px) !important;
}

body.home-page .pricing-card .card-label {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--hd-taupe) !important;
}

body.home-page .pricing-card.standard .card-label,
body.home-page .pricing-card.standard .pricing-headline,
body.home-page .pricing-card.standard .pricing-description {
  color: #FFFFFF !important;
}

body.home-page .pricing-card .pricing-headline {
  font-size: 28px !important;
  font-weight: 500 !important;
  letter-spacing: -0.018em !important;
  line-height: 1.15 !important;
  color: var(--hd-charcoal) !important;
  margin: 0 !important;
  text-wrap: balance !important;
}

body.home-page .pricing-card .pricing-description {
  font-size: 16px !important;
  line-height: 1.55 !important;
  color: var(--hd-charcoal-70) !important;
  text-align: left !important;
  margin: 0 !important;
  text-wrap: pretty !important;
}

body.home-page .pricing-cards-grid + .section-description {
  max-width: 760px !important;
  margin: 0 auto !important;
  text-align: center !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  color: var(--hd-charcoal-70) !important;
  padding-top: 8px !important;
}

body.home-page .pricing-cards-grid + .section-description strong {
  color: var(--hd-charcoal) !important;
  font-weight: 600 !important;
}

/* Mobile hero containment */
@media (max-width: 768px) {
  body.home-page .hero-section {
    padding: 56px 20px !important;
    overflow: hidden !important;
  }

  body.home-page .hero-headline {
    font-size: 34px !important;
    line-height: 1.1 !important;
    letter-spacing: -0.025em !important;
    margin: 0 0 20px !important;
    text-wrap: balance !important;
  }

  body.home-page .hero-description,
  body.home-page .hero-subtext {
    font-size: 15px !important;
    line-height: 1.55 !important;
    margin: 0 0 16px !important;
  }

  body.home-page .hero-subtext {
    color: #FFFFFF !important;
    font-weight: 600 !important;
    padding-bottom: 6px !important;
    display: inline-block !important;
    position: relative !important;
  }

  body.home-page .hero-subtext::after {
    content: '';
    position: absolute;
    left: 0;
    right: 30%;
    bottom: 0;
    height: 2px;
    background: var(--hd-teal);
  }

  body.home-page .primary.book-button.book-walkthrough-btn.cta-button {
    display: block !important;
    background: var(--hd-teal) !important;
    color: #FFFFFF !important;
    padding: 16px 24px !important;
    border-radius: 999px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    text-align: center !important;
    margin: 32px 0 12px !important;
    text-decoration: none !important;
  }

  body.home-page .hero-footnote {
    text-align: center !important;
    font-size: 13px !important;
    color: rgba(250,248,245,0.55) !important;
  }

  body.home-page .site-footer {
    padding: 48px 20px 24px !important;
  }

  body.home-page .site-footer .footer-block.footer-links {
    gap: 24px !important;
  }

  body.home-page .site-footer .footer-link-subtext {
    font-size: 17px !important;
  }

  body.home-page .pricing-section,
  body.home-page .pricing-section-refined,
  body.home-page .pricing-section.alt-section {
    padding: 56px 20px !important;
  }

  body.home-page .pricing-section .section-headline {
    font-size: 32px !important;
    line-height: 1.12 !important;
  }

  body.home-page .pricing-section > .container > .section-description:first-of-type {
    font-size: 16px !important;
    margin-bottom: 40px !important;
  }

  body.home-page .pricing-cards-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    max-width: 100% !important;
  }

  body.home-page .pricing-card {
    padding: 24px !important;
  }

  body.home-page .pricing-card.standard {
    transform: none !important;
  }

  body.home-page .pricing-card .pricing-headline {
    font-size: 22px !important;
  }

  body.home-page .pricing-cards-grid + .section-description {
    font-size: 15px !important;
  }
}

/* ===== HELODESK CLAUDE TRANSLATION MOBILE PRICING ALIGNMENT, 2026-05-23 ===== */
@media (max-width: 768px) {
  body.home-page .pricing-section,
  body.home-page .pricing-section-refined,
  body.home-page .pricing-section.alt-section {
    box-sizing: border-box !important;
    left: calc(12px + ((100vw - 100%) / 2)) !important;
    right: auto !important;
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}
