/* BODYSCULPT homepage — sales-focused platform showcase */

body.marketing .hp-section {
  padding-block: clamp(3.5rem, 7vw, 5.5rem);
  scroll-margin-top: calc(var(--bs-header, 76px) + 16px);
}

body.marketing .hp-section--alt {
  background: color-mix(in srgb, var(--bs-bg-card) 55%, transparent);
  border-block: 1px solid var(--bs-border);
}

body.marketing .hp-section--dark {
  background: linear-gradient(165deg, color-mix(in srgb, var(--bs-ink) 92%, #0a1628), color-mix(in srgb, var(--bs-ink) 78%, #1a3a2e));
  color: #e8f0ec;
}

body.marketing .hp-section--dark h2,
body.marketing .hp-section--dark h3,
body.marketing .hp-section--dark .hp-eyebrow { color: #f4faf7; }

body.marketing .hp-section--dark p { color: color-mix(in srgb, #e8f0ec 72%, transparent); }

body.marketing .hp-eyebrow {
  display: inline-block;
  margin-bottom: 0.6rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bs-accent-dark);
}

body.marketing .hp-section-head {
  text-align: center;
  max-width: 680px;
  margin: 0 auto clamp(2rem, 4vw, 3rem);
}

body.marketing .hp-section-head h2 {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  margin-bottom: 0.65rem;
}

body.marketing .hp-section-head p {
  margin: 0;
  color: var(--bs-muted);
  font-size: 1.05rem;
  line-height: 1.65;
}

/* Hero */
body.marketing .hp-hero {
  position: relative;
  padding-top: clamp(2.75rem, 5.5vw, 4.25rem);
  padding-bottom: clamp(0.75rem, 2vw, 1.25rem);
  text-align: center;
  isolation: isolate;
}

body.marketing .hp-hero::before {
  content: "";
  position: absolute;
  inset: -10% 0 0;
  pointer-events: none;
  z-index: -1;
  background:
    radial-gradient(ellipse 70% 55% at 50% -5%, color-mix(in srgb, var(--bs-accent) 9%, transparent), transparent 62%),
    radial-gradient(ellipse 45% 40% at 85% 20%, rgba(52, 211, 153, 0.05), transparent 55%);
}

body.marketing .hp-hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 3vw, 2rem);
  align-items: start;
  max-width: 52rem;
  margin-inline: auto;
  text-align: center;
}

/* Override global section rhythm for hero + preview pair */
body.marketing .hp-hero.hp-section {
  padding-bottom: clamp(0.75rem, 2vw, 1.25rem);
}

body.marketing .hp-live-preview {
  padding-bottom: clamp(3rem, 6vw, 5rem);
}

body.marketing .hp-live-preview__inner {
  width: min(100% - 2rem, 960px);
  margin-inline: auto;
}

body.marketing .hp-live-preview__head {
  text-align: center;
  max-width: 620px;
  margin: 0 auto clamp(1.5rem, 3vw, 2.25rem);
}

body.marketing .hp-live-preview__head h2 {
  font-size: clamp(1.75rem, 3.8vw, 2.45rem);
  margin: 0 0 0.7rem;
  letter-spacing: -0.02em;
}

body.marketing .hp-live-preview__head p {
  margin: 0;
  color: var(--bs-muted);
  font-size: 1.06rem;
  line-height: 1.65;
}

/* Showcase frame — hero & section previews */
body.marketing .hp-showcase-frame {
  position: relative;
  border-radius: 28px;
  border: 1px solid color-mix(in srgb, var(--bs-border) 72%, transparent);
  background: var(--bs-bg-card);
  box-shadow:
    0 1px 0 color-mix(in srgb, #fff 22%, transparent) inset,
    0 28px 64px color-mix(in srgb, var(--bs-ink) 8%, transparent);
  overflow: visible;
}

body.marketing .hp-showcase-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 70% 50% at 12% -8%, color-mix(in srgb, var(--bs-accent) 5%, transparent), transparent 55%),
    radial-gradient(ellipse 45% 40% at 96% 100%, rgba(52, 211, 153, 0.05), transparent 52%);
}

body.marketing .hp-showcase-frame__head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.95rem 1.35rem;
  border-bottom: 1px solid color-mix(in srgb, var(--bs-border) 80%, transparent);
  border-radius: 28px 28px 0 0;
  background: var(--bs-bg-card);
}

body.marketing .hp-showcase-frame__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--bs-text, var(--bs-ink));
}

body.marketing .hp-showcase-frame__brand img {
  display: block;
  border-radius: 10px;
  flex-shrink: 0;
}

body.marketing .hp-showcase-frame__title {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bs-muted);
}

body.marketing .hp-showcase-frame__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.28rem 0.6rem;
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--bs-accent-dark);
  background: color-mix(in srgb, var(--bs-accent) 8%, var(--bs-bg-card));
  border: 1px solid color-mix(in srgb, var(--bs-accent) 18%, var(--bs-border));
}

body.marketing .hp-showcase-frame__pulse {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--bs-accent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--bs-accent) 28%, transparent);
  animation: hp-showcase-pulse 2.4s ease-in-out infinite;
}

@keyframes hp-showcase-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.55; transform: scale(0.88); }
}

body.marketing .hp-showcase-frame__body {
  position: relative;
  z-index: 1;
  padding: clamp(1.25rem, 2.5vw, 2rem);
  background: color-mix(in srgb, var(--bs-bg) 22%, transparent);
  overflow: visible;
}

body.marketing .hp-showcase-frame__foot {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.85rem 1.35rem 1rem;
  border-top: 1px solid color-mix(in srgb, var(--bs-border) 80%, transparent);
  border-radius: 0 0 28px 28px;
  background: var(--bs-bg-card);
}

body.marketing .hp-showcase-hint-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.32rem 0.72rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--bs-muted);
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--bs-border) 88%, transparent);
}

body.marketing .hp-showcase-frame .hp-dual-device {
  padding: 0;
  border: none;
  border-radius: var(--hp-r-sm, 16px);
  background: transparent;
  overflow: hidden;
}

body.marketing .hp-showcase-frame .hp-dual-device--app {
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: visible;
}

body.marketing .hp-dual-device--app [data-app-phone] {
  width: 100%;
  max-width: 260px;
  margin-inline: auto;
}

@media (max-width: 959px) {
  body.marketing .hp-dual-device--app [data-app-phone] {
    max-width: 240px;
  }
}

@media (min-width: 960px) {
  body.marketing .hp-showcase-frame .hp-dual-device--coach {
    position: relative;
    padding-right: clamp(1rem, 2vw, 1.75rem);
  }

  body.marketing .hp-showcase-frame .hp-dual-device--coach::after {
    content: "";
    position: absolute;
    right: 0;
    top: 8%;
    bottom: 8%;
    width: 1px;
    background: color-mix(in srgb, var(--bs-border) 85%, transparent);
  }

  body.marketing .hp-showcase-frame .hp-dual-device--app {
    padding-left: 0.15rem;
  }
}

body.marketing .hp-showcase-frame--featured {
  border-radius: 28px;
}

body.marketing .hp-showcase-frame--featured .hp-showcase-frame__body {
  padding: clamp(1rem, 2vw, 1.35rem);
}

body.marketing .hp-showcase-frame--featured .hp-showcase-frame__head {
  padding: 0.75rem 1.1rem;
}

body.marketing .hp-showcase-frame--featured .hp-showcase-frame__foot {
  padding: 0.65rem 1.1rem 0.75rem;
}

body.marketing .hp-showcase-frame--large .hp-showcase-frame__body {
  padding: clamp(1.15rem, 2.5vw, 1.65rem);
}

body.marketing .hp-showcase-frame--large .hp-dual-showcase {
  gap: clamp(1rem, 2vw, 1.5rem);
}

@media (prefers-reduced-motion: reduce) {
  body.marketing .hp-showcase-frame__pulse {
    animation: none;
  }
}

/* Dual device showcase — base; hero column rules live in media queries below */
body.marketing .hp-dual-showcase:not(.hp-dual-showcase--hero) {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  align-items: start;
}

body.marketing .hp-dual-showcase--hero {
  display: grid;
  gap: 1.25rem;
  align-items: start;
  grid-template-columns: 1fr;
}

@media (min-width: 960px) {
  body.marketing .hp-dual-showcase--hero {
    grid-template-columns: minmax(0, 1.15fr) minmax(220px, 0.85fr);
    gap: clamp(0.85rem, 1.8vw, 1.25rem);
    align-items: center;
  }

  body.marketing .hp-showcase-frame--featured .hp-dual-device--app .bs-app-phone {
    max-width: 260px;
  }
}

@media (min-width: 1200px) {
  body.marketing .hp-dual-showcase--hero {
    grid-template-columns: minmax(0, 1.12fr) minmax(240px, 0.88fr);
    gap: clamp(1rem, 2vw, 1.35rem);
  }

  body.marketing .hp-showcase-frame--featured .hp-dual-device--app .bs-app-phone {
    max-width: 280px;
  }
}

@media (max-width: 959px) {
  body.marketing .hp-dual-showcase--hero {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  body.marketing .hp-dual-device--app .bs-app-phone {
    max-width: 240px;
  }
}

@media (min-width: 720px) {
  body.marketing .hp-dual-showcase:not(.hp-dual-showcase--hero) {
    grid-template-columns: minmax(0, 1.12fr) minmax(160px, 0.88fr);
    gap: 1.1rem;
    align-items: end;
  }
}

body.marketing .hp-hero-visual {
  min-width: 0;
  width: 100%;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

body.marketing .hp-dual-showcase--large {
  gap: clamp(1.25rem, 3vw, 2rem);
}

@media (min-width: 900px) {
  body.marketing .hp-dual-showcase--large {
    grid-template-columns: 1.12fr 0.88fr;
    align-items: center;
  }
}

body.marketing .hp-dual-device {
  min-width: 0;
  max-width: 100%;
}

body.marketing .hp-dual-label {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  margin: 0 0 0.65rem;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--bs-muted);
}

body.marketing .hp-showcase-frame .hp-dual-label::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--bs-accent);
  flex-shrink: 0;
  opacity: 0.8;
}

body.marketing .hp-showcase-frame .hp-dual-device--app .hp-dual-label::before {
  background: #34d399;
}

body.marketing .hp-dual-device--coach .hp-dual-label {
  text-align: left;
}

body.marketing .hp-dual-device--app .hp-dual-label {
  text-align: center;
  justify-content: center;
}

body.marketing .hp-app-features {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  margin: 1.75rem 0 0;
  padding: 0;
  list-style: none;
}

body.marketing .hp-app-features li {
  padding: 0.45rem 0.85rem;
  font-size: 0.82rem;
  font-weight: 600;
  border-radius: 999px;
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, transform 0.2s;
}

body.marketing .hp-app-features li:hover,
body.marketing .hp-app-features li.is-active {
  border-color: var(--bs-accent);
  background: color-mix(in srgb, var(--bs-accent) 12%, var(--bs-bg-card));
  transform: translateY(-1px);
}

body.marketing .hp-triple-demo {
  margin: 0.75rem 0 1rem;
  border-radius: 12px;
  overflow: hidden;
  transform: scale(0.92);
  transform-origin: top center;
}

body.marketing .hp-triple-demo .bs-coach-demo__layout {
  min-height: 220px;
  max-height: 240px;
}

body.marketing .hp-triple-demo .bs-coach-demo__hint {
  display: none;
}

body.marketing .hp-triple-demo--phone {
  display: flex;
  justify-content: center;
}

body.marketing .hp-triple-demo--phone .bs-app-phone {
  --iphone-w: 200px;
}

body.marketing .hp-triple-demo--phone .bs-app-phone__hint {
  display: none;
}

body.marketing .hp-hero-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 1.25rem;
  font-weight: 800;
  font-size: 0.88rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bs-accent-dark);
  justify-content: center;
}

body.marketing .hp-hero-brand img {
  width: 36px;
  height: 36px;
  border-radius: 10px;
}

body.marketing .hp-hero h1 {
  font-size: clamp(2.35rem, 5.8vw, 3.65rem);
  line-height: 1.06;
  margin-bottom: 1.1rem;
  letter-spacing: -0.025em;
  max-width: 18ch;
  margin-inline: auto;
}

body.marketing .hp-hero-lead {
  font-size: clamp(1.06rem, 2.1vw, 1.22rem);
  color: var(--bs-muted);
  max-width: 40rem;
  line-height: 1.68;
  margin: 0 auto 1.85rem;
}

body.marketing .hp-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
  justify-content: center;
}

body.marketing .hp-hero-note {
  font-size: 0.88rem;
  color: var(--bs-muted);
  margin: 0 auto;
  max-width: 36rem;
}

/* Quick actions */
body.marketing .hp-quickbar-wrap {
  position: sticky;
  top: calc(var(--bs-header, 76px) - 1px);
  z-index: 40;
  background: color-mix(in srgb, var(--bs-bg) 88%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--bs-border);
}

body.marketing .hp-quickbar {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  padding-block: 0.75rem;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

body.marketing .hp-quickbar::-webkit-scrollbar { display: none; }

body.marketing .hp-quickchip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 0.9rem;
  font-size: 0.82rem;
  font-weight: 600;
  white-space: nowrap;
  border-radius: 999px;
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  color: var(--bs-text);
  transition: border-color 0.2s, transform 0.2s;
}

body.marketing .hp-quickchip:hover {
  border-color: var(--bs-accent);
  transform: translateY(-1px);
}

body.marketing .hp-quickchip span { font-size: 1rem; line-height: 1; }

/* Dashboard mock */
body.marketing .hp-dash {
  border-radius: var(--bs-radius-lg, 20px);
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  box-shadow: var(--bs-shadow-lg, 0 24px 60px rgba(0,0,0,0.12));
  overflow: hidden;
}

body.marketing .hp-dash-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.85rem 1.1rem;
  border-bottom: 1px solid var(--bs-border);
  background: color-mix(in srgb, var(--bs-bg-card) 80%, var(--bs-accent) 4%);
}

