﻿:root {
  --ink: #151719;
  --muted: #667079;
  --paper: #fbfaf7;
  --surface: #ffffff;
  --soft: #f2f6f4;
  --line: #e5dfd5;
  --red: #d3144c;
  --blue: #2382b7;
  --cyan: #40bfe8;
  --green: #667f58;
  --gold: #c79d45;
  --shadow: 0 18px 48px rgba(21, 23, 25, .11);
  --glow-red: 0 0 0 1px rgba(211, 20, 76, .22), 0 20px 60px rgba(211, 20, 76, .18);
  --glow-blue: 0 0 0 1px rgba(35, 130, 183, .20), 0 20px 60px rgba(35, 130, 183, .16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
.icon-sprite { position: absolute; width: 0; height: 0; overflow: hidden; pointer-events: none; }
.mobile-thumb {
  display: block;
  width: calc(100% + 48px);
  margin: -24px -24px 16px;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 8px 8px 0 0;
}
.symptom-stack article,
.feature-grid.four article { overflow: hidden; }
.metric-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  margin-bottom: 6px;
  border-radius: 14px;
  background:
    radial-gradient(120% 120% at 25% 22%, rgba(255,255,255,.96) 0%, rgba(255,244,247,.92) 55%, rgba(232,247,253,.92) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 14px 30px rgba(35,130,183,.10),
    0 4px 10px rgba(211,20,76,.08);
  position: relative;
}
.metric-icon::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.4px;
  background: linear-gradient(135deg, #d3144c 0%, #a13776 55%, #1f7da6 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  opacity: .85;
}
.metric-icon svg { width: 28px; height: 28px; display: block; overflow: visible; }
.card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  margin: 14px 0 8px;
  border-radius: 12px;
  background:
    radial-gradient(120% 120% at 25% 22%, rgba(255,255,255,.96) 0%, rgba(255,244,247,.92) 55%, rgba(232,247,253,.92) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 8px 18px rgba(35,130,183,.10),
    0 2px 6px rgba(211,20,76,.06);
  position: relative;
  flex: 0 0 auto;
}
.card-icon::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.2px;
  background: linear-gradient(135deg, #d3144c 0%, #a13776 55%, #1f7da6 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  opacity: .85;
}
.card-icon svg { width: 22px; height: 22px; display: block; overflow: visible; }
.symptom-stack .card-icon,
.feature-grid .card-icon,
.process-grid .card-icon,
.vieva-value-grid .card-icon,
.youth-process .card-icon,
.youth-card-grid .card-icon,
.youth-practice-list .card-icon,
.academy-benefits .card-icon { margin-top: 4px; }
.symptom-stack .card-icon,
.feature-grid.four .card-icon { display: none; }
@media (min-width: 901px) {
  .card-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
  }
  .card-icon svg { width: 26px; height: 26px; }
}
.section-accent {
  width: 56px;
  height: 4px;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--red), var(--cyan), var(--blue));
  margin: 18px 0 0;
  box-shadow: 0 6px 20px rgba(211,20,76,.18);
}
.eyebrow-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  margin-right: 8px;
  vertical-align: -5px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(211,20,76,.10), rgba(64,191,232,.12));
}
.eyebrow-icon svg { width: 14px; height: 14px; }
.wrap { width: min(1120px, calc(100% - 40px)); margin: 0 auto; }
.narrow { width: min(820px, calc(100% - 40px)); }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  padding: 14px max(20px, calc((100vw - 1120px) / 2));
  background: rgba(251, 250, 247, .88);
  border-bottom: 1px solid rgba(229, 223, 213, .92);
  backdrop-filter: blur(16px);
}
.brand { display: flex; align-items: center; text-decoration: none; white-space: nowrap; }
.brand-logo {
  width: auto;
  height: 48px;
  max-width: 210px;
  object-fit: contain;
  object-position: left center;
  filter: drop-shadow(0 6px 16px rgba(211,20,76,.12)) drop-shadow(0 6px 18px rgba(35,130,183,.10));
}
.site-nav { display: flex; align-items: center; gap: 20px; font-size: 14px; }
.site-nav a { text-decoration: none; color: var(--muted); white-space: nowrap; }
.site-nav a:hover { color: var(--ink); }
.site-nav .nav-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.nav-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.nav-dropdown-trigger::after {
  content: "\25BE";
  font-size: 10px;
  line-height: 1;
  color: var(--red);
}
.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  z-index: 20;
  min-width: 236px;
  padding: 10px;
  border: 1px solid rgba(211,20,76,.14);
  border-radius: 10px;
  background: rgba(255,255,255,.97);
  box-shadow: 0 18px 48px rgba(35,130,183,.14), 0 0 34px rgba(211,20,76,.10);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(-50%) translateY(6px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
}
.nav-dropdown-menu::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -16px;
  height: 16px;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav-dropdown-menu a {
  display: block;
  padding: 10px 12px;
  border-radius: 8px;
  color: var(--ink);
}
.nav-dropdown-menu a:hover {
  color: var(--red);
  background: linear-gradient(90deg, rgba(255,231,237,.92), rgba(232,247,250,.72));
}
.site-nav .nav-pill {
  color: var(--ink);
  padding: 8px 12px;
  border: 1px solid rgba(211,20,76,.24);
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  box-shadow: 0 0 22px rgba(211,20,76,.10);
}
.nav-toggle { display: none; }

.hero {
  position: relative;
  min-height: calc(100vh - 70px);
  display: flex;
  align-items: center;
  overflow: hidden;
  width: 100%;
  padding: 78px max(20px, calc((100vw - 1180px) / 2)) 64px;
  background:
    linear-gradient(118deg, #fff 0%, #fff6f8 27%, #eaf8fb 58%, #f2f8ef 100%),
    linear-gradient(30deg, rgba(211,20,76,.10), transparent 36%, rgba(35,130,183,.12) 64%, rgba(102,127,88,.10));
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(251,250,247,.98) 0%, rgba(251,250,247,.88) 34%, rgba(251,250,247,.36) 64%, rgba(251,250,247,.08) 100%),
    linear-gradient(145deg, rgba(211,20,76,.18) 0%, transparent 24%, rgba(35,130,183,.16) 56%, rgba(102,127,88,.15) 100%),
    linear-gradient(22deg, transparent 0%, rgba(255,255,255,.35) 42%, rgba(211,20,76,.08) 43%, transparent 60%);
}
.hero::after {
  content: "";
  position: absolute;
  left: max(20px, calc((100vw - 1180px) / 2));
  bottom: 40px;
  z-index: 1;
  width: 220px;
  height: 5px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--red), var(--blue), var(--green));
  box-shadow: 0 0 28px rgba(211,20,76,.32), 0 0 30px rgba(35,130,183,.28);
}
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
.hero-bg img {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center right;
  filter: drop-shadow(0 28px 50px rgba(21,23,25,.16));
}
.hero-copy { position: relative; z-index: 2; max-width: 680px; padding: 12px 0 38px; }
.hero-portrait-mobile { display: none; }
.hero h1 {
  text-shadow: 0 18px 44px rgba(255,255,255,.78);
}
.hero h1::after {
  content: "";
  display: block;
  width: 170px;
  height: 6px;
  margin-top: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--red), var(--blue), var(--green));
  box-shadow: 0 0 28px rgba(211,20,76,.24), 0 0 28px rgba(35,130,183,.22);
}
.hero .lead { text-shadow: 0 10px 30px rgba(255,255,255,.72); }
.eyebrow {
  margin: 0 0 12px;
  color: var(--red);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}
h1, h2, h3 { line-height: 1.08; margin: 0; letter-spacing: 0; }
h1 { font-size: 74px; max-width: 850px; }
h2 { font-size: 50px; }
h3 { font-size: 22px; }
.lead { margin: 22px 0 0; max-width: 650px; color: #3d444a; font-size: 20px; }
.copy-mobile { display: none; }
.hero-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
  max-width: 680px;
}
.hero-trust {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  width: min(620px, 100%);
  margin-top: 18px;
}
.hero-trust span {
  padding: 12px;
  background: rgba(255,255,255,.68);
  border: 1px solid rgba(255,255,255,.82);
  border-radius: 8px;
  color: #454c52;
  box-shadow: 0 10px 28px rgba(21,23,25,.08);
}
.hero-trust strong { display: block; color: var(--ink); line-height: 1.15; }
.trust-rating { display: grid; gap: 3px; align-content: center; }
.trust-rating .stars { display: inline-flex; gap: 1px; line-height: 0; }
.trust-rating .stars svg { width: 12px; height: 12px; display: block; flex: 0 0 auto; }
.trust-rating strong { font-size: 13px; line-height: 1.15; }
.trust-rating em { font-style: normal; font-size: 11px; color: var(--muted); line-height: 1.2; }
.rating-row { display: inline-flex; align-items: center; gap: 10px; margin-top: 8px; flex-wrap: wrap; justify-content: center; }
.stars-lg { display: inline-flex; gap: 2px; line-height: 0; }
.stars-lg svg { width: 16px; height: 16px; display: block; flex: 0 0 auto; }
.rating-google { display: inline-flex; align-items: center; gap: 5px; font-weight: 600; color: var(--ink); font-size: 13px; letter-spacing: .01em; }
.rating-google .g-mark { width: 14px; height: 14px; display: block; flex: 0 0 auto; }
.hero-points span, .outcome-list span {
  padding: 12px 14px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(255,255,255,.72);
  border-radius: 8px;
  box-shadow: 0 10px 28px rgba(21, 23, 25, .08), inset 0 0 0 1px rgba(35,130,183,.08);
  backdrop-filter: blur(10px);
}
.hero-points span { font-size: 15px; line-height: 1.35; }
.hero-points span:nth-child(1) { border-left: 4px solid var(--red); }
.hero-points span:nth-child(2) { border-left: 4px solid var(--blue); }
.hero-points span:nth-child(3) { border-left: 4px solid var(--green); }
.hero-actions, .contact-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }
.hero .hero-actions { margin-top: 18px; }
.button, .price-grid a, .rush-box a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 18px;
  border: 1px solid var(--ink);
  border-radius: 6px;
  text-decoration: none;
  font-weight: 800;
}
.button.primary, .price-grid a {
  color: #fff;
  background: var(--ink);
  box-shadow: 0 12px 34px rgba(21, 23, 25, .18), 0 0 28px rgba(35, 130, 183, .12);
}
.button.secondary { color: var(--ink); background: rgba(255,255,255,.68); border-color: rgba(35,130,183,.24); box-shadow: 0 0 26px rgba(35,130,183,.10); }
.button:hover, .price-grid a:hover { transform: translateY(-1px); }
.text-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 12px;
  color: var(--red);
  font-weight: 900;
  text-decoration: none;
}
.text-link::after { content: ">"; color: var(--blue); }