body.marketing .hp-dash-top strong { font-size: 0.92rem; }

body.marketing .hp-dash-top span {
  font-size: 0.78rem;
  color: var(--bs-muted);
}

body.marketing .hp-dash-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.65rem;
  padding: 1rem;
}

@media (min-width: 520px) {
  body.marketing .hp-dash-grid { grid-template-columns: repeat(4, 1fr); }
}

body.marketing .hp-dash-stat {
  padding: 0.75rem 0.85rem;
  border-radius: 12px;
  background: color-mix(in srgb, var(--bs-bg) 60%, transparent);
  border: 1px solid var(--bs-border);
}

body.marketing .hp-dash-stat .val {
  display: block;
  font-size: 1.35rem;
  font-weight: 800;
  font-family: var(--bs-font-display);
  color: var(--bs-ink);
  line-height: 1.1;
}

body.marketing .hp-dash-stat .lbl {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.72rem;
  color: var(--bs-muted);
  line-height: 1.3;
}

body.marketing .hp-dash-stat--accent .val { color: var(--bs-accent-dark); }

body.marketing .hp-dash-feed {
  padding: 0 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

body.marketing .hp-dash-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.65rem 0.85rem;
  border-radius: 10px;
  background: color-mix(in srgb, var(--bs-bg) 50%, transparent);
  font-size: 0.84rem;
}

body.marketing .hp-dash-row strong { font-weight: 600; }

body.marketing .hp-dash-row .tag {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.2rem 0.5rem;
  border-radius: var(--hp-r-xs);
  background: color-mix(in srgb, var(--bs-accent) 18%, transparent);
  color: var(--bs-accent-dark);
}

/* Feature blocks */
body.marketing .hp-feature {
  display: grid;
  gap: clamp(2rem, 4vw, 3rem);
  align-items: center;
}

@media (min-width: 900px) {
  body.marketing .hp-feature { grid-template-columns: 1fr 1fr; }
  body.marketing .hp-feature--reverse .hp-feature-visual { order: -1; }
}

body.marketing .hp-feature h2 {
  font-size: clamp(1.6rem, 3.5vw, 2.15rem);
  margin-bottom: 0.75rem;
}

body.marketing .hp-feature-lead {
  color: var(--bs-muted);
  margin-bottom: 1.25rem;
  line-height: 1.65;
}

body.marketing .hp-checklist {
  display: grid;
  gap: 0.55rem;
  margin-bottom: 1.5rem;
}

body.marketing .hp-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  font-size: 0.95rem;
  line-height: 1.45;
}

body.marketing .hp-checklist li::before {
  content: "✓";
  flex-shrink: 0;
  width: 1.25rem;
  height: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 0.65rem;
  font-weight: 800;
  background: color-mix(in srgb, var(--bs-accent) 22%, transparent);
  color: var(--bs-accent-dark);
}

body.marketing .hp-btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body.marketing .hp-mini-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

body.marketing .hp-mini-btn {
  padding: 0.45rem 0.95rem;
  font-size: 0.8rem;
  font-weight: 650;
  border-radius: var(--bs-radius-pill);
  border: 2px solid var(--bs-border-strong);
  background: var(--bs-bg-elevated);
}

/* Cards / panels */
body.marketing .hp-panel {
  border-radius: var(--bs-radius-lg, 18px);
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  padding: 1.25rem;
  box-shadow: var(--bs-shadow, 0 8px 32px rgba(0,0,0,0.06));
}

body.marketing .hp-panel h3 {
  font-size: 1rem;
  margin-bottom: 0.85rem;
}

body.marketing .hp-tag-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

body.marketing .hp-tag {
  padding: 0.35rem 0.7rem;
  font-size: 0.78rem;
  font-weight: 600;
  border-radius: 12px;
  background: color-mix(in srgb, var(--bs-accent) 12%, transparent);
  color: var(--bs-accent-dark);
  border: 1px solid color-mix(in srgb, var(--bs-accent) 25%, transparent);
}

body.marketing .hp-split-week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.35rem;
}

body.marketing .hp-split-day {
  text-align: center;
  padding: 0.55rem 0.25rem;
  border-radius: 10px;
  border: 1px solid var(--bs-border);
  background: color-mix(in srgb, var(--bs-bg) 40%, transparent);
  font-size: 0.72rem;
}

body.marketing .hp-split-day strong {
  display: block;
  font-size: 0.78rem;
  margin-top: 0.15rem;
}

body.marketing .hp-split-day--rest { opacity: 0.55; }

body.marketing .hp-ai-inputs {
  display: grid;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

body.marketing .hp-ai-input {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.6rem 0.85rem;
  border-radius: 10px;
  border: 1px dashed var(--bs-border);
  font-size: 0.84rem;
}

body.marketing .hp-ai-input em {
  font-style: normal;
  color: var(--bs-muted);
  font-size: 0.78rem;
}

body.marketing .hp-ai-output {
  padding: 0.85rem;
  border-radius: 12px;
  background: color-mix(in srgb, var(--bs-accent) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--bs-accent) 20%, transparent);
  font-size: 0.84rem;
  line-height: 1.55;
}

/* Revenue grid */
body.marketing .hp-revenue-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
}

@media (min-width: 700px) {
  body.marketing .hp-revenue-grid { grid-template-columns: repeat(4, 1fr); }
}

body.marketing .hp-revenue-card {
  padding: 1rem;
  border-radius: 14px;
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
}

body.marketing .hp-revenue-card .val {
  font-size: 1.5rem;
  font-weight: 800;
  font-family: var(--bs-font-display);
  color: var(--bs-ink);
}

body.marketing .hp-revenue-card .lbl {
  font-size: 0.78rem;
  color: var(--bs-muted);
  margin-top: 0.2rem;
}

body.marketing .hp-revenue-card .delta {
  font-size: 0.75rem;
  font-weight: 700;
  color: #1a8f4a;
  margin-top: 0.35rem;
}

/* AI assistant */
body.marketing .hp-ai-feed {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

body.marketing .hp-ai-bubble {
  padding: 0.85rem 1rem;
  border-radius: 14px;
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  font-size: 0.9rem;
  line-height: 1.5;
  position: relative;
  padding-left: 2.5rem;
}

body.marketing .hp-ai-bubble::before {
  content: "🤖";
  position: absolute;
  left: 0.85rem;
  top: 0.85rem;
  font-size: 1rem;
}

/* Triple dashboards */
body.marketing .hp-triple {
  display: grid;
  gap: 1.25rem;
}

@media (min-width: 900px) {
  body.marketing .hp-triple { grid-template-columns: repeat(3, 1fr); }
  body.marketing .hp-triple--duo { grid-template-columns: repeat(2, 1fr); max-width: 920px; margin-inline: auto; }
}

body.marketing .hp-triple-card {
  border-radius: var(--bs-radius-lg, 18px);
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  height: 100%;
}

body.marketing .hp-triple-card--featured {
  border-color: color-mix(in srgb, var(--bs-accent) 45%, var(--bs-border));
  box-shadow: 0 12px 40px color-mix(in srgb, var(--bs-accent) 12%, transparent);
}

body.marketing .hp-triple-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  background: color-mix(in srgb, var(--bs-accent) 15%, transparent);
  margin-bottom: 1rem;
}

body.marketing .hp-triple-card h3 { margin-bottom: 0.5rem; }

body.marketing .hp-triple-card p {
  color: var(--bs-muted);
  font-size: 0.92rem;
  flex: 1;
  margin-bottom: 1rem;
}

body.marketing .hp-triple-card ul {
  display: grid;
  gap: 0.4rem;
  margin-bottom: 1.25rem;
  font-size: 0.86rem;
}

body.marketing .hp-triple-card ul li::before {
  content: "· ";
  color: var(--bs-accent-dark);
  font-weight: 800;
}

/* Why grid */
body.marketing .hp-why-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

@media (min-width: 700px) {
  body.marketing .hp-why-grid { grid-template-columns: repeat(3, 1fr); }
}

body.marketing .hp-why-item {
  padding: 1.25rem;
  border-radius: 14px;
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  text-align: center;
}

body.marketing .hp-why-item .icon {
  font-size: 1.75rem;
  margin-bottom: 0.65rem;
}

body.marketing .hp-why-item h3 {
  font-size: 1rem;
  margin-bottom: 0.35rem;
}

body.marketing .hp-why-item p {
  font-size: 0.85rem;
  color: var(--bs-muted);
  margin: 0;
  line-height: 1.5;
}

/* Progress demo */
body.marketing .hp-progress-demo {
  display: grid;
  gap: 0.75rem;
}

body.marketing .hp-progress-bar-wrap {
  height: 8px;
  border-radius: 99px;
  background: var(--bs-border);
  overflow: hidden;
}

body.marketing .hp-progress-bar {
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--bs-accent), var(--bs-accent-dark));
}

body.marketing .hp-photo-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}

body.marketing .hp-photo-slot {
  aspect-ratio: 3/4;
  border-radius: 12px;
  border: 1px solid var(--bs-border);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0.5rem;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--bs-muted);
  background: linear-gradient(160deg, color-mix(in srgb, var(--bs-bg-card) 80%, #888), color-mix(in srgb, var(--bs-bg) 60%, #666));
}

body.marketing .hp-photo-slot--has-img {
  position: relative;
  padding: 0;
  overflow: hidden;
  background: var(--bs-bg-card);
}

body.marketing .hp-photo-slot--has-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

body.marketing .hp-photo-slot-label {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0.4rem 0.5rem;
  font-size: 0.72rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.62));
}

body.marketing .hp-photo-slot--after {
  background: linear-gradient(160deg, color-mix(in srgb, var(--bs-accent) 25%, #888), color-mix(in srgb, var(--bs-accent-dark) 15%, #444));
}

/* Check-in actions */
body.marketing .hp-checkin-card {
  padding: 1rem;
  border-radius: 14px;
  border: 1px solid var(--bs-border);
  background: color-mix(in srgb, var(--bs-bg) 30%, transparent);
}

body.marketing .hp-checkin-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  margin: 0.75rem 0;
  font-size: 0.78rem;
  text-align: center;
}

body.marketing .hp-checkin-metrics strong {
  display: block;
  font-size: 1rem;
}

/* Hero eyebrow — plain label, no box */
body.marketing .hp-hero-eyebrow {
  display: block;
  margin: 0 0 0.75rem;
  padding: 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bs-accent-dark);
  border: none;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}

/* Audience navigation bar */
body.marketing .hp-audience-bar {
  position: sticky;
  top: calc(var(--bs-header, 76px) - 1px);
  z-index: 40;
  background: color-mix(in srgb, var(--bs-bg) 90%, transparent);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--bs-border);
}

body.marketing .hp-audience-nav {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  padding-block: 0.75rem;
}

@media (min-width: 768px) {
  body.marketing .hp-audience-nav {
    grid-template-columns: repeat(4, 1fr);
  }
}

body.marketing .hp-audience-link {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.65rem 1rem;
  border-radius: var(--bs-radius-pill);
  border: 2px solid var(--bs-border-strong);
  background: var(--bs-bg-elevated);
  color: var(--bs-text);
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s, transform 0.2s;
  min-width: 0;
}

body.marketing .hp-audience-link:hover {
  border-color: var(--bs-accent);
  background: var(--bs-accent-soft);
  transform: translateY(-1px);
}

body.marketing .hp-audience-link--cta {
  border-color: color-mix(in srgb, var(--bs-accent) 35%, var(--bs-border));
  background: color-mix(in srgb, var(--bs-accent-soft) 40%, var(--bs-bg-card));
}

body.marketing .hp-audience-icon {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  display: grid;
  place-items: center;
  border-radius: 10px;
  font-size: 1rem;
  background: color-mix(in srgb, var(--bs-accent-soft) 60%, transparent);
}

body.marketing .hp-audience-text {
  display: grid;
  gap: 0.1rem;
  min-width: 0;
}

body.marketing .hp-audience-text strong {
  font-size: 0.82rem;
  line-height: 1.2;
  color: var(--bs-ink);
}

body.marketing .hp-audience-text small {
  font-size: 0.7rem;
  color: var(--bs-muted);
  line-height: 1.3;
}

/* How it works steps */
body.marketing .hp-steps {
  display: grid;
  gap: 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: hp-step;
}

@media (min-width: 900px) {
  body.marketing .hp-steps {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
  }
}

body.marketing .hp-step {
  position: relative;
  padding: 1.5rem 1.35rem 1.35rem;
  border-radius: var(--bs-radius-xl, 20px);
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  box-shadow: var(--bs-shadow-sm);
}

body.marketing .hp-step-num {
  display: inline-grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  margin-bottom: 0.85rem;
  border-radius: 50%;
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--bs-accent-text, #fff);
  background: linear-gradient(160deg, var(--bs-accent-light), var(--bs-accent-dark));
}

body.marketing .hp-step h3 {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  font-family: var(--bs-font-display);
}

body.marketing .hp-step p {
  margin: 0 0 0.85rem;
  font-size: 0.9rem;
  color: var(--bs-muted);
  line-height: 1.6;
}

body.marketing .hp-step-link {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--bs-accent-dark);
}

body.marketing .hp-step-link:hover {
  color: var(--bs-accent-light);
}

/* Client app section */
body.marketing .hp-feature-visual--phone {
  display: flex;
  justify-content: center;
  align-items: center;
}

body.marketing .hp-feature-visual--phone .bs-app-phone {
  --iphone-w: min(100%, 260px);
}

body.marketing .hp-client-features {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-top: clamp(2rem, 4vw, 3rem);
}

@media (min-width: 768px) {
  body.marketing .hp-client-features {
    grid-template-columns: repeat(4, 1fr);
  }
}

body.marketing .hp-client-feature {
  padding: 0;
  border: none;
  background: transparent;
  text-align: center;
}

body.marketing .hp-client-feature-icon {
  display: block;
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
}

body.marketing .hp-client-feature h3 {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
}

body.marketing .hp-client-feature p {
  margin: 0;
  font-size: 0.82rem;
  color: var(--bs-muted);
  line-height: 1.5;
}

body.marketing #coach-dashboard .hp-feature h3 {
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  margin-bottom: 0.65rem;
}

/* Trust band + stats */
body.marketing .hp-trust-band {
  padding: 1.25rem 0 1.5rem;
  border-bottom: 1px solid var(--bs-border);
  background: color-mix(in srgb, var(--bs-bg-card) 40%, transparent);
}

body.marketing .hp-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.85rem;
  margin: 0 0 1rem;
  padding: 0;
  list-style: none;
}

@media (min-width: 768px) {
  body.marketing .hp-stats {
    grid-template-columns: repeat(4, 1fr);
  }
}

body.marketing .hp-stat {
  padding: 0.85rem 1rem;
  border-radius: 14px;
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  text-align: center;
}

body.marketing .hp-stat-value {
  display: block;
  font-family: var(--bs-font-display);
  font-size: clamp(1.25rem, 2.5vw, 1.65rem);
  font-weight: 650;
  color: var(--bs-ink);
  line-height: 1.1;
}

body.marketing .hp-stat-label {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.75rem;
  color: var(--bs-muted);
  line-height: 1.35;
}

body.marketing .hp-trust-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--bs-muted);
}

/* Day one timeline */
body.marketing .hp-day-one {
  margin-top: 2rem;
  padding: 1.5rem;
  border-radius: var(--bs-radius-xl, 20px);
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
}

body.marketing .hp-day-one-title {
  margin: 0 0 1.25rem;
  font-size: 1.1rem;
  text-align: center;
  font-family: var(--bs-font-display);
}

body.marketing .hp-day-one-track {
  display: grid;
  gap: 0.85rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

@media (min-width: 900px) {
  body.marketing .hp-day-one-track {
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
  }
}

body.marketing .hp-day-one-track li {
  padding: 1rem;
  border-radius: 14px;
  background: color-mix(in srgb, var(--bs-bg) 50%, transparent);
  border: 1px solid var(--bs-border);
}

body.marketing .hp-day-one-time {
  display: inline-block;
  margin-bottom: 0.4rem;
  padding: 0.2rem 0.55rem;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border-radius: 999px;
  color: var(--bs-accent-dark);
  background: var(--bs-accent-soft);
}

body.marketing .hp-day-one-track strong {
  display: block;
  font-size: 0.92rem;
  margin-bottom: 0.25rem;
}

body.marketing .hp-day-one-track p {
  margin: 0;
  font-size: 0.82rem;
  color: var(--bs-muted);
  line-height: 1.5;
}

/* Quiz + ROI */
body.marketing .hp-convert-grid {
  display: grid;
  gap: 1.25rem;
}

@media (min-width: 960px) {
  body.marketing .hp-convert-grid {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}

body.marketing .hp-convert-card {
  padding: 1.5rem;
  border-radius: var(--bs-radius-xl, 20px);
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  box-shadow: var(--bs-shadow-sm);
}

body.marketing .hp-convert-card h3 {
  margin: 0 0 0.35rem;
  font-size: 1.15rem;
}

body.marketing .hp-convert-lead {
  margin: 0 0 1.25rem;
  font-size: 0.9rem;
  color: var(--bs-muted);
  line-height: 1.55;
}

body.marketing .hp-quiz-step {
  display: none;
}

body.marketing .hp-quiz-step.is-active {
  display: block;
}

body.marketing .hp-quiz-q {
  margin: 0 0 0.75rem;
  font-weight: 700;
  font-size: 0.95rem;
}

body.marketing .hp-quiz-options {
  display: grid;
  gap: 0.5rem;
}

body.marketing .hp-quiz-option {
  padding: 0.75rem 1rem;
  border-radius: var(--bs-radius-pill);
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-elevated);
  font: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}

body.marketing .hp-quiz-option:hover,
body.marketing .hp-quiz-option.is-selected {
  border-color: var(--bs-accent);
  background: color-mix(in srgb, var(--bs-accent-soft) 55%, var(--bs-bg-elevated));
}

body.marketing .hp-quiz-result {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--bs-border);
}

body.marketing .hp-quiz-result-eyebrow {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bs-accent-dark);
}

body.marketing .hp-quiz-result h4 {
  margin: 0 0 0.5rem;
  font-size: 1.2rem;
}

body.marketing .hp-roi-fields {
  display: grid;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

body.marketing .hp-roi-field {
  display: grid;
  gap: 0.35rem;
  font-size: 0.85rem;
  font-weight: 600;
}

body.marketing .hp-roi-field input[type="range"] {
  width: 100%;
  accent-color: var(--bs-accent);
}

body.marketing .hp-roi-field output {
  font-size: 0.82rem;
  color: var(--bs-muted);
}

body.marketing .hp-roi-results {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.65rem;
}

body.marketing .hp-roi-result {
  padding: 0.75rem 0.5rem;
  border-radius: 12px;
  background: color-mix(in srgb, var(--bs-accent-soft) 40%, transparent);
  border: 1px solid color-mix(in srgb, var(--bs-accent) 20%, var(--bs-border));
  text-align: center;
}

body.marketing .hp-roi-result strong {
  display: block;
  font-size: 1.15rem;
  font-family: var(--bs-font-display);
  color: var(--bs-accent-dark);
}

body.marketing .hp-roi-result span {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.68rem;
  color: var(--bs-muted);
  line-height: 1.3;
}

body.marketing .hp-roi-note {
  margin: 0.85rem 0 0;
  font-size: 0.78rem;
  color: var(--bs-dim);
}

/* Comparison table */
body.marketing .hp-compare-wrap {
  overflow-x: auto;
  border-radius: var(--bs-radius-xl, 20px);
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
}

body.marketing .hp-compare-table {
  width: 100%;
  min-width: 560px;
  border-collapse: collapse;
  font-size: 0.9rem;
}

body.marketing .hp-compare-table th,
body.marketing .hp-compare-table td {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid var(--bs-border);
  text-align: center;
}

body.marketing .hp-compare-table th[scope="row"] {
  text-align: left;
  font-weight: 600;
}

body.marketing .hp-compare-highlight {
  background: color-mix(in srgb, var(--bs-accent-soft) 45%, var(--bs-bg-card));
  color: var(--bs-accent-dark);
}

body.marketing .hp-compare-yes {
  color: #15803d;
  font-weight: 700;
}

body.marketing .hp-compare-no {
  color: var(--bs-dim);
}

body.marketing .hp-compare-partial {
  color: var(--bs-muted);
  font-size: 0.85rem;
}

body.marketing .hp-compare-cta {
  text-align: center;
  margin: 1.5rem 0 0;
}

/* Founder */
body.marketing .hp-founder {
  display: grid;
  gap: 1.5rem;
  align-items: center;
  padding: clamp(1.5rem, 3vw, 2.25rem);
  border-radius: var(--bs-radius-xl, 20px);
  border: 1px solid var(--bs-border);
  background: linear-gradient(145deg, color-mix(in srgb, var(--bs-accent-soft) 35%, var(--bs-bg-card)), var(--bs-bg-card));
  box-shadow: var(--bs-shadow-sm);
}

@media (min-width: 768px) {
  body.marketing .hp-founder {
    grid-template-columns: auto 1fr;
    gap: 2rem;
  }
}

body.marketing .hp-founder-mark img {
  border-radius: 16px;
  box-shadow: var(--bs-shadow-sm);
}

body.marketing .hp-founder-copy h2 {
  font-size: clamp(1.35rem, 2.5vw, 1.85rem);
  margin: 0 0 0.65rem;
}

body.marketing .hp-founder-copy p {
  margin: 0 0 1.25rem;
  color: var(--bs-muted);
  line-height: 1.65;
  max-width: 52ch;
}

/* Sticky mobile CTA */
body.marketing .hp-sticky-cta {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 120;
  padding: 0.65rem 1rem calc(0.65rem + env(safe-area-inset-bottom, 0px));
  background: color-mix(in srgb, var(--bs-bg) 92%, transparent);
  backdrop-filter: blur(14px);
  border-top: 1px solid var(--bs-border);
  transform: translateY(110%);
  opacity: 0;
  visibility: hidden;
  transition: transform 0.3s ease, opacity 0.3s ease, visibility 0.3s;
}

body.marketing .hp-sticky-cta.is-visible {
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
}

body.marketing .hp-sticky-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  max-width: var(--bs-container, 1180px);
  margin: 0 auto;
}

body.marketing .hp-sticky-cta p {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.3;
}

body.marketing .hp-sticky-cta p span {
  display: block;
  color: var(--bs-muted);
  font-weight: 500;
}

@media (min-width: 768px) {
  body.marketing .hp-sticky-cta {
    display: none;
  }
}

/* Social proof (early access) */
body.marketing .hp-social-proof-sub {
  max-width: 640px;
  margin: -1rem auto 1.75rem;
  text-align: center;
  color: var(--bs-muted);
  font-size: 1.02rem;
  line-height: 1.6;
}

body.marketing .hp-social-proof-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-bottom: 1.75rem;
}

@media (min-width: 720px) {
  body.marketing .hp-social-proof-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

body.marketing .hp-social-proof-card {
  padding: 1.15rem 1.2rem;
  border-radius: 14px;
  border: 1px solid var(--bs-border);
  background: var(--bs-bg-card);
  box-shadow: var(--bs-shadow-sm, 0 8px 24px rgba(0, 0, 0, 0.06));
}

body.marketing .hp-social-proof-icon {
  display: inline-flex;
  margin-bottom: 0.55rem;
  font-size: 1.25rem;
  line-height: 1;
}

body.marketing .hp-social-proof-card h3 {
  margin: 0 0 0.4rem;
  font-size: 1rem;
}

body.marketing .hp-social-proof-card p {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--bs-muted);
}

body.marketing .hp-social-proof-cta {
  text-align: center;
  margin: 0;
}

body.marketing .hp-ios-note {
  margin: 0.75rem 0 0;
  font-size: 0.82rem;
  color: var(--bs-muted);
}

/* GSAP motion — hide until animated */
body.marketing.gsap-enhanced .hp-hero-copy,
body.marketing.gsap-enhanced .hp-live-preview__head,
body.marketing.gsap-enhanced .hp-showcase-frame,
body.marketing.gsap-enhanced .hp-section-head,
body.marketing.gsap-enhanced .hp-feature,
body.marketing.gsap-enhanced .hp-stat,
body.marketing.gsap-enhanced .hp-step,
body.marketing.gsap-enhanced .hp-triple-card,
body.marketing.gsap-enhanced .hp-founder,
body.marketing.gsap-enhanced .hp-convert-card,
body.marketing.gsap-enhanced .hp-coach-highlight,
body.marketing.gsap-enhanced .hp-compare-table {
  will-change: transform, opacity;
}

body.marketing.gsap-enhanced.motion-ready .hp-dual-device {
  transform-style: preserve-3d;
  perspective: 1200px;
}

body.marketing.gsap-enhanced .hp-showcase-frame .hp-dual-device {
  backface-visibility: hidden;
}

@media (prefers-reduced-motion: reduce) {
  body.marketing .hp-hero-copy,
  body.marketing .hp-live-preview__head,
  body.marketing .hp-showcase-frame,
  body.marketing .hp-section-head,
  body.marketing .hp-feature,
  body.marketing .hp-stat {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}


/* ========== homepage-polish.css ========== */

/* Homepage polish — professional layout, icons, rhythm */

/* ── Page flow ─────────────────────────────────────────────────── */

body.marketing .hp-hero.hp-section {
  padding-block: clamp(2.75rem, 5.5vw, 4.5rem) clamp(0.5rem, 1.5vw, 1rem);
}

body.marketing .hp-live-preview.hp-section {
  padding-block: clamp(0.75rem, 2vw, 1.5rem) clamp(2.5rem, 5vw, 4rem);
}

body.marketing .hp-trust-band {
  padding: clamp(1.5rem, 3vw, 2rem) 0;
  border-block: 1px solid color-mix(in srgb, var(--bs-border) 80%, transparent);
  background: color-mix(in srgb, var(--bs-bg-card) 55%, transparent);
}

body.marketing .hp-section--alt {
  background: color-mix(in srgb, var(--bs-bg-card) 42%, transparent);
  border-block: 1px solid color-mix(in srgb, var(--bs-border) 65%, transparent);
}

body.marketing .hp-section-head {
  max-width: 680px;
}

body.marketing .hp-btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

body.marketing .hp-btn-row--center {
  justify-content: center;
  margin-top: 1.5rem;
}

/* ── Icon system (CSS-only, no emoji) ───────────────────────────── */

body.marketing .hp-i {
  display: inline-block;
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  background: currentColor;
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
}

body.marketing .hp-i--lock {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='11' width='18' height='11' rx='2'/%3E%3Cpath d='M7 11V7a5 5 0 0110 0v4'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='11' width='18' height='11' rx='2'/%3E%3Cpath d='M7 11V7a5 5 0 0110 0v4'/%3E%3C/svg%3E");
}

body.marketing .hp-i--check {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5'%3E%3Cpath d='M5 12l4 4L19 6'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5'%3E%3Cpath d='M5 12l4 4L19 6'/%3E%3C/svg%3E");
}

body.marketing .hp-i--grid {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='3' width='7' height='7' rx='1'/%3E%3Crect x='14' y='3' width='7' height='7' rx='1'/%3E%3Crect x='3' y='14' width='7' height='7' rx='1'/%3E%3Crect x='14' y='14' width='7' height='7' rx='1'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='3' y='3' width='7' height='7' rx='1'/%3E%3Crect x='14' y='3' width='7' height='7' rx='1'/%3E%3Crect x='3' y='14' width='7' height='7' rx='1'/%3E%3Crect x='14' y='14' width='7' height='7' rx='1'/%3E%3C/svg%3E");
}

body.marketing .hp-i--phone {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='6' y='2' width='12' height='20' rx='2'/%3E%3Cpath d='M12 18h.01'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Crect x='6' y='2' width='12' height='20' rx='2'/%3E%3Cpath d='M12 18h.01'/%3E%3C/svg%3E");
}

body.marketing .hp-i--arrow {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M5 12h14M13 6l6 6-6 6'/%3E%3C/svg%3E");
}

body.marketing .hp-i--bolt {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M13 2L3 14h8l-1 8 10-12h-8l1-8z'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M13 2L3 14h8l-1 8 10-12h-8l1-8z'/%3E%3C/svg%3E");
}

body.marketing .hp-i--dumbbell {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M6 7h2v10H6zM16 7h2v10h-2zM8 10h8v4H8z'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M6 7h2v10H6zM16 7h2v10h-2zM8 10h8v4H8z'/%3E%3C/svg%3E");
}

body.marketing .hp-i--meal {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M8 4v8a3 3 0 006 0V4M11 12v8M14 4v5a3 3 0 006 0V4M17 9v11'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M8 4v8a3 3 0 006 0V4M11 12v8M14 4v5a3 3 0 006 0V4M17 9v11'/%3E%3C/svg%3E");
}

body.marketing .hp-i--camera {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M23 19a2 2 0 01-2 2H3a2 2 0 01-2-2V8a2 2 0 012-2h4l2-3h6l2 3h4a2 2 0 012 2z'/%3E%3Ccircle cx='12' cy='13' r='4'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M23 19a2 2 0 01-2 2H3a2 2 0 01-2-2V8a2 2 0 012-2h4l2-3h6l2 3h4a2 2 0 012 2z'/%3E%3Ccircle cx='12' cy='13' r='4'/%3E%3C/svg%3E");
}

body.marketing .hp-i--chat {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 15a2 2 0 01-2 2H7l-4 4V5a2 2 0 012-2h14a2 2 0 012 2z'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'%3E%3Cpath d='M21 15a2 2 0 01-2 2H7l-4 4V5a2 2 0 012-2h14a2 2 0 012 2z'/%3E%3C/svg%3E");
}

/* ── Stats & trust ───────────────────────────────────────────────── */

body.marketing .hp-stats {
  gap: 1rem;
  margin-bottom: 1.25rem;
}

body.marketing .hp-stat {
  padding: 1rem 1.1rem;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--bs-border) 85%, transparent);
  background: var(--bs-bg-card);
  box-shadow: 0 1px 0 color-mix(in srgb, #fff 30%, transparent) inset;
  transition: border-color 0.2s, transform 0.2s;
}