.section { padding: 96px 0; }
.band { background: linear-gradient(135deg, #eef8f6 0%, #f6f1f6 48%, #f4f7ed 100%); border-top: 1px solid rgba(102, 127, 88, .15); border-bottom: 1px solid rgba(102, 127, 88, .15); }
.section-heading { position: relative; max-width: 790px; margin-bottom: 34px; padding-bottom: 14px; }
.section-heading::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 92px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--red), var(--blue), var(--green));
  box-shadow: 0 0 20px rgba(211,20,76,.24), 0 0 22px rgba(35,130,183,.22);
}
.section-heading p:not(.eyebrow) { color: var(--muted); font-size: 18px; }
.feature-grid, .metric-grid, .target-grid, .service-grid, .process-grid, .experience-grid, .price-grid, .mini-price-grid, .blog-grid, .quote-grid, .video-grid, .seo-grid {
  display: grid;
  gap: 18px;
}
.feature-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.metric-grid, .target-grid, .blog-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.feature-grid article, .metric-grid article, .target-grid article, .service-grid article, .process-grid article, .experience-grid article, .price-grid article, .mini-price-grid article, .blog-card, blockquote, .video-grid article, .seo-grid article, .contact-card, .conversion-panel, .rush-box {
  background: rgba(255,255,255,.84);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 24px;
  box-shadow: 0 14px 40px rgba(21, 23, 25, .07);
}
.feature-grid article:nth-child(1), .service-grid article:nth-child(2), .price-grid .highlight { background: linear-gradient(180deg, #fff 0%, #fff4f7 100%); box-shadow: var(--glow-red); }
.feature-grid article:nth-child(2), .service-grid article:nth-child(4), .metric-grid article:nth-child(2) { background: linear-gradient(180deg, #fff 0%, #f7f3e8 100%); }
.feature-grid article:nth-child(3), .metric-grid article:nth-child(1), .service-grid article:nth-child(3) { background: linear-gradient(180deg, #fff 0%, #eff9fd 100%); box-shadow: var(--glow-blue); }
.feature-grid article:nth-child(4), .service-grid article:nth-child(5), .metric-grid article:nth-child(3) { background: linear-gradient(180deg, #fff 0%, #f2f8ef 100%); }
.feature-grid span, .service-grid span, .process-grid span, .story-card span { color: var(--blue); font-weight: 900; }
.feature-grid h3, .metric-grid h3, .target-grid h3, .service-grid h3, .experience-grid h3, .price-grid h3, .blog-card h3, .video-grid h3, .seo-grid h3 { margin-top: 12px; }
.feature-grid p, .metric-grid p, .target-grid p, .service-grid p, .experience-grid p, .price-grid span, .price-grid small, .blog-card p, blockquote p, .seo-grid p { color: var(--muted); }

.imagery-section {
  padding-top: 18px;
}
.imagery-panel {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 26px;
  align-items: center;
  padding: 32px;
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(21,23,25,.96), rgba(17,45,58,.90) 54%, rgba(45,20,36,.88)),
    radial-gradient(circle at top right, rgba(64,191,232,.24), transparent 38%);
  color: #fff;
  box-shadow: 0 24px 70px rgba(21,23,25,.18), 0 0 42px rgba(64,191,232,.12);
}
.imagery-panel h2 { color: #fff; }
.imagery-panel p { color: rgba(255,255,255,.74); }
.imagery-steps {
  display: grid;
  gap: 12px;
}
.imagery-steps article {
  padding: 18px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 10px;
  background: rgba(255,255,255,.08);
}
.imagery-steps span {
  display: inline-block;
  margin-bottom: 8px;
  color: var(--red);
  font-weight: 900;
}
.imagery-steps strong {
  display: block;
  margin-bottom: 6px;
  color: #fff;
}

.story-grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr .9fr;
  gap: 18px;
  align-items: stretch;
}
.story-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  box-shadow: var(--shadow);
}
.story-card img, .service-grid img, .pain-grid img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 8px;
  margin: 12px 0 18px;
}
.story-card.tall img { aspect-ratio: 1 / 1; }
.story-card p { color: var(--muted); }

.pain-section { background: linear-gradient(135deg, #151719 0%, #183241 46%, #261924 100%); color: #fff; }
.pain-section .section-heading p:not(.eyebrow), .pain-section .pain-grid p { color: rgba(255,255,255,.72); }
.pain-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-bottom: 26px; }
.pain-grid article {
  padding: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 8px;
  box-shadow: 0 18px 50px rgba(0,0,0,.22), 0 0 32px rgba(64,191,232,.10);
}

.split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 520px);
  gap: 48px;
  align-items: center;
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
}
.split-image img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 8px; box-shadow: var(--shadow); }
.about-photo img {
  aspect-ratio: 4 / 5;
  object-position: center 18%;
}
.split-copy p { color: var(--muted); font-size: 18px; }
.glow-panel, .academy-section, .anniversary { background: linear-gradient(135deg, rgba(255,255,255,.82), rgba(239,249,253,.72) 52%, rgba(255,244,247,.74)); border: 1px solid rgba(255,255,255,.82); border-radius: 8px; padding: 34px; box-shadow: var(--glow-blue); }
.outcome-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin: 24px 0; }
.service-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.mini-list { display: grid; gap: 12px; margin: 22px 0; }
.mini-list article { border-top: 1px solid var(--line); padding-top: 14px; }
.mini-list p { margin-bottom: 0; }
.academy-media { display: grid; gap: 16px; }
.academy-preview {
  padding: 24px;
  border-radius: 8px;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(21,23,25,.94), rgba(17,45,58,.92)),
    radial-gradient(circle at top right, rgba(211,20,76,.28), transparent 42%);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 22px 62px rgba(21,23,25,.18), 0 0 36px rgba(211,20,76,.16);
}
.academy-preview span { color: #93daf2; font-weight: 800; text-transform: uppercase; font-size: 13px; }
.academy-preview strong { display: block; margin: 10px 0; font-size: 24px; line-height: 1.12; }
.academy-preview p { color: rgba(255,255,255,.76); margin-bottom: 0; }

.video-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.video-grid article { padding: 16px; }
.video-embed {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: 8px;
  background: #111;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 22px 62px rgba(21,23,25,.18), 0 0 36px rgba(64,191,232,.16);
}
.youtube-link-card {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  min-height: 280px;
  background:
    linear-gradient(135deg, rgba(21,23,25,.95), rgba(17,45,58,.88)),
    linear-gradient(45deg, rgba(211,20,76,.22), transparent 46%, rgba(64,191,232,.18));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 24px 70px rgba(21,23,25,.22), 0 0 42px rgba(64,191,232,.18);
}
.youtube-link-card a {
  position: relative;
  display: grid;
  align-content: end;
  min-height: 280px;
  padding: 24px;
  color: #fff;
  text-decoration: none;
}
.youtube-link-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .44;
  filter: saturate(1.05) contrast(1.03);
}
.youtube-link-card a::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(21,23,25,.08) 0%, rgba(21,23,25,.78) 100%);
}
.youtube-link-card .play-mark,
.youtube-link-card strong,
.youtube-link-card small {
  position: relative;
  z-index: 1;
}
.youtube-link-card .play-mark {
  display: inline-grid;
  place-items: center;
  width: 64px;
  height: 64px;
  margin-bottom: 16px;
  border-radius: 50%;
  color: transparent;
  background: #fff;
  box-shadow: 0 0 34px rgba(211,20,76,.24), 0 0 40px rgba(64,191,232,.20);
}
.youtube-link-card .play-mark::after {
  content: "";
  width: 0;
  height: 0;
  margin-left: 5px;
  border-top: 11px solid transparent;
  border-bottom: 11px solid transparent;
  border-left: 17px solid var(--red);
}
.youtube-link-card strong { font-size: 26px; line-height: 1.1; }
.youtube-link-card small { margin-top: 8px; color: rgba(255,255,255,.76); font-weight: 800; }
.wistia_responsive_padding { padding: 56.25% 0 0 0; position: relative; }
.wistia_responsive_wrapper { height: 100%; left: 0; position: absolute; top: 0; width: 100%; }
.testimonial-video { max-width: 760px; margin: 0 auto 26px; }