body.marketing .hp-stat:hover {
  border-color: color-mix(in srgb, var(--bs-accent) 25%, var(--bs-border));
  transform: translateY(-2px);
}

body.marketing .hp-trust-strip {
  gap: 0.5rem;
  padding-top: 0.25rem;
}

body.marketing .hp-trust-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--bs-muted);
  background: color-mix(in srgb, var(--bs-bg-card) 90%, transparent);
  border: 1px solid color-mix(in srgb, var(--bs-border) 88%, transparent);
}

body.marketing .hp-trust-chip .hp-i {
  width: 0.85rem;
  height: 0.85rem;
  color: var(--bs-accent-dark);
}

/* ── Audience bar ────────────────────────────────────────────────── */

body.marketing .hp-audience-bar {
  background: color-mix(in srgb, var(--bs-bg) 94%, transparent);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid color-mix(in srgb, var(--bs-border) 80%, transparent);
}

body.marketing .hp-audience-nav {
  gap: 0.65rem;
  padding-block: 0.85rem;
}

body.marketing .hp-audience-link {
  padding: 0.75rem 0.95rem;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--bs-border) 85%, transparent);
  background: var(--bs-bg-card);
}

body.marketing .hp-audience-icon {
  display: grid;
  place-items: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 12px;
  font-size: 0;
  background: color-mix(in srgb, var(--bs-accent) 10%, var(--bs-bg-card));
  border: 1px solid color-mix(in srgb, var(--bs-accent) 15%, var(--bs-border));
}

body.marketing .hp-audience-icon .hp-i {
  width: 1.05rem;
  height: 1.05rem;
  color: var(--bs-accent-dark);
}

body.marketing .hp-audience-link--cta .hp-audience-icon {
  background: color-mix(in srgb, var(--bs-accent) 18%, var(--bs-bg-card));
}

/* ── Steps & cards ─────────────────────────────────────────────── */

body.marketing .hp-step {
  border-radius: 20px;
  box-shadow: 0 1px 0 color-mix(in srgb, #fff 25%, transparent) inset;
}

body.marketing .hp-app-features li {
  padding: 0.5rem 0.95rem;
  font-size: 0.8rem;
  letter-spacing: 0.01em;
  border-color: color-mix(in srgb, var(--bs-border) 90%, transparent);
}

body.marketing .hp-coach-highlights {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.85rem;
  margin-top: 2rem;
}

@media (min-width: 768px) {
  body.marketing .hp-coach-highlights {
    grid-template-columns: repeat(4, 1fr);
  }
}

body.marketing .hp-coach-highlight {
  padding: 0;
  border: none;
  background: transparent;
}

body.marketing .hp-coach-highlight strong {
  display: block;
  font-size: 0.88rem;
  margin-bottom: 0.25rem;
  color: var(--bs-ink);
}

body.marketing .hp-coach-highlight span {
  display: block;
  font-size: 0.76rem;
  color: var(--bs-muted);
  line-height: 1.4;
}

/* ── Client features ─────────────────────────────────────────────── */

body.marketing .hp-client-feature {
  border-radius: 18px;
  padding: 1.25rem 1rem;
  transition: border-color 0.2s, transform 0.2s;
}

body.marketing .hp-client-feature:hover {
  border-color: color-mix(in srgb, var(--bs-accent) 30%, var(--bs-border));
  transform: translateY(-2px);
}

body.marketing .hp-client-feature-icon {
  display: inline-grid;
  place-items: center;
  width: 2.5rem;
  height: 2.5rem;
  margin: 0 auto 0.75rem;
  border-radius: 12px;
  font-size: 0;
  background: color-mix(in srgb, var(--bs-accent) 10%, var(--bs-bg-card));
  border: 1px solid color-mix(in srgb, var(--bs-accent) 15%, var(--bs-border));
}

body.marketing .hp-client-feature-icon .hp-i {
  width: 1.15rem;
  height: 1.15rem;
  color: var(--bs-accent-dark);
}

/* ── Social proof ────────────────────────────────────────────────── */

body.marketing .k-testimonials h2 {
  text-align: center;
}

body.marketing .hp-social-proof-card {
  border-radius: 20px;
  padding: 1.35rem 1.25rem;
  border: 1px solid color-mix(in srgb, var(--bs-border) 85%, transparent);
  background: var(--bs-bg-card);
  box-shadow: 0 1px 0 color-mix(in srgb, #fff 22%, transparent) inset;
  transition: border-color 0.2s, transform 0.2s;
}

body.marketing .hp-social-proof-card:hover {
  border-color: color-mix(in srgb, var(--bs-accent) 28%, var(--bs-border));
  transform: translateY(-2px);
}

body.marketing .hp-social-proof-icon {
  display: inline-grid;
  place-items: center;
  width: 2.5rem;
  height: 2.5rem;
  margin-bottom: 0.85rem;
  border-radius: 12px;
  font-size: 0;
  background: color-mix(in srgb, var(--bs-accent) 10%, var(--bs-bg-card));
  border: 1px solid color-mix(in srgb, var(--bs-accent) 15%, var(--bs-border));
}

body.marketing .hp-social-proof-icon .hp-i {
  width: 1.15rem;
  height: 1.15rem;
  color: var(--bs-accent-dark);
}

body.marketing .hp-social-proof-cta {
  text-align: center;
}

/* ── Showcase frame refinement ───────────────────────────────────── */

body.marketing .hp-showcase-frame {
  border-color: color-mix(in srgb, var(--bs-border) 68%, transparent);
  box-shadow:
    0 1px 0 color-mix(in srgb, #fff 24%, transparent) inset,
    0 32px 72px color-mix(in srgb, var(--bs-ink) 7%, transparent);
}

body.marketing .hp-live-preview__head .hp-eyebrow {
  margin-bottom: 0.75rem;
}

/* ── Compact homepage rhythm (all sections & containers) ─────────── */

body.marketing .hp-section {
  padding-block: clamp(2rem, 4vw, 3rem);
}

body.marketing .hp-hero.hp-section {
  padding-block: clamp(1.85rem, 3.8vw, 2.75rem) clamp(0.35rem, 1vw, 0.6rem);
}

body.marketing .hp-live-preview.hp-section {
  padding-block: clamp(0.45rem, 1vw, 0.75rem) clamp(1.5rem, 3vw, 2.25rem);
}

body.marketing .hp-hero-grid {
  max-width: 42rem;
  gap: clamp(0.85rem, 1.8vw, 1.25rem);
}

body.marketing .hp-hero h1 {
  font-size: clamp(1.95rem, 4.5vw, 2.85rem);
  margin-bottom: 0.75rem;
}

body.marketing .hp-hero-lead {
  font-size: clamp(0.98rem, 1.7vw, 1.1rem);
  margin-bottom: 1.25rem;
  max-width: 36rem;
}

body.marketing .hp-hero-actions {
  margin-bottom: 1.1rem;
  gap: 0.6rem;
}

body.marketing .hp-hero-brand {
  margin-bottom: 1rem;
}

body.marketing .hp-live-preview__inner {
  width: min(100% - 2rem, 900px);
}

body.marketing .hp-live-preview__head {
  max-width: 480px;
  margin-bottom: clamp(0.85rem, 1.8vw, 1.15rem);
}

body.marketing .hp-live-preview__head h2 {
  font-size: clamp(1.35rem, 2.8vw, 1.85rem);
  margin-bottom: 0.45rem;
}

body.marketing .hp-live-preview__head p {
  font-size: 0.95rem;
  line-height: 1.55;
}

body.marketing .hp-section-head {
  max-width: 560px;
  margin-bottom: clamp(1.1rem, 2.2vw, 1.5rem);
}

body.marketing .hp-section-head h2 {
  font-size: clamp(1.45rem, 3vw, 2rem);
  margin-bottom: 0.45rem;
}

body.marketing .hp-section-head p {
  font-size: 0.95rem;
  line-height: 1.55;
}

body.marketing .hp-trust-band {
  padding: clamp(0.75rem, 1.8vw, 1rem) 0;
}

body.marketing .hp-stats {
  gap: 0.65rem;
  margin-bottom: 0.85rem;
}

body.marketing .hp-stat {
  padding: 0.65rem 0.8rem;
  border-radius: 12px;
}

body.marketing .hp-stat-value {
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
}

body.marketing .hp-stat-label {
  font-size: 0.7rem;
  margin-top: 0.15rem;
}

body.marketing .hp-trust-chip {
  padding: 0.28rem 0.6rem;
  font-size: 0.72rem;
}

body.marketing .hp-audience-nav {
  gap: 0.45rem;
  padding-block: 0.55rem;
}

body.marketing .hp-audience-link {
  padding: 0.55rem 0.7rem;
  border-radius: 12px;
}

body.marketing .hp-audience-icon {
  width: 1.85rem;
  height: 1.85rem;
  border-radius: 9px;
}

body.marketing .hp-audience-text strong {
  font-size: 0.78rem;
}

body.marketing .hp-audience-text small {
  font-size: 0.66rem;
}

body.marketing .hp-steps {
  gap: 0.7rem;
}

body.marketing .hp-step {
  padding: 1.1rem 1rem;
  border-radius: 16px;
}

body.marketing .hp-step-num {
  width: 1.75rem;
  height: 1.75rem;
  margin-bottom: 0.65rem;
  font-size: 0.8rem;
}

body.marketing .hp-step h3 {
  font-size: 0.95rem;
  margin-bottom: 0.35rem;
}

body.marketing .hp-step p {
  margin-bottom: 0.65rem;
  font-size: 0.84rem;
}

body.marketing .hp-day-one {
  margin-top: 1.15rem;
  padding: 1rem;
  border-radius: 16px;
}

body.marketing .hp-day-one-title {
  margin-bottom: 0.85rem;
  font-size: 1rem;
}

body.marketing .hp-day-one-track {
  gap: 0.65rem;
}

body.marketing .hp-day-one-track li {
  padding: 0.75rem;
  border-radius: 12px;
}

body.marketing .hp-feature {
  gap: clamp(1.25rem, 2.5vw, 1.85rem);
}

body.marketing .hp-feature h2 {
  font-size: clamp(1.4rem, 2.8vw, 1.85rem);
  margin-bottom: 0.55rem;
}

body.marketing .hp-feature-lead {
  margin-bottom: 0.95rem;
  font-size: 0.92rem;
  line-height: 1.55;
}

body.marketing .hp-feature-visual--phone .bs-app-phone {
  --iphone-w: min(100%, 220px);
}

body.marketing .hp-showcase-frame {
  border-radius: 18px;
  box-shadow:
    0 1px 0 color-mix(in srgb, #fff 20%, transparent) inset,
    0 20px 48px color-mix(in srgb, var(--bs-ink) 6%, transparent);
}

body.marketing .hp-showcase-frame__head {
  padding: 0.6rem 0.95rem;
  border-radius: 18px 18px 0 0;
}

body.marketing .hp-showcase-frame__body {
  padding: clamp(0.75rem, 1.6vw, 1rem);
}

body.marketing .hp-showcase-frame__foot {
  padding: 0.5rem 0.95rem 0.6rem;
  border-radius: 0 0 18px 18px;
}

body.marketing .hp-showcase-frame--featured,
body.marketing .hp-showcase-frame--featured .hp-showcase-frame__head {
  border-radius: 18px 18px 0 0;
}

body.marketing .hp-showcase-frame--featured .hp-showcase-frame__body {
  padding: clamp(0.75rem, 1.6vw, 1rem);
}

body.marketing .hp-showcase-frame--large .hp-showcase-frame__body {
  padding: clamp(0.75rem, 1.6vw, 1rem);
}

body.marketing .hp-showcase-frame--featured .bs-coach-demo[data-mode="hero"] .bs-coach-demo__layout {
  grid-template-columns: 100px 1fr;
  height: 290px;
}

body.marketing .hp-showcase-frame--large .bs-coach-demo[data-mode="showcase"] .bs-coach-demo__layout {
  grid-template-columns: 108px 1fr;
  height: 360px;
}

body.marketing .hp-showcase-frame--large .hp-dual-device--app .bs-app-phone {
  max-width: 240px;
}

body.marketing .hp-dual-label {
  margin-bottom: 0.45rem;
  font-size: 0.62rem;
}

body.marketing .hp-app-features {
  margin-top: 1rem;
  gap: 0.35rem;
}

body.marketing .hp-app-features li {
  padding: 0.38rem 0.75rem;
  font-size: 0.76rem;
}

body.marketing .hp-coach-highlights {
  margin-top: 1.1rem;
  gap: 0.55rem;
}

body.marketing .hp-coach-highlight {
  padding: 0.7rem 0.8rem;
  border-radius: 12px;
}

body.marketing .hp-coach-highlight strong {
  font-size: 0.82rem;
}

body.marketing .hp-coach-highlight span {
  font-size: 0.72rem;
}

body.marketing .hp-btn-row--center {
  margin-top: 0.85rem;
  gap: 0.6rem;
}

body.marketing .hp-client-features {
  margin-top: clamp(1rem, 2vw, 1.5rem);
  gap: 0.6rem;
}

body.marketing .hp-client-feature {
  padding: 0.85rem 0.75rem;
  border-radius: 14px;
}

body.marketing .hp-client-feature-icon {
  width: 2.1rem;
  height: 2.1rem;
  margin-bottom: 0.55rem;
}

body.marketing .hp-client-feature h3 {
  font-size: 0.88rem;
}

body.marketing .hp-client-feature p {
  font-size: 0.78rem;
}

body.marketing .hp-convert-card {
  padding: 1rem;
  border-radius: 16px;
}

body.marketing .hp-convert-grid {
  gap: 0.75rem;
}

body.marketing .k-testimonials h2 {
  font-size: clamp(1.35rem, 2.6vw, 1.75rem);
  margin-bottom: 1rem;
}

body.marketing .hp-social-proof-sub {
  margin: -0.35rem auto 1rem;
  font-size: 0.92rem;
}

body.marketing .hp-social-proof-grid {
  gap: 0.65rem;
  margin-bottom: 1rem;
}

body.marketing .hp-social-proof-card {
  padding: 0.95rem 0.85rem;
  border-radius: 14px;
}

body.marketing .hp-social-proof-icon {
  width: 2.1rem;
  height: 2.1rem;
  margin-bottom: 0.6rem;
}

body.marketing .hp-social-proof-card h3 {
  font-size: 0.92rem;
  margin-bottom: 0.35rem;
}

body.marketing .hp-social-proof-card p {
  font-size: 0.82rem;
  line-height: 1.5;
}

body.marketing .k-pricing h2 {
  font-size: clamp(1.4rem, 2.8vw, 1.95rem);
}

body.marketing .k-pricing-sub {
  margin-bottom: 0.85rem;
  font-size: 0.92rem;
}

body.marketing .k-pricing-grid {
  gap: 0.85rem;
}

body.marketing .k-faq-header {
  margin-bottom: 1rem;
}

body.marketing .k-faq-header h2 {
  font-size: clamp(1.35rem, 2.6vw, 1.75rem);
}

body.marketing .k-faq-header p {
  font-size: 0.88rem;
}

body.marketing .k-faq-item button {
  padding: 0.85rem 1rem;
  font-size: 0.9rem;
}

body.marketing .k-faq-answer p {
  padding-bottom: 0.85rem;
  font-size: 0.86rem;
}

body.marketing .k-final-cta h2 {
  font-size: clamp(1.4rem, 2.8vw, 1.95rem);
  margin-bottom: 0.55rem;
}

body.marketing .k-final-cta-sub {
  font-size: 0.92rem;
  margin-bottom: 0.85rem;
  line-height: 1.55;
}

body.marketing .k-final-cta-inner {
  max-width: 560px;
}

body.marketing .hp-sticky-cta {
  padding: 0.5rem 0.85rem calc(0.5rem + env(safe-area-inset-bottom, 0px));
}

body.marketing .hp-sticky-cta p {
  font-size: 0.76rem;
}

@media (max-width: 959px) {
  body.marketing .hp-showcase-frame--featured .bs-coach-demo[data-mode="hero"] .bs-coach-demo__layout {
    height: 280px;
  }
}


/* ========== homepage-apple.css ========== */

/* Apple-grade homepage surfaces — unified radius, depth, clarity */

/* ── Shared surface recipe ───────────────────────────────────────── */

body.marketing {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.marketing .hp-surface,
body.marketing .hp-showcase-frame,
body.marketing .hp-convert-card,
body.marketing .hp-social-proof-card,
body.marketing .hp-compare-wrap,
body.marketing .k-price-card,
body.marketing .k-faq-item,
body.marketing .bs-coach-demo__browser {
  border-radius: var(--hp-r-md);
  border: 1px solid var(--hp-surface-border);
  background: var(--bs-bg-card);
  box-shadow: var(--hp-surface-inset), var(--hp-surface-shadow);
}

/* ── Radius scale ────────────────────────────────────────────────── */

body.marketing .hp-showcase-frame,
body.marketing .hp-compare-wrap,
body.marketing .k-final-cta-inner,
body.marketing .k-price-card {
  border-radius: var(--hp-r-lg);
  overflow: hidden;
}

body.marketing .hp-showcase-frame {
  border-radius: var(--hp-r-xl);
}

body.marketing .hp-showcase-frame__head {
  border-radius: var(--hp-r-xl) var(--hp-r-xl) 0 0;
  border-bottom: 1px solid var(--hp-surface-border);
  background: color-mix(in srgb, var(--bs-bg-elevated) 65%, var(--bs-bg-card));
}

body.marketing .hp-showcase-frame__foot {
  border-radius: 0 0 var(--hp-r-xl) var(--hp-r-xl);
  border-top: 1px solid var(--hp-surface-border);
  background: color-mix(in srgb, var(--bs-bg-elevated) 50%, var(--bs-bg-card));
}

body.marketing .hp-showcase-frame__body {
  background: color-mix(in srgb, var(--bs-bg) 18%, var(--bs-bg-card));
}

body.marketing .bs-coach-demo__browser {
  border-radius: var(--hp-r-md);
  overflow: hidden;
  box-shadow:
    var(--hp-surface-inset),
    0 4px 20px color-mix(in srgb, var(--bs-ink) 5%, transparent);
}

body.marketing .hp-social-proof-card,
body.marketing .hp-convert-card,
body.marketing .k-faq-item {
  border-radius: var(--hp-r-sm);
}

body.marketing .hp-audience-link {
  border-radius: var(--bs-radius-pill);
  transition:
    border-color 0.22s var(--bs-ease-out),
    background 0.22s var(--bs-ease-out),
    transform 0.22s var(--bs-ease-out);
}

body.marketing .hp-audience-link:hover {
  transform: translateY(-1px);
}

body.marketing .hp-trust-chip,
body.marketing .hp-app-features li,
body.marketing .hp-showcase-hint-chip,
body.marketing .hp-showcase-frame__badge,
body.marketing .k-billing-toggle button {
  border-radius: var(--bs-radius-pill);
}

body.marketing .hp-audience-icon,
body.marketing .hp-client-feature-icon,
body.marketing .hp-social-proof-icon,
body.marketing .hp-triple-icon,
body.marketing .k-logo-mark {
  border-radius: var(--hp-r-xs);
}

body.marketing .k-action-box {
  border-radius: 0;
  background: transparent;
  backdrop-filter: none;
  border: none;
  box-shadow: none;
}

body.marketing .k-btn {
  border-radius: var(--bs-radius-pill);
  border-width: 2px;
  border-style: solid;
}

/* ── FAQ as rounded cards (not flat list) ────────────────────────── */

body.marketing .k-faq-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

body.marketing .k-faq-item {
  border-bottom: none;
  overflow: hidden;
}

body.marketing .k-faq-item button {
  padding: 0.95rem 1.1rem;
}

body.marketing .k-faq-answer p {
  padding: 0 1.1rem 0.95rem;
}

/* ── Final CTA panel ─────────────────────────────────────────────── */

body.marketing .k-final-cta-inner {
  padding: 0;
  background: transparent;
  backdrop-filter: none;
  border: none;
  box-shadow: none;
}

/* ── Sticky mobile CTA ───────────────────────────────────────────── */

body.marketing .hp-sticky-cta {
  left: 0.65rem;
  right: 0.65rem;
  bottom: 0.65rem;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

body.marketing .hp-sticky-cta-inner {
  padding: 0.65rem 0.85rem;
  border-radius: var(--hp-r-lg);
  background: color-mix(in srgb, var(--bs-bg-card) 94%, transparent);
  backdrop-filter: blur(20px) saturate(1.35);
  box-shadow:
    var(--hp-surface-inset),
    0 8px 32px color-mix(in srgb, var(--bs-ink) 14%, transparent);
}

/* ── Billing toggle ──────────────────────────────────────────────── */

body.marketing .k-billing-toggle {
  display: inline-flex;
  padding: 0;
  gap: 0.45rem;
  margin-bottom: 1rem;
  background: transparent;
  border: none;
  box-shadow: none;
}

body.marketing .k-billing-toggle button {
  min-height: 42px;
  padding: 0.55rem 1.1rem;
  font-weight: 650;
  border: 2px solid var(--bs-border-strong);
  background: var(--bs-bg-elevated);
  color: var(--bs-ink);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, color 0.2s, transform 0.2s;
}

body.marketing .k-billing-toggle button.is-active,
body.marketing .k-billing-toggle button[aria-pressed="true"] {
  border-color: color-mix(in srgb, var(--bs-accent-dark) 80%, #000);
  background: linear-gradient(160deg, var(--bs-accent-light) 0%, var(--bs-accent-dark) 100%);
  color: var(--bs-accent-text);
}

/* ── Icon tiles ──────────────────────────────────────────────────── */

body.marketing .hp-audience-icon,
body.marketing .hp-client-feature-icon,
body.marketing .hp-social-proof-icon {
  background: color-mix(in srgb, var(--bs-accent) 8%, var(--bs-bg-card));
  border: 1px solid color-mix(in srgb, var(--bs-accent) 12%, var(--hp-surface-border));
  box-shadow: var(--hp-surface-inset);
}

/* ── Section alternates — softer, not harsh bands ─────────────────── */

body.marketing .hp-section--alt {
  background: color-mix(in srgb, var(--bs-bg-card) 35%, transparent);
  border-block-color: color-mix(in srgb, var(--bs-border) 50%, transparent);
}

body.marketing .hp-trust-band {
  background: color-mix(in srgb, var(--bs-bg-card) 45%, transparent);
  border-block-color: color-mix(in srgb, var(--bs-border) 55%, transparent);
}

/* ── Header refinement ───────────────────────────────────────────── */

body.marketing .k-header {
  backdrop-filter: blur(20px) saturate(1.4);
  border-bottom-color: var(--hp-surface-border);
}

/* ── Hover — subtle lift, Apple-style ────────────────────────────── */

body.marketing .hp-stat:hover,
body.marketing .hp-client-feature:hover,
body.marketing .hp-social-proof-card:hover,
body.marketing .k-price-card:hover {
  transform: translateY(-2px);
  box-shadow:
    var(--hp-surface-inset),
    0 10px 36px color-mix(in srgb, var(--bs-ink) 9%, transparent);
}

body.marketing .k-action-box:hover {
  transform: translateY(-1px);
}

/* ── Phone frame — continuous corners ────────────────────────────── */

body.marketing .bs-app-phone__shell {
  border-radius: 44px;
}

body.marketing .bs-app-phone__screen {
  border-radius: 40px;
}

/* ── Remove square corners on misc elements ──────────────────────── */

body.marketing .hp-step-num,
body.marketing .hp-day-one-time {
  border-radius: var(--bs-radius-pill);
}

body.marketing .hp-showcase-frame__brand img {
  border-radius: 6px;
}

body.marketing .hp-hero-brand img {
  border-radius: var(--hp-r-xs);
}

@media (prefers-reduced-motion: reduce) {
  body.marketing .hp-stat:hover,
  body.marketing .hp-client-feature:hover,
  body.marketing .hp-social-proof-card:hover,
  body.marketing .k-price-card:hover,
  body.marketing .hp-audience-link:hover,
  body.marketing .k-action-box:hover {
    transform: none;
  }
}

/* ── Checklist + feature visuals ─────────────────────────────────── */

body.marketing .hp-checklist li {
  padding: 0.55rem 0.75rem;
  border-radius: var(--hp-r-xs);
  border: 1px solid var(--hp-surface-border);
  background: color-mix(in srgb, var(--bs-bg-card) 70%, transparent);
  box-shadow: var(--hp-surface-inset);
}

body.marketing .hp-feature-visual {
  border-radius: var(--hp-r-md);
  border: 1px solid var(--hp-surface-border);
  overflow: hidden;
  box-shadow: var(--hp-surface-inset), var(--hp-surface-shadow);
}

body.marketing .hp-dash-row {
  border-radius: var(--hp-r-xs);
}

body.marketing .hp-dash-row .tag {
  border-radius: var(--bs-radius-pill);
}

/* ── Coach demo — marketing embed polish ─────────────────────────── */

body.marketing .bs-coach-demo-card,
body.marketing .bs-coach-demo-stat,
body.marketing .bs-coach-demo-pill,
body.marketing .bs-coach-demo-pill--soft,
body.marketing .bs-coach-demo__url,
body.marketing .bs-coach-demo__nav,
body.marketing .bs-coach-demo-feed li,
body.marketing .bs-coach-demo-program,
body.marketing .bs-coach-demo-checkin,
body.marketing .bs-coach-demo-table-wrap,
body.marketing .bs-coach-demo-search,
body.marketing .bs-coach-demo-feed__icon {
  border-radius: var(--hp-r-xs);
}

body.marketing .bs-coach-demo__brand img {
  border-radius: var(--hp-r-xs);
}

body.marketing .bs-coach-demo__sidebar {
  border-radius: 0 0 0 var(--hp-r-md);
}

body.marketing .bs-coach-demo-page__meta span {
  border-radius: var(--bs-radius-pill);
}


/* ========== homepage-wow.css ========== */

/* BODYSCULPT homepage — fresh, cinematic “wow” layer */

/* ── Living ambient background ── */
body.marketing .k-ambient-orb--1 {
  animation: hp-orb-drift-1 22s ease-in-out infinite;
}

body.marketing .k-ambient-orb--2 {
  animation: hp-orb-drift-2 26s ease-in-out infinite;
}

body.marketing .k-ambient-orb--3 {
  animation: hp-orb-drift-3 20s ease-in-out infinite;
}

@keyframes hp-orb-drift-1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(6vw, 4vh) scale(1.06); }
  66% { transform: translate(2vw, -3vh) scale(0.96); }
}

@keyframes hp-orb-drift-2 {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(-5vw, 5vh); }
}

@keyframes hp-orb-drift-3 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(4vw, -4vh) scale(1.08); }
}

body.marketing .k-ambient-grid {
  animation: hp-grid-breathe 14s ease-in-out infinite;
}

@keyframes hp-grid-breathe {
  0%, 100% { opacity: var(--bs-ambient-strength, 1); }
  50% { opacity: calc(var(--bs-ambient-strength, 1) * 0.72); }
}

/* ── Hero — keynote scale ── */
body.marketing .hp-hero::before {
  background:
    radial-gradient(ellipse 85% 60% at 50% -8%, color-mix(in srgb, var(--bs-accent) 14%, transparent), transparent 58%),
    radial-gradient(ellipse 50% 45% at 92% 18%, rgba(52, 211, 153, 0.09), transparent 55%),
    radial-gradient(ellipse 40% 35% at 8% 35%, color-mix(in srgb, var(--bs-accent) 6%, transparent), transparent 50%);
}

body.marketing .hp-hero h1 {
  font-size: clamp(2.65rem, 7.2vw, 4.35rem);
  letter-spacing: -0.038em;
  line-height: 1.04;
  max-width: 15ch;
  text-wrap: balance;
}

body.marketing .hp-text-shine {
  display: inline-block;
  background: linear-gradient(
    120deg,
    var(--bs-accent-light) 0%,
    var(--bs-accent-dark) 38%,
    #34d399 72%,
    var(--bs-accent-light) 100%
  );
  background-size: 220% auto;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: hp-text-shine 7s ease-in-out infinite;
}

@keyframes hp-text-shine {
  0%, 100% { background-position: 0% center; }
  50% { background-position: 100% center; }
}

body.marketing .hp-hero-br {
  display: none;
}

@media (min-width: 640px) {
  body.marketing .hp-hero-br {
    display: block;
  }
}

/* Hero capability pills */
body.marketing .hp-hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  justify-content: center;
  margin: 0;
  padding: 0.85rem 0 0;
  list-style: none;
  max-width: 38rem;
}

body.marketing .hp-hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.42rem 0.9rem;
  border-radius: var(--bs-radius-pill);
  font-size: 0.76rem;
  font-weight: 650;
  letter-spacing: 0.01em;
  color: var(--bs-ink-soft, var(--bs-ink));
  border: 1px solid color-mix(in srgb, var(--bs-accent) 22%, var(--bs-border));
  background: color-mix(in srgb, var(--bs-bg-card) 78%, transparent);
  backdrop-filter: blur(14px) saturate(1.2);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent),
    0 6px 24px color-mix(in srgb, var(--bs-ink) 7%, transparent);
  transition: transform 0.35s var(--bs-ease-spring), border-color 0.3s, box-shadow 0.3s;
}