.testimonials { background: #eef5f1; }
.proof-wall { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; margin-bottom: 26px; }
.proof-wall article {
  padding: 18px;
  border-radius: 8px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(255,255,255,.88);
  box-shadow: 0 14px 36px rgba(21,23,25,.07);
}
.proof-wall span { display: inline-block; color: var(--red); font-size: 13px; font-weight: 900; text-transform: uppercase; }
.proof-wall p { color: #3f464d; margin: 12px 0; }
.proof-wall strong { color: var(--ink); }
.compact-advantages {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 20px;
}
.compact-advantages article {
  padding: 16px 18px;
  border-radius: 12px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.86);
  box-shadow: 0 14px 34px rgba(21,23,25,.08);
}
.compact-advantages strong {
  display: block;
  color: var(--ink);
  margin-bottom: 5px;
  font-size: 15px;
}
.compact-advantages span,
.quote-snippets p {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}
.testimonials-dive {
  max-width: 900px;
  margin: 4px auto 0;
}
.quote-snippets {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.quote-snippets p {
  margin: 0;
  padding: 14px;
  border-radius: 10px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(211,20,76,.10);
}
.quote-grid.rich { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.quote-archive { margin-top: 20px; background: rgba(255,255,255,.62); }
.quote-archive summary { color: var(--ink); }
.quote-archive .quote-grid { margin-top: 18px; }
blockquote { margin: 0; }
cite { display: block; margin-top: 14px; font-style: normal; font-weight: 800; }
.stats { display: grid; gap: 10px; margin-top: 24px; }
.stats strong { padding: 14px 0; border-top: 1px solid var(--line); }
.process-grid, .experience-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.experience-showcase {
  position: relative;
  overflow: hidden;
  padding: 44px;
  border: 1px solid rgba(255,255,255,.82);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.92) 0%, rgba(255,241,246,.82) 44%, rgba(235,249,255,.84) 100%),
    linear-gradient(35deg, rgba(211,20,76,.08), rgba(35,130,183,.10));
  box-shadow: 0 22px 62px rgba(211,20,76,.10), 0 18px 48px rgba(35,130,183,.08);
}
.experience-showcase::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(120deg, rgba(255,255,255,.38), transparent 42%, rgba(64,191,232,.08));
}
.experience-showcase > * { position: relative; z-index: 1; }
.experience-showcase .experience-grid article:nth-child(1),
.experience-showcase .experience-grid article:nth-child(4) {
  background: linear-gradient(180deg, #fff 0%, #fff2f6 100%);
  box-shadow: var(--glow-red);
}
.experience-showcase .experience-grid article:nth-child(2),
.experience-showcase .experience-grid article:nth-child(3) {
  background: linear-gradient(180deg, #fff 0%, #edfaff 100%);
  box-shadow: var(--glow-blue);
}
.anniversary {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(21,23,25,.96) 0%, rgba(18,47,63,.94) 52%, rgba(52,18,34,.96) 100%);
  color: #fff;
  box-shadow: 0 24px 70px rgba(21,23,25,.18), 0 0 52px rgba(211,20,76,.12);
}
.anniversary::before {
  content: "6";
  position: absolute;
  right: 34px;
  top: -26px;
  color: rgba(255,255,255,.07);
  font-size: 240px;
  font-weight: 900;
  line-height: .8;
}
.anniversary .split-copy,
.anniversary .split-image { position: relative; z-index: 1; }
.anniversary p:not(.eyebrow),
.anniversary .mini-list p { color: rgba(255,255,255,.74); }
.anniversary .mini-list article {
  padding: 16px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
}
.anniversary .mini-list article + article { margin-top: 0; }

.conversion-panel {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
  gap: 30px;
  align-items: center;
  padding: 34px;
  background:
    linear-gradient(135deg, rgba(21,23,25,.98) 0%, rgba(18,47,63,.95) 47%, rgba(45,20,36,.96) 100%),
    linear-gradient(35deg, rgba(211,20,76,.22), transparent 42%, rgba(64,191,232,.18));
  color: #fff;
  border-color: rgba(255,255,255,.12);
  box-shadow: 0 24px 70px rgba(21,23,25,.26), 0 0 52px rgba(211,20,76,.16), 0 0 42px rgba(64,191,232,.12);
}
.conversion-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08) 0 1px, transparent 1px 100%),
    linear-gradient(180deg, rgba(255,255,255,.08) 0 1px, transparent 1px 100%);
  background-size: 42px 42px;
  opacity: .16;
}
.conversion-copy,
.conversion-action { position: relative; z-index: 1; }
.conversion-panel h2 span { display: block; }
.conversion-panel h2 span:nth-child(1) { color: #fff; }
.conversion-panel h2 span:nth-child(2) { color: #93daf2; }
.conversion-panel h2 span:nth-child(3) { color: #ff8bad; }
.conversion-panel p { color: rgba(255,255,255,.76); }
.conversion-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.conversion-tags span {
  padding: 9px 12px;
  border-radius: 999px;
  color: #fff;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.16);
  font-weight: 800;
}
.conversion-action {
  padding: 22px;
  border-radius: 8px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
}
.conversion-action strong { display: block; font-size: 24px; line-height: 1.15; }
.conversion-action p { margin-bottom: 0; }
.conversion-panel .button.primary { background: #fff; color: var(--ink); border-color: #fff; }

.price-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.price-grid p { margin: 0; color: var(--red); font-weight: 800; }
.price-grid h3 { font-size: 40px; }
.price-grid small { display: block; margin-top: 14px; font-size: 15px; }
.price-grid ul { padding-left: 18px; color: #3e464d; }
.price-grid a { margin-top: 18px; width: 100%; }
.price-grid .badge {
  display: inline-flex;
  margin-bottom: 14px;
  padding: 7px 10px;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(90deg, var(--red), var(--blue));
  box-shadow: 0 0 24px rgba(211,20,76,.20);
  font-size: 13px;
  font-weight: 900;
}
.price-grid .depth { background: linear-gradient(180deg, #fff 0%, #f2f8ef 100%); box-shadow: 0 0 0 1px rgba(102,127,88,.24), 0 20px 60px rgba(102,127,88,.17); }
.mini-price-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.mini-price-grid p { color: var(--red); font-weight: 800; margin: 8px 0; }
.mini-price-grid span { color: var(--muted); }
.rush-box { margin-top: 18px; box-shadow: var(--glow-red); }

.blog-teaser .button { margin-top: 24px; }
.blog-card { padding: 0; }
.blog-card a { display: block; height: 100%; padding: 24px; text-decoration: none; }
.blog-card span { color: var(--blue); font-size: 13px; font-weight: 800; text-transform: uppercase; }
.blog-card.visual { overflow: hidden; }
.blog-card.visual a { padding: 0; }
.blog-card.visual img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; }
.blog-card.visual span, .blog-card.visual h3, .blog-card.visual p { display: block; margin-left: 22px; margin-right: 22px; }
.blog-card.visual span { margin-top: 20px; }
.blog-card.visual p { margin-bottom: 24px; }
.blog-landing-hero {
  background:
    linear-gradient(135deg, rgba(238,245,241,.98), rgba(239,249,253,.90)),
    radial-gradient(circle at 80% 15%, rgba(211,20,76,.16), transparent 38%);
}
.topic-rail { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.topic-rail span {
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.88);
  box-shadow: 0 8px 24px rgba(21,23,25,.06);
  font-weight: 800;
}

.contact { background: linear-gradient(135deg, #151719 0%, #112d3a 48%, #2a1421 100%); color: #fff; }
.contact .eyebrow { color: #ff8bad; }
.contact p { color: rgba(255,255,255,.78); }
.contact-inner { display: grid; grid-template-columns: 1fr minmax(280px, 420px); gap: 36px; align-items: center; }
.contact-card { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.16); display: grid; gap: 8px; }
.contact-card span, .contact-card a { color: rgba(255,255,255,.82); text-decoration: none; }
.contact-options { display: grid; gap: 10px; margin-top: 12px; }
.contact-options a {
  display: grid;
  gap: 3px;
  padding: 14px;
  border-radius: 8px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
}
.contact-options a:hover { background: rgba(255,255,255,.14); }
.contact-options span { color: #93daf2; font-size: 13px; font-weight: 900; text-transform: uppercase; }
.contact-options strong { color: #fff; overflow-wrap: anywhere; }
.contact .button.primary { background: #fff; color: var(--ink); border-color: #fff; }
.contact .button.secondary { color: #fff; border-color: rgba(255,255,255,.5); background: transparent; }

.seo-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.faq { background: #f4f0e8; }
details {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  margin-bottom: 10px;
  padding: 18px 20px;
  box-shadow: 0 10px 32px rgba(21, 23, 25, .05);
}
summary { cursor: pointer; font-weight: 800; }
details p { color: var(--muted); }
.final-cta { background: linear-gradient(135deg, #151719 0%, #122f3f 48%, #291721 100%); color: #fff; }
.final-cta h2 { max-width: 850px; }
.final-cta .button.secondary { color: #fff; border-color: rgba(255,255,255,.45); background: transparent; }

.page-hero { padding: 90px 0 50px; background: #eef5f1; }
.page-hero.compact h1 { font-size: 62px; }
.page-hero p:not(.eyebrow) { color: var(--muted); font-size: 20px; max-width: 720px; }
.vieva-hero-page {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(120deg, rgba(255,255,255,.98) 0%, rgba(239,249,253,.92) 45%, rgba(242,248,239,.94) 100%),
    linear-gradient(28deg, rgba(211,20,76,.12), transparent 42%, rgba(35,130,183,.16));
}
.vieva-hero-page::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(251,250,247,.96), rgba(251,250,247,.56) 58%, rgba(251,250,247,.18)),
    radial-gradient(circle at 82% 18%, rgba(64,191,232,.24), transparent 30%),
    radial-gradient(circle at 20% 86%, rgba(211,20,76,.13), transparent 28%);
}
.vieva-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 460px);
  gap: 48px;
  align-items: center;
}
.vieva-hero-card, .vieva-measurement-shot {
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.84);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow), 0 0 44px rgba(64,191,232,.16);
}
.vieva-hero-card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}
.vieva-hero-card figcaption, .vieva-measurement-shot figcaption {
  padding: 12px 14px;
  color: var(--muted);
  font-size: 14px;
}
.vieva-value-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.vieva-value-grid article {
  min-height: 100%;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,.86);
  box-shadow: 0 14px 40px rgba(21,23,25,.07);
}
.vieva-value-grid article:nth-child(1) { background: linear-gradient(180deg, #fff 0%, #eff9fd 100%); box-shadow: var(--glow-blue); }
.vieva-value-grid article:nth-child(2) { background: linear-gradient(180deg, #fff 0%, #fff4f7 100%); box-shadow: var(--glow-red); }
.vieva-value-grid article:nth-child(3) { background: linear-gradient(180deg, #fff 0%, #f2f8ef 100%); }
.vieva-value-grid article:nth-child(4) { background: linear-gradient(180deg, #fff 0%, #f7f3e8 100%); }
.vieva-value-grid span { color: var(--blue); font-weight: 900; }
.vieva-value-grid h3 { margin-top: 12px; }
.vieva-value-grid p { color: var(--muted); }
.vieva-example-grid {
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(380px, 1.14fr);
  gap: 42px;
  align-items: center;
}
.vieva-measurement-shot img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: left top;
}
.vieva-honesty {
  background:
    linear-gradient(135deg, rgba(21,23,25,.98), rgba(18,47,63,.96) 54%, rgba(41,23,33,.98)),
    linear-gradient(90deg, rgba(211,20,76,.18), rgba(64,191,232,.16));
}
.vieva-honesty-panel {
  display: grid;
  grid-template-columns: minmax(0, .75fr) minmax(0, 1.25fr);
  gap: 36px;
  align-items: start;
  min-width: 0;
  padding: 42px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  color: #fff;
  background: rgba(255,255,255,.06);
  box-shadow: 0 24px 70px rgba(0,0,0,.22);
}
.vieva-honesty-panel *, .vieva-honesty-list { min-width: 0; }
.vieva-honesty-panel h2, .vieva-honesty-panel h3, .vieva-honesty-panel p { overflow-wrap: anywhere; }
.vieva-honesty-panel p:not(.eyebrow), .vieva-honesty-list p { color: rgba(255,255,255,.76); }
.vieva-honesty-list {
  display: grid;
  gap: 14px;
}
.vieva-honesty-list article {
  padding: 18px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
}
.vieva-use-section .glow-panel { width: 100%; }
.vieva-price-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px);
  gap: 28px;
  align-items: center;
  padding: 36px;
  border: 1px solid rgba(255,255,255,.84);
  border-radius: 8px;
  background: linear-gradient(135deg, #fff 0%, #eff9fd 48%, #fff4f7 100%);
  box-shadow: var(--glow-blue);
}
.vieva-price-panel p { color: var(--muted); font-size: 18px; }
.price-note {
  padding: 24px;
  border: 1px solid rgba(35,130,183,.18);
  border-radius: 8px;
  background: rgba(255,255,255,.82);
  box-shadow: 0 14px 40px rgba(21,23,25,.08);
}
.price-note strong { display: block; margin-bottom: 8px; font-size: 22px; line-height: 1.15; }
.price-note .button { margin-top: 12px; }
.vieva-faq .faq-list { max-width: 920px; }
.academy-hero-page {
  min-height: 560px;
  display: flex;
  align-items: center;
  background:
    linear-gradient(135deg, rgba(21,23,25,.92), rgba(17,45,58,.84)),
    url("../images/mountain-balance.jpg") center / cover;
  color: #fff;
}
.academy-hero-page p:not(.eyebrow) { color: rgba(255,255,255,.78); }
.academy-showcase { display: grid; grid-template-columns: 1.15fr .85fr; gap: 24px; align-items: start; }
.academy-main-video { box-shadow: 0 24px 70px rgba(21,23,25,.22), 0 0 42px rgba(64,191,232,.18); }
.academy-benefits { display: grid; gap: 14px; }
.academy-benefits article, .academy-flow-grid article {
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,.86);
  box-shadow: 0 12px 34px rgba(21,23,25,.06);
}
.academy-benefits span { color: var(--blue); font-weight: 900; }
.academy-benefits p, .academy-flow p, .academy-flow-grid span { color: var(--muted); }
.academy-flow { display: grid; grid-template-columns: .9fr 1.1fr; gap: 34px; align-items: center; }
.academy-flow-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.academy-flow-grid strong { display: block; margin-bottom: 8px; }
.mobile-visual-strip,
.mobile-icon-row,
.mobile-image-break { display: none; }
.article { padding: 64px 0 96px; }
.article h2 { margin: 42px 0 12px; font-size: 34px; }
.article h3 { margin: 30px 0 10px; }
.article p { color: #343a40; font-size: 18px; }
.article-cta {
  margin-top: 56px;
  padding: 28px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--glow-blue);
}
.legal {
  display: grid;
  gap: 18px;
  padding-top: 44px;
}
.legal-toc, .legal-card, .legal-section {
  min-width: 0;
  background: rgba(255,255,255,.86);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 14px 40px rgba(21,23,25,.07);
}
.legal-toc {
  padding: 20px;
  position: sticky;
  top: 86px;
  z-index: 2;
}
.legal-toc strong { display: block; margin-bottom: 12px; }
.legal-toc div { display: flex; flex-wrap: wrap; gap: 8px; }
.legal-toc a {
  display: block;
  padding: 8px 10px;
  border: 1px solid rgba(35,130,183,.18);
  border-radius: 999px;
  color: #38424a;
  background: rgba(239,249,253,.68);
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  overflow-wrap: anywhere;
}
.legal-card, .legal-section { padding: 28px; }
.legal-section {
  scroll-margin-top: 260px;
}
.legal h2 {
  font-size: 28px;
  padding-bottom: 12px;
  margin-top: 0;
  border-bottom: 1px solid var(--line);
  overflow-wrap: anywhere;
}
.legal p { margin: 12px 0 0; overflow-wrap: anywhere; }
.legal-list {
  margin: 14px 0 0;
  padding: 16px 18px 16px 34px;
  background: #f7faf8;
  border: 1px solid rgba(102,127,88,.14);
  border-radius: 8px;
}
.legal-list li { margin: 6px 0; color: #3e464d; overflow-wrap: anywhere; }

.site-footer {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 28px;
  padding: 44px max(20px, calc((100vw - 1120px) / 2));
  background: #fff;
  border-top: 1px solid var(--line);
}
.site-footer strong { display: block; margin-bottom: 12px; }
.site-footer p { color: var(--muted); margin: 0; }
.site-footer a { display: block; margin-bottom: 8px; color: var(--muted); text-decoration: none; }

@media (max-width: 1100px) {
  h1 { font-size: 62px; }
  h2 { font-size: 42px; }
  .site-nav { gap: 14px; font-size: 13px; }
  .feature-grid, .service-grid, .mini-price-grid, .quote-grid.rich, .compact-advantages, .quote-snippets { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .vieva-value-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .process-grid, .experience-grid, .price-grid, .seo-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-trust, .proof-wall, .academy-flow-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .academy-showcase, .academy-flow { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0 14px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: #fff;
  }
  .site-nav {
    position: absolute;
    left: 20px;
    right: 20px;
    top: 70px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 12px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow);
  }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 12px; }
  .site-nav .nav-dropdown {
    display: block;
  }
  .nav-dropdown-trigger {
    width: 100%;
    justify-content: space-between;
  }
  .nav-dropdown-menu {
    position: static;
    min-width: 0;
    padding: 0 0 8px 14px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
  }
  .nav-dropdown-menu::before {
    display: none;
  }
  .nav-dropdown:hover .nav-dropdown-menu,
  .nav-dropdown:focus-within .nav-dropdown-menu {
    transform: none;
  }
  .nav-dropdown-menu a {
    padding: 9px 12px;
    color: var(--muted);
  }
  .site-nav .nav-pill { border-radius: 6px; }
  .split, .contact-inner, .conversion-panel, .imagery-panel, .vieva-hero-grid, .vieva-example-grid, .vieva-honesty-panel, .vieva-price-panel { grid-template-columns: 1fr; }
  .hero {
    min-height: auto;
    align-items: flex-start;
    padding-top: 46px;
    padding-bottom: 74px;
    background: linear-gradient(180deg, #fff 0%, #fbfaf7 48%, #eaf8fb 78%, #f7edf2 100%);
  }
  .hero::before {
    background:
      linear-gradient(180deg, rgba(251,250,247,.98) 0%, rgba(251,250,247,.90) 54%, rgba(251,250,247,.62) 100%),
      linear-gradient(90deg, rgba(35,130,183,.10), rgba(211,20,76,.06), rgba(102,127,88,.08));
  }
  .hero::after { bottom: 24px; width: 160px; }
  .hero-copy { padding-bottom: 0; max-width: 100%; }
  .hero-points { grid-template-columns: 1fr; max-width: 100%; }
  .copy-desktop { display: none; }
  .copy-mobile { display: inline; }
  .hero-bg img {
    width: 100%;
    max-width: none;
    height: 100%;
    min-height: 100%;
    right: 0;
    bottom: 0;
    object-fit: cover;
    object-position: right top;
    opacity: .36;
  }
  .story-grid, .pain-grid, .metric-grid, .target-grid, .blog-grid, .video-grid, .seo-grid, .price-grid, .process-grid, .experience-grid, .feature-grid, .service-grid, .mini-price-grid, .quote-grid.rich, .outcome-list, .hero-trust, .proof-wall, .academy-flow-grid, .vieva-value-grid, .compact-advantages, .quote-snippets { grid-template-columns: 1fr; }
  .vieva-hero-card img { aspect-ratio: 16 / 9; max-height: 380px; }
  .vieva-measurement-shot img { aspect-ratio: 4 / 3; }
  .section { padding: 66px 0; }
  .glow-panel, .academy-section, .anniversary { padding: 22px; }
  .legal-toc { position: static; }
  .legal-toc a { border-radius: 8px; max-width: 100%; }
  .legal-section { scroll-margin-top: 92px; }
  .site-footer { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 560px) {
  .wrap, .narrow, .split { width: min(100% - 28px, 1120px); }
  .hero { padding-left: 14px; padding-right: 14px; padding-bottom: 40px; }
  .hero-bg img { width: 100%; right: 0; height: 100%; object-position: right top; opacity: .34; }
  .site-header { padding-left: 14px; padding-right: 14px; }
  h1 { font-size: 40px; }
  h2, .page-hero.compact h1 { font-size: 34px; }
  h3 { font-size: 20px; }
  .lead, .section-heading p:not(.eyebrow), .split-copy p, .article p { font-size: 17px; }
  .legal-toc div { display: grid; grid-template-columns: 1fr; }
  .legal-toc a { width: 100%; }
  .vieva-honesty-panel, .vieva-price-panel { padding: 22px; }
  .legal-card, .legal-section { padding: 22px; }
  .site-footer { grid-template-columns: 1fr; }
}

/* Premium direction */
.hero {
  background:
    linear-gradient(112deg, rgba(255,255,255,.99) 0%, rgba(255,244,247,.96) 25%, rgba(230,248,253,.94) 56%, rgba(239,247,234,.95) 100%),
    radial-gradient(circle at 16% 18%, rgba(211,20,76,.16), transparent 26%),
    radial-gradient(circle at 68% 16%, rgba(64,191,232,.20), transparent 30%);
}
.hero::before {
  background:
    linear-gradient(90deg, rgba(251,250,247,.99) 0%, rgba(251,250,247,.91) 36%, rgba(251,250,247,.34) 66%, rgba(251,250,247,.04) 100%),
    linear-gradient(150deg, rgba(211,20,76,.18) 0%, transparent 22%, rgba(64,191,232,.16) 58%, rgba(102,127,88,.18) 100%);
}
.hero::after {
  width: 320px;
  height: 7px;
  background: linear-gradient(90deg, var(--red), var(--cyan), var(--green));
  box-shadow: 0 0 36px rgba(211,20,76,.30), 0 0 36px rgba(64,191,232,.28);
}
.hero h1 { max-width: 900px; }
.hero-signature {
  display: grid;
  gap: 4px;
  width: min(560px, 100%);
  margin: 18px 0 0;
  padding: 14px 16px;
  border-radius: 8px;
  background: rgba(21,23,25,.86);
  color: #fff;
  box-shadow: 0 14px 38px rgba(21,23,25,.16), 0 0 26px rgba(64,191,232,.14);
}
.hero-signature span { color: rgba(255,255,255,.72); }
.hero-trust span {
  background: rgba(255,255,255,.78);
  border-color: rgba(255,255,255,.95);
}
.academy-section {
  background:
    linear-gradient(135deg, rgba(21,23,25,.94), rgba(17,45,58,.90) 48%, rgba(45,20,36,.88)),
    radial-gradient(circle at top right, rgba(211,20,76,.25), transparent 42%);
  color: #fff;
  box-shadow: 0 24px 70px rgba(21,23,25,.20), 0 0 48px rgba(64,191,232,.16);
}
.academy-section .split-copy p,
.academy-section .mini-list p { color: rgba(255,255,255,.74); }
.academy-section .mini-list article { border-color: rgba(255,255,255,.16); }
.academy-overview-shot {
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 18px 48px rgba(21,23,25,.16);
}
.academy-overview-shot img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  object-position: center top;
}
.academy-overview-shot figcaption {
  padding: 10px 12px;
  color: rgba(255,255,255,.78);
  font-size: 14px;
}
.academy-overview-shot.large figcaption { color: var(--muted); }
.academy-showcase {
  width: min(1180px, calc(100% - 40px));
}
.academy-video-focus { display: grid; gap: 18px; }
.academy-benefits article {
  background: linear-gradient(180deg, #fff 0%, #f3fbfd 100%);
}
.academy-benefits article:nth-child(2) { background: linear-gradient(180deg, #fff 0%, #fff4f7 100%); }
.academy-benefits article:nth-child(3) { background: linear-gradient(180deg, #fff 0%, #f2f8ef 100%); }
.conversion-panel {
  border-radius: 12px;
  transform: translateZ(0);
}
.conversion-panel h2 {
  font-size: 54px;
}
.about-photo img {
  box-shadow: 0 22px 60px rgba(21,23,25,.13), 0 0 42px rgba(102,127,88,.10);
}
.problem-section {
  background:
    linear-gradient(135deg, #151719 0%, #203b45 50%, #2e1927 100%),
    radial-gradient(circle at top left, rgba(211,20,76,.28), transparent 36%);
  color: #fff;
}
.problem-grid {
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 34px;
  align-items: start;
}
.problem-grid h2 { color: #fff; }
.problem-grid p { color: rgba(255,255,255,.76); }
.symptom-stack {
  display: grid;
  gap: 14px;
}
.symptom-stack article,
.performance-note {
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 10px;
  background: rgba(255,255,255,.08);
  box-shadow: 0 18px 50px rgba(21,23,25,.18);
}
.symptom-stack article {
  padding: 20px;
}
.symptom-stack span,
.performance-grid span {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--red);
  font-weight: 900;
}
.symptom-stack strong {
  display: block;
  margin-bottom: 8px;
  color: #fff;
  font-size: 21px;
}
.performance-section {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.performance-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.performance-grid article {
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: linear-gradient(180deg, #fff 0%, #f4fbfd 100%);
  box-shadow: 0 14px 38px rgba(21,23,25,.06);
}
.performance-grid article:nth-child(2) { background: linear-gradient(180deg, #fff 0%, #fff4f7 100%); }
.performance-grid article:nth-child(3) { background: linear-gradient(180deg, #fff 0%, #f2f8ef 100%); }
.performance-note {
  margin-top: 18px;
  padding: 22px;
  background:
    linear-gradient(135deg, rgba(21,23,25,.94), rgba(17,45,58,.88)),
    radial-gradient(circle at top right, rgba(64,191,232,.22), transparent 38%);
  color: #fff;
}
.performance-note strong {
  display: block;
  margin-bottom: 8px;
  font-size: 20px;
}
.performance-note p { color: rgba(255,255,255,.74); }
.youth-hero-page {
  overflow: hidden;
  padding: 86px 0 72px;
  background:
    linear-gradient(135deg, rgba(251,250,247,.98) 0%, rgba(231,249,253,.95) 42%, rgba(255,241,246,.94) 100%),
    radial-gradient(circle at 18% 12%, rgba(211,20,76,.18), transparent 30%),
    radial-gradient(circle at 80% 18%, rgba(64,191,232,.24), transparent 34%);
}
.youth-hero-grid {
  display: grid;
  grid-template-columns: .88fr 1.12fr;
  gap: 38px;
  align-items: center;
  min-width: 0;
}
.youth-hero-page h1 {
  max-width: 760px;
  font-size: clamp(48px, 6.6vw, 92px);
  line-height: .9;
}
.youth-hero-page p {
  max-width: 680px;
  font-size: 19px;
}
.youth-hero-media {
  margin: 0;
  position: relative;
  min-width: 0;
}
.youth-hero-media::before {
  content: "";
  position: absolute;
  inset: -14px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(211,20,76,.30), rgba(64,191,232,.30), rgba(102,127,88,.24));
  filter: blur(18px);
  opacity: .64;
  z-index: -1;
}
.youth-hero-media img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  object-position: center;
  border-radius: 10px;
  box-shadow: 0 28px 80px rgba(21,23,25,.20);
}
.youth-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  max-width: 680px;
  margin-top: 24px;
}
.youth-proof span {
  padding: 11px 12px;
  border: 1px solid rgba(21,23,25,.10);
  border-radius: 8px;
  background: rgba(255,255,255,.72);
  color: var(--ink);
  font-weight: 900;
  text-align: center;
  box-shadow: 0 10px 28px rgba(21,23,25,.06);
}
.youth-intro .section-heading {
  max-width: 900px;
}
.youth-card-grid,
.youth-image-grid,
.youth-process {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.youth-card-grid article,
.youth-process article {
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: linear-gradient(180deg, #fff 0%, #f6fbfd 100%);
  box-shadow: 0 14px 38px rgba(21,23,25,.06);
}
.youth-card-grid article:nth-child(2),
.youth-process article:nth-child(2) {
  background: linear-gradient(180deg, #fff 0%, #fff4f7 100%);
}
.youth-card-grid article:nth-child(3),
.youth-process article:nth-child(3) {
  background: linear-gradient(180deg, #fff 0%, #f1f8ee 100%);
}
.youth-card-grid span,
.youth-process span {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--red);
  font-weight: 900;
}
.youth-split {
  background:
    linear-gradient(135deg, #151719 0%, #163744 50%, #322033 100%),
    radial-gradient(circle at top left, rgba(64,191,232,.24), transparent 36%);
  color: #fff;
}
.youth-split-grid {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 38px;
  align-items: center;
}
.youth-split h2,
.youth-split h3 { color: #fff; }
.youth-split p,
.youth-mini-list p { color: rgba(255,255,255,.74); }
.youth-photo-stack {
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: 14px;
  align-items: end;
}
.youth-photo-stack img {
  width: 100%;
  min-height: 360px;
  object-fit: cover;
  border-radius: 10px;
  box-shadow: 0 24px 70px rgba(0,0,0,.26);
}
.youth-photo-stack img:first-child {
  aspect-ratio: 4 / 5;
}
.youth-photo-stack img:last-child {
  aspect-ratio: 4 / 3;
  transform: translateY(32px);
}
.youth-photo-stack-single {
  grid-template-columns: 1fr;
}
.youth-photo-stack-single img {
  aspect-ratio: 5 / 4;
  min-height: 0;
  transform: none;
}
.youth-mini-list { gap: 14px; }
.youth-mini-list article {
  border: 1px solid rgba(255,255,255,.18);
  border-top: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  border-radius: 12px;
  padding: 22px 24px;
}
.youth-mini-list article h3 {
  margin: 0 0 10px;
}
.youth-mini-list article p {
  margin: 0;
}
.youth-image-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 14px 38px rgba(21,23,25,.06);
}
.youth-image-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  object-position: center;
}
.youth-image-card div {
  padding: 20px;
}
.youth-process {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.youth-space-link {
  padding-top: 0;
}
.youth-space-panel {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 26px;
  align-items: center;
  padding: 32px;
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(21,23,25,.94), rgba(17,45,58,.90)),
    radial-gradient(circle at top right, rgba(211,20,76,.22), transparent 40%);
  color: #fff;
  box-shadow: 0 24px 70px rgba(21,23,25,.18);
}
.youth-space-panel h2 { color: #fff; }
.youth-space-panel p { color: rgba(255,255,255,.74); }
.youth-practice .section-heading {
  max-width: 950px;
}
.youth-practice-grid {
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: 22px;
  align-items: stretch;
}
.youth-practice-media {
  margin: 0;
  overflow: hidden;
  border-radius: 12px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 20px 58px rgba(21,23,25,.10);
}
.youth-practice-media img {
  width: 100%;
  height: 100%;
  min-height: 520px;
  object-fit: cover;
  object-position: center;
}
.youth-practice-media figcaption {
  padding: 12px 16px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}
.youth-practice-list {
  display: grid;
  gap: 14px;
}
.youth-practice-list article {
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: linear-gradient(180deg, #fff 0%, #f6fbfd 100%);
  box-shadow: 0 14px 38px rgba(21,23,25,.06);
}
.youth-practice-list article:nth-child(2) { background: linear-gradient(180deg, #fff 0%, #fff4f7 100%); }
.youth-practice-list article:nth-child(3) { background: linear-gradient(180deg, #fff 0%, #f1f8ee 100%); }
.youth-practice-list span,
.youth-price-card span {
  display: inline-block;
  margin-bottom: 10px;
  color: var(--red);
  font-weight: 900;
  text-transform: uppercase;
  font-size: 13px;
  letter-spacing: .02em;
}
.youth-video-section {
  background:
    linear-gradient(135deg, rgba(21,23,25,.96), rgba(17,45,58,.92) 52%, rgba(45,20,36,.90)),
    radial-gradient(circle at top right, rgba(64,191,232,.24), transparent 38%);
  color: #fff;
}
.youth-video-grid {
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: 34px;
  align-items: center;
}
.youth-video-section h2 { color: #fff; }
.youth-video-section p { color: rgba(255,255,255,.74); }
.youth-video-panel {
  padding: 10px;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 24px 70px rgba(0,0,0,.20);
}
.youth-pricing {
  padding-top: 0;
}
.youth-price-panel {
  display: grid;
  grid-template-columns: 1fr .72fr;
  gap: 24px;
  align-items: center;
  padding: 34px;
  border-radius: 12px;
  background:
    linear-gradient(135deg, #fff 0%, #f3fbfd 50%, #fff3f7 100%);
  border: 1px solid rgba(21,23,25,.10);
  box-shadow: 0 20px 58px rgba(21,23,25,.08), 0 0 34px rgba(64,191,232,.10);
}
.youth-price-card {
  padding: 24px;
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(21,23,25,.96), rgba(17,45,58,.90)),
    radial-gradient(circle at top right, rgba(211,20,76,.22), transparent 38%);
  color: #fff;
  box-shadow: 0 18px 48px rgba(21,23,25,.16);
}
.youth-price-card strong {
  display: block;
  margin-bottom: 10px;
  font-size: 24px;
  line-height: 1.05;
}
.youth-price-card p { color: rgba(255,255,255,.74); }

@media (max-width: 900px) {
  .problem-grid,
  .performance-grid,
  .youth-hero-grid,
  .youth-split-grid,
  .youth-card-grid,
  .youth-image-grid,
  .youth-process,
  .youth-space-panel,
  .youth-practice-grid,
  .youth-video-grid,
  .youth-price-panel { grid-template-columns: 1fr; }
  .youth-hero-page { padding-top: 58px; }
  .youth-proof { grid-template-columns: 1fr; }
  .youth-photo-stack img:last-child { transform: none; }
  .youth-practice-media img { min-height: 320px; }
  .hero {
    min-height: calc(100svh - 70px);
    padding-top: 54px;
    padding-bottom: 74px;
    background:
      linear-gradient(145deg, rgba(255,255,255,.98) 0%, rgba(255,245,248,.96) 32%, rgba(230,248,253,.94) 70%, rgba(241,248,237,.95) 100%);
  }
  .hero::before {
    background:
      linear-gradient(180deg, rgba(251,250,247,.96) 0%, rgba(251,250,247,.82) 48%, rgba(251,250,247,.58) 100%),
      linear-gradient(105deg, rgba(211,20,76,.12) 0%, rgba(64,191,232,.12) 58%, rgba(102,127,88,.13) 100%);
  }
  .hero-bg { display: none; }
  .hero-portrait-mobile {
    display: block;
    width: calc(100% + 28px);
    margin: 14px -14px 18px;
    aspect-ratio: 5 / 4;
    overflow: hidden;
    border-radius: 0;
    position: relative;
    background: linear-gradient(135deg, #fff8fa, #eaf6fc);
    box-shadow: 0 20px 50px rgba(21,23,25,.14);
  }
  .hero-portrait-mobile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 78% center;
    display: block;
  }
  .hero-portrait-mobile::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--red), var(--cyan), var(--blue));
  }
  .hero-signature { background: rgba(255,255,255,.76); color: var(--ink); }
  .hero-signature span { color: #525b63; }
  .academy-section { color: #fff; }
  .conversion-panel h2 { font-size: 38px; }
}

@media (max-width: 560px) {
  .hero {
    min-height: auto;
    padding-top: 54px;
    padding-bottom: 38px;
  }
  .hero::before {
    background:
      linear-gradient(180deg, rgba(251,250,247,.86) 0%, rgba(251,250,247,.78) 43%, rgba(251,250,247,.66) 70%, rgba(232,249,253,.76) 100%),
      linear-gradient(105deg, rgba(251,250,247,.92) 0%, rgba(251,250,247,.62) 58%, rgba(64,191,232,.14) 100%),
      linear-gradient(110deg, rgba(211,20,76,.15), rgba(64,191,232,.14), rgba(102,127,88,.12));
  }
  .hero-bg img {
    width: 100%;
    right: 0;
    object-position: center 18%;
    opacity: .58;
  }
  .hero h1 { max-width: 360px; }
  .hero .lead { max-width: 350px; margin-top: 16px; font-size: 16px; line-height: 1.52; }
  .hero::after { width: 170px; }
  .hero-points span { background: rgba(255,255,255,.82); }
  .academy-overview-shot img { aspect-ratio: 4 / 3; }
}

/* Mobile polish: softer brand colour rhythm */
@media (max-width: 900px) {
  body {
    background:
      linear-gradient(180deg, #fff6f8 0%, #fbfaf7 18%, #eefaff 42%, #fff3f7 68%, #f4fbff 100%);
  }
  .site-header {
    min-height: 68px;
    background: rgba(255,246,249,.94);
    border-bottom: 1px solid rgba(211,20,76,.12);
    box-shadow: 0 10px 30px rgba(211,20,76,.06), 0 10px 30px rgba(35,130,183,.05);
  }
  .brand-logo {
    width: auto;
    height: 44px;
  }
  .nav-toggle {
    background: rgba(255,255,255,.86);
    border-color: rgba(211,20,76,.18);
    box-shadow: 0 8px 22px rgba(211,20,76,.08);
  }
  .site-nav {
    background: linear-gradient(180deg, #fff 0%, #fff6f8 54%, #eefaff 100%);
    border-color: rgba(211,20,76,.14);
  }
  .hero {
    background:
      linear-gradient(150deg, rgba(255,247,250,.98) 0%, rgba(255,244,248,.94) 34%, rgba(236,250,255,.94) 74%, rgba(255,250,244,.96) 100%);
  }
  .hero::before {
    background:
      linear-gradient(180deg, rgba(255,247,250,.90) 0%, rgba(255,247,250,.78) 46%, rgba(238,250,255,.72) 100%),
      linear-gradient(115deg, rgba(211,20,76,.16), rgba(255,255,255,.16) 45%, rgba(35,130,183,.16));
  }
  .hero-signature {
    background: linear-gradient(135deg, rgba(255,255,255,.90), rgba(255,238,244,.84));
    border: 1px solid rgba(211,20,76,.16);
    box-shadow: 0 16px 42px rgba(211,20,76,.10), 0 0 30px rgba(35,130,183,.08);
  }
  .hero-points span {
    display: flex;
    align-items: flex-start;
    gap: 10px;
  }
  .hero-points span::before {
    content: "";
    flex: 0 0 auto;
    width: 24px;
    height: 24px;
    margin-top: 1px;
    border-radius: 50%;
    background:
      linear-gradient(135deg, rgba(211,20,76,.92), rgba(64,191,232,.88));
    box-shadow: 0 8px 20px rgba(211,20,76,.16);
    mask: radial-gradient(circle at center, transparent 0 4px, #000 5px);
  }
  .hero-points span:nth-child(1),
  .hero-trust span:nth-child(1),
  .feature-grid article:nth-child(odd),
  .target-grid article:nth-child(odd),
  .process-grid article:nth-child(odd),
  .experience-grid article:nth-child(odd),
  .youth-card-grid article:nth-child(odd),
  .vieva-value-grid article:nth-child(odd) {
    background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,241,246,.88));
    border-color: rgba(211,20,76,.14);
    box-shadow: 0 14px 38px rgba(211,20,76,.09);
  }
  .hero-points span:nth-child(2),
  .hero-trust span:nth-child(2),
  .feature-grid article:nth-child(even),
  .target-grid article:nth-child(even),
  .process-grid article:nth-child(even),
  .experience-grid article:nth-child(even),
  .youth-card-grid article:nth-child(even),
  .vieva-value-grid article:nth-child(even) {
    background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(236,249,255,.88));
    border-color: rgba(35,130,183,.15);
    box-shadow: 0 14px 38px rgba(35,130,183,.08);
  }
  .problem-section,
  .pain-section,
  .testimonials,
  .faq {
    background: linear-gradient(180deg, #fff3f7 0%, #f3fbff 100%);
    border-top: 1px solid rgba(211,20,76,.08);
    border-bottom: 1px solid rgba(35,130,183,.08);
  }
  .problem-section,
  .pain-section {
    color: var(--ink);
  }
  .problem-section .section-heading p:not(.eyebrow),
  .pain-section .section-heading p:not(.eyebrow),
  .problem-grid p,
  .pain-section .pain-grid p {
    color: #4d5861;
  }
  .problem-grid h2,
  .pain-section h2,
  .symptom-stack strong {
    color: var(--ink);
  }
  .symptom-stack article,
  .pain-grid article {
    background: rgba(255,255,255,.88);
    border-color: rgba(211,20,76,.12);
    box-shadow: 0 14px 38px rgba(35,130,183,.07), 0 12px 30px rgba(211,20,76,.06);
  }
  .band,
  .youth-space-link {
    background: linear-gradient(180deg, #eefaff 0%, #fff7fa 100%);
  }
  .glow-panel,
  .youth-price-panel,
  .vieva-price-panel {
    background: linear-gradient(135deg, rgba(255,255,255,.90) 0%, rgba(255,240,246,.82) 45%, rgba(236,249,255,.84) 100%);
    border-color: rgba(211,20,76,.12);
    box-shadow: 0 20px 58px rgba(211,20,76,.10), 0 18px 48px rgba(35,130,183,.08);
  }
  .imagery-panel,
  .academy-section {
    background:
      linear-gradient(135deg, rgba(21,23,25,.97) 0%, rgba(18,48,64,.94) 52%, rgba(61,22,43,.94) 100%),
      linear-gradient(120deg, rgba(211,20,76,.16), rgba(64,191,232,.14));
    color: #fff;
    border-color: rgba(255,255,255,.14);
    box-shadow: 0 24px 70px rgba(21,23,25,.22), 0 0 48px rgba(211,20,76,.12), 0 0 42px rgba(64,191,232,.12);
  }
  .imagery-panel h2,
  .academy-section h2 { color: #fff; }
  .imagery-panel p,
  .imagery-steps p,
  .academy-section .split-copy p,
  .academy-section .mini-list p { color: rgba(255,255,255,.76); }
  .imagery-steps article,
  .academy-section .mini-list article {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.15);
  }
  .section-heading::after,
  .hero::after,
  .hero h1::after {
    background: linear-gradient(90deg, var(--red), var(--cyan), var(--blue));
    box-shadow: 0 0 26px rgba(211,20,76,.25), 0 0 24px rgba(64,191,232,.20);
  }
  .mobile-visual-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    width: min(100% - 28px, 1120px);
    margin: -26px auto 16px;
    position: relative;
    z-index: 3;
  }
  .mobile-visual-strip article {
    position: relative;
    min-width: 0;
    overflow: hidden;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,.86);
    background: #fff;
    box-shadow: 0 16px 40px rgba(21,23,25,.10);
  }
  .mobile-visual-strip img {
    width: 100%;
    aspect-ratio: 1 / 1.15;
    object-fit: cover;
  }
  .mobile-visual-strip strong {
    display: block;
    padding: 10px;
    font-size: 13px;
    line-height: 1.1;
  }
  .mobile-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background:
      radial-gradient(120% 120% at 30% 22%, #ffffff 0%, #fff4f7 55%, #ecf7fc 100%);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.95),
      inset 0 -10px 22px rgba(64,191,232,.12),
      0 12px 28px rgba(211,20,76,.13),
      0 4px 10px rgba(35,130,183,.08);
    position: relative;
    flex: 0 0 auto;
    transition: transform .25s ease, box-shadow .25s ease;
  }
  .mobile-icon::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1.4px;
    background: linear-gradient(135deg, #d3144c 0%, #a13776 55%, #1f7da6 100%);
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
            mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    pointer-events: none;
    opacity: .9;
  }
  .mobile-icon svg {
    width: 26px;
    height: 26px;
    display: block;
    overflow: visible;
  }
  .mobile-visual-strip .mobile-icon {
    position: absolute;
    left: 10px;
    top: 10px;
    z-index: 2;
    width: 42px;
    height: 42px;
  }
  .mobile-visual-strip .mobile-icon svg {
    width: 22px;
    height: 22px;
  }
  .mobile-icon-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin: -4px 0 22px;
  }
  .mobile-icon-row.three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .mobile-icon-row span {
    display: grid;
    justify-items: center;
    gap: 9px;
    min-width: 0;
    padding: 16px 6px 14px;
    border: 1px solid rgba(255,255,255,.92);
    border-radius: 14px;
    background:
      linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(255,247,250,.85) 100%);
    box-shadow:
      0 14px 34px rgba(35,130,183,.09),
      0 2px 6px rgba(211,20,76,.05),
      inset 0 1px 0 rgba(255,255,255,.92);
    text-align: center;
    position: relative;
    overflow: hidden;
  }
  .mobile-icon-row span::before {
    content: "";
    position: absolute;
    left: 14%;
    right: 14%;
    top: 0;
    height: 2px;
    border-radius: 0 0 4px 4px;
    background: linear-gradient(90deg, var(--red), var(--cyan), var(--blue));
    opacity: .7;
  }
  .mobile-icon-row strong {
    font-size: 12px;
    line-height: 1.1;
    letter-spacing: .01em;
  }
  .mobile-thumb {
    display: block;
    width: calc(100% + 32px);
    margin: -20px -16px 14px;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: 8px 8px 0 0;
  }
  .symptom-stack article,
  .feature-grid.four article {
    overflow: hidden;
  }
  .mobile-image-break {
    display: grid;
    width: min(100% - 28px, 1120px);
    margin: -20px auto 26px;
    overflow: hidden;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,.88);
    background: linear-gradient(135deg, #fff, #fff2f6 52%, #edfaff);
    box-shadow: 0 18px 48px rgba(21,23,25,.10);
  }
  .mobile-image-break img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
  }
  .mobile-image-break div {
    padding: 16px;
  }
  .mobile-image-break span {
    display: block;
    color: var(--red);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
  }
  .mobile-image-break strong {
    display: block;
    margin-top: 4px;
    font-size: 20px;
    line-height: 1.1;
  }
  .experience-showcase {
    width: min(100% - 28px, 1120px);
    padding: 24px 16px;
  }
  .anniversary {
    background:
      linear-gradient(145deg, rgba(21,23,25,.97), rgba(20,56,73,.95) 54%, rgba(65,20,41,.96)),
      linear-gradient(120deg, rgba(211,20,76,.14), rgba(64,191,232,.12));
  }
}

@media (max-width: 560px) {
  .brand-logo {
    width: auto;
    height: 42px;
  }
  .site-header {
    gap: 10px;
  }
  .hero {
    min-height: auto;
    padding-top: 42px;
    padding-bottom: 34px;
  }
  .hero-copy {
    padding-top: 4px;
  }
  .hero-signature {
    margin-top: 14px;
    padding: 12px 13px;
  }
  .hero-points {
    gap: 8px;
    margin-top: 12px;
  }
  .hero-trust {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }
  .hero-trust span {
    padding: 9px 7px;
    font-size: 12px;
    line-height: 1.25;
  }
  .hero-trust strong {
    font-size: 14px;
  }
  .hero-trust span,
  .hero-points span,
  .feature-grid article,
  .target-grid article,
  .process-grid article,
  .experience-grid article,
  .youth-card-grid article,
  .vieva-value-grid article {
    border-radius: 10px;
  }
}

/* === V9 NEW COMPONENTS === */

/* 5 Bausteine */
.bausteine-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
  margin-top: 8px;
}
.bausteine-grid article {
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(255,255,255,.85);
  border-radius: 14px;
  padding: 22px 18px;
  box-shadow:
    0 14px 32px rgba(35,130,183,.10),
    0 4px 10px rgba(211,20,76,.06),
    inset 0 1px 0 rgba(255,255,255,.92);
  position: relative;
  overflow: hidden;
}
.bausteine-grid article::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18%;
  right: 18%;
  height: 3px;
  border-radius: 0 0 4px 4px;
  background: linear-gradient(90deg, var(--red), var(--cyan), var(--blue));
  opacity: .8;
}
.bausteine-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  margin: 6px 0 14px;
  border-radius: 14px;
  background:
    radial-gradient(120% 120% at 25% 22%, #ffffff 0%, #fff4f7 55%, #ecf7fc 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 12px 24px rgba(35,130,183,.10),
    0 4px 8px rgba(211,20,76,.07);
  position: relative;
}
.bausteine-icon::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.4px;
  background: linear-gradient(135deg, #d3144c 0%, #a13776 55%, #1f7da6 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: .9;
  pointer-events: none;
}
.bausteine-icon svg { width: 26px; height: 26px; display: block; overflow: visible; }
.bausteine-grid h3 { font-size: 17px; line-height: 1.25; margin: 0 0 8px; }
.bausteine-grid p { font-size: 14px; color: var(--muted); margin: 0; line-height: 1.5; }
.section.band .bausteine-grid article { background: rgba(255,255,255,.96); }
.baustein-link {
  display: inline-block;
  margin-top: 12px;
  font-size: 14px;
  font-weight: 700;
  color: var(--red);
  text-decoration: none;
  letter-spacing: .005em;
  transition: color .25s ease, transform .25s ease;
}
.baustein-link:hover { color: var(--blue); transform: translateX(2px); }
.audience-teaser {
  margin-top: 28px;
  padding: 24px 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(255,247,250,.86) 100%);
  border: 1px solid rgba(211,20,76,.12);
  border-radius: 14px;
  box-shadow: 0 12px 30px rgba(35,130,183,.08);
}
.audience-teaser .eyebrow { margin: 0 0 6px; }
.audience-teaser > p { color: var(--muted); font-size: 16px; line-height: 1.6; margin: 0 0 16px; }
.audience-teaser .deep-dive { margin-top: 10px; }

.bausteine-grid.bausteine-four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
@media (max-width: 1100px) {
  .bausteine-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .bausteine-grid.bausteine-four { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 700px) {
  .bausteine-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
  .bausteine-grid article { padding: 18px 14px; border-radius: 12px; }
  .bausteine-icon { width: 44px; height: 44px; border-radius: 12px; margin: 4px 0 10px; }
  .bausteine-icon svg { width: 22px; height: 22px; }
  .bausteine-grid h3 { font-size: 15px; }
  .bausteine-grid p { font-size: 13px; }
}
@media (max-width: 420px) {
  .bausteine-grid { grid-template-columns: 1fr; }
}

/* Teaser-Tiles für Academy/VIEVA/Jugendliche */
.teaser-section { padding-bottom: 18px; }
.teaser-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 8px;
}
.teaser-grid.teaser-grid-four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.teaser-grid.teaser-grid-three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 1100px) {
  .teaser-grid.teaser-grid-four { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
  .teaser-grid.teaser-grid-three { grid-template-columns: 1fr; }
}
.teaser-tile {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 14px 40px rgba(21,23,25,.08);
  transition: transform .28s ease, box-shadow .28s ease;
  position: relative;
}
.teaser-tile:hover {
  transform: translateY(-3px);
  box-shadow:
    0 22px 50px rgba(21,23,25,.12),
    0 0 0 1px rgba(211,20,76,.18);
}
.teaser-image {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: linear-gradient(135deg, #fff4f7, #eaf6fc);
}
.teaser-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .6s ease;
}
.teaser-tile:hover .teaser-image img { transform: scale(1.04); }
.teaser-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0) 60%, rgba(255,255,255,.18) 100%);
}
.teaser-body {
  padding: 22px 22px 24px;
  position: relative;
}
.teaser-body .card-icon {
  margin: -42px 0 14px;
  background:
    radial-gradient(120% 120% at 25% 22%, #ffffff 0%, #fff4f7 55%, #ecf7fc 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.95),
    0 12px 26px rgba(35,130,183,.16),
    0 4px 10px rgba(211,20,76,.10);
}
.teaser-body h3 {
  margin: 0 0 8px;
  font-size: 22px;
  line-height: 1.2;
}
.teaser-body p {
  color: var(--muted);
  margin: 0 0 14px;
  font-size: 15px;
  line-height: 1.5;
}
.teaser-link {
  font-weight: 700;
  color: var(--red);
  font-size: 14px;
  letter-spacing: .01em;
  display: inline-block;
}
.teaser-tile:hover .teaser-link { color: var(--blue); }

@media (max-width: 900px) {
  .teaser-grid { grid-template-columns: 1fr; gap: 14px; }
  .teaser-image { aspect-ratio: 16 / 9; }
  .teaser-body h3 { font-size: 19px; }
  .teaser-body { padding: 18px 18px 20px; }
}

/* More-Formats expander */
.more-formats {
  margin-top: 22px;
  background: rgba(255,255,255,.7);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px 22px;
}
.more-formats summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--ink);
  list-style: none;
  position: relative;
  padding-right: 28px;
}
.more-formats summary::-webkit-details-marker { display: none; }
.more-formats summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  color: var(--red);
  font-weight: 700;
  line-height: 1;
}
.more-formats[open] summary::after { content: "−"; }
.more-formats[open] summary { margin-bottom: 14px; }
.more-formats .mini-price-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.more-formats .mini-price-grid article {
  padding: 16px;
  border-radius: 10px;
  background: rgba(255,255,255,.86);
  border: 1px solid var(--line);
  box-shadow: 0 8px 20px rgba(21,23,25,.06);
}
.more-formats .mini-price-grid h3 { margin: 0 0 4px; font-size: 16px; }
.more-formats .mini-price-grid p { margin: 0 0 6px; font-weight: 800; color: var(--red); font-size: 18px; }
.more-formats .mini-price-grid span { display: block; color: var(--muted); font-size: 13px; line-height: 1.4; }

@media (max-width: 900px) {
  .more-formats .mini-price-grid { grid-template-columns: 1fr; }
}

/* Contact grid */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 8px 0 22px;
}
.contact-card {
  display: grid;
  gap: 6px;
  text-decoration: none;
  color: inherit;
  padding: 22px 22px 24px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(0,0,0,.24);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  align-content: start;
}
.contact-card:hover {
  transform: translateY(-2px);
  background: rgba(255,255,255,.10);
  box-shadow: 0 18px 38px rgba(0,0,0,.28), 0 0 0 1px rgba(255,139,173,.32);
}
.contact-card strong { font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: #ff8bad; }
.contact-card span { font-size: 16px; font-weight: 700; color: #fff; word-break: break-word; }
.contact-card small { color: rgba(255,255,255,.72); font-size: 13px; line-height: 1.4; }

@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; }
}

/* Full-width image break section */
.image-break-section {
  position: relative;
  background: linear-gradient(135deg, #fff7f9 0%, #eaf5fc 100%);
  padding: 0;
  margin: 28px 0;
  overflow: hidden;
}
.image-break-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
  width: min(1280px, 100%);
  margin: 0 auto;
}
.image-break-photo {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #fff7f9, #eaf6fc);
}
.image-break-photo img {
  width: 100%;
  height: 100%;
  min-height: 380px;
  object-fit: cover;
  object-position: center 35%;
  display: block;
}
.image-break-copy {
  padding: 56px 56px 60px;
  display: grid;
  align-content: center;
  gap: 14px;
}
.image-break-copy h2 { margin: 0; max-width: 480px; }
.image-break-copy p { color: var(--muted); font-size: 17px; line-height: 1.6; max-width: 520px; }
.image-break-copy .eyebrow { margin: 0; }

@media (max-width: 900px) {
  .image-break-grid { grid-template-columns: 1fr; }
  .image-break-photo img { min-height: 280px; aspect-ratio: 16 / 10; }
  .image-break-copy { padding: 32px 24px 36px; }
}

/* Events page (Live Meditationen) */
.events-hero {
  background:
    radial-gradient(120% 90% at 18% 14%, rgba(211,20,76,.10), transparent 60%),
    radial-gradient(120% 90% at 82% 86%, rgba(64,191,232,.14), transparent 60%),
    linear-gradient(180deg, #fdf3f6 0%, #eaf6fc 100%);
}
.events-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 460px);
  gap: 48px;
  align-items: center;
}
.events-hero-card {
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.86);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 22px 60px rgba(21,23,25,.12), 0 0 44px rgba(64,191,232,.18);
}
.events-hero-card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}
.events-hero-card figcaption {
  padding: 14px 18px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.4;
  border-top: 1px solid rgba(211,20,76,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.8), rgba(255,247,250,.7));
}
.events-hero-facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 20px;
  width: min(560px, 100%);
}
.events-hero-facts span {
  display: grid;
  align-content: start;
  gap: 4px;
  padding: 14px 14px 16px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(255,255,255,.92);
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(35,130,183,.08);
  font-size: 13px;
  color: var(--muted);
  line-height: 1.4;
}
.events-hero-facts .card-icon {
  margin: 0 0 6px;
  width: 38px;
  height: 38px;
  border-radius: 10px;
}
.events-hero-facts .card-icon svg { width: 22px; height: 22px; }
.events-hero-facts strong {
  color: var(--ink);
  font-size: 15px;
  letter-spacing: .005em;
}
.events-access-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.events-access-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.events-access-tile.highlight .teaser-body { background: linear-gradient(180deg, #fff 0%, #fff4f7 100%); }
.events-access-tile .teaser-body p strong { color: var(--red); }
.events-access-tile .teaser-body .button {
  margin-top: 10px;
}

.meditation-style-section { padding-top: 40px; }
.meditation-style-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 40px;
  align-items: center;
  margin-bottom: 36px;
}
.meditation-style-image {
  margin: 0;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 22px 56px rgba(21,23,25,.14), 0 0 32px rgba(64,191,232,.14);
  border: 1px solid rgba(255,255,255,.86);
}
.meditation-style-image img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
}

.anonymity-section {
  margin-top: 8px;
}
.anonymity-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: 36px;
  background:
    radial-gradient(120% 90% at 18% 14%, rgba(211,20,76,.08), transparent 60%),
    radial-gradient(120% 90% at 82% 86%, rgba(64,191,232,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(248,250,252,.92) 100%);
  border: 1px solid rgba(211,20,76,.12);
  border-radius: 18px;
  padding: 36px;
  box-shadow: 0 18px 48px rgba(35,130,183,.10);
}
.anonymity-copy h2 { margin-top: 6px; }
.anonymity-copy p { color: var(--muted); font-size: 17px; line-height: 1.6; }
.anonymity-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
}
.anonymity-list li {
  position: relative;
  padding: 14px 16px 14px 44px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(211,20,76,.10);
  border-radius: 12px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--muted);
}
.anonymity-list li::before {
  content: "";
  position: absolute;
  left: 16px;
  top: 22px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--red), var(--blue));
  box-shadow: 0 4px 10px rgba(211,20,76,.2);
}
.anonymity-list li strong { color: var(--ink); }

@media (max-width: 1100px) {
  .meditation-style-grid { grid-template-columns: 1fr; gap: 28px; }
  .meditation-style-image { max-width: 460px; }
  .anonymity-panel { grid-template-columns: 1fr; gap: 24px; padding: 28px; }
  .events-access-grid.three { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .anonymity-panel { padding: 22px; }
}

@media (max-width: 1100px) {
  .events-hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .events-hero-card img { aspect-ratio: 16 / 10; max-height: 420px; }
}
@media (max-width: 700px) {
  .events-hero-facts { grid-template-columns: 1fr; }
  .events-access-grid { grid-template-columns: 1fr; }
}

/* Deep-dive expander (für Mehr-Info ohne Seite zu strecken) */
.deep-dive {
  margin: 28px 0 0;
  background: linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(255,247,250,.84) 100%);
  border: 1px solid rgba(211,20,76,.14);
  border-radius: 14px;
  padding: 18px 22px;
  box-shadow: 0 12px 30px rgba(35,130,183,.07);
  transition: box-shadow .25s ease, border-color .25s ease;
}
.deep-dive[open] {
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(255,247,250,.94) 100%);
  border-color: rgba(211,20,76,.22);
  box-shadow: 0 18px 40px rgba(35,130,183,.10);
}
.deep-dive summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--ink);
  list-style: none;
  position: relative;
  padding-right: 36px;
  font-size: 15px;
  line-height: 1.4;
}
.deep-dive summary::-webkit-details-marker { display: none; }
.deep-dive summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--red), var(--blue));
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 14px rgba(211,20,76,.18);
  transition: transform .25s ease;
}
.deep-dive[open] summary::after { content: "−"; transform: translateY(-50%) rotate(180deg); }
.deep-dive[open] summary { margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px solid rgba(211,20,76,.10); }
.deep-dive-content { color: var(--muted); line-height: 1.6; font-size: 15px; }
.deep-dive-content p { margin: 0 0 12px; }
.deep-dive-content p:last-child { margin-bottom: 0; }
.deep-dive-content p strong { color: var(--ink); }
.deep-dive-content .dive-list {
  list-style: none;
  padding: 0;
  margin: 12px 0 4px;
  display: grid;
  gap: 10px;
}
.deep-dive-content .dive-list li {
  padding: 12px 14px 12px 38px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(211,20,76,.10);
  border-radius: 10px;
  font-size: 14px;
  line-height: 1.5;
  position: relative;
}
.deep-dive-content .dive-list li::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 18px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--red), var(--blue));
  box-shadow: 0 4px 10px rgba(211,20,76,.18);
}
.deep-dive-content .dive-list li strong { color: var(--ink); }
.contact .deep-dive {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
}
.contact .deep-dive summary { color: #fff; }
.contact .deep-dive[open] {
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.28);
}
.contact .deep-dive-content { color: rgba(255,255,255,.78); }
.contact .deep-dive-content p strong,
.contact .deep-dive-content .dive-list li strong { color: #fff; }
.contact .deep-dive-content .dive-list li {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.14);
  color: rgba(255,255,255,.78);
}

@media (max-width: 560px) {
  .deep-dive { padding: 16px 18px; }
  .deep-dive summary { font-size: 14px; padding-right: 32px; }
  .deep-dive summary::after { width: 24px; height: 24px; }
  .deep-dive-content { font-size: 14px; }
}