body.marketing .hp-hero-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--bs-accent-light), var(--bs-accent-dark));
  box-shadow: 0 0 8px color-mix(in srgb, var(--bs-accent) 45%, transparent);
}

body.marketing .hp-hero-pill:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--bs-accent) 45%, var(--bs-border));
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #fff 14%, transparent),
    0 10px 32px color-mix(in srgb, var(--bs-accent) 14%, transparent);
}

/* Primary CTA — shimmer */
body.marketing .hp-hero-actions .k-btn-primary,
body.marketing .hp-sticky-cta .k-btn-primary {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

body.marketing .hp-hero-actions .k-btn-primary::after,
body.marketing .hp-sticky-cta .k-btn-primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 35%,
    color-mix(in srgb, #fff 35%, transparent) 50%,
    transparent 65%
  );
  transform: translateX(-120%);
  animation: hp-btn-shimmer 4.5s ease-in-out infinite;
  pointer-events: none;
}

@keyframes hp-btn-shimmer {
  0%, 72% { transform: translateX(-120%); }
  100% { transform: translateX(120%); }
}

body.marketing .k-action-box .k-btn-primary {
  --mx: 50%;
  --my: 50%;
}

body.marketing .k-action-box .k-btn-primary::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(
    circle at var(--mx) var(--my),
    color-mix(in srgb, #fff 28%, transparent),
    transparent 55%
  );
  opacity: 0;
  transition: opacity 0.25s;
  pointer-events: none;
}

body.marketing .k-action-box .k-btn-primary:hover::before {
  opacity: 1;
}

/* ── Live preview — cinematic stack ── */
body.marketing .hp-live-preview {
  position: relative;
  z-index: 2;
}

body.marketing .hp-live-preview__head h2 {
  font-size: clamp(1.85rem, 4.2vw, 2.65rem);
  letter-spacing: -0.03em;
}

body.marketing .hp-showcase-spotlight {
  position: relative;
  margin-inline: auto;
  perspective: 1400px;
  transform-style: preserve-3d;
}

body.marketing .hp-showcase-aurora {
  position: absolute;
  inset: -18% -8% -12%;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(ellipse 55% 45% at 28% 42%, color-mix(in srgb, var(--bs-accent) 22%, transparent), transparent 68%),
    radial-gradient(ellipse 48% 52% at 72% 58%, rgba(52, 211, 153, 0.14), transparent 70%),
    radial-gradient(ellipse 35% 30% at 50% 90%, color-mix(in srgb, var(--bs-accent) 8%, transparent), transparent);
  filter: blur(36px);
  animation: hp-aurora-shift 14s ease-in-out infinite alternate;
}

@keyframes hp-aurora-shift {
  0% { transform: translate(0, 0) scale(1); opacity: 0.85; }
  100% { transform: translate(2%, -3%) scale(1.05); opacity: 1; }
}

body.marketing .hp-showcase-spotlight::before {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: calc(var(--hp-r-xl, 28px) + 2px);
  padding: 2px;
  background: conic-gradient(
    from 0deg,
    color-mix(in srgb, var(--bs-accent) 70%, transparent),
    transparent 22%,
    rgba(52, 211, 153, 0.55) 42%,
    transparent 62%,
    color-mix(in srgb, var(--bs-accent-light) 65%, transparent) 82%,
    transparent
  );
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: hp-border-spin 10s linear infinite;
  opacity: 0.75;
  z-index: 0;
  pointer-events: none;
}

@keyframes hp-border-spin {
  to { transform: rotate(360deg); }
}

body.marketing .hp-showcase-spotlight .hp-showcase-frame {
  position: relative;
  z-index: 1;
  box-shadow:
    0 1px 0 color-mix(in srgb, #fff 24%, transparent) inset,
    0 32px 80px color-mix(in srgb, var(--bs-ink) 12%, transparent),
    0 0 0 1px color-mix(in srgb, var(--bs-accent) 8%, transparent);
  transition: transform 0.12s ease-out;
  will-change: transform;
}

body.marketing.gsap-enhanced .hp-showcase-spotlight.is-floating {
  animation: hp-showcase-float 5.5s ease-in-out infinite;
}

@keyframes hp-showcase-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* Stats — glass + gradient numbers */
body.marketing .hp-stat {
  background: color-mix(in srgb, var(--bs-bg-card) 82%, transparent);
  backdrop-filter: blur(16px) saturate(1.25);
  border-color: color-mix(in srgb, var(--bs-accent) 12%, var(--bs-border));
  transition:
    transform 0.4s var(--bs-ease-spring),
    box-shadow 0.4s ease,
    border-color 0.3s;
}

body.marketing .hp-stat:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--bs-accent) 28%, var(--bs-border));
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent),
    0 16px 48px color-mix(in srgb, var(--bs-accent) 12%, transparent);
}

body.marketing .hp-stat-value {
  background: linear-gradient(
    145deg,
    var(--bs-ink) 0%,
    var(--bs-accent-dark) 55%,
    #34d399 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

body.marketing .hp-trust-band {
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--bs-bg-card) 55%, transparent),
      color-mix(in srgb, var(--bs-bg-card) 35%, transparent)
    );
  backdrop-filter: blur(8px);
}

body.marketing .hp-trust-chip {
  backdrop-filter: blur(10px);
  box-shadow: inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
}

/* Audience bar — subtle strip */
body.marketing .hp-audience-bar {
  background: color-mix(in srgb, var(--bs-bg-card) 18%, transparent);
  backdrop-filter: none;
  border-bottom-color: color-mix(in srgb, var(--bs-border) 45%, transparent);
}

body.marketing .hp-audience-link--cta {
  box-shadow: 0 8px 28px color-mix(in srgb, var(--bs-accent) 14%, transparent);
}

/* Feature blocks — glow on scroll-in */
body.marketing .hp-feature-visual {
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent),
    0 24px 64px color-mix(in srgb, var(--bs-ink) 10%, transparent),
    0 0 0 1px color-mix(in srgb, var(--bs-accent) 6%, transparent);
  transition: box-shadow 0.5s ease, transform 0.5s var(--bs-ease-spring);
}

body.marketing .hp-feature-visual:hover {
  transform: translateY(-3px);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent),
    0 32px 72px color-mix(in srgb, var(--bs-accent) 14%, transparent),
    0 0 0 1px color-mix(in srgb, var(--bs-accent) 14%, transparent);
}

body.marketing .hp-eyebrow {
  position: relative;
  display: inline-block;
}

body.marketing .hp-eyebrow::after {
  content: "";
  display: block;
  width: 2rem;
  height: 2px;
  margin: 0.45rem auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--bs-accent), #34d399);
  animation: hp-eyebrow-grow 1.2s var(--bs-ease-out) both;
}

body.marketing .hp-section-head .hp-eyebrow::after {
  margin-inline: auto;
}

@keyframes hp-eyebrow-grow {
  from { width: 0; opacity: 0; }
  to { width: 2rem; opacity: 1; }
}

/* Pricing cards pop */
body.marketing .k-price-card.is-featured,
body.marketing .k-price-card:has(.k-price-badge) {
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent),
    0 24px 64px color-mix(in srgb, var(--bs-accent) 16%, transparent),
    0 0 0 1px color-mix(in srgb, var(--bs-accent) 22%, transparent);
}

@media (prefers-reduced-motion: reduce) {
  body.marketing .k-ambient-orb,
  body.marketing .k-ambient-grid,
  body.marketing .hp-text-shine,
  body.marketing .hp-showcase-spotlight::before,
  body.marketing .hp-showcase-aurora,
  body.marketing .hp-hero-actions .k-btn-primary::after {
    animation: none !important;
  }

  body.marketing .hp-showcase-spotlight .hp-showcase-frame {
    transition: none;
  }
}


/* ========== homepage-organize.css ========== */

/* Homepage — layout, rhythm & visual organization */

body.marketing main {
  --hp-stack-xs: 0.5rem;
  --hp-stack-sm: 0.85rem;
  --hp-stack-md: 1.25rem;
  --hp-stack-lg: clamp(1.75rem, 3.5vw, 2.5rem);
  --hp-stack-xl: clamp(2.5rem, 5vw, 3.75rem);
  --hp-copy-max: 36rem;
  --hp-head-max: 34rem;
  --hp-demo-max: 920px;
}

/* ── Hero — clear vertical stack ── */
body.marketing .hp-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
  max-width: var(--hp-copy-max);
  margin-inline: auto;
}

body.marketing .hp-hero-brand {
  margin-bottom: var(--hp-stack-sm);
}

body.marketing .hp-hero-eyebrow {
  margin-bottom: var(--hp-stack-md);
}

body.marketing .hp-hero h1 {
  margin: 0 0 var(--hp-stack-md);
  max-width: 16ch;
}

body.marketing .hp-hero-lead {
  margin: 0 0 var(--hp-stack-md);
  max-width: var(--hp-copy-max);
}

body.marketing .hp-hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.65rem;
  width: 100%;
  max-width: 32rem;
  margin: 0 auto var(--hp-stack-sm);
}

body.marketing .hp-hero-actions {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

body.marketing .hp-hero-note {
  margin: 0;
  max-width: 32rem;
  line-height: 1.5;
}

body.marketing .hp-hero-pills {
  margin: 0;
  padding-top: var(--hp-stack-xs);
  border-top: 1px solid color-mix(in srgb, var(--bs-border) 55%, transparent);
  max-width: 100%;
}

/* ── Live preview — dedicated block ── */
body.marketing .hp-live-preview {
  margin-top: 0;
  padding-top: var(--hp-stack-lg);
  padding-bottom: var(--hp-stack-xl);
  border-top: 1px solid color-mix(in srgb, var(--bs-border) 50%, transparent);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bs-bg-card) 28%, transparent),
    transparent 45%
  );
}

body.marketing .hp-live-preview__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: min(100% - 2rem, var(--hp-demo-max));
  margin-inline: auto;
  gap: var(--hp-stack-md);
}

body.marketing .hp-live-preview__head {
  text-align: center;
  max-width: var(--hp-head-max);
  margin: 0;
}

body.marketing .hp-live-preview__inner .hp-app-features {
  width: 100%;
  margin-top: 0.25rem;
}

body.marketing .hp-live-preview__inner .hp-btn-row {
  width: 100%;
  margin-top: 0.15rem;
}

body.marketing .hp-showcase-frame__body {
  padding: clamp(0.85rem, 1.8vw, 1.15rem);
}

body.marketing .hp-dual-showcase--hero {
  gap: clamp(1rem, 2vw, 1.35rem);
  align-items: stretch;
}

body.marketing .hp-dual-device {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

body.marketing .hp-dual-label {
  flex-shrink: 0;
  margin-bottom: 0.5rem;
  text-align: center;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bs-muted);
}

body.marketing .hp-dual-device--coach,
body.marketing .hp-dual-device--app {
  align-items: stretch;
}

body.marketing .hp-dual-device--app {
  align-items: center;
}

body.marketing .hp-showcase-frame__foot {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.55rem 1rem 0.65rem;
}

/* ── Trust band — one tidy panel ── */
body.marketing .hp-trust-band .k-container {
  display: flex;
  flex-direction: column;
  gap: var(--hp-stack-sm);
}

body.marketing .hp-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
  margin: 0;
  padding: 0;
  width: 100%;
}

@media (min-width: 768px) {
  body.marketing .hp-stats {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

body.marketing .hp-stat {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 4.5rem;
  text-align: center;
}

body.marketing .hp-trust-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.45rem 0.65rem;
  padding-top: 0.15rem;
  border-top: 1px solid color-mix(in srgb, var(--bs-border) 45%, transparent);
}

/* ── Audience bar ── */
body.marketing .hp-audience-bar .k-container {
  padding-block: 0.15rem;
}

body.marketing .hp-audience-nav {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
}

@media (min-width: 768px) {
  body.marketing .hp-audience-nav {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

body.marketing .hp-audience-link {
  min-height: 3.25rem;
}

body.marketing .hp-audience-text {
  text-align: left;
}

/* ── Section heads — aligned center column ── */
body.marketing .hp-section-head {
  text-align: center;
  max-width: var(--hp-head-max);
  margin-inline: auto;
  margin-bottom: var(--hp-stack-lg);
}

body.marketing .hp-section > .k-container:not(:last-child) {
  margin-bottom: var(--hp-stack-md);
}

/* ── Feature rows — copy + visual grid ── */
body.marketing .hp-feature {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--hp-stack-lg);
  align-items: center;
  max-width: 100%;
}

@media (min-width: 900px) {
  body.marketing .hp-feature {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(2rem, 4vw, 3rem);
  }

  body.marketing .hp-feature--reverse .hp-feature-visual {
    order: -1;
  }
}

body.marketing .hp-feature-copy {
  max-width: var(--hp-copy-max);
}

@media (min-width: 900px) {
  body.marketing .hp-feature-copy {
    max-width: none;
  }

  body.marketing .hp-feature:not(.hp-feature--reverse) .hp-feature-copy {
    padding-right: 0.5rem;
  }

  body.marketing .hp-feature--reverse .hp-feature-copy {
    padding-left: 0.5rem;
  }
}

body.marketing .hp-feature-visual {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 0;
}

body.marketing .hp-feature-visual--phone {
  padding: 0.5rem;
}

body.marketing .hp-checklist {
  margin-bottom: var(--hp-stack-md);
}

body.marketing .hp-btn-row {
  margin-top: 0.25rem;
}

/* ── Sub-grids inside sections ── */
body.marketing .hp-coach-highlights,
body.marketing .hp-client-features {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
  margin-top: var(--hp-stack-md);
}

@media (min-width: 768px) {
  body.marketing .hp-coach-highlights {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  body.marketing .hp-client-features {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

body.marketing .hp-coach-highlight,
body.marketing .hp-client-feature {
  height: 100%;
  display: flex;
  flex-direction: column;
}

body.marketing .hp-steps {
  display: grid;
  gap: 0.75rem;
}

@media (min-width: 900px) {
  body.marketing .hp-steps {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
  }
}

body.marketing .hp-step {
  display: flex;
  flex-direction: column;
  height: 100%;
}

body.marketing .hp-step-link {
  margin-top: auto;
}

body.marketing .hp-day-one-track {
  display: grid;
  gap: 0.65rem;
}

@media (min-width: 768px) {
  body.marketing .hp-day-one-track {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1100px) {
  body.marketing .hp-day-one-track {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

body.marketing .hp-day-one-track li {
  height: 100%;
}

/* ── Pricing & social proof grids ── */
body.marketing .hp-triple {
  display: grid;
  gap: 0.75rem;
}

@media (min-width: 768px) {
  body.marketing .hp-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
  }
}

body.marketing .hp-triple-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

body.marketing .hp-social-proof-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

@media (min-width: 600px) {
  body.marketing .hp-social-proof-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 960px) {
  body.marketing .hp-social-proof-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* ── Section spacing overrides (clean rhythm) ── */
body.marketing .hp-section {
  padding-block: var(--hp-stack-xl);
}

body.marketing .hp-hero.hp-section {
  padding-bottom: var(--hp-stack-md);
}

body.marketing .hp-trust-band {
  padding-block: var(--hp-stack-md);
}

/* Tone down wow overlap for clarity */
body.marketing .hp-showcase-spotlight::before {
  display: none;
}

body.marketing .hp-showcase-aurora {
  opacity: 0.35;
}

body.marketing .hp-hero-eyebrow {
  box-shadow: none;
  border: none;
  background: transparent;
  padding: 0;
  border-radius: 0;
}

body.marketing .hp-trust-band {
  background: transparent;
  backdrop-filter: none;
}

body.marketing .hp-section--alt {
  background: color-mix(in srgb, var(--bs-bg-card) 22%, transparent);
}

@media (max-width: 639px) {
  body.marketing .hp-hero-actions .k-btn {
    flex: 1 1 calc(50% - 0.35rem);
    min-width: 9.5rem;
    justify-content: center;
  }

  body.marketing .hp-hero-actions .k-btn-ghost {
    flex: 1 1 100%;
  }

  body.marketing .hp-hero h1 {
    font-size: clamp(2.1rem, 9vw, 2.65rem);
    max-width: none;
  }
}

/* ── Clarity — flat hierarchy, selective surfaces ── */

body.marketing main {
  --hp-surface-border: color-mix(in srgb, var(--bs-border) 72%, transparent);
  --hp-surface-r: var(--hp-r-md, 20px);
}

/* Open layout shells — no frames around whole sections */
body.marketing .hp-hero-copy,
body.marketing .hp-live-preview__inner,
body.marketing .hp-trust-band .k-container,
body.marketing .hp-audience-bar .k-container,
body.marketing .hp-section:not(.hp-hero):not(.hp-live-preview):not(.k-final-cta) > .k-container,
body.marketing .k-pricing.hp-section > .k-container,
body.marketing .k-final-cta > .k-container {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  border-radius: 0;
}

body.marketing main .hp-feature,
body.marketing .hp-section-head {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

/* Grid wrappers stay open */
body.marketing .hp-coach-highlights,
body.marketing .hp-client-features,
body.marketing .hp-why-grid,
body.marketing .hp-revenue-grid,
body.marketing .hp-convert-grid,
body.marketing .hp-social-proof-grid,
body.marketing .hp-steps,
body.marketing .hp-app-features,
body.marketing .k-pricing-grid {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

/* Stats — open grid, no outer panel */
body.marketing .hp-stats {
  gap: clamp(0.75rem, 2vw, 1.25rem);
  border: none;
  border-radius: 0;
  overflow: visible;
  background: transparent;
}

body.marketing .hp-stat {
  padding: 0;
  text-align: center;
}

@media (min-width: 768px) {
  body.marketing .hp-stat:not(:last-child) {
    border-right: none;
  }
}

@media (max-width: 767px) {
  body.marketing .hp-stat:nth-child(odd),
  body.marketing .hp-stat:nth-child(-n + 2) {
    border: none;
  }
}

/* Content blocks — open layout */
body.marketing .hp-coach-highlight,
body.marketing .hp-client-feature,
body.marketing .hp-why-item,
body.marketing .hp-founder,
body.marketing .hp-day-one,
body.marketing .hp-triple-card,
body.marketing .hp-revenue-card {
  padding: 0;
  border: none;
  box-shadow: none;
  background: transparent;
}

body.marketing .hp-coach-highlights {
  gap: clamp(0.85rem, 2vw, 1.25rem);
}

body.marketing .hp-coach-highlight strong {
  font-size: 0.92rem;
}

body.marketing .hp-coach-highlight span {
  font-size: 0.82rem;
}

/* Audience nav — bordered pill buttons, not card tiles */
body.marketing .hp-audience-link {
  padding: 0.65rem 1rem;
  border: 2px solid var(--bs-border-strong);
  background: var(--bs-bg-elevated);
  box-shadow: none;
}

body.marketing .hp-audience-link:hover {
  border-color: var(--bs-accent);
  background: var(--bs-accent-soft);
}

body.marketing .hp-audience-link--cta {
  border-color: color-mix(in srgb, var(--bs-accent-dark) 80%, #000);
  background: linear-gradient(160deg, var(--bs-accent-light) 0%, var(--bs-accent-dark) 100%);
  color: var(--bs-accent-text);
}

body.marketing .hp-audience-link--cta .hp-audience-text strong,
body.marketing .hp-audience-link--cta .hp-audience-text small {
  color: inherit;
}

body.marketing .hp-audience-link--cta .hp-audience-icon {
  background: color-mix(in srgb, #fff 18%, transparent);
}

/* Surfaces only where structure is needed */
body.marketing main :is(
  .hp-showcase-frame,
  .hp-convert-card,
  .hp-social-proof-card,
  .hp-compare-wrap,
  .k-price-card,
  .k-faq-item
) {
  border-radius: var(--hp-surface-r);
  border: 1px solid var(--hp-surface-border);
  box-shadow: 0 8px 28px color-mix(in srgb, var(--bs-ink) 4%, transparent);
}

body.marketing .hp-feature-visual {
  border: none;
  box-shadow: none;
  background: transparent;
}

body.marketing .hp-feature-visual:hover {
  box-shadow: none;
  transform: none;
}

/* Interactive chips = surrounded buttons */
body.marketing .hp-app-features li,
body.marketing .hp-mini-btn,
body.marketing .hp-showcase-hint-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0.45rem 0.95rem;
  font-weight: 650;
  border: 2px solid var(--bs-border-strong);
  background: var(--bs-bg-elevated);
  box-shadow: none;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, color 0.2s, transform 0.2s;
}

body.marketing .hp-app-features li:hover,
body.marketing .hp-mini-btn:hover,
body.marketing .hp-showcase-hint-chip:hover {
  border-color: var(--bs-accent);
  background: var(--bs-accent-soft);
  color: var(--bs-accent-dark);
}

body.marketing .hp-app-features li.is-active,
body.marketing .hp-app-features li[aria-current="true"] {
  border-color: color-mix(in srgb, var(--bs-accent-dark) 80%, #000);
  background: linear-gradient(160deg, var(--bs-accent-light) 0%, var(--bs-accent-dark) 100%);
  color: var(--bs-accent-text);
}

body.marketing .hp-step-link {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.45rem 0.95rem;
  border-radius: var(--bs-radius-pill);
  border: 2px solid var(--bs-border-strong);
  background: var(--bs-bg-elevated);
  text-decoration: none;
  transition: border-color 0.2s, background 0.2s, color 0.2s, transform 0.2s;
}

body.marketing .hp-step-link:hover {
  border-color: var(--bs-accent);
  background: var(--bs-accent-soft);
  color: var(--bs-accent-dark);
}

body.marketing .k-final-cta-inner {
  border: none;
  box-shadow: none;
  background: transparent;
}

/* Checklists & steps — typography, not boxes */
body.marketing .hp-checklist li,
body.marketing .hp-step,
body.marketing .hp-day-one-track li {
  border: none;
  box-shadow: none;
  background: transparent;
}

body.marketing .hp-checklist li {
  padding: 0;
}

/* Softer live preview separation */
body.marketing .hp-live-preview {
  border-top: none;
  background: transparent;
}

body.marketing .hp-live-preview__head .hp-eyebrow::after {
  margin-inline: auto;
}

@media (max-width: 639px) {
  body.marketing .hp-section {
    padding-block: var(--hp-stack-lg);
  }
}

/* Label lines — copy only, never boxed */
body.marketing .hp-hero-eyebrow,
body.marketing .hp-eyebrow {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}

/* ========== homepage-pro.css — professional coaching platform ========== */

body.marketing {
  --hp-coach-accent: #2563eb;
  --hp-coach-soft: color-mix(in srgb, #2563eb 10%, transparent);
  --hp-client-accent: var(--bs-accent-dark);
  --hp-client-soft: var(--bs-accent-soft);
  --bs-ambient-strength: 0.18;
  --bs-shadow-accent: 0 4px 16px color-mix(in srgb, var(--bs-accent) 22%, transparent);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) body.marketing {
    --bs-ambient-strength: 0.12;
  }
}

[data-theme="dark"] body.marketing {
  --bs-ambient-strength: 0.12;
}

/* Calm backdrop — no drifting orbs */
body.marketing .k-ambient-orb,
body.marketing .k-ambient-grid {
  animation: none !important;
  opacity: 0.35;
}

body.marketing .k-ambient-grid {
  opacity: 0.12;
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.15), transparent 85%);
}

/* Typography — confident studio tone */
body.marketing .hp-hero h1 {
  font-size: clamp(2.15rem, 4.8vw, 3.15rem);
  letter-spacing: -0.028em;
  line-height: 1.12;
  max-width: 22ch;
  font-weight: 600;
  text-wrap: balance;
}

body.marketing .hp-hero-lead {
  font-size: clamp(1.02rem, 1.85vw, 1.15rem);
  line-height: 1.72;
  color: var(--bs-muted);
  max-width: 38rem;
}

body.marketing .hp-hero-eyebrow {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  color: var(--bs-dim);
  margin-bottom: 0.85rem;
}

body.marketing .hp-hero-brand {
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  color: var(--bs-ink-soft);
  margin-bottom: 1rem;
}

body.marketing .hp-hero-note {
  font-size: 0.84rem;
  color: var(--bs-dim);
}

body.marketing .hp-text-shine {
  animation: none;
  background: none;
  -webkit-background-clip: unset;
  background-clip: unset;
  color: var(--bs-accent-dark);
}

body.marketing .hp-eyebrow::after {
  display: none;
}

body.marketing .hp-section-head h2,
body.marketing .k-testimonials h2,
body.marketing .k-pricing h2 {
  font-weight: 600;
  letter-spacing: -0.022em;
}

/* Buttons — restrained, studio-grade */
body.marketing .k-btn:hover {
  transform: translateY(-1px);
}

body.marketing .k-btn-primary {
  box-shadow: 0 2px 10px color-mix(in srgb, var(--bs-accent) 24%, transparent);
}

body.marketing .hp-hero-actions .k-btn-primary::after,
body.marketing .hp-sticky-cta .k-btn-primary::after {
  display: none;
}

/* Product preview — clean studio demo */
body.marketing .hp-showcase-aurora {
  display: none;
}

body.marketing .hp-showcase-spotlight::before {
  display: none;
}

body.marketing.gsap-enhanced .hp-showcase-spotlight.is-floating .hp-showcase-frame,
body.marketing .hp-showcase-spotlight .hp-showcase-frame {
  transform: none !important;
  animation: none !important;
}

body.marketing .hp-showcase-frame {
  border-color: color-mix(in srgb, var(--bs-border) 90%, transparent);
  box-shadow:
    0 1px 2px color-mix(in srgb, var(--bs-ink) 4%, transparent),
    0 16px 48px color-mix(in srgb, var(--bs-ink) 7%, transparent);
}

body.marketing .hp-showcase-frame__head {
  background: color-mix(in srgb, var(--bs-bg-elevated) 88%, var(--bs-bg-card));
}

body.marketing .hp-showcase-frame__badge {
  border: 1px solid color-mix(in srgb, var(--bs-accent) 22%, var(--bs-border));
  background: var(--bs-accent-soft);
  font-size: 0.6rem;
  letter-spacing: 0.06em;
}

body.marketing .hp-dual-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  font-size: 0.65rem;
  letter-spacing: 0.12em;
}

body.marketing .hp-dual-device--coach .hp-dual-label::before,
body.marketing .hp-dual-device--app .hp-dual-label::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}

body.marketing .hp-dual-device--coach .hp-dual-label::before {
  background: var(--hp-coach-accent);
  box-shadow: 0 0 0 3px var(--hp-coach-soft);
}

body.marketing .hp-dual-device--app .hp-dual-label::before {
  background: var(--hp-client-accent);
  box-shadow: 0 0 0 3px var(--hp-client-soft);
}

body.marketing .hp-dual-device--coach {
  padding-top: 0.15rem;
  border-top: 2px solid color-mix(in srgb, var(--hp-coach-accent) 35%, transparent);
}

body.marketing .hp-dual-device--app {
  padding-top: 0.15rem;
  border-top: 2px solid color-mix(in srgb, var(--hp-client-accent) 35%, transparent);
}

/* Trust metrics */
body.marketing .hp-trust-band {
  border-bottom: 1px solid color-mix(in srgb, var(--bs-border) 70%, transparent);
  padding-block: clamp(1.5rem, 3vw, 2rem);
}

body.marketing .hp-stat-value {
  font-family: var(--bs-font-display);
  font-size: clamp(1.45rem, 2.5vw, 1.85rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  background: none;
  -webkit-background-clip: unset;
  background-clip: unset;
  color: var(--bs-ink);
}

body.marketing .hp-stat-label {
  font-size: 0.82rem;
  color: var(--bs-muted);
  line-height: 1.45;
}

/* Audience paths — coach vs client */
body.marketing .hp-audience-bar {
  background: color-mix(in srgb, var(--bs-bg-card) 72%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--bs-border) 65%, transparent);
}

body.marketing .hp-audience-link {
  border-width: 1px;
  font-size: 0.88rem;
}

body.marketing .hp-audience-link--cta {
  background: var(--bs-bg-elevated);
  border-color: color-mix(in srgb, var(--bs-accent) 35%, var(--bs-border));
  color: var(--bs-ink);
}

body.marketing .hp-audience-link--cta .hp-audience-text strong,
body.marketing .hp-audience-link--cta .hp-audience-text small {
  color: inherit;
}

body.marketing .hp-audience-link--cta:hover {
  background: var(--bs-accent-soft);
  border-color: var(--bs-accent);
}

/* How-it-works steps */
body.marketing .hp-step {
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  border-top: 1px solid color-mix(in srgb, var(--bs-border) 60%, transparent);
  padding-top: 1.35rem;
}

body.marketing .hp-step-num {
  width: 1.85rem;
  height: 1.85rem;
  font-size: 0.82rem;
  font-weight: 700;
  background: var(--bs-bg-elevated);
  color: var(--bs-accent-dark);
  border: 2px solid color-mix(in srgb, var(--bs-accent) 35%, var(--bs-border));
  box-shadow: none;
}

body.marketing .hp-coach-highlight {
  border-left: 2px solid var(--hp-coach-accent);
  padding-left: 0.85rem;
  text-align: left;
}

body.marketing .hp-coach-highlight strong {
  font-size: 0.92rem;
  font-weight: 650;
}

body.marketing .hp-client-feature {
  text-align: left;
  padding-left: 0.15rem;
}

body.marketing .hp-client-feature-icon {
  width: 2.25rem;
  height: 2.25rem;
  display: grid;
  place-items: center;
  margin-bottom: 0.65rem;
  border-radius: 10px;
  background: var(--hp-client-soft);
  border: 1px solid color-mix(in srgb, var(--hp-client-accent) 20%, var(--bs-border));
}

/* Social proof — credible, not salesy */
body.marketing .k-testimonials h2 {
  text-align: center;
  max-width: 22ch;
  margin-inline: auto;
}

body.marketing .hp-social-proof-sub {
  text-align: center;
  max-width: 36rem;
  margin-inline: auto;
  color: var(--bs-muted);
}

body.marketing .hp-social-proof-card {
  background: var(--bs-bg-card);
  border: 1px solid color-mix(in srgb, var(--bs-border) 80%, transparent);
  box-shadow: 0 4px 20px color-mix(in srgb, var(--bs-ink) 4%, transparent);
}

body.marketing .hp-section--alt {
  background: color-mix(in srgb, var(--bs-bg-card) 55%, transparent);
}

body.marketing .hp-app-features li {
  font-size: 0.82rem;
  border-width: 1px;
}

body.marketing .hp-app-features li.is-active,
body.marketing .hp-app-features li[aria-current="true"] {
  background: var(--bs-accent-soft);
  color: var(--bs-accent-dark);
  border-color: color-mix(in srgb, var(--bs-accent) 40%, var(--bs-border));
}

@media (min-width: 900px) {
  body.marketing .hp-hero h1 {
    max-width: 20ch;
  }
}

/* ========== Light · open layout · soft rounded buttons ========== */

body.marketing {
  --bs-shadow-accent: 0 4px 14px color-mix(in srgb, var(--bs-accent) 26%, transparent);
}

body.marketing .k-ambient {
  display: none;
}

body.marketing .hp-section--alt {
  background: var(--bs-bg-elevated);
}

body.marketing .hp-trust-band,
body.marketing .hp-audience-bar {
  background: var(--bs-bg);
}

/* Remove all content containers / boxes */
body.marketing main :is(
  .hp-showcase-frame,
  .hp-showcase-frame__head,
  .hp-showcase-frame__foot,
  .hp-showcase-frame__body,
  .hp-convert-card,
  .hp-social-proof-card,
  .hp-compare-wrap,
  .hp-panel,
  .hp-day-one,
  .hp-convert-grid input,
  .hp-convert-grid select
) {
  border: none;
  box-shadow: none;
  background: transparent;
  border-radius: 0;
}

body.marketing .bs-coach-demo__browser {
  border: none;
  box-shadow: 0 12px 40px color-mix(in srgb, var(--bs-ink) 8%, transparent);
  border-radius: var(--hp-r-md, 20px);
}

body.marketing .k-pricing-grid {
  gap: clamp(1.25rem, 3vw, 2rem);
}

body.marketing .k-price-card {
  padding: 0;
}

body.marketing .k-faq-item {
  border-bottom: 1px solid color-mix(in srgb, var(--bs-border) 55%, transparent);
}

body.marketing .k-faq-list {
  gap: 0;
}

body.marketing .hp-coach-highlight {
  border-left: none;
  padding-left: 0;
}

body.marketing .hp-client-feature-icon {
  border: none;
  border-radius: 50%;
  background: var(--hp-client-soft);
}

body.marketing .hp-dual-device--coach,
body.marketing .hp-dual-device--app {
  border-top: none;
  padding-top: 0;
}

body.marketing .hp-showcase-hints {
  margin: clamp(0.85rem, 2vw, 1.15rem) 0 0;
  text-align: center;
  font-size: 0.82rem;
  color: var(--bs-dim);
  line-height: 1.5;
}

body.marketing .hp-showcase-spotlight {
  width: 100%;
}

/* Rounded buttons — no box borders */
body.marketing :is(
  .k-btn,
  a.k-btn,
  .hp-audience-link,
  .hp-app-features li,
  .hp-step-link,
  .hp-showcase-hint-chip,
  .hp-mini-btn,
  .hp-quiz-option,
  .k-billing-toggle button,
  .k-theme-toggle,
  .k-menu-btn,
  .k-testimonial-slider-btn
) {
  border: none;
  box-shadow: none;
  border-radius: var(--bs-radius-pill);
}

body.marketing .hp-audience-link,
body.marketing .hp-app-features li,
body.marketing .hp-step-link,
body.marketing .hp-quiz-option {
  background: color-mix(in srgb, var(--bs-ink) 4%, transparent);
}

body.marketing .hp-audience-link:hover,
body.marketing .hp-app-features li:hover,
body.marketing .hp-step-link:hover,
body.marketing .hp-quiz-option:hover {
  background: var(--bs-accent-soft);
  color: var(--bs-accent-dark);
}

body.marketing .hp-app-features li.is-active,
body.marketing .hp-app-features li[aria-current="true"] {
  background: linear-gradient(160deg, var(--bs-accent-light) 0%, var(--bs-accent-dark) 100%);
  color: var(--bs-accent-text);
}

body.marketing .hp-audience-link--cta {
  background: linear-gradient(160deg, var(--bs-accent-light) 0%, var(--bs-accent-dark) 100%);
  color: var(--bs-accent-text);
}

body.marketing .hp-audience-link--cta .hp-audience-text strong,
body.marketing .hp-audience-link--cta .hp-audience-text small {
  color: inherit;
}

body.marketing .hp-audience-nav {
  gap: 0.65rem;
}

body.marketing .hp-sticky-cta-inner {
  background: color-mix(in srgb, var(--bs-bg) 88%, transparent);
  backdrop-filter: blur(12px);
  border-radius: var(--bs-radius-pill);
  box-shadow: 0 4px 24px color-mix(in srgb, var(--bs-ink) 10%, transparent);
}

body.marketing .k-btn:hover {
  transform: translateY(-1px);
}

body.marketing .k-btn-primary:hover {
  filter: brightness(1.04);
}

body.marketing .hp-social-proof-card {
  padding: 0;
  text-align: center;
}

body.marketing .hp-social-proof-icon {
  border: none;
  background: var(--bs-accent-soft);
  border-radius: 50%;
}

/* ========== Hero — crisp, clear CTAs ========== */

body.marketing .hp-hero {
  background: transparent;
  isolation: auto;
}

body.marketing .hp-hero::before {
  display: none;
}

body.marketing .hp-hero-copy {
  backdrop-filter: none;
  filter: none;
  opacity: 1;
}

body.marketing .hp-hero h1,
body.marketing .hp-hero-lead,
body.marketing .hp-hero-note,
body.marketing .hp-hero-eyebrow {
  text-shadow: none;
  opacity: 1;
  color: var(--bs-ink);
}

body.marketing .hp-hero-lead {
  color: var(--bs-muted);
}

body.marketing .hp-hero-note {
  color: var(--bs-dim);
}

body.marketing .hp-hero-eyebrow {
  color: var(--bs-dim);
}

body.marketing .hp-hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.65rem;
  margin: 0 auto;
  max-width: 36rem;
}

body.marketing .hp-hero-actions .k-btn {
  border-radius: var(--bs-radius-pill);
  border: none;
  min-height: 46px;
  padding: 0.7rem 1.35rem;
  font-size: 0.92rem;
  font-weight: 650;
  box-shadow: none;
}

body.marketing .hp-hero-actions .k-btn-primary {
  background: linear-gradient(160deg, var(--bs-accent-light) 0%, var(--bs-accent-dark) 100%);
  color: var(--bs-accent-text);
  box-shadow: 0 4px 14px color-mix(in srgb, var(--bs-accent) 28%, transparent);
}

body.marketing .hp-hero-actions .k-btn-outline {
  background: color-mix(in srgb, var(--bs-ink) 5%, transparent);
  color: var(--bs-ink);
}

body.marketing .hp-hero-actions .k-btn-outline:hover {
  background: var(--bs-accent-soft);
  color: var(--bs-accent-dark);
}

body.marketing .hp-hero-actions .k-btn-ghost {
  background: color-mix(in srgb, var(--bs-ink) 4%, transparent);
  color: var(--bs-ink);
}

body.marketing .hp-hero-actions .k-btn-ghost:hover {
  background: var(--bs-accent-soft);
  color: var(--bs-accent-dark);
}

@media (max-width: 639px) {
  body.marketing .hp-hero-actions .k-btn {
    flex: 1 1 calc(50% - 0.35rem);
    min-width: 10rem;
  }

  body.marketing .hp-hero-actions .k-btn-ghost {
    flex: 1 1 100%;
  }
}
