/**
 * ReadyToDeploy Front Page Styles
 * Redesigned homepage - separate CSS file
 * @version 7.39.0 - UI audit: standardized buttons, radius, shadows with CSS variables
 */

/* ==========================================================================
   CSS VARIABLES
   ========================================================================== */

:root {
  /* Brand - aligned with Client Portal */
  --blue: #147aff;
  --blue-dark: #0d5fd9;
  --blue-ink: #054d9b;
  --blue-tint: rgba(20, 122, 255, 0.08);
  --blue-tint-2: rgba(20, 122, 255, 0.04);

  /* Block/Ink from logo */
  --ink: #0f172a;
  --ink-2: #1e293b;
  --ink-3: #475569;
  --block-darkest: #060605;
  --block-dark: #2d2d2c;
  --block-mid: #40403f;

  /* Surfaces */
  --paper: #ffffff;
  --paper-2: #f8fafc;
  --paper-3: #f1f5f9;
  --line: #e2e8f0;
  --line-2: #cbd5e1;

  /* Type */
  --text: #334155;
  --muted: #64748b;

  /* Semantic */
  --good: #10b981;
  --good-dark: #10b981;
  --good-tint: rgba(16, 185, 129, 0.08);
  --bad: #ef4444;
  --bad-tint: rgba(239, 68, 68, 0.1);
  --warn: #f59e0b;

  /* Radii - Brand: sharp geometric */
  --radius: 0;
  --radius-sm: 2px;
  --radius-md: 4px;
  --radius-lg: 6px;
  --radius-pill: 999px;

  /* Shadows - Brand: offset style */
  --shadow-sm: 2px 2px 0 var(--ink);
  --shadow-md: 3px 3px 0 var(--ink);
  --shadow-lg: 5px 5px 0 var(--ink);
  --shadow-primary: 3px 3px 0 var(--blue-dark);
  --shadow-primary-lg: 5px 5px 0 var(--blue-dark);

  /* Typography Scale */
  --fs-xs: 12px;
  --fs-sm: 14px;
  --fs-base: 16px;
  --fs-md: 18px;
  --fs-lg: 20px;
  --fs-xl: 24px;

  /* Font Weights */
  --fw-normal: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;

  /* Fonts */
  --f-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --f-disp: 'Space Grotesk', ui-sans-serif, system-ui, sans-serif;
  --f-mono: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  --f-hero: 'Chakra Petch', ui-sans-serif, system-ui, sans-serif;
}

/* ==========================================================================
   BASE / RESET (scoped to front page)
   ========================================================================== */

.rtd-fp * { box-sizing: border-box; }
.rtd-fp { font-family: var(--f-sans); color: #334155; background: #ffffff !important; font-size: 16px; line-height: 1.6; -webkit-font-smoothing: antialiased; }
.rtd-fp a { color: inherit; text-decoration: none; }
.rtd-fp h1, .rtd-fp h2, .rtd-fp h3, .rtd-fp h4 { font-family: var(--f-disp); color: #0f172a; letter-spacing: -0.025em; line-height: 1.05; margin: 0; font-weight: 600; text-wrap: balance; }
.rtd-fp p { margin: 0; text-wrap: pretty; }
.rtd-fp img { max-width: 100%; display: block; }
.rtd-fp ::selection { background: #147aff; color: #fff; }

/* Force light backgrounds on light sections - override style.css */
/* All sections use same white for seamless flow - no visible lines */
.rtd-fp .hero,
.rtd-fp .proof,
.rtd-fp .product,
.rtd-fp .tl,
.rtd-fp .pricing,
.rtd-fp .who,
.rtd-fp .faq,
.rtd-fp .salon-types,
.rtd-fp .own {
  background-color: #ffffff !important;
}
/* Dark sections - keep dark gradient backgrounds */
.rtd-fp .cmd,
.rtd-fp .final {
  background: #0f172a !important;
}
.rtd-fp .cmd::before {
  content: ""; position: absolute; top: -300px; right: -200px; width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(20, 122, 255, .18), transparent 60%) !important;
  pointer-events: none;
}
.rtd-fp .final::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse 800px 500px at 50% 120%, rgba(20, 122, 255, .3), transparent 60%) !important;
  pointer-events: none;
}

.rtd-fp .wrap { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.rtd-fp .wrap--narrow { max-width: 880px; }

/* ==========================================================================
   KICKER (section labels)
   ========================================================================== */

.kick {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--f-disp); font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-3); font-weight: 600;
  margin-bottom: 20px;
}
.kick::before { content: ""; width: 24px; height: 2px; background: var(--blue); }
.kick--light { color: #a8a6a0; }
.kick--light::before { background: #71b5ff; }

/* ==========================================================================
   HEADER
   ========================================================================== */

.hd {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.hd__inner { display: flex; align-items: center; gap: 28px; height: 68px; max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.hd__logo { display: flex; align-items: center; gap: 10px; font-family: var(--f-hero); font-weight: 700; color: var(--ink); font-size: 18px; letter-spacing: 0.02em; text-transform: uppercase; }
.hd__logo svg { height: 30px; width: auto; }
.hd__logo em { font-style: normal; color: var(--blue); }
.hd__nav { display: flex; gap: 26px; margin-left: auto; }
.hd__nav a { font-size: 14px; font-weight: 500; color: var(--text); transition: color .15s; }
.hd__nav a:hover { color: var(--blue); }
.hd__cta { display: flex; align-items: center; gap: 12px; }
.hd__lang { width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 0; font-family: var(--f-disp); font-size: 11px; font-weight: 600; letter-spacing: .06em; color: var(--text); }
.hd__acct { width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--line); border-radius: 0; color: var(--text); }

/* Header logo line-draw animation */
.hdr-strokes polygon { stroke-dasharray: 500; stroke-dashoffset: 0; }
.hdr-stroke-left { animation: hdrDrawLine 6s ease-out infinite; }
.hdr-stroke-right { animation: hdrDrawLine 6s ease-out infinite .2s; }
.hdr-stroke-bottom { animation: hdrDrawLine 6s ease-out infinite .4s; }
.hdr-fills g { opacity: 1; }
.hdr-fill-left { animation: hdrFadeInFill 6s ease-out infinite .5s; }
.hdr-fill-right { animation: hdrFadeInFill 6s ease-out infinite .6s; }
.hdr-fill-bottom { animation: hdrFadeInFill 6s ease-out infinite .7s; }
.hdr-fill-center { animation: hdrFadeInFillGlow 6s ease-out infinite .9s; }

@keyframes hdrDrawLine {
  0%, 5% { stroke-dashoffset: 500; opacity: 0; }
  10% { opacity: 1; }
  25% { stroke-dashoffset: 0; }
  85% { stroke-dashoffset: 0; opacity: 1; }
  95%, 100% { stroke-dashoffset: 0; opacity: 0; }
}
@keyframes hdrFadeInFill {
  0%, 8% { opacity: 0; }
  20%, 90% { opacity: 1; }
  95%, 100% { opacity: 1; }
}
@keyframes hdrFadeInFillGlow {
  0%, 12% { opacity: 0; filter: brightness(1); }
  22% { opacity: 1; filter: brightness(1.5) drop-shadow(0 0 10px rgba(20, 122, 255, .6)); }
  35%, 90% { opacity: 1; filter: brightness(1); }
  95%, 100% { opacity: 1; }
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */

.rtd-fp .btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  font-family: var(--f-disp); font-size: 13px; letter-spacing: .04em; text-transform: uppercase; font-weight: 600;
  border: 2px solid var(--ink); border-radius: var(--radius);
  background: #fff !important; color: var(--ink) !important; cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, background .12s;
  box-shadow: var(--shadow-md);
}
.rtd-fp .btn:hover { transform: translate(-2px, -2px); box-shadow: var(--shadow-lg); }
.rtd-fp .btn--primary { background: var(--blue) !important; color: #fff !important; border-color: var(--blue); box-shadow: var(--shadow-primary); }
.rtd-fp .btn--primary:hover { background: var(--blue-dark) !important; color: #fff !important; box-shadow: var(--shadow-primary-lg); }
.rtd-fp .btn--fresha { background: #fff !important; color: var(--ink) !important; border-color: var(--ink); box-shadow: var(--shadow-md); }
.rtd-fp .btn--fresha:hover { box-shadow: var(--shadow-lg); }
.rtd-fp .btn--fresha svg { color: var(--warn); }
.rtd-fp .btn--ghost { border-color: transparent; background: transparent !important; box-shadow: none; padding: 12px 8px; }
.rtd-fp .btn--ghost:hover { transform: none; box-shadow: none; color: var(--blue) !important; }
.rtd-fp .btn--sm { padding: 8px 16px; font-size: 11px; box-shadow: var(--shadow-sm); }
.rtd-fp .btn--sm:hover { box-shadow: var(--shadow-md); }
.rtd-fp .btn--sm.btn--primary { box-shadow: 2px 2px 0 var(--blue-dark); }
.rtd-fp .btn--sm.btn--primary:hover { box-shadow: var(--shadow-primary); }
.rtd-fp .btn--lg { padding: 14px 28px; font-size: 14px; }
.rtd-fp .btn--on-dark { background: #fff !important; color: #0f172a !important; border-color: #fff; box-shadow: var(--shadow-primary); }
.rtd-fp .btn--on-dark:hover { box-shadow: var(--shadow-primary-lg); }

/* ==========================================================================
   HERO
   ========================================================================== */

.rtd-fp .hero {
  position: relative;
  overflow: visible;
  background: #ffffff;
  min-height: calc(100vh - 68px);
  display: flex;
  align-items: center;
}

.rtd-fp .hero > .wrap {
  width: 100%;
  max-width: none;
  padding: 40px 80px 80px;
}

/* Hero 2-column layout: text LEFT, visual RIGHT — full bleed */
.rtd-fp .hero__grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 48px;
  align-items: start;
  position: relative;
  max-width: 1300px;
  margin: 0 auto;
}

.rtd-fp .hero__content {
  padding-top: 60px;
}

/* Mobile hero content padding is set in the main mobile block below */

/* Text column */
.rtd-fp .hero__content { }
.rtd-fp .hero__eyebrow { font-family: var(--f-sans); font-size: 14px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--blue); margin-bottom: 16px; }
.rtd-fp .hero h1 { font-family: var(--f-hero); font-size: clamp(48px, 6vw, 72px); line-height: 1.05; margin-bottom: 24px; letter-spacing: -0.02em; font-weight: 700; color: #0f172a; text-transform: uppercase; }
.rtd-fp .hero h1 em { font-style: normal; color: var(--blue); position: relative; display: inline-block; }
.rtd-fp .hero h1 em::after { content: ""; position: absolute; left: -2%; right: -2%; bottom: 4%; height: 16%; background: rgba(20, 122, 255, .15); z-index: -1; transform: skewX(-6deg); }

/* Typewriter cursor */
.rtd-typewriter__cursor {
  color: var(--blue);
  animation: blink 0.7s step-end infinite;
  font-weight: 300;
  margin-left: 2px;
}
.rtd-typewriter__cursor.is-done {
  animation-duration: 1.2s;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}
.rtd-fp .hero__lead { font-size: 20px; line-height: 1.5; color: #334155; max-width: 520px; margin-bottom: 24px; }
.rtd-fp .hero__sub { font-size: 14px; color: #64748b; margin-bottom: 28px; font-family: var(--f-disp); font-weight: 500; }
.rtd-fp .hero__cta { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 20px; }
.rtd-fp .hero__fine { font-size: 13px; color: #64748b; display: flex; gap: 8px; align-items: center; }
.rtd-fp .hero__fine b { color: #0f172a; font-weight: 600; }
.rtd-fp .hero__fine::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: #10b981; box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.08); }

/* Mobile CTAs - hidden on desktop, shown on mobile */
.rtd-fp .hero__cta--mobile,
.rtd-fp .hero__fine--mobile { display: none; }

@media (max-width: 767px) {
  .rtd-fp .hero__cta--desktop,
  .rtd-fp .hero__fine--desktop { display: none; }
  .rtd-fp .hero__cta--mobile { display: flex; }
  .rtd-fp .hero__fine--mobile { display: flex; }
}

/* ==========================================================================
   HERO STAGE — Right-side booking visual
   ========================================================================== */

.rtd-stage {
  position: relative;
  width: 100%;
  max-width: 900px;
  height: 720px;
  margin: 0 auto;
  isolation: isolate;
}

/* z=0 — blue hue backdrop behind phone */
.rtd-stage__glow {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(20, 122, 255, .14), transparent 55%),
    radial-gradient(ellipse at 30% 40%, rgba(20, 122, 255, .10), transparent 50%),
    radial-gradient(ellipse at 70% 60%, rgba(20, 122, 255, .08), transparent 50%);
  z-index: 0;
  pointer-events: none;
}

/* ==========================================================================
   VIDEO TILES
   ========================================================================== */

.rtd-tile {
  position: absolute;
  width: 260px;
  height: 260px;
  border: 2px solid var(--ink);
  border-radius: var(--radius);
  box-shadow: 7px 7px 0 var(--ink);
  overflow: hidden;
  background: #1a1a1a;
  animation: rtd-tile-breathe 5s ease-in-out infinite;
}

/* Tile A placeholder gradient — cool tones suggesting nails/polish */
.rtd-tile--a {
  background:
    radial-gradient(circle at 35% 35%, rgba(236, 72, 153, 0.3) 0%, transparent 55%),
    radial-gradient(circle at 70% 65%, rgba(139, 92, 246, 0.4) 0%, transparent 60%),
    linear-gradient(135deg, #1a0f1a 0%, #261426 100%);
  top: 30px;
  left: 0;
  transform: rotate(-3deg);
  z-index: 1;
}

/* Tile B placeholder gradient — warm tones suggesting hair/salon */
.rtd-tile--b {
  background:
    radial-gradient(circle at 30% 30%, rgba(245, 158, 11, 0.35) 0%, transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(180, 83, 9, 0.45) 0%, transparent 60%),
    linear-gradient(135deg, #1c1410 0%, #2a1810 100%);
  bottom: 30px;
  right: 0;
  transform: rotate(2.5deg);
  z-index: 3;
  animation-delay: -1.2s;
}

.rtd-tile video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Bottom dark gradient overlay for label legibility */
.rtd-tile__overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 50%;
  background: linear-gradient(to bottom,
    rgba(0, 0, 0, 0) 0%,
    rgba(0, 0, 0, 0.55) 100%);
  pointer-events: none;
}

/* Bottom-left category label */
.rtd-tile__label {
  position: absolute;
  left: 10px;
  bottom: 10px;
  font-family: var(--f-disp);
  font-size: 10px;
  font-weight: 600;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  z-index: 2;
}

/* Top-right time badge */
.rtd-tile__time {
  position: absolute;
  top: 8px;
  right: 8px;
  padding: 2px 5px;
  font-family: var(--f-disp);
  font-size: 9px;
  font-weight: 500;
  color: #fff;
  background: rgba(0, 0, 0, 0.5);
  border-radius: var(--radius);
  letter-spacing: 0.04em;
  z-index: 2;
}

@keyframes rtd-tile-breathe {
  0%, 100% { scale: 1; }
  50%      { scale: 1.015; }
}

/* ==========================================================================
   PHONE — z=2, dominant centerpiece
   ========================================================================== */

.rtd-phone-wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

.rtd-phone {
  position: relative;
  width: 320px;
  height: 640px;
  background: var(--ink);
  border-radius: 42px;
  padding: 12px;
  box-shadow:
    10px 10px 0 var(--blue-dark),
    0 0 0 0 rgba(20, 122, 255, 0);
  animation: rtd-phone-pulse 3.5s ease-in-out infinite;
}

@keyframes rtd-phone-pulse {
  0%, 100% {
    box-shadow:
      6px 6px 0 var(--blue-dark),
      0 0 0 0 rgba(20, 122, 255, 0);
  }
  50% {
    box-shadow:
      6px 6px 0 var(--blue-dark),
      0 0 0 5px rgba(20, 122, 255, 0.10);
  }
}

/* Phone screen - static mockup, no interactions */
.rtd-phone__screen {
  position: relative;
  width: 100%;
  height: 100%;
  background: #ffffff;
  border-radius: 30px;
  overflow: hidden;
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, sans-serif;
  pointer-events: none;
  cursor: default;
}
.rtd-phone__screen * {
  cursor: default !important;
}

/* Dynamic Island */
.rtd-phone__island {
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: 90px;
  height: 22px;
  background: var(--ink);
  border-radius: var(--radius-pill);
  z-index: 5;
}

/* iOS status bar */
.rtd-status {
  position: relative;
  height: 38px;
  padding: 12px 18px 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  z-index: 6;
}
.rtd-status__icons {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ==========================================================================
   BOOKING UI — inside phone screen
   ========================================================================== */

.rtd-screen-body {
  padding: 12px 14px 14px;
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, sans-serif;
  color: #0b0f17;
}

/* Header: Bella Studio brand lockup + close X */
.rtd-bk-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin: 0 0 16px;
}
.rtd-brand {
  display: flex;
  align-items: center;
  gap: 8px;
}
.rtd-brand__mark {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #f9e8ec 0%, #f3d4dc 100%);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: #b8556e;
}
.rtd-brand__name {
  font-size: 16px;
  font-weight: 700;
  color: #0b0f17;
  letter-spacing: -0.015em;
  line-height: 1;
  margin: 0;
}
.rtd-brand__sub {
  font-size: 10px;
  font-weight: 500;
  color: #6b7280;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-top: 2px;
}
.rtd-bk-head__close {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: #f5f5f7;
  border: none;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: #1f2937;
  cursor: pointer;
}

/* Category segmented control */
.rtd-cats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 3px;
  background: #f5f5f7;
  border-radius: 10px;
  margin-bottom: 14px;
}
.rtd-cat {
  padding: 7px 8px;
  border: none;
  border-radius: 8px;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: #6b7280;
  cursor: pointer;
}
.rtd-cat svg { display: block; opacity: 0.6; }
.rtd-cat.is-active {
  background: #fff;
  color: #0b0f17;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06), 0 0 0 0.5px rgba(0,0,0,0.04);
}
.rtd-cat.is-active svg { opacity: 1; }

/* Service rows */
.rtd-services {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.rtd-svc {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 11px;
  border: 1px solid #ececf0;
  border-radius: 10px;
  background: #fff;
}
.rtd-svc.is-selected {
  border-color: #0b0f17;
  background: #fff;
  box-shadow: 0 0 0 1px #0b0f17 inset;
}
.rtd-svc__radio {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  border: 1.5px solid #d1d5db;
  flex-shrink: 0;
  position: relative;
}
.rtd-svc.is-selected .rtd-svc__radio {
  border-color: #0b0f17;
  background: #0b0f17;
}
.rtd-svc.is-selected .rtd-svc__radio::after {
  content: "";
  position: absolute;
  inset: 3.5px;
  background: #fff;
  border-radius: 50%;
}
.rtd-svc__body { flex: 1; min-width: 0; }
.rtd-svc__name {
  font-size: 13px;
  font-weight: 600;
  color: #0b0f17;
  line-height: 1.2;
  letter-spacing: -0.005em;
}
.rtd-svc__meta {
  font-size: 10px;
  color: #6b7280;
  margin-top: 2px;
}
.rtd-svc__price {
  font-size: 13px;
  font-weight: 700;
  color: #0b0f17;
  flex-shrink: 0;
  letter-spacing: -0.01em;
}

/* Section label */
.rtd-screen__lbl {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 11px;
  font-weight: 600;
  color: #0b0f17;
  margin: 0 0 8px;
  letter-spacing: -0.005em;
}
.rtd-screen__lbl-month {
  font-size: 10px;
  font-weight: 500;
  color: #6b7280;
}

/* Date scroller */
.rtd-dates {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 4px;
  margin-bottom: 16px;
}
.rtd-date {
  padding: 7px 0 8px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid #ececf0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  color: #0b0f17;
}
.rtd-date__dow {
  font-size: 9px;
  font-weight: 600;
  color: #6b7280;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.rtd-date__num {
  font-size: 13.5px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
}
.rtd-date.is-selected {
  background: #0b0f17;
  border-color: #0b0f17;
  color: #fff;
}
.rtd-date.is-selected .rtd-date__dow { color: rgba(255,255,255,0.75); }

/* Time slots — 2-col */
.rtd-times {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  margin-bottom: 14px;
}
.rtd-time {
  padding: 9px 8px;
  border: 1px solid #ececf0;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 600;
  color: #0b0f17;
  background: #fff;
  text-align: center;
  letter-spacing: -0.005em;
}
.rtd-time.is-unavail {
  color: #c8ccd3;
  text-decoration: line-through;
  background: #f5f5f7;
  border-color: transparent;
}
.rtd-time.is-selected {
  background: #0b0f17;
  border-color: #0b0f17;
  color: #fff;
}

/* Sticky-feel CTA bar at bottom of screen */
.rtd-cta-bar {
  margin: 0 -14px -14px;
  padding: 12px 14px 14px;
  background: #fff;
  border-top: 1px solid #ececf0;
}
.rtd-cta-bar__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 9px;
}
.rtd-cta-bar__lbl {
  font-size: 10px;
  color: #6b7280;
  font-weight: 500;
  line-height: 1.3;
}
.rtd-cta-bar__lbl strong {
  display: block;
  color: #0b0f17;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 1px;
  letter-spacing: -0.005em;
}
.rtd-cta-bar__amount {
  font-size: 19px;
  font-weight: 700;
  color: #0b0f17;
  letter-spacing: -0.025em;
  line-height: 1;
}

/* Confirm button (inside phone) */
.rtd-confirm-btn {
  width: 100%;
  padding: 12px;
  background: #0b0f17;
  color: #fff;
  border: none;
  border-radius: 11px;
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.rtd-confirm-btn svg { display: block; }

/* ==========================================================================
   NOTIFICATION — z=4, animated booking-confirmed card
   ========================================================================== */

.rtd-notif {
  position: absolute;
  top: 36%;
  right: 8px;
  width: 198px;
  padding: 10px 12px;
  background: #fff;
  border: 1.5px solid var(--ink);
  border-radius: var(--radius);
  box-shadow: 4px 4px 0 var(--good-dark);
  z-index: 10;
  transform-origin: right center;
  animation: rtd-notif-slide 7s ease-in-out infinite;
}

.rtd-notif__head {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
}
.rtd-notif__icon {
  width: 14px;
  height: 14px;
  background: var(--good);
  border-radius: 2px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.rtd-notif__icon svg { display: block; }
.rtd-notif__kicker {
  font-family: var(--f-disp);
  font-size: 8px;
  font-weight: 600;
  color: var(--good-dark);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.rtd-notif__name {
  font-family: var(--f-disp);
  font-size: 12px;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 1px;
}
.rtd-notif__meta {
  font-family: var(--f-sans);
  font-size: 9px;
  color: var(--muted);
  margin: 0;
}

/* Slide in from right edge — settle, hold, exit right */
@keyframes rtd-notif-slide {
  0%   { opacity: 0; transform: translateX(110%) scale(0.92) rotate(-2.5deg); }
  10%  { opacity: 1; transform: translateX(-6%)  scale(1.04) rotate(-2.5deg); }
  16%  { opacity: 1; transform: translateX(0)    scale(1)    rotate(-2.5deg); }
  80%  { opacity: 1; transform: translateX(0)    scale(1)    rotate(-2.5deg); }
  100% { opacity: 0; transform: translateX(40%)  scale(0.96) rotate(-2.5deg); }
}

/* ==========================================================================
   HERO STAGE RESPONSIVE
   ========================================================================== */

@media (max-width: 1024px) {
  .rtd-fp .hero {
    min-height: auto;
  }
  .rtd-fp .hero__grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .rtd-fp .hero__content {
    text-align: center;
    max-width: 560px;
    margin: 0 auto;
  }
  .rtd-fp .hero__lead {
    margin-left: auto;
    margin-right: auto;
  }
  .rtd-fp .hero__cta {
    justify-content: center;
  }
  .rtd-fp .hero__fine {
    justify-content: center;
  }
}

/* Reduced motion — kill all animations, show static state */
@media (prefers-reduced-motion: reduce) {
  .rtd-tile,
  .rtd-phone,
  .rtd-notif {
    animation: none !important;
  }
  .rtd-notif {
    opacity: 1;
    transform: translateX(0) rotate(-2.5deg);
  }
}

/* ==========================================================================
   PROOF STRIP
   ========================================================================== */

.proof {
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: 24px 0; background: var(--paper);
}
.proof__row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; align-items: center; }
.proof__item { display: flex; align-items: center; gap: 14px; }
.proof__num { font-family: var(--f-disp); font-size: 30px; font-weight: 700; color: var(--ink); line-height: 1; letter-spacing: -0.02em; }
.proof__label { font-size: 13px; color: var(--muted); line-height: 1.35; }
.proof__label b { color: var(--ink); font-weight: 600; display: block; font-family: var(--f-disp); font-size: 13px; letter-spacing: .02em; }

/* ==========================================================================
   SECTIONS (common)
   ========================================================================== */

.rtd-fp section { padding: 100px 0; }
.sect-head { margin-bottom: 56px; max-width: 720px; }
.sect-head--center { margin-left: auto; margin-right: auto; text-align: center; }
.sect-head--center .kick { justify-content: center; }
.sect-head h2 { font-family: var(--f-hero); font-size: clamp(36px, 4.6vw, 56px); font-weight: 700; line-height: 1.02; letter-spacing: -0.03em; margin-bottom: 18px; text-transform: uppercase; }
.sect-head p { font-size: 18px; color: var(--muted); max-width: 560px; }
.sect-head--center p { margin-left: auto; margin-right: auto; }
.sect-head h2 em { font-style: normal; color: var(--blue); }

/* ==========================================================================
   PROBLEM SECTION (Comparison)
   ========================================================================== */

/* Problem section em = red (negative connotation) */
.problem .sect-head h2 em { color: var(--bad); }

.problem { background: #ffffff; position: relative; overflow: visible; }
.problem::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 700px 400px at 50% 30%, rgba(20, 122, 255, .08), transparent 55%),
    radial-gradient(ellipse 500px 300px at 80% 80%, rgba(20, 122, 255, .04), transparent 50%);
}
.problem > .wrap { position: relative; z-index: 2; }

/* "heavy" emphasis - red color for problem word */
[data-rd-emphasis="bad"] {
  font-style: normal;
  color: var(--bad);
}

/* Comparison table */
.compare__defs {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

/* Compare wrapper - positions logos relative to the box */
.compare-wrap {
  position: relative;
  max-width: 980px;
  margin: 0 auto;
}

/* Sub-overflow: Competitor logos flowing out from sides of the box */
.sub-overflow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}
.sub-overflow__logo {
  position: absolute;
  opacity: 0;
  filter: grayscale(100%);
  transition: transform 0.7s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.5s ease;
}

/* Left side logos - start inside, push out to left */
.sub-overflow__logo--1 {
  left: -60px;
  top: 12%;
  transform: translateX(80px) scale(0.7);
}
.sub-overflow__logo--2 {
  left: -80px;
  top: 45%;
  transform: translateX(100px) scale(0.7);
}
.sub-overflow__logo--3 {
  left: -60px;
  top: 78%;
  transform: translateX(80px) scale(0.7);
}

/* Right side logos - start inside, push out to right */
.sub-overflow__logo--4 {
  right: -60px;
  top: 12%;
  transform: translateX(-80px) scale(0.7);
}
.sub-overflow__logo--5 {
  right: -80px;
  top: 45%;
  transform: translateX(-100px) scale(0.7);
}
.sub-overflow__logo--6 {
  right: -60px;
  top: 78%;
  transform: translateX(-80px) scale(0.7);
}

/* Visible state - logos push OUT from the box (15% further) */
.sub-overflow.is-visible .sub-overflow__logo {
  opacity: 0.4;
}
.sub-overflow.is-visible .sub-overflow__logo--1 {
  transform: translateX(-60px) scale(1);
  transition-delay: 0.1s;
}
.sub-overflow.is-visible .sub-overflow__logo--2 {
  transform: translateX(-90px) scale(1);
  transition-delay: 0.2s;
}
.sub-overflow.is-visible .sub-overflow__logo--3 {
  transform: translateX(-60px) scale(1);
  transition-delay: 0.3s;
}
.sub-overflow.is-visible .sub-overflow__logo--4 {
  transform: translateX(60px) scale(1);
  transition-delay: 0.15s;
}
.sub-overflow.is-visible .sub-overflow__logo--5 {
  transform: translateX(90px) scale(1);
  transition-delay: 0.25s;
}
.sub-overflow.is-visible .sub-overflow__logo--6 {
  transform: translateX(60px) scale(1);
  transition-delay: 0.35s;
}

/* Strike animation - logos fade and drift further out */
.sub-overflow.is-struck .sub-overflow__logo {
  opacity: 0.15;
}
.sub-overflow.is-struck .sub-overflow__logo--1 { transform: translateX(-100px) scale(0.85); }
.sub-overflow.is-struck .sub-overflow__logo--2 { transform: translateX(-130px) scale(0.85); }
.sub-overflow.is-struck .sub-overflow__logo--3 { transform: translateX(-100px) scale(0.85); }
.sub-overflow.is-struck .sub-overflow__logo--4 { transform: translateX(100px) scale(0.85); }
.sub-overflow.is-struck .sub-overflow__logo--5 { transform: translateX(130px) scale(0.85); }
.sub-overflow.is-struck .sub-overflow__logo--6 { transform: translateX(100px) scale(0.85); }

/* Mobile: hide side logos (not enough space) */
@media (max-width: 1200px) {
  .sub-overflow {
    display: none;
  }
}

.compare {
  --rtd-blue: #147aff;
  --rtd-shadow: #054d9b;
  --rtd-highlight: #71b5ff;
  --strike-color: #ef4444;
  background: #fff; border: 2px solid var(--ink); border-radius: var(--radius-md);
  box-shadow: 8px 8px 0 var(--ink);
  overflow: hidden; position: relative;
  z-index: 2;
  /* Simple fade-up entrance */
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1), transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.compare.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ==========================================================================
   COMPARISON TABLE ANIMATION
   Strikethrough prices + RTD logo pop
   ========================================================================== */

/* Price cell - strikethrough animation */
.compare__bad {
  position: relative;
  transition: color 0.4s ease, opacity 0.4s ease;
}
.compare__bad::after {
  content: "";
  position: absolute;
  left: 50%;
  right: 50%;
  top: 50%;
  height: 2px;
  background: var(--strike-color);
  transform: translateY(-50%);
  transition: left 0.4s cubic-bezier(0.22, 1, 0.36, 1), right 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.compare__bad.is-struck {
  color: var(--muted);
  opacity: 0.5;
}
.compare__bad.is-struck::after {
  left: 10%;
  right: 10%;
}

/* RTD Logo - BURST OUT OF BOX animation */
.compare__good {
  overflow: visible !important; /* Allow logo to escape cell */
  position: relative;
  z-index: 1;
}
.compare__good.is-revealed {
  z-index: 10; /* Pop above other rows during animation */
}

.compare__rtd {
  flex-shrink: 0;
  position: relative;
  /* Initial state: hidden below, scaled down */
  transform: scale(0) translateY(30px);
  opacity: 0;
  filter: blur(4px);
  will-change: transform, opacity, filter;
}

/* The burst ring effect */
.compare__rtd::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 200%;
  height: 200%;
  transform: translate(-50%, -50%) scale(0);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(20, 122, 255, 0.4) 0%, transparent 70%);
  opacity: 0;
  pointer-events: none;
  z-index: -1;
}

/* Revealed state: burst upward and outward */
.compare__good.is-revealed .compare__rtd {
  transform: scale(1.15) translateY(-8px); /* Overshoot UP and OUT of box */
  opacity: 1;
  filter: blur(0);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1),
              opacity 0.3s ease-out,
              filter 0.3s ease-out;
  animation: rtd-settle 0.5s 0.35s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

/* Burst ring animation */
.compare__good.is-revealed .compare__rtd::before {
  animation: rtd-burst 0.5s ease-out forwards;
}

@keyframes rtd-settle {
  0% { transform: scale(1.15) translateY(-8px); }
  100% { transform: scale(1) translateY(0); }
}

@keyframes rtd-burst {
  0% {
    transform: translate(-50%, -50%) scale(0);
    opacity: 1;
  }
  100% {
    transform: translate(-50%, -50%) scale(2);
    opacity: 0;
  }
}

/* Footer strikethrough - animated line sweep */
.compare__foot-bad .amt {
  position: relative;
  display: inline-block;
  transition: opacity 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.compare__foot-bad .amt::after {
  content: "";
  position: absolute;
  left: 50%;
  right: 50%;
  top: 50%;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--strike-color) 10%, var(--strike-color) 90%, transparent);
  transform: translateY(-50%);
  transition: left 0.5s cubic-bezier(0.22, 1, 0.36, 1) 0.1s, right 0.5s cubic-bezier(0.22, 1, 0.36, 1) 0.1s;
}
.compare__foot-bad.is-struck .amt::after {
  left: -5%;
  right: -5%;
}
.compare__foot-bad.is-struck .amt {
  opacity: 0.4;
}

/* Footer $0 emphasis - scale + glow */
.compare__foot-good .amt {
  display: inline-block;
  transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), text-shadow 0.5s ease;
  will-change: transform;
}
.compare__foot-good.is-revealed .amt {
  transform: scale(1.1);
  text-shadow: 0 0 40px rgba(255, 255, 255, 0.6), 0 0 80px rgba(255, 255, 255, 0.3);
}

/* Reduced motion - instant states, no animation */
@media (prefers-reduced-motion: reduce) {
  .compare { opacity: 1; transform: none; transition: none; }
  .compare__bad { transition: none; }
  .compare__bad::after { transition: none; }
  .compare__bad.is-struck::after { left: 10%; right: 10%; }
  .compare__rtd {
    transform: scale(1) translateY(0) !important;
    opacity: 1 !important;
    filter: none !important;
    animation: none !important;
  }
  .compare__rtd::before { display: none; }
  .compare__foot-bad .amt::after { transition: none; }
  .compare__foot-bad.is-struck .amt::after { left: -5%; right: -5%; }
  .compare__foot-good .amt { transform: scale(1.1); transition: none; }
}

.compare__head { display: grid; grid-template-columns: 1.8fr 1fr 1.2fr; }
.compare__head > div { padding: 22px 24px; font-family: var(--f-disp); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; }
.compare__head-feat { background: var(--paper-2); color: var(--ink-3); border-right: 1px solid var(--line); }
.compare__head-bad { background: var(--paper-2); color: var(--bad); border-right: 1px solid var(--line); text-align: center; }
.compare__head-bad span { display: inline-block; padding: 4px 10px; background: var(--bad-tint); border-radius: var(--radius-sm); font-size: 10px; font-weight: 700; letter-spacing: .1em; }
.compare__head-good { background: var(--blue); color: #fff; text-align: center; position: relative; }
.compare__head-good span { display: inline-block; padding: 4px 10px; background: #fff; color: var(--blue); border-radius: var(--radius-sm); font-size: 10px; font-weight: 700; letter-spacing: .1em; }
.compare__row { display: grid; grid-template-columns: 1.8fr 1fr 1.2fr; border-top: 1px solid var(--line); transition: background 0.2s ease; }
.compare__row--highlight { background: rgba(20, 122, 255, 0.03); }
@media (hover: hover) { .compare__row:hover { background: var(--paper-2); } }
.compare__row > div { padding: 18px 24px; border-right: 1px solid var(--line); display: flex; align-items: center; gap: 12px; font-size: 15px; }
.compare__row > div:last-child { border-right: 0; }
.compare__feat { color: var(--ink); font-weight: 500; }
.compare__feat svg { color: var(--ink-3); flex-shrink: 0; }
.compare__bad { justify-content: center; color: var(--ink); font-family: var(--f-disp); font-weight: 500; font-size: 14px; font-variant-numeric: tabular-nums; text-align: center; flex-direction: column; }
.compare__bad strong { display: block; font-size: 15px; font-weight: 700; color: var(--bad); }
.compare__bad small { display: block; font-size: 11px; color: var(--muted); font-weight: 500; margin-top: 2px; }
.compare__good { justify-content: center; background: rgba(20, 122, 255, .04); flex-direction: column; }
.compare__good strong { display: block; font-size: 15px; font-weight: 700; color: var(--good); }
.compare__good small { display: block; font-size: 11px; color: var(--muted); font-weight: 500; margin-top: 2px; }
.compare__foot { display: grid; grid-template-columns: 1.8fr 1fr 1.2fr; border-top: 2px solid var(--ink); background: var(--ink); color: #fff; }
.compare__foot > div { padding: 24px; border-right: 1px solid #2f2e2c; }
.compare__foot > div:last-child { border-right: 0; }
.compare__foot-total { font-family: var(--f-disp); font-size: 14px; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; color: #c6c4bd; }
.compare__foot-bad .amt, .compare__foot-good .amt { display: block; font-family: var(--f-disp); font-size: 28px; font-weight: 700; letter-spacing: -0.02em; line-height: 1; }
.compare__foot-bad .per, .compare__foot-good .per { display: block; font-size: 12px; color: #8d8b83; margin-top: 4px; letter-spacing: .04em; text-transform: uppercase; font-weight: 600; }
.compare__foot-bad { color: #f87171; text-align: center; }
.compare__foot-bad .amt { color: #fca5a5; }
.compare__foot-good { background: var(--blue); text-align: center; }
.compare__foot-good .amt { color: #fff; }
.compare__foot-good .per { color: rgba(255, 255, 255, .8); }

/* ==========================================================================
   PRODUCT CAROUSEL
   ========================================================================== */

.product { background: var(--paper); position: relative; overflow: hidden; }
.product::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .35;
  background-image:
    linear-gradient(to right, rgba(20, 122, 255, .07) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(20, 122, 255, .07) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
}
.product::after {
  content: ""; position: absolute; bottom: 0; left: 0; right: 0; height: 200px; pointer-events: none;
  background:
    radial-gradient(ellipse 900px 400px at 90% 100%, rgba(20,122,255,.10), transparent 60%),
    radial-gradient(ellipse 700px 350px at 10% 100%, rgba(20,122,255,.06), transparent 60%);
}
.carousel { position: relative; max-width: 1180px; margin: 0 auto; }
.carousel__tabs {
  display: flex; gap: 4px; justify-content: center; margin-bottom: 48px; flex-wrap: wrap;
  padding: 6px; background: #fff; border: 1.5px solid var(--ink); border-radius: var(--radius-md);
  width: max-content; max-width: 100%; margin-left: auto; margin-right: auto;
  box-shadow: 4px 4px 0 var(--blue-dark);
}
.carousel__tab {
  appearance: none; background: transparent; border: 0; cursor: pointer;
  font-family: var(--f-disp); font-size: 13px; font-weight: 600; letter-spacing: .02em;
  color: var(--muted); padding: 10px 22px; border-radius: 2px;
  display: inline-flex; align-items: center; gap: 8px;
  transition: all .2s ease; white-space: nowrap;
}
.carousel__tab:hover { color: var(--ink); }
.carousel__tab .num { font-family: var(--f-mono); font-size: 10px; opacity: .55; letter-spacing: .1em; }
.carousel__tab.is-active { background: var(--ink); color: #fff; }
.carousel__tab.is-active .num { color: var(--blue); opacity: 1; }

.carousel__stage {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
  min-height: 580px;
}
.carousel__track { position: relative; }
.carousel__slide {
  position: absolute; inset: 0; opacity: 0; pointer-events: none;
  transform: translateY(14px);
  transition: opacity .4s ease, transform .4s ease;
}
.carousel__slide.is-active { position: relative; opacity: 1; pointer-events: auto; transform: none; }

.fslide__kick { display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-disp); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; font-weight: 700; color: var(--blue); margin-bottom: 20px; padding: 6px 12px; background: var(--blue-tint); border-radius: var(--radius-pill); }
.fslide__kick .dot { width: 5px; height: 5px; background: var(--blue); border-radius: 50%; animation: rtdPulse 2s ease-in-out infinite; }
@keyframes rtdPulse { 0%, 100% { opacity: .5; transform: scale(1); } 50% { opacity: 1; transform: scale(1.3); } }
.fslide h3 { font-size: 44px; margin: 0 0 18px; letter-spacing: -0.03em; line-height: 1.05; font-weight: 600; }
.fslide > p { color: var(--muted); font-size: 17px; line-height: 1.55; max-width: 460px; margin-bottom: 28px; }

/* Centered slide variant */
.fslide--centered {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 400px;
}
.fslide--centered h3 {
  font-size: clamp(36px, 5vw, 56px);
  max-width: 500px;
  margin-bottom: 24px;
}
.fslide--centered > p {
  font-size: 19px;
  max-width: 480px;
  margin: 0 auto;
}
.fslide__feats { list-style: none; padding: 0; margin: 0 0 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px 20px; }
.fslide__feats li { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--text); font-weight: 500; }
.fslide__feats li svg { flex-shrink: 0; margin-top: 2px; color: var(--blue); }
.fslide__meta { display: flex; gap: 24px; padding-top: 22px; border-top: 1px dashed var(--line); }
.fslide__meta-item .v { font-family: var(--f-disp); font-size: 22px; font-weight: 700; color: var(--ink); letter-spacing: -0.01em; line-height: 1; font-variant-numeric: tabular-nums; }
.fslide__meta-item .l { display: block; margin-top: 6px; font-size: 11px; color: var(--muted); font-family: var(--f-disp); letter-spacing: .1em; text-transform: uppercase; font-weight: 600; }

/* Device showcase */
.showcase {
  position: relative; min-height: 580px;
  display: flex; align-items: center; justify-content: center;
}
.showcase__backdrop {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 40% 50%, rgba(20, 122, 255, .14), transparent 60%),
    radial-gradient(ellipse at 70% 30%, rgba(20, 122, 255, .08), transparent 55%);
  pointer-events: none;
}
/* rtd-phone inside showcase - override hero absolute positioning */
.showcase .rtd-phone {
  position: relative;
  z-index: 2;
}
.showcase .rtd-phone__screen {
  pointer-events: auto;
  cursor: default;
}
.showcase .phone__slides {
  position: relative;
  width: 100%;
  height: 100%;
}

/* Phone mockup */
.phone {
  position: relative; width: 280px; height: 560px;
  background: #0f172a; border-radius: 38px; padding: 10px;
  box-shadow:
    0 30px 60px -20px rgba(15, 23, 42, .4),
    0 0 0 1.5px var(--ink),
    inset 0 0 0 1px rgba(255, 255, 255, .06);
  z-index: 2;
}
.phone__notch {
  position: absolute; top: 12px; left: 50%; transform: translateX(-50%);
  width: 110px; height: 26px; background: #0f172a; border-radius: var(--radius-pill); z-index: 3;
}
.phone__screen {
  width: 100%; height: 100%; background: #fff; border-radius: 28px;
  overflow: hidden; position: relative;
}
.phone__slides { position: relative; width: 100%; height: 100%; }
.phone__slide {
  position: absolute; inset: 0; opacity: 0; pointer-events: none;
  transition: opacity .4s ease;
}
.phone__slide.is-active { opacity: 1; pointer-events: auto; }

/* Phone UI atoms */
.ph-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 44px 18px 8px; font-family: var(--f-disp); font-size: 10px; font-weight: 700; color: var(--ink);
}
.ph-bar__right { display: flex; gap: 4px; align-items: center; }
.ph-bar__sig, .ph-bar__bat { display: inline-block; }
.ph-header { padding: 16px 20px 18px; border-bottom: 1px solid var(--line); display: flex; align-items: center; gap: 14px; }
.ph-header__logo { width: 36px; height: 36px; background: var(--ink); color: #fff; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-family: var(--f-disp); font-weight: 700; font-size: 16px; }
.ph-header__t { font-family: var(--f-disp); font-size: 17px; font-weight: 700; color: var(--ink); letter-spacing: -0.01em; }
.ph-header__s { font-size: 12px; color: var(--muted); margin-top: 2px; }

/* Site slide */
.ph-site__hero { padding: 22px; background: linear-gradient(180deg, #eff6ff, #fff); border-bottom: 1px solid var(--line); }
.ph-site__kicker { font-size: 11px; letter-spacing: .18em; color: var(--blue); font-weight: 700; text-transform: uppercase; margin-bottom: 8px; font-family: var(--f-disp); }
.ph-site__h { font-family: var(--f-disp); font-size: 26px; font-weight: 700; line-height: 1.05; letter-spacing: -0.02em; color: var(--ink); margin-bottom: 10px; }
.ph-site__p { font-size: 13px; color: var(--muted); line-height: 1.4; margin-bottom: 14px; }
.ph-site__btn { display: inline-block; padding: 10px 18px; background: var(--blue); color: #fff; font-family: var(--f-disp); font-size: 13px; font-weight: 700; border-radius: var(--radius-lg); }
.ph-site__img { height: 88px; background: linear-gradient(135deg, #cbd5e1, #e2e8f0); margin: 14px 14px 10px; border-radius: var(--radius-lg); position: relative; overflow: hidden; }
.ph-site__img::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, .5), transparent 50%); }
.ph-site__rows { padding: 0 14px 14px; display: flex; flex-direction: column; gap: 6px; }
.ph-site__row { height: 7px; background: var(--paper-2); border-radius: 2px; }
.ph-site__row:nth-child(1) { width: 70%; }
.ph-site__row:nth-child(2) { width: 90%; }
.ph-site__row:nth-child(3) { width: 50%; }

/* Booking slide */
.ph-book { padding: 18px 20px; }
.ph-book__tabs { display: flex; gap: 6px; margin-bottom: 16px; }
.ph-book__tab { flex: 1; text-align: center; padding: 10px 0; font-family: var(--f-disp); font-size: 12px; font-weight: 700; color: var(--muted); border-radius: var(--radius-lg); background: var(--paper-2); }
.ph-book__tab.is-on { background: var(--ink); color: #fff; }
.ph-book__month { font-family: var(--f-disp); font-size: 14px; font-weight: 700; margin-bottom: 12px; display: flex; justify-content: space-between; align-items: center; }
.ph-book__month span:last-child { font-size: 12px; color: var(--muted); }
.ph-book__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; margin-bottom: 16px; }
.ph-book__d { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-family: var(--f-mono); font-size: 11px; color: var(--text); border-radius: var(--radius-md); position: relative; }
.ph-book__d.dim { color: var(--muted); opacity: .4; }
.ph-book__d.on { background: var(--blue); color: #fff; font-weight: 700; }
.ph-book__d.has::after { content: ""; width: 3px; height: 3px; background: var(--blue); border-radius: 50%; position: absolute; margin-top: 16px; }
.ph-book__times { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.ph-book__time { padding: 12px 14px; border: 1px solid var(--line); border-radius: var(--radius-lg); display: flex; justify-content: space-between; align-items: center; font-size: 13px; }
.ph-book__time.on { border-color: var(--blue); background: var(--blue-tint); color: var(--blue); font-weight: 700; }
.ph-book__time span:first-child { font-family: var(--f-mono); font-weight: 600; color: var(--ink); }
.ph-book__time.on span:first-child { color: var(--blue); }

/* Clients slide */
.ph-cli { padding: 12px 14px; }
.ph-cli__search { background: var(--paper-2); border-radius: var(--radius-pill); padding: 7px 12px; font-size: 10px; color: var(--muted); margin-bottom: 10px; display: flex; align-items: center; gap: 6px; }
.ph-cli__list { display: flex; flex-direction: column; gap: 6px; }
.ph-cli__row { display: flex; align-items: center; gap: 10px; padding: 8px; border: 1px solid var(--line); border-radius: var(--radius-md); }
.ph-cli__row.on { border-color: var(--blue); background: var(--blue-tint); }
.ph-cli__av { width: 28px; height: 28px; border-radius: 50%; background: var(--ink); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--f-disp); font-weight: 700; font-size: 10px; flex-shrink: 0; }
.ph-cli__av--a { background: #1e40af; }
.ph-cli__av--b { background: #9f1239; }
.ph-cli__av--c { background: #065f46; }
.ph-cli__av--d { background: #7c2d12; }
.ph-cli__name { font-family: var(--f-disp); font-size: 11px; font-weight: 700; color: var(--ink); line-height: 1.1; }
.ph-cli__meta { font-size: 9px; color: var(--muted); margin-top: 2px; font-family: var(--f-mono); }
.ph-cli__tag { margin-left: auto; font-size: 8px; padding: 2px 6px; border-radius: var(--radius-sm); font-family: var(--f-disp); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.ph-cli__tag.vip { background: #fef3c7; color: #92400e; }
.ph-cli__tag.new { background: var(--blue-tint); color: var(--blue); }

/* Payments slide */
.ph-pay { padding: 14px 16px; }
.ph-pay__total { text-align: center; padding: 14px 0 12px; border-bottom: 1px dashed var(--line); margin-bottom: 12px; }
.ph-pay__total-l { font-size: 10px; color: var(--muted); font-family: var(--f-disp); letter-spacing: .08em; text-transform: uppercase; font-weight: 700; margin-bottom: 6px; }
.ph-pay__total-v { font-family: var(--f-disp); font-size: 32px; font-weight: 700; letter-spacing: -0.02em; color: var(--ink); font-variant-numeric: tabular-nums; }
.ph-pay__delta { font-size: 10px; color: var(--good); font-family: var(--f-mono); font-weight: 700; margin-top: 4px; }
.ph-pay__bars { display: flex; align-items: flex-end; gap: 4px; height: 70px; margin-bottom: 14px; padding: 0 4px; }
.ph-pay__bars div { flex: 1; background: var(--blue); border-radius: 2px 2px 0 0; opacity: .35; }
.ph-pay__bars div:nth-child(n+5) { opacity: .65; }
.ph-pay__bars div:last-child { opacity: 1; background: var(--blue); }
.ph-pay__list { display: flex; flex-direction: column; gap: 4px; }
.ph-pay__row { display: flex; justify-content: space-between; align-items: center; padding: 6px 0; font-size: 10px; border-bottom: 1px solid var(--paper-2); }
.ph-pay__row:last-child { border-bottom: 0; }
.ph-pay__row b { color: var(--ink); font-weight: 600; }
.ph-pay__row span { font-family: var(--f-mono); color: var(--good); font-weight: 700; font-variant-numeric: tabular-nums; }

/* Floating popups */
.float {
  position: absolute; z-index: 5;
  background: #fff; border: 1.5px solid var(--ink);
  box-shadow: 6px 6px 0 var(--blue-dark);
  border-radius: var(--radius-md); padding: 14px;
  font-size: 12px;
  animation: floatIn .5s ease-out both;
}
@keyframes floatIn {
  from { opacity: 0; transform: translateY(10px) scale(.96); }
  to { opacity: 1; transform: none; }
}
.float--speed { top: 10%; left: -20px; width: 190px; }
.float--mail { top: 18%; right: -30px; width: 220px; }
.float--sms { bottom: 28%; left: -40px; width: 200px; }
.float--square { bottom: 8%; right: -30px; width: 220px; }

.float__head { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; font-family: var(--f-disp); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; font-weight: 700; color: var(--muted); }
.float__head .ic { width: 18px; height: 18px; border-radius: var(--radius-md); background: var(--blue); color: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* Speed gauge */
.gauge { position: relative; width: 100%; aspect-ratio: 2/1; margin-bottom: 8px; }
.gauge svg { width: 100%; height: 100%; display: block; }
.gauge__num { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); font-family: var(--f-disp); font-weight: 700; font-size: 28px; color: var(--ink); letter-spacing: -0.02em; line-height: 1; }
.gauge__num sup { font-size: 12px; color: var(--muted); font-weight: 600; }
.float__sub { font-size: 11px; color: var(--muted); line-height: 1.4; text-align: center; }

/* Mail popup */
.float__mail-from { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.float__mail-from .av { width: 22px; height: 22px; border-radius: 50%; background: var(--blue); color: #fff; font-family: var(--f-disp); font-weight: 700; font-size: 10px; display: flex; align-items: center; justify-content: center; }
.float__mail-from b { font-family: var(--f-disp); font-size: 11px; font-weight: 700; color: var(--ink); }
.float__mail-from span { font-size: 9px; color: var(--muted); font-family: var(--f-mono); margin-left: auto; }
.float__mail-subj { font-family: var(--f-disp); font-size: 11px; font-weight: 700; color: var(--ink); margin-bottom: 4px; line-height: 1.3; }
.float__mail-body { font-size: 10px; color: var(--muted); line-height: 1.4; }
.float__mail-tail { position: absolute; left: -8px; top: 30px; width: 0; height: 0; border-top: 8px solid transparent; border-bottom: 8px solid transparent; border-right: 8px solid var(--ink); }

/* SMS */
.float--sms { padding: 12px; }
.sms__bubble { background: #eff6ff; border: 1px solid var(--blue-tint); color: var(--ink); padding: 8px 10px; border-radius: 12px 12px 12px 2px; font-size: 11px; line-height: 1.4; margin-bottom: 6px; }
.sms__bubble b { color: var(--blue); font-weight: 700; }
.sms__meta { display: flex; justify-content: space-between; font-size: 9px; color: var(--muted); font-family: var(--f-mono); }
.sms__status { color: var(--good); font-weight: 700; display: inline-flex; align-items: center; gap: 3px; }

/* Square */
.square__head { display: flex; align-items: center; gap: 8px; padding-bottom: 10px; border-bottom: 1px dashed var(--line); margin-bottom: 10px; }
.square__logo { width: 22px; height: 22px; background: #000; border-radius: var(--radius-sm); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--f-disp); font-weight: 900; font-size: 13px; }
.square__head b { font-family: var(--f-disp); font-size: 11px; font-weight: 700; color: var(--ink); }
.square__head span { margin-left: auto; font-size: 9px; color: var(--good); font-family: var(--f-mono); font-weight: 700; }
.square__amt { font-family: var(--f-disp); font-size: 26px; font-weight: 700; color: var(--ink); letter-spacing: -0.02em; line-height: 1; margin-bottom: 4px; font-variant-numeric: tabular-nums; }
.square__for { font-size: 10px; color: var(--muted); margin-bottom: 10px; }
.square__card { display: flex; align-items: center; gap: 8px; padding: 8px 10px; background: var(--paper-2); border-radius: var(--radius-sm); font-size: 10px; }
.square__card .brand { width: 28px; height: 18px; background: var(--ink); border-radius: 2px; color: #fff; font-family: var(--f-disp); font-weight: 900; font-size: 8px; display: flex; align-items: center; justify-content: center; letter-spacing: .02em; }
.square__card .num { font-family: var(--f-mono); color: var(--text); letter-spacing: .1em; }

/* Carousel controls */
.carousel__nav { display: flex; align-items: center; gap: 16px; margin-top: 40px; justify-content: center; }
.carousel__arrow {
  width: 44px; height: 44px; border: 1.5px solid var(--ink); background: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; border-radius: var(--radius-md); transition: all .15s ease;
  color: var(--ink);
}
.carousel__arrow:hover { background: var(--ink); color: #fff; transform: translateY(-1px); box-shadow: 3px 3px 0 var(--blue-dark); }
.carousel__progress { flex: 0 0 160px; height: 4px; background: var(--line); border-radius: var(--radius-pill); overflow: hidden; position: relative; }
.carousel__progress-bar { position: absolute; inset: 0; background: var(--blue); transform-origin: left; transform: scaleX(0); transition: transform .1s linear; }
.carousel__count { font-family: var(--f-mono); font-size: 12px; color: var(--muted); min-width: 40px; text-align: center; letter-spacing: .05em; }
.carousel__count b { color: var(--ink); font-weight: 700; }

/* ==========================================================================
   FEATURED DASHBOARD SECTION
   ========================================================================== */

/* Calendar color swatches */
.featdash {
  --cal-blue: #dbeafe;     --cal-blue-ink: #1e40af;
  --cal-cyan: #cffafe;     --cal-cyan-ink: #155e75;
  --cal-mint: #d1fae5;     --cal-mint-ink: #047857;
  --cal-yellow: #fef3c7;   --cal-yellow-ink: #92400e;
  --cal-peach: #fed7aa;    --cal-peach-ink: #9a3412;
  --cal-pink: #fbcfe8;     --cal-pink-ink: #9d174d;
  --cal-rose: #fecdd3;     --cal-rose-ink: #9f1239;
  --cal-violet: #ede9fe;   --cal-violet-ink: #5b21b6;
}

.featdash {
  position: relative;
  padding: 120px 0 130px;
  overflow: hidden;
  background: var(--paper);
}
.featdash::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 64px 64px;
  mask: radial-gradient(ellipse 1100px 700px at 50% 40%, #000 20%, transparent 70%);
  opacity: .30;
}

/* Blue hue glow behind dashboard */
.featdash::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 800px 500px at 50% 60%, rgba(20, 122, 255, .12), transparent 55%),
    radial-gradient(ellipse 400px 300px at 30% 40%, rgba(20, 122, 255, .08), transparent 50%);
  z-index: 0;
}
.featdash__head { position: relative; text-align: center; max-width: 760px; margin: 0 auto 56px; }
.featdash__kick {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--f-disp); font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-3); font-weight: 600;
  margin-bottom: 20px;
}
.featdash__kick::before { content: ""; width: 24px; height: 2px; background: var(--blue); }
.featdash__head h2 { font-family: var(--f-hero); font-size: clamp(36px, 4.4vw, 56px); font-weight: 700; letter-spacing: -0.03em; margin-bottom: 18px; text-transform: uppercase; }
.featdash__head h2 em { font-style: normal; color: var(--blue); position: relative; display: inline-block; }
.featdash__head h2 em::after { content: ""; position: absolute; left: -2%; right: -2%; bottom: 4%; height: 16%; background: rgba(20,122,255,.15); z-index: -1; transform: skewX(-6deg); }
.featdash__head p { font-size: 19px; color: var(--text); max-width: 580px; margin: 0 auto; line-height: 1.5; }

/* Stage holds desktop dashboard */
.featdash__stage {
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
}

/* Desktop frame */
.dashf {
  position: relative;
  background: #fff;
  border: 2px solid var(--ink);
  border-radius: var(--radius);
  box-shadow: 14px 14px 0 var(--blue-dark);
  overflow: hidden;
}
.dashf__top {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 22px;
  border-bottom: 1.5px solid var(--ink);
  background: #fff;
}
.dashf__logo {
  display: flex; align-items: center; gap: 10px;
}
.dashf__logo-svg {
  flex-shrink: 0;
}
.dashf__logo-text {
  font-family: 'Chakra Petch', var(--f-disp); font-weight: 700; font-size: 15px; color: var(--ink);
  letter-spacing: -0.02em; text-transform: uppercase;
}
.dashf__logo-text em { font-style: normal; color: var(--blue); }
.dashf__topright { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.dashf__icon {
  width: 32px; height: 32px; display: grid; place-items: center;
  color: var(--ink-3); position: relative; cursor: pointer;
}
.dashf__icon:hover { color: var(--blue); }
.dashf__badge {
  position: absolute; top: -2px; right: -2px;
  background: var(--blue); color: #fff;
  font-family: var(--f-disp); font-size: 10px; font-weight: 600;
  width: 16px; height: 16px; border-radius: 50%;
  display: grid; place-items: center;
  border: 1.5px solid #fff;
}
.dashf__avatar {
  width: 34px; height: 34px; border-radius: 50%;
  border: 1.5px solid var(--ink);
  background: linear-gradient(135deg, #fbcfe8 0%, #fed7aa 100%);
  position: relative; overflow: hidden;
}
.dashf__avatar::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 38%, #2d1e16 0 18%, transparent 19%),
             radial-gradient(ellipse at 50% 90%, #b08968 0 35%, transparent 36%);
}

/* Toolbar row */
.dashf__bar {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  border-bottom: 1.5px solid var(--ink);
  background: var(--paper-2);
  flex-wrap: nowrap;
}
.dashf__pill {
  display: inline-flex; align-items: center; gap: 6px;
  height: 32px; padding: 0 12px;
  background: #fff; border: 1.5px solid var(--ink); border-radius: var(--radius);
  font-family: var(--f-disp); font-size: 12px; font-weight: 600; color: var(--ink);
  letter-spacing: .02em; cursor: pointer;
  box-shadow: 2px 2px 0 var(--ink);
  transition: transform .1s, box-shadow .1s;
}
.dashf__pill:hover { transform: translate(-1px, -1px); box-shadow: 3px 3px 0 var(--ink); }
.dashf__pill .arrow { display: inline-flex; color: var(--ink-3); }
.dashf__pill--today { background: var(--ink); color: #fff; border-color: var(--ink); box-shadow: 2px 2px 0 var(--blue); }
.dashf__pill--today:hover { box-shadow: 3px 3px 0 var(--blue); }
.dashf__pill--icon { padding: 0 9px; }
.dashf__pill--ghost { background: transparent; border-color: var(--line-2); color: var(--ink-3); box-shadow: none; }
.dashf__pill--ghost:hover { background: #fff; color: var(--ink); border-color: var(--ink); box-shadow: 2px 2px 0 var(--ink); }
.dashf__navarrow {
  width: 24px; height: 24px; display: grid; place-items: center;
  border: 1.5px solid var(--line-2); background: #fff; color: var(--ink);
  border-radius: var(--radius); cursor: pointer;
}
.dashf__navarrow:hover { border-color: var(--ink); }
.dashf__bar-spacer { flex: 1; }
.dashf__pill--add {
  background: var(--blue); color: #fff; border-color: var(--blue);
  box-shadow: 2px 2px 0 var(--blue-dark); padding: 0 14px;
}
.dashf__pill--add:hover { box-shadow: 3px 3px 0 var(--blue-dark); background: var(--blue-dark); }

/* Body: sidebar + grid */
.dashf__body { display: grid; grid-template-columns: 56px 1fr; min-height: 540px; }

.dashf__side {
  background: var(--ink);
  border-right: 1.5px solid var(--ink);
  display: flex; flex-direction: column; align-items: center;
  padding: 14px 0; gap: 6px;
}
.dashf__side-item {
  width: 36px; height: 36px; display: grid; place-items: center;
  color: #94a3b8; border-radius: var(--radius); cursor: pointer;
  transition: background .12s, color .12s;
}
.dashf__side-item:hover { color: #fff; background: rgba(255,255,255,.08); }
.dashf__side-item--active { background: var(--blue); color: #fff; }
.dashf__side-item--active:hover { background: var(--blue); color: #fff; }
.dashf__side-divider { flex: 1; }

/* Calendar grid */
.dashf__cal { display: flex; flex-direction: column; background: #fff; overflow: hidden; }
.dashf__staff {
  display: grid; grid-template-columns: 60px repeat(5, 1fr);
  border-bottom: 1.5px solid var(--ink);
  background: #fff;
}
.dashf__staff-cell {
  padding: 14px 8px 12px;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  border-right: 1px solid var(--line);
  font-family: var(--f-disp); font-size: 12px; font-weight: 600; color: var(--ink);
}
.dashf__staff-cell:last-child { border-right: none; }
.dashf__staff-cell--time { border-right: 1.5px solid var(--ink); padding: 14px 4px; }
.dashf__avatar-sm {
  width: 42px; height: 42px; border-radius: 50%;
  border: 1.5px solid var(--ink);
  background: #e2e8f0; position: relative; overflow: hidden;
}
.dashf__avatar-sm.sophie { background: linear-gradient(135deg, #fbcfe8 0%, #f9a8d4 100%); }
.dashf__avatar-sm.maria { background: linear-gradient(135deg, #fde68a 0%, #fbbf24 100%); }
.dashf__avatar-sm.wendy { background: linear-gradient(135deg, #c7d2fe 0%, #818cf8 100%); }
.dashf__avatar-sm.amy { background: linear-gradient(135deg, #fed7aa 0%, #fb923c 100%); }
.dashf__avatar-sm.luc { background: linear-gradient(135deg, #bfdbfe 0%, #93c5fd 100%); }
.dashf__avatar-sm::after {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 50% 36%, var(--ink) 0 20%, transparent 21%),
    radial-gradient(ellipse at 50% 92%, rgba(15,23,42,.55) 0 38%, transparent 39%);
  opacity: .5;
}

/* Schedule grid: 5 staff cols x 9 rows (8am-4pm) */
.dashf__sched {
  position: relative;
  flex: 1;
  display: grid;
  grid-template-columns: 60px repeat(5, 1fr);
  grid-auto-rows: 62px;
  background:
    linear-gradient(var(--line) 1px, transparent 1px) 0 0/100% 62px;
}
.dashf__time {
  border-right: 1.5px solid var(--ink);
  border-bottom: 1px solid var(--line);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 6px;
  font-family: var(--f-mono); font-size: 10px; font-weight: 500; color: var(--muted);
  text-align: center; line-height: 1.2;
}
.dashf__time small { display: block; font-size: 9px; opacity: .7; }
.dashf__col {
  border-right: 1px solid var(--line);
  position: relative;
}
.dashf__col:last-child { border-right: none; }

/* Appointment cards */
.appt {
  position: absolute;
  left: 4px; right: 4px;
  border: 1.5px solid var(--ink);
  border-radius: var(--radius);
  padding: 7px 8px 6px;
  background: var(--cal-yellow);
  color: var(--cal-yellow-ink);
  box-shadow: 2px 2px 0 var(--ink);
  overflow: hidden;
  transition: transform .12s, box-shadow .12s;
  cursor: pointer;
}
.appt:hover { transform: translate(-1px, -1px); box-shadow: 3px 3px 0 var(--ink); }
.appt__time {
  font-family: var(--f-mono); font-size: 9px; font-weight: 500;
  opacity: .85; letter-spacing: .01em;
  margin-bottom: 2px;
}
.appt__name {
  font-family: var(--f-disp); font-size: 12px; font-weight: 600; line-height: 1.15;
  letter-spacing: -0.01em; color: var(--ink);
  margin-bottom: 1px;
}
.appt__svc {
  font-size: 10px; font-weight: 500; line-height: 1.25; opacity: .78;
}
.appt--blue { background: var(--cal-blue); color: var(--cal-blue-ink); }
.appt--cyan { background: var(--cal-cyan); color: var(--cal-cyan-ink); }
.appt--mint { background: var(--cal-mint); color: var(--cal-mint-ink); }
.appt--peach { background: var(--cal-peach); color: var(--cal-peach-ink); }
.appt--pink { background: var(--cal-pink); color: var(--cal-pink-ink); }
.appt--rose { background: var(--cal-rose); color: var(--cal-rose-ink); }
.appt--violet { background: var(--cal-violet); color: var(--cal-violet-ink); }

@media (max-width: 767px) {
  .featdash { padding: 80px 0 100px; }
  .featdash__head { margin-bottom: 40px; }
  .featdash__head p { font-size: 17px; }
  .dashf__bar { overflow-x: auto; padding: 10px 16px; }
  .dashf__body { grid-template-columns: 1fr; }
  .dashf__side { display: none; }
  .dashf__staff { grid-template-columns: 50px repeat(5, minmax(70px, 1fr)); overflow-x: auto; }
  .dashf__sched { grid-template-columns: 50px repeat(5, minmax(70px, 1fr)); overflow-x: auto; }
  .featdash__caption { margin-top: 48px; }
}

/* ==========================================================================
   TIMELINE
   ========================================================================== */

.tl { background: transparent; }
.tl__steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: 22px; position: relative; }
.tl__line { position: absolute; top: 28px; left: 28px; right: calc(20% - 28px); height: 2px; background: repeating-linear-gradient(to right, var(--ink) 0 8px, transparent 8px 16px); z-index: 0; }
.tl__step { position: relative; z-index: 1; }
.tl__num { width: 56px; height: 56px; border-radius: var(--radius-md); background: #fff; border: 2px solid var(--ink); display: flex; align-items: center; justify-content: center; font-family: var(--f-disp); font-weight: 700; font-size: 18px; color: var(--ink); margin-bottom: 20px; box-shadow: 3px 3px 0 var(--blue-dark); position: relative; }
.tl__step:nth-child(1) .tl__num { background: var(--blue); color: #fff; border-color: var(--blue-dark); }
.tl__step:last-child .tl__num { background: var(--ink); color: #fff; border-color: var(--ink); box-shadow: 3px 3px 0 var(--blue); }
.tl__step h3 { font-size: 22px; margin-bottom: 8px; }
.tl__step p { font-size: 14px; color: var(--muted); line-height: 1.5; }
.tl__launch { display: inline-block; margin-top: 10px; font-family: var(--f-disp); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--blue); font-weight: 700; padding: 4px 10px; background: var(--blue-tint); border-radius: var(--radius-sm); }

/* ==========================================================================
   WHO I WORK WITH (Industries)
   ========================================================================== */

.who { background: transparent; position: relative; overflow: hidden; }
.who::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    radial-gradient(circle at 18% 25%, rgba(20, 122, 255, .1), transparent 40%),
    radial-gradient(circle at 82% 75%, rgba(20, 122, 255, .07), transparent 45%);
}
.who__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  max-width: 1160px; margin: 0 auto; position: relative; z-index: 1;
}

.icard {
  position: relative; background: #fff;
  border: 1px solid var(--line); border-radius: var(--radius-md);
  padding: 32px 28px;
  transition: border-color .2s ease, transform .2s ease;
}
.icard:hover { border-color: var(--ink-3); transform: translateY(-2px); }
.icard__icon {
  width: 44px; height: 44px; border-radius: var(--radius-md);
  background: var(--blue-tint); color: var(--blue);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 20px;
}
.icard__title { font-family: var(--f-disp); font-size: 20px; font-weight: 600; color: var(--ink); letter-spacing: -0.02em; line-height: 1.2; margin: 0 0 8px; }
.icard__desc { font-size: 14px; color: var(--muted); line-height: 1.55; margin: 0 0 14px; }
.icard__egs { font-family: var(--f-mono); font-size: 11px; color: var(--ink-3); letter-spacing: .01em; line-height: 1.55; }

.icard--more { background: transparent; border: 1.5px dashed var(--line-2); }
.icard--more:hover { border-color: var(--ink); background: #fff; }
.icard--more .icard__icon { background: var(--ink); color: #fff; }
.icard--more .icard__cta { display: inline-flex; align-items: center; gap: 6px; margin-top: 8px; font-family: var(--f-disp); font-size: 13px; font-weight: 600; color: var(--blue); letter-spacing: -0.005em; }
.icard--more .icard__cta svg { transition: transform .2s ease; }
.icard--more:hover .icard__cta svg { transform: translateX(3px); }

/* ==========================================================================
   PRICING
   ========================================================================== */

.rtd-fp .pricing { background: #ffffff !important; }
.rtd-fp .pricing__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; max-width: 920px; margin: 0 auto; }
.rtd-fp .plan {
  border: 2px solid #0f172a; background: #ffffff !important; border-radius: var(--radius-md);
  padding: 36px; box-shadow: 8px 8px 0 #0d5fd9;
  position: relative; display: flex; flex-direction: column; gap: 18px;
}
.rtd-fp .plan--alt { box-shadow: 8px 8px 0 #0f172a; background: #f8fafc !important; }
.rtd-fp .plan__label { font-family: var(--f-disp); font-size: 13px; letter-spacing: .12em; text-transform: uppercase; color: #475569; font-weight: 700; }
.rtd-fp .plan__name { font-family: var(--f-disp); font-size: 26px; color: #0f172a; font-weight: 700; letter-spacing: -0.02em; margin-top: -10px; }
.rtd-fp .plan__price { display: flex; align-items: baseline; gap: 4px; font-family: var(--f-disp); color: #0f172a; font-weight: 700; margin: 4px 0 4px; }
.rtd-fp .plan__price .curr { font-size: 26px; color: #64748b; font-weight: 600; }
.rtd-fp .plan__price .amt { font-size: 68px; line-height: 1; letter-spacing: -0.035em; }
.rtd-fp .plan__price .per { font-size: 18px; color: #64748b; font-weight: 500; margin-left: 4px; }
.rtd-fp .plan__tag { font-size: 14px; color: #64748b; }
.rtd-fp .plan__feats { list-style: none; padding: 20px 0 0; margin: 0; display: flex; flex-direction: column; gap: 10px; border-top: 1px dashed #e2e8f0; }
.rtd-fp .plan__feats li { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: #334155; }
.rtd-fp .plan__feats li::before { content: ""; flex-shrink: 0; margin-top: 4px; width: 16px; height: 16px; border-radius: var(--radius-md); background: #147aff; clip-path: polygon(20% 50%, 42% 70%, 80% 28%, 72% 20%, 42% 55%, 28% 40%); }
.rtd-fp .plan--alt .plan__feats li::before { background: #0f172a; }
.rtd-fp .plan__note { font-size: 13px; color: #64748b; font-style: italic; border-top: 1px dashed #e2e8f0; padding-top: 14px; margin-top: auto; }
.rtd-fp .plan__badge { position: absolute; top: -14px; right: 24px; font-family: var(--f-disp); font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; background: #147aff; color: #fff; padding: 6px 12px; border-radius: var(--radius-sm); }
.rtd-fp .plan--alt .plan__badge { background: #f1f5f9; color: #0f172a; }
.rtd-fp .pricing__cta { margin-top: 48px; text-align: center; }
.rtd-fp .pricing__note { margin-top: 18px; font-size: 13px; color: #64748b; }
.rtd-fp .pricing__guar { margin-top: 14px; font-size: 13px; display: inline-flex; align-items: center; gap: 8px; color: #334155; padding: 10px 16px; background: #f8fafc; border-radius: var(--radius-md); border: 1px solid #e2e8f0; }
.rtd-fp .pricing__guar b { color: #0f172a; font-weight: 600; }
.rtd-fp .pricing__guar svg { color: #147aff; flex-shrink: 0; }

/* ==========================================================================
   OWNERSHIP
   ========================================================================== */

.own { background: transparent; }
.infinity-icon { vertical-align: middle; margin-left: 8px; }
.own__cert-wrap { display: flex; justify-content: center; }
.own__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.own__pts { display: flex; flex-direction: column; gap: 18px; margin-top: 8px; }
.own__pt { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: flex-start; }
.own__pt-icon { width: 36px; height: 36px; border-radius: 2px; background: var(--blue); color: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 2px 2px 0 var(--blue-dark); }
.own__pt strong { display: block; font-family: var(--f-disp); font-size: 17px; color: var(--ink); font-weight: 700; margin-bottom: 4px; letter-spacing: -0.01em; }
.own__pt span { font-size: 14px; color: var(--muted); line-height: 1.5; }
.own__cert {
  background: #fff; border: 2px solid var(--ink); border-radius: var(--radius-md);
  box-shadow: 8px 8px 0 var(--blue-dark); overflow: hidden;
}
.own__cert-h { background: var(--ink); color: #fff; padding: 20px 24px; display: flex; align-items: center; gap: 12px; font-family: var(--f-disp); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; font-size: 12px; }
.own__cert-h svg { color: var(--blue); }
.own__cert-body { padding: 8px 24px; }
.own__cert-row { display: flex; justify-content: space-between; align-items: center; padding: 16px 0; border-bottom: 1px dashed var(--line); }
.own__cert-row:last-child { border-bottom: 0; }
.own__cert-row span { font-size: 15px; color: var(--text); }
.own__cert-row strong { font-family: var(--f-disp); color: var(--blue); font-weight: 700; font-size: 14px; letter-spacing: .02em; display: flex; align-items: center; gap: 6px; }
.own__cert-row strong::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--good); box-shadow: 0 0 0 3px var(--good-tint); }
.own__cert-f { padding: 14px 24px; background: var(--paper-2); font-size: 13px; color: var(--ink-3); display: flex; align-items: center; gap: 8px; border-top: 1px solid var(--line); }
.own__cert-f svg { color: var(--good); }

/* ==========================================================================
   FAQ
   ========================================================================== */

.faq__list { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--line); }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__item summary { list-style: none; cursor: pointer; padding: 22px 0; display: flex; align-items: center; gap: 18px; font-family: var(--f-disp); font-size: 19px; font-weight: 600; color: var(--ink); }
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::before { content: ""; width: 10px; height: 10px; flex-shrink: 0; background: var(--blue); clip-path: polygon(50% 0, 100% 100%, 0 100%); transition: transform .2s ease; }
.faq__item[open] summary::before { transform: rotate(180deg); }
.faq__tgl { margin-left: auto; width: 32px; height: 32px; border: 1.5px solid var(--line); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; transition: all .2s; }
.faq__tgl::before, .faq__tgl::after { content: ""; position: absolute; background: var(--ink); }
.faq__tgl::before { width: 12px; height: 2px; }
.faq__tgl::after { width: 2px; height: 12px; transition: transform .2s ease; }
.faq__item[open] .faq__tgl { background: var(--blue); border-color: var(--blue-dark); }
.faq__item[open] .faq__tgl::before { background: #fff; }
.faq__item[open] .faq__tgl::after { transform: scaleY(0); background: #fff; }
.faq__ans { padding: 0 0 26px 28px; color: var(--muted); font-size: 16px; line-height: 1.6; max-width: 720px; }
.faq__ans p { margin-bottom: 10px; }
.faq__ans p:last-child { margin-bottom: 0; }

/* ==========================================================================
   FINAL CTA
   ========================================================================== */

.final { background: var(--ink); color: #fff; padding: 120px 0; text-align: center; position: relative; overflow: hidden; }
.final::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse 800px 500px at 50% 120%, rgba(20, 122, 255, .3), transparent 60%); pointer-events: none; }
.final__inner { position: relative; z-index: 1; }
.final h2 { font-family: var(--f-hero); color: #fff; font-size: clamp(42px, 5.5vw, 72px); font-weight: 700; margin-bottom: 20px; letter-spacing: -0.03em; text-transform: uppercase; }
.final p { color: #a8a6a0; font-size: 18px; margin-bottom: 40px; }
.final__cta { display: inline-flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

/* ==========================================================================
   FOOTER
   ========================================================================== */

.ft { background: #0a0a09; color: #8d8b83; padding: 36px 0; font-size: 13px; border-top: 1px solid #1e1d1c; }
.ft__row { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.ft a { color: #c6c4bd; }
.ft a:hover { color: #fff; }

/* ==========================================================================
   RESPONSIVE - TABLET (768px+)
   ========================================================================== */

@media (max-width: 960px) {
  .rtd-fp .hero { padding: 48px 0 64px; }
  .rtd-fp .hero__grid { grid-template-columns: 1fr; gap: 40px; }
  .proof__row { grid-template-columns: 1fr; gap: 16px; }
  .tl__steps { grid-template-columns: 1fr 1fr; gap: 32px; }
  .tl__line { display: none; }
  .who__grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .pricing__grid { grid-template-columns: 1fr; }
  .own__grid { grid-template-columns: 1fr; gap: 40px; }
  .dash__body { grid-template-columns: 1fr; }
  .dash__side { display: none; }
  .dash__stats { grid-template-columns: 1fr 1fr; }
  .compare { font-size: 14px; }
  .compare__head > div, .compare__row > div, .compare__foot > div { padding: 14px 12px; }
  .hd__nav { display: none; }
  .rtd-fp section { padding: 72px 0; }
  .carousel__stage { grid-template-columns: 1fr; gap: 40px; min-height: 0; }
  .carousel__slide { position: relative; opacity: 1; transform: none; pointer-events: auto; display: none; }
  .carousel__slide.is-active { display: block; }
  .fslide h3 { font-size: 32px; }
  .fslide__feats { grid-template-columns: 1fr; }
  .showcase { min-height: 620px; }
  .float--speed { left: 10px; }
  .float--mail { right: 10px; }
  .float--sms { left: 10px; }
  .float--square { right: 10px; }
  .carousel__tab { padding: 8px 14px; font-size: 12px; }
}

/* ==========================================================================
   RESPONSIVE - MOBILE (max-width: 767px)
   Mobile-First Standards Applied
   ========================================================================== */

@media (max-width: 767px) {
  /* ===== BASE MOBILE ADJUSTMENTS ===== */
  .rtd-fp { font-size: 15px; }
  .rtd-fp .wrap { padding: 0 20px; }
  .rtd-fp section { padding: 48px 0; }

  /* ===== DISABLE HOVER TRANSFORMS ===== */
  .rtd-fp .btn:hover,
  .rtd-fp .btn--primary:hover,
  .rtd-fp .btn--fresha:hover,
  .rtd-fp .btn--sm:hover,
  .icard:hover,
  .carousel__arrow:hover,
  .compare__row:hover,
  .faq__item summary:hover {
    transform: none !important;
  }

  /* Simplified button transitions */
  .rtd-fp .btn,
  .rtd-fp .btn--primary,
  .rtd-fp .btn--fresha {
    transition: opacity 0.3s ease, background 0.3s ease;
    box-shadow: 2px 2px 0 #0f172a;
  }
  .rtd-fp .btn--primary {
    box-shadow: 2px 2px 0 #0d5fd9;
  }
  .rtd-fp .btn:hover,
  .rtd-fp .btn--primary:hover {
    box-shadow: 2px 2px 0 #0d5fd9;
  }

  /* Touch target minimum 44x44px */
  .rtd-fp .btn {
    min-height: 44px;
    padding: 12px 20px;
  }
  .carousel__arrow {
    width: 44px;
    height: 44px;
  }
  .carousel__tab {
    min-height: 44px;
    padding: 10px 16px;
  }

  /* ===== SIMPLIFIED ANIMATIONS ===== */
  .float {
    animation: none !important;
  }

  /* ===== REDUCED SHADOWS ===== */
  .compare {
    box-shadow: 4px 4px 0 var(--ink);
  }
  .rtd-fp .plan {
    box-shadow: 4px 4px 0 #0d5fd9;
  }
  .rtd-fp .plan--alt {
    box-shadow: 4px 4px 0 #0f172a;
  }
  .own__cert {
    box-shadow: 4px 4px 0 var(--blue-dark);
  }
  .dash {
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.4);
  }
  .phone {
    box-shadow: 0 20px 40px -15px rgba(15, 23, 42, 0.35);
  }
  .float {
    box-shadow: 4px 4px 0 var(--blue-dark);
  }

  /* ===== HEADER MOBILE ===== */
  .hd__inner {
    height: 60px;
    padding: 0 20px;
  }
  .hd__logo {
    font-size: 14px;
  }
  .hd__logo svg {
    height: 26px;
  }

  /* ===== HERO MOBILE ===== */
  .rtd-fp .hero {
    padding: 20px 0 24px;
  }
  .rtd-fp .hero > .wrap {
    padding: 0 20px;
  }
  .rtd-fp .hero__content {
    padding-top: 60px;
  }
  .rtd-fp .hero__grid {
    display: flex;
    flex-direction: column;
    gap: 24px;
    text-align: center;
  }
  .rtd-fp .hero h1 {
    font-size: 38px;
    margin-bottom: 14px;
    line-height: 1.1;
  }
  .rtd-fp .hero__lead {
    font-size: 15px;
    margin-bottom: 16px;
  }
  .rtd-fp .hero__sub {
    font-size: 13px;
    margin-bottom: 0;
  }

  /* Mobile CTAs - side by side */
  .rtd-fp .hero__cta--mobile {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 10px;
    padding: 0;
    width: 100%;
  }
  .rtd-fp .hero__cta--mobile .btn {
    flex: 1;
    max-width: 160px;
    justify-content: center;
    padding: 12px 14px;
    font-size: 12px;
    min-height: 48px;
    white-space: nowrap;
  }
  .rtd-fp .hero__cta--mobile .btn svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
  }
  .rtd-fp .hero__fine--mobile {
    display: none;
  }

  /* ===== HERO STAGE MOBILE ===== */
  /* Relative container with tiles in corners around phone */
  .rtd-stage {
    position: relative;
    display: block !important;
    width: 100%;
    max-width: 100%;
    height: 580px;
    margin: 0 auto;
  }

  .rtd-stage__glow {
    display: none;
  }

  /* Phone - centered */
  .rtd-phone-wrap {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
  }
  .rtd-phone {
    width: 240px;
    height: 480px;
    border-radius: 32px;
    animation: none;
    box-shadow: 6px 6px 0 var(--blue-dark);
  }
  .rtd-phone__screen {
    border-radius: 26px;
  }
  .rtd-phone__island {
    width: 70px;
    height: 18px;
    top: 8px;
  }
  /* Phone content - no scaling, just smaller fonts */
  .rtd-screen-body {
    padding: 10px 12px 12px;
  }
  .rtd-status {
    padding: 10px 16px 0;
    font-size: 12px;
  }
  .rtd-bk-head {
    margin-bottom: 12px;
  }
  .rtd-brand__name {
    font-size: 14px;
  }
  .rtd-brand__sub {
    font-size: 10px;
  }
  .rtd-cats {
    margin-bottom: 12px;
  }
  .rtd-cat {
    font-size: 11px;
    padding: 6px 8px;
  }
  /* Fix service row - price next to name */
  .rtd-svc {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 8px 10px;
    gap: 8px;
  }
  .rtd-svc__body {
    flex: 1;
    min-width: 0;
  }
  .rtd-svc__name {
    font-size: 11px;
  }
  .rtd-svc__meta {
    font-size: 9px;
  }
  .rtd-svc__price {
    font-size: 11px;
    flex-shrink: 0;
  }
  .rtd-svc__radio {
    width: 13px;
    height: 13px;
    flex-shrink: 0;
  }

  /* Notification - bottom center, overlapping phone */
  .rtd-notif {
    position: absolute !important;
    bottom: 10px !important;
    left: 50% !important;
    transform: translateX(-50%) rotate(-2deg) !important;
    top: auto !important;
    right: auto !important;
    z-index: 10;
    width: auto;
    max-width: 200px;
    margin: 0 !important;
    opacity: 1 !important;
  }

  /* Tiles - corners around phone */
  .rtd-tile {
    position: absolute !important;
    width: 190px !important;
    height: 190px !important;
    animation: none !important;
    box-shadow: 5px 5px 0 var(--ink) !important;
  }
  .rtd-tile--a {
    top: 0 !important;
    left: 0 !important;
    right: auto !important;
    bottom: auto !important;
    transform: rotate(-3deg) !important;
    z-index: 1 !important;
  }
  .rtd-tile--b {
    top: auto !important;
    left: auto !important;
    right: 0 !important;
    bottom: 80px !important;
    transform: rotate(2deg) !important;
    z-index: 3 !important;
  }
  /* ===== PROOF STRIP MOBILE ===== */
  .proof {
    padding: 20px 0;
  }
  .proof__row {
    grid-template-columns: 1fr;
    gap: 14px;
    text-align: center;
  }
  .proof__item {
    justify-content: center;
  }
  .proof__num {
    font-size: 24px;
  }
  .proof__label {
    font-size: 12px;
  }

  /* ===== SECTION HEADERS MOBILE ===== */
  .sect-head {
    margin-bottom: 32px;
  }
  .sect-head h2 {
    font-size: clamp(32px, 4.5vw, 56px);
    font-weight: 700;
    margin-bottom: 12px;
  }
  .sect-head p {
    font-size: 15px;
  }
  .kick {
    font-size: 10px;
    margin-bottom: 14px;
  }

  /* ===== COMPARISON TABLE MOBILE ===== */
  .compare {
    margin: 0 -16px;
    border-radius: 0;
    border-left: none;
    border-right: none;
    box-shadow: 0 6px 0 var(--ink);
  }
  .compare__head,
  .compare__row,
  .compare__foot {
    grid-template-columns: 1.5fr 1fr 0.6fr;
  }
  .compare__head > div {
    padding: 12px 8px;
    font-size: 8px;
    letter-spacing: 0.08em;
  }
  .compare__row > div {
    padding: 14px 8px;
  }
  .compare__foot > div {
    padding: 16px 8px;
  }
  .compare__feat {
    font-size: 13px;
  }
  .compare__feat svg {
    display: none;
  }
  .compare__bad {
    font-size: 11px;
  }
  .compare__rtd {
    width: 22px;
    height: 18px;
  }
  .compare__foot-bad .amt,
  .compare__foot-good .amt {
    font-size: 20px;
  }
  .compare__foot-bad .per,
  .compare__foot-good .per {
    font-size: 9px;
  }

  /* ===== CAROUSEL MOBILE ===== */
  .carousel__tabs {
    padding: 4px;
    gap: 2px;
    margin-bottom: 28px;
    width: 100%;
    max-width: 100%;
    flex-wrap: nowrap;
  }
  .carousel__tab {
    flex: 1;
    font-size: 11px;
    padding: 8px 6px;
    justify-content: center;
  }
  .carousel__tab .num {
    display: none;
  }
  .fslide h3 {
    font-size: 26px;
  }
  .fslide > p {
    font-size: 15px;
  }
  .fslide__feats {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .fslide__feats li {
    font-size: 13px;
  }
  .fslide__meta {
    gap: 16px;
    flex-wrap: wrap;
  }
  .fslide__meta-item .v {
    font-size: 18px;
  }
  .fslide__meta-item .l {
    font-size: 10px;
  }
  .fslide__kick {
    font-size: 10px;
    padding: 5px 10px;
  }
  .fslide--centered {
    min-height: auto;
    padding: 0;
  }
  .fslide--centered h3 {
    font-size: 24px;
    margin-bottom: 12px;
  }
  .fslide--centered > p {
    font-size: 15px;
  }
  .carousel__stage {
    gap: 24px;
  }

  /* Phone mockup mobile */
  .showcase {
    min-height: auto;
    padding: 20px 0;
  }
  .showcase .rtd-phone {
    width: 260px;
    height: 520px;
    border-radius: 36px;
  }
  .showcase .rtd-phone__screen {
    border-radius: 30px;
  }
  .showcase .rtd-phone__island {
    width: 80px;
    height: 20px;
    top: 10px;
  }
  .phone {
    width: 240px;
    height: 480px;
    padding: 8px;
    border-radius: 32px;
  }
  .phone__notch {
    width: 90px;
    height: 22px;
    top: 10px;
  }
  .phone__screen {
    border-radius: 24px;
  }

  /* Floating popups mobile */
  .float {
    display: none; /* Hide floating popups on mobile for cleaner look */
  }

  /* Carousel navigation mobile */
  .carousel__nav {
    margin-top: 28px;
    gap: 12px;
  }
  .carousel__progress {
    flex: 0 0 100px;
  }
  .carousel__count {
    font-size: 11px;
  }

  /* ===== COMMAND CENTER (DASHBOARD) MOBILE ===== */
  .cmd {
    padding: 48px 0;
  }
  .dash {
    margin: 0 -10px;
    border-radius: 0;
  }
  .dash__bar {
    padding: 10px 14px;
    font-size: 10px;
  }
  .dash__main {
    padding: 16px;
  }
  .dash__stats {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .dash__stat {
    padding: 12px;
  }
  .dash__stat-label {
    font-size: 9px;
  }
  .dash__stat-val {
    font-size: 22px;
  }
  .dash__stat-delta {
    font-size: 10px;
  }
  .dash__list-row {
    padding: 10px 12px;
    gap: 10px;
  }
  .dash__avatar {
    width: 26px;
    height: 26px;
    font-size: 10px;
  }
  .dash__list-name {
    font-size: 12px;
  }
  .dash__list-sub {
    font-size: 10px;
  }
  .dash__list-time {
    font-size: 10px;
    display: none; /* Hide time on mobile */
  }
  .dash__list-pill {
    font-size: 8px;
    padding: 2px 5px;
  }

  /* ===== TIMELINE MOBILE ===== */
  .tl__steps {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 16px;
    margin: 0 -20px;
    padding-left: 20px;
    padding-right: 20px;
  }
  .tl__line {
    display: block;
    top: 22px;
    left: 22px;
    right: auto;
    width: calc(140px * 5 + 16px * 4 - 44px);
  }
  .tl__step {
    flex: 0 0 140px;
    min-width: 140px;
  }
  .tl__num {
    width: 44px;
    height: 44px;
    font-size: 15px;
    margin-bottom: 12px;
    box-shadow: 2px 2px 0 var(--blue-dark);
    border-radius: var(--radius-md);
  }
  .tl__step h3 {
    font-size: 16px;
  }
  .tl__step p {
    font-size: 12px;
  }
  .tl__launch {
    font-size: 9px;
  }

  /* ===== INDUSTRIES MOBILE ===== */
  .who__grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .icard {
    padding: 24px 20px;
  }
  .icard__icon {
    width: 40px;
    height: 40px;
    margin-bottom: 16px;
  }
  .icard__title {
    font-size: 18px;
  }
  .icard__desc {
    font-size: 13px;
  }
  .icard__egs {
    font-size: 10px;
  }

  /* ===== PRICING MOBILE ===== */
  .rtd-fp .pricing__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .rtd-fp .plan {
    padding: 28px 24px;
    gap: 14px;
  }
  .rtd-fp .plan__label {
    font-size: 11px;
  }
  .rtd-fp .plan__name {
    font-size: 22px;
  }
  .rtd-fp .plan__price .curr {
    font-size: 20px;
  }
  .rtd-fp .plan__price .amt {
    font-size: 52px;
  }
  .rtd-fp .plan__price .per {
    font-size: 14px;
  }
  .rtd-fp .plan__tag {
    font-size: 13px;
  }
  .rtd-fp .plan__feats {
    padding-top: 16px;
    gap: 8px;
  }
  .rtd-fp .plan__feats li {
    font-size: 13px;
  }
  .rtd-fp .plan__note {
    font-size: 12px;
  }
  .rtd-fp .plan__badge {
    font-size: 10px;
    padding: 5px 10px;
    top: -12px;
    right: 16px;
  }
  .rtd-fp .pricing__cta {
    margin-top: 32px;
  }
  .rtd-fp .pricing__note {
    font-size: 12px;
  }
  .rtd-fp .pricing__guar {
    font-size: 12px;
    padding: 8px 12px;
  }

  /* ===== OWNERSHIP MOBILE ===== */
  .own__grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .own__pts {
    gap: 14px;
  }
  .own__pt {
    gap: 12px;
  }
  .own__pt-icon {
    width: 32px;
    height: 32px;
    box-shadow: 2px 2px 0 var(--blue-dark);
  }
  .own__pt strong {
    font-size: 15px;
  }
  .own__pt span {
    font-size: 13px;
  }
  .own__cert-h {
    padding: 16px 20px;
    font-size: 11px;
  }
  .own__cert-body {
    padding: 4px 20px;
  }
  .own__cert-row {
    padding: 14px 0;
  }
  .own__cert-row span {
    font-size: 13px;
  }
  .own__cert-row strong {
    font-size: 12px;
  }
  .own__cert-f {
    padding: 12px 20px;
    font-size: 12px;
  }

  /* ===== FAQ MOBILE ===== */
  .faq__item summary {
    padding: 18px 0;
    font-size: 16px;
    gap: 14px;
  }
  .faq__tgl {
    width: 28px;
    height: 28px;
  }
  .faq__ans {
    padding: 0 0 20px 24px;
    font-size: 14px;
  }

  /* ===== FINAL CTA MOBILE ===== */
  .final {
    padding: 64px 0;
  }
  .final h2 {
    font-size: clamp(32px, 4.5vw, 56px);
    font-weight: 700;
    margin-bottom: 14px;
  }
  .final p {
    font-size: 15px;
    margin-bottom: 28px;
  }
  .final__cta {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .final__cta .btn {
    width: 100%;
    justify-content: center;
  }

  /* ===== FOOTER MOBILE ===== */
  .ft {
    padding: 28px 0;
    font-size: 12px;
  }
  .ft__row {
    flex-direction: column;
    text-align: center;
    gap: 12px;
  }
}

/* ==========================================================================
   SMALL MOBILE (max-width: 480px)
   ========================================================================== */

@media (max-width: 480px) {
  .rtd-fp .hero {
    padding: 40px 0 20px;
  }
  .rtd-fp .hero h1 {
    font-size: 32px;
  }
  .rtd-fp .hero__lead {
    font-size: 14px;
  }
  .rtd-fp .hero__sub {
    font-size: 12px;
    margin-bottom: 16px;
  }
  /* Small mobile: slightly smaller stage */
  .rtd-stage {
    max-width: 100% !important;
    height: 520px !important;
  }
  .rtd-phone {
    width: 200px !important;
    height: 400px !important;
  }
  .rtd-tile {
    width: 150px !important;
    height: 150px !important;
  }
  .rtd-tile--b {
    bottom: 70px !important;
  }
  .rtd-notif {
    max-width: 180px !important;
    font-size: 11px !important;
  }
  /* Buttons side by side, smaller */
  .rtd-fp .hero__cta--mobile .btn {
    font-size: 11px;
    padding: 10px 12px;
    max-width: 140px;
  }
  .sect-head h2 {
    font-size: clamp(28px, 5vw, 42px);
    font-weight: 700;
  }
  .fslide h3 {
    font-size: 22px;
  }
  .dash__stats {
    grid-template-columns: 1fr;
  }
  .compare__head,
  .compare__row,
  .compare__foot {
    grid-template-columns: 1.4fr 1fr 0.5fr;
  }
  .compare__head > div {
    padding: 10px 6px;
    font-size: 7px;
  }
  .compare__row > div {
    padding: 12px 6px;
  }
  .compare__foot > div {
    padding: 14px 6px;
  }
  .compare__feat {
    font-size: 11px;
  }
  .compare__bad {
    font-size: 10px;
  }
  .compare__rtd {
    width: 20px;
    height: 17px;
  }
  .compare__foot-bad .amt,
  .compare__foot-good .amt {
    font-size: 16px;
  }
  .rtd-fp .plan__price .amt {
    font-size: 44px;
  }
  .phone {
    width: 220px;
    height: 440px;
  }
}


/* ==========================================================================
   SALON TYPES - Branded Shaped Container
   Pattern stack from web-animation skill:
     - Series 1 (SVG mask) — chamfered silhouette
     - Series 2 (double stroke) — base + accent outline pop
     - Series 11 (theme cascade) — data-theme="dark"
     - Series 12 (CSS marquee) — GPU-accelerated scroll
   ========================================================================== */

/* Section Shell — provides outer padding around the shape */
.rtd-fp .salon-types {
  position: relative;
  padding: 100px 24px;
  background: transparent;
}

/* Blue offset shadow — echoes brand button geometry */
.rtd-fp .salon-types__shadow {
  position: absolute;
  top: calc(100px + 12px);
  left: calc(24px + 12px);
  right: calc(24px - 12px);
  bottom: calc(100px - 12px);
  background: var(--blue);
  clip-path: polygon(
    32px 0,
    100% 0,
    100% calc(100% - 32px),
    calc(100% - 32px) 100%,
    0 100%,
    0 32px
  );
  pointer-events: none;
  z-index: 0;
}

/* Series 1 — the masked shape itself */
.rtd-fp .salon-types__shape {
  position: relative;
  z-index: 1;
  background: var(--ink);
  color: #fff;
  -webkit-mask-image: var(--mask-url);
          mask-image: var(--mask-url);
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  min-height: 620px;
}

@media (max-width: 767px) {
  .rtd-fp .salon-types__shape {
    -webkit-mask-image: var(--mask-url-mobile);
            mask-image: var(--mask-url-mobile);
    min-height: auto;
  }
}

/* Series 2 — double-stroke frame layers */
.rtd-fp .salon-types__frame {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}

.rtd-fp .salon-types__frame svg {
  width: 100%;
  height: 100%;
  display: block;
}

.rtd-fp .salon-types__frame--base {
  color: rgba(255, 255, 255, 0.12);
}

.rtd-fp .salon-types__frame--accent {
  opacity: 0;
  transition: opacity 1s cubic-bezier(0.65, 0.05, 0, 1);
}

.rtd-fp .salon-types__frame--accent.is-visible {
  opacity: 1;
}

/* Inner content — sits above frame layers */
.rtd-fp .salon-types__inner {
  position: relative;
  z-index: 3;
  padding: 60px 48px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

@media (max-width: 991px) {
  .rtd-fp .salon-types__inner {
    padding: 48px 32px;
  }
}

@media (max-width: 479px) {
  .rtd-fp .salon-types__inner {
    padding: 40px 20px;
  }
}

/* Header */
.rtd-fp .salon-types__header {
  max-width: 700px;
  margin: 0 auto 40px;
  text-align: center;
}

.rtd-fp .salon-types__eyebrow {
  font-family: var(--f-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--blue);
  letter-spacing: 0.04em;
  margin: 0 0 12px;
}

.rtd-fp .salon-types__header h2 {
  font-family: var(--f-hero);
  font-size: clamp(32px, 4.5vw, 56px);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: #fff;
  margin: 0;
  text-transform: uppercase;
}

/* Marquee Container */
.rtd-fp .salon-types__marquee {
  display: flex;
  flex-direction: column;
  gap: 20px;
  overflow: visible;
  flex: 1;
  padding: 10px 0;
  margin: -10px 0;
  /* Series 3 - Gradient mask edge fade */
  -webkit-mask-image: linear-gradient(
    90deg,
    hsla(0, 0%, 100%, 0) 0%,
    white 3%,
    white 97%,
    hsla(0, 0%, 100%, 0) 100%
  );
  mask-image: linear-gradient(
    90deg,
    hsla(0, 0%, 100%, 0) 0%,
    white 3%,
    white 97%,
    hsla(0, 0%, 100%, 0) 100%
  );
}

.rtd-fp .salon-types__row {
  display: flex;
  gap: 20px;
  width: max-content;
  animation-duration: 45s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

.rtd-fp .salon-types__row--1 { animation-name: marquee-ltr; }
.rtd-fp .salon-types__row--2 { animation-name: marquee-rtl; }

@keyframes marquee-ltr {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

@keyframes marquee-rtl {
  from { transform: translateX(-50%); }
  to { transform: translateX(0); }
}

/* Pause when not visible */
.rtd-fp .salon-types__marquee[data-paused="true"] .salon-types__row {
  animation-play-state: paused;
}

/* Salon Card — dark theme variant */
.rtd-fp .scard {
  position: relative;
  flex: 0 0 320px;
  height: 220px;
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
  background: #1e293b;
  border: 2px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 0 0 0 transparent;
  transition: transform 0.3s cubic-bezier(0.65, 0.05, 0, 1),
              border-color 0.3s ease,
              box-shadow 0.3s ease,
              background-color 0.3s ease;
}

.rtd-fp .scard:hover {
  transform: translateY(-4px);
  border-color: var(--blue);
  box-shadow: 0 0 0 1px var(--blue), 0 8px 24px rgba(20, 122, 255, 0.25);
  background: rgba(20, 122, 255, 0.08);
}

/* Image */
.rtd-fp .scard__media {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
}

.rtd-fp .scard__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.01);
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.rtd-fp .scard:hover .scard__media img {
  transform: scale(1.06);
}

/* Overlay */
.rtd-fp .scard__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(
    to top,
    rgba(15, 23, 42, 0.92) 0%,
    rgba(15, 23, 42, 0.5) 45%,
    rgba(15, 23, 42, 0.1) 100%
  );
  transition: opacity 0.4s ease;
  pointer-events: none;
}

.rtd-fp .scard:hover .scard__overlay {
  opacity: 0.95;
}

.rtd-fp .scard__overlay--solid {
  background: var(--blue);
  opacity: 1;
}

/* Content */
.rtd-fp .scard__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 3;
  padding: 22px;
  color: #fff;
}

/* Index */
.rtd-fp .scard__index {
  display: block;
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.45);
  margin-bottom: 6px;
  transition: color 0.3s ease, transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.rtd-fp .scard:hover .scard__index {
  color: var(--blue);
  transform: translateY(-2px);
}

/* Title with text-shadow slide trick */
.rtd-fp .scard__title-wrap {
  overflow: hidden;
  height: 1.3em;
}

.rtd-fp .scard__title {
  --offset: 1.3em;
  font-family: var(--f-disp);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.3;
  margin: 0;
  color: #fff;
  text-shadow: 0 var(--offset) 0 #fff;
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

.rtd-fp .scard:hover .scard__title {
  transform: translateY(calc(var(--offset) * -1));
}

/* Tagline with clip-path reveal */
.rtd-fp .scard__tagline {
  font-family: var(--f-sans);
  font-size: 13px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.6);
  margin: 4px 0 0;
  line-height: 1.4;
  clip-path: inset(0 0 100% 0);
  opacity: 0;
  transform: translateY(6px);
  transition: clip-path 0.4s cubic-bezier(0.16, 1, 0.3, 1),
              opacity 0.3s ease 0.08s,
              transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.rtd-fp .scard:hover .scard__tagline {
  clip-path: inset(0 0 0 0);
  opacity: 1;
  transform: translateY(0);
}

/* Arrow with circle expand */
.rtd-fp .scard__arrow {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--blue);
  border-radius: var(--radius-sm);
  color: #fff;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.rtd-fp .scard:hover .scard__arrow {
  clip-path: inset(0 0 0 0);
}

.rtd-fp .scard__arrow svg {
  width: 14px;
  height: 14px;
  transition: transform 0.25s ease;
}

.rtd-fp .scard:hover .scard__arrow:hover svg {
  transform: translateX(2px);
}

/* Tail Card — CTA card */
.rtd-fp .scard--tail {
  background: linear-gradient(135deg, rgba(20, 122, 255, 0.15) 0%, rgba(20, 122, 255, 0.05) 100%);
  border: 2px solid rgba(20, 122, 255, 0.4);
  text-decoration: none;
  display: block;
}

.rtd-fp .scard--tail:hover {
  border-color: var(--blue);
  background: linear-gradient(135deg, rgba(20, 122, 255, 0.25) 0%, rgba(20, 122, 255, 0.1) 100%);
  box-shadow: 0 0 0 1px var(--blue), 0 8px 24px rgba(20, 122, 255, 0.3);
}

.rtd-fp .scard__content--tail {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  height: 100%;
  padding: 24px;
  position: relative;
  z-index: 3;
}

.rtd-fp .scard__logo {
  color: #fff;
  margin-bottom: 16px;
}

.rtd-fp .scard--tail .scard__title {
  font-size: 20px;
  margin-bottom: 6px;
  text-shadow: none;
  color: #fff;
}

.rtd-fp .scard--tail .scard__tagline {
  clip-path: none;
  opacity: 0.7;
  transform: none;
  margin-bottom: 18px;
  font-size: 14px;
}

/* Button inside tail card */
.rtd-fp .scard__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: #fff;
  color: var(--blue);
  font-family: var(--f-disp);
  font-size: 14px;
  font-weight: 600;
  border-radius: var(--radius-sm);
  border: 2px solid #fff;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.rtd-fp .scard--tail:hover .scard__btn {
  transform: translateY(-2px);
  box-shadow: 3px 3px 0 var(--blue-dark);
}

.rtd-fp .scard__btn svg {
  flex-shrink: 0;
  transition: transform 0.25s ease;
}

.rtd-fp .scard--tail:hover .scard__btn svg {
  transform: translateX(3px);
}

/* Responsive — Salon Types */
@media (max-width: 991px) {
  .rtd-fp .salon-types {
    padding: 80px 16px;
  }

  .rtd-fp .salon-types__shadow {
    top: calc(80px + 10px);
    left: calc(16px + 10px);
    right: calc(16px - 10px);
    bottom: calc(80px - 10px);
    clip-path: polygon(
      24px 0,
      100% 0,
      100% calc(100% - 24px),
      calc(100% - 24px) 100%,
      0 100%,
      0 24px
    );
  }
}

@media (max-width: 768px) {
  .rtd-fp .salon-types {
    padding: 60px 12px;
  }

  .rtd-fp .salon-types__shadow {
    top: calc(60px + 8px);
    left: calc(12px + 8px);
    right: calc(12px - 8px);
    bottom: calc(60px - 8px);
    clip-path: polygon(
      16px 0,
      100% 0,
      100% calc(100% - 16px),
      calc(100% - 16px) 100%,
      0 100%,
      0 16px
    );
  }

  .rtd-fp .salon-types__header {
    margin-bottom: 28px;
  }

  .rtd-fp .salon-types__marquee {
    gap: 14px;
  }

  .rtd-fp .salon-types__row {
    gap: 14px;
    animation-duration: 35s;
  }

  .rtd-fp .scard {
    flex: 0 0 260px;
    height: 190px;
  }

  .rtd-fp .scard__content {
    padding: 18px;
  }

  .rtd-fp .scard__title {
    font-size: 16px;
  }

  .rtd-fp .scard__tagline {
    font-size: 12px;
  }
}

@media (max-width: 480px) {
  .rtd-fp .scard {
    flex: 0 0 230px;
    height: 170px;
  }

  .rtd-fp .scard__arrow {
    width: 28px;
    height: 28px;
    top: 12px;
    right: 12px;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .rtd-fp .salon-types__row {
    animation: none;
  }

  .rtd-fp .salon-types__frame--accent {
    opacity: 1;
    transition: none;
  }

  .rtd-fp .scard,
  .rtd-fp .scard__media img,
  .rtd-fp .scard__index,
  .rtd-fp .scard__title,
  .rtd-fp .scard__tagline,
  .rtd-fp .scard__arrow,
  .rtd-fp .scard__cta,
  .rtd-fp .scard__cta-text,
  .rtd-fp .scard__cta svg {
    transition: none;
  }

  .rtd-fp .scard__tagline {
    clip-path: none;
    opacity: 0.65;
    transform: none;
  }

  .rtd-fp .scard__arrow {
    clip-path: inset(0 0 0 0);
  }
}

/* ==========================================================================
   FRESHA ALTERNATIVE PAGE STYLES
   ========================================================================== */

/* Hero variant for Fresha page */
.rtd-fp--fresha .hero--fresha {
  min-height: auto;
  padding: 80px 0 100px;
}

.rtd-fp--fresha .hero__grid {
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

.rtd-fp--fresha .hero__content {
  padding-top: 40px;
}

/* Warning badge */
.fresha-warn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 18px;
  font-family: var(--f-disp);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #b45309;
  background: #fffbeb;
  border: 2px solid #f59e0b;
  border-radius: var(--radius);
  box-shadow: 3px 3px 0 #d97706;
  margin-bottom: 24px;
}
.fresha-warn svg { color: #f59e0b; flex-shrink: 0; }

/* Calculator Card */
.calc-card {
  background: #fff;
  border: 2px solid var(--ink);
  border-radius: var(--radius);
  box-shadow: 8px 8px 0 var(--ink);
  padding: 32px;
}

.calc-card__head {
  text-align: center;
  margin-bottom: 28px;
}
.calc-card__head h2 {
  font-family: var(--f-disp);
  font-size: 20px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 6px;
}
.calc-card__head p {
  font-size: 14px;
  color: var(--muted);
}

.calc-card__inputs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

.calc-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.calc-field label {
  font-family: var(--f-disp);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
}
.calc-field input {
  padding: 14px 12px;
  font-family: var(--f-disp);
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper-2);
  color: var(--ink);
  transition: border-color 0.15s, background 0.15s;
}
.calc-field input:focus {
  outline: none;
  border-color: var(--blue);
  background: #fff;
}
.calc-field__hint {
  font-size: 11px;
  color: var(--muted);
  text-align: center;
}

.calc-card__results {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 20px;
}

.calc-result {
  padding: 20px 16px;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  text-align: center;
}
.calc-result--bad {
  background: var(--bad-tint);
  border-color: var(--bad);
  box-shadow: 3px 3px 0 #dc2626;
}
.calc-result--good {
  background: var(--good-tint);
  border-color: var(--good);
  box-shadow: 3px 3px 0 #059669;
}
.calc-result__label {
  display: block;
  font-family: var(--f-disp);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}
.calc-result--bad .calc-result__label { color: var(--bad); }
.calc-result--good .calc-result__label { color: #059669; }
.calc-result__value {
  display: block;
  font-family: var(--f-disp);
  font-size: 28px;
  font-weight: 800;
  color: var(--ink);
}
.calc-result__per {
  font-size: 12px;
  color: var(--muted);
}

.calc-card__savings {
  background: var(--blue);
  border-radius: var(--radius);
  padding: 20px;
  text-align: center;
  margin-bottom: 20px;
}
.calc-savings__label {
  display: block;
  font-family: var(--f-disp);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.7);
  margin-bottom: 4px;
}
.calc-savings__value {
  display: block;
  font-family: var(--f-disp);
  font-size: 40px;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  margin-bottom: 4px;
}
.calc-savings__note {
  font-size: 14px;
  color: rgba(255,255,255,0.8);
}

.calc-card__cta {
  width: 100%;
  justify-content: center;
  margin-bottom: 16px;
}

.calc-card__guarantee {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 13px;
  color: var(--muted);
}
.calc-card__guarantee svg { color: var(--good); }

.calc-footnote {
  margin-top: 20px;
  padding: 16px;
  font-size: 13px;
  color: var(--muted);
  background: var(--paper-2);
  border-radius: var(--radius);
}
.calc-footnote strong { color: var(--text); }

/* Complaints section */
.complaints {
  background: var(--ink) !important;
  padding: 100px 0;
}
.complaints .sect-head h2 { color: #fff; }
.complaints .sect-head h2 em { color: var(--bad); font-style: normal; }
.complaints .sect-head p { color: rgba(255,255,255,0.6); }

.complaints__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 48px;
}

.complaint {
  background: rgba(255,255,255,0.03);
  border: 2px solid rgba(255,255,255,0.1);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: 3px 3px 0 rgba(0,0,0,0.3);
  transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s;
}
.complaint:hover {
  transform: translate(-2px, -2px);
  border-color: rgba(255,255,255,0.2);
  box-shadow: 5px 5px 0 rgba(0,0,0,0.4);
}
.complaint--featured {
  grid-column: span 1;
}
.complaint__stars { margin-bottom: 12px; }
.complaint p {
  font-size: 15px;
  color: rgba(255,255,255,0.85);
  line-height: 1.7;
  margin-bottom: 16px;
}
.complaint p strong { color: #fca5a5; }
.complaint footer {
  display: flex;
  gap: 12px;
  font-size: 13px;
}
.complaint cite {
  font-style: normal;
  color: rgba(255,255,255,0.5);
}
.complaint a {
  color: var(--blue);
  text-decoration: underline;
}

.complaints__cta {
  text-align: center;
}
.complaints__cta p {
  color: rgba(255,255,255,0.7);
  margin-bottom: 16px;
  font-size: 18px;
}
.complaints__cta strong { color: #fff; }

/* Comparison table - same as front page .compare */
/* Override animation - show immediately (no JS on this page) */
.rtd-fp--fresha .compare {
  max-width: 900px;
  margin: 0 auto 48px;
  opacity: 1 !important;
  transform: none !important;
}
.rtd-fp--fresha .compare__rtd {
  transform: scale(1) translateY(0) !important;
  opacity: 1 !important;
  filter: none !important;
}
.rtd-fp--fresha .compare__bad::after {
  display: none; /* No strikethrough animation */
}

.compare__cta {
  text-align: center;
}

/* Hidden costs cards */
.costs {
  background: var(--paper-2) !important;
  padding: 100px 0;
}

.costs__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.cost-card {
  background: #fff;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: 3px 3px 0 var(--line-2);
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
.cost-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 var(--ink);
  border-color: var(--bad);
}
.cost-card__icon {
  width: 48px;
  height: 48px;
  background: var(--bad-tint);
  border: 2px solid #fecaca;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  color: var(--bad);
}
.cost-card h3 {
  font-family: var(--f-disp);
  font-size: 16px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 10px;
}
.cost-card p {
  font-size: 14px;
  color: var(--text);
  line-height: 1.6;
}
.cost-card p strong { color: var(--ink); }

/* Timeline */
.tl {
  padding: 100px 0;
}

.tl__track {
  max-width: 700px;
  margin: 0 auto 48px;
  position: relative;
  padding-left: 80px;
}
.tl__track::before {
  content: '';
  position: absolute;
  left: 35px;
  top: 40px;
  bottom: 40px;
  width: 2px;
  background: linear-gradient(180deg, var(--blue) 0%, var(--good) 100%);
}

.tl__step {
  position: relative;
  margin-bottom: 24px;
}
.tl__step:last-child { margin-bottom: 0; }

.tl__num {
  position: absolute;
  left: -80px;
  top: 24px;
  width: 48px;
  height: 48px;
  background: #fff;
  border: 2px solid var(--blue);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--f-disp);
  font-size: 14px;
  font-weight: 700;
  color: var(--blue);
  z-index: 2;
}
.tl__step--done .tl__num {
  background: var(--good);
  border-color: var(--good);
  color: #fff;
}

.tl__card {
  background: #fff;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: 4px 4px 0 var(--line-2);
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
.tl__card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--ink);
  border-color: var(--blue);
}
.tl__card--done {
  background: #f0fdf4;
  border-color: var(--good);
  box-shadow: 4px 4px 0 #059669;
}
.tl__card h3 {
  font-family: var(--f-disp);
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 8px;
}
.tl__card p {
  font-size: 14px;
  color: var(--text);
  line-height: 1.6;
  margin-bottom: 12px;
}

.tl__checks {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 20px;
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
}
.tl__checks li {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
}
.tl__checks svg { color: var(--good); }

.tl__time {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-disp);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--blue);
  background: var(--blue-tint);
  padding: 6px 12px;
  border-radius: var(--radius);
}

.tl__result {
  background: #fff;
  border: 2px solid #86efac;
  border-radius: var(--radius);
  padding: 12px 16px;
  font-size: 14px;
  color: #166534;
  box-shadow: 2px 2px 0 var(--good);
}
.tl__result strong { color: #15803d; }

.tl__cta {
  text-align: center;
}
.tl__guarantee {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #f0fdf4;
  border: 2px solid var(--good);
  border-radius: var(--radius);
  padding: 12px 20px;
  margin-bottom: 20px;
  font-size: 14px;
  font-weight: 500;
  color: #166534;
  box-shadow: 2px 2px 0 #059669;
}
.tl__guarantee svg { color: var(--good); }

/* Pricing section */
.rtd-fp--fresha .pricing {
  background: #fff !important;
  padding: 100px 0;
}

.rtd-fp--fresha .pricing__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 800px;
  margin: 0 auto 48px;
}

.rtd-fp--fresha .pricing__card {
  background: #fff;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform 0.15s, box-shadow 0.15s;
}
.rtd-fp--fresha .pricing__card:hover {
  transform: translate(-3px, -3px);
  box-shadow: 6px 6px 0 var(--line-2);
}
.rtd-fp--fresha .pricing__card--primary {
  border-color: var(--blue);
  box-shadow: 6px 6px 0 var(--blue-dark);
}
.rtd-fp--fresha .pricing__card--primary:hover {
  box-shadow: 10px 10px 0 var(--blue-dark);
}
.rtd-fp--fresha .pricing__card--secondary {
  border-color: var(--good);
  box-shadow: 3px 3px 0 #059669;
  position: relative;
}

.rtd-fp--fresha .pricing__badge {
  position: absolute;
  top: 16px;
  right: 16px;
  background: var(--good);
  color: #fff;
  font-family: var(--f-disp);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 6px 12px;
  border-radius: var(--radius);
  box-shadow: 2px 2px 0 #047857;
  z-index: 2;
}

.rtd-fp--fresha .pricing__card-top {
  padding: 36px 28px 28px;
  text-align: center;
  background: var(--blue);
  color: #fff;
}
.rtd-fp--fresha .pricing__card-top--green {
  background: var(--good);
}
.rtd-fp--fresha .pricing__label {
  display: block;
  font-family: var(--f-disp);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.8;
  margin-bottom: 8px;
}
.rtd-fp--fresha .pricing__price {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 4px;
}
.rtd-fp--fresha .pricing__currency {
  font-family: var(--f-disp);
  font-size: 24px;
  font-weight: 700;
}
.rtd-fp--fresha .pricing__amount {
  font-family: var(--f-disp);
  font-size: 56px;
  font-weight: 800;
  line-height: 1;
}
.rtd-fp--fresha .pricing__period {
  font-size: 18px;
  opacity: 0.7;
}
.rtd-fp--fresha .pricing__tagline {
  font-size: 13px;
  opacity: 0.8;
  margin-top: 8px;
}

.rtd-fp--fresha .pricing__features {
  list-style: none;
  padding: 28px;
  margin: 0;
}
.rtd-fp--fresha .pricing__features li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
  font-size: 14px;
  color: var(--text);
}
.rtd-fp--fresha .pricing__features li:last-child { border-bottom: none; }
.rtd-fp--fresha .pricing__features svg { color: var(--blue); flex-shrink: 0; }
.rtd-fp--fresha .pricing__features--green svg { color: var(--good); }

.rtd-fp--fresha .pricing__footer {
  padding: 20px 28px;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  color: var(--blue);
  background: var(--blue-tint);
  border-top: 1px solid var(--line);
}
.rtd-fp--fresha .pricing__footer--green {
  color: #059669;
  background: var(--good-tint);
}

.rtd-fp--fresha .pricing__cta {
  text-align: center;
}
.rtd-fp--fresha .pricing__note {
  font-size: 14px;
  color: var(--muted);
  margin-top: 16px;
}
.rtd-fp--fresha .pricing__guarantee {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--text);
  margin-top: 16px;
}
.rtd-fp--fresha .pricing__guarantee svg { color: var(--good); }

/* FAQ */
.rtd-fp--fresha .faq {
  background: var(--paper-2) !important;
  padding: 100px 0;
}

.faq__list {
  max-width: 700px;
  margin: 0 auto;
}

.faq__item {
  background: #fff;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  margin-bottom: 12px;
  box-shadow: 2px 2px 0 var(--line-2);
  transition: box-shadow 0.15s, border-color 0.15s, transform 0.15s;
}
.faq__item:hover {
  border-color: var(--blue);
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--ink);
}
.faq__item[open] {
  border-color: var(--blue);
  box-shadow: 3px 3px 0 var(--blue-dark);
}

.faq__q {
  padding: 20px 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  list-style: none;
}
.faq__q::-webkit-details-marker { display: none; }
.faq__q span:first-child {
  font-family: var(--f-disp);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
}

.faq__toggle {
  width: 24px;
  height: 24px;
  border-radius: var(--radius);
  background: var(--paper-2);
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  transition: background 0.15s, border-color 0.15s;
}
.faq__toggle::before,
.faq__toggle::after {
  content: '';
  position: absolute;
  background: var(--text);
  transition: transform 0.15s;
}
.faq__toggle::before { width: 10px; height: 2px; }
.faq__toggle::after { width: 2px; height: 10px; }
.faq__item[open] .faq__toggle::after { transform: rotate(90deg); }
.faq__item[open] .faq__toggle {
  background: var(--blue-tint);
  border-color: var(--blue);
}
.faq__item[open] .faq__toggle::before,
.faq__item[open] .faq__toggle::after {
  background: var(--blue);
}

.faq__a {
  padding: 0 24px 24px;
  animation: faqReveal 0.2s ease-out;
}
.faq__a p {
  font-size: 15px;
  color: var(--text);
  line-height: 1.7;
}

@keyframes faqReveal {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Final CTA */
.rtd-fp--fresha .final {
  background: var(--ink) !important;
  padding: 100px 0;
  position: relative;
  overflow: hidden;
}
.rtd-fp--fresha .final::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(30deg, rgba(20, 122, 255, 0.08) 1px, transparent 1px),
    linear-gradient(150deg, rgba(20, 122, 255, 0.08) 1px, transparent 1px);
  background-size: 40px 23px;
  pointer-events: none;
}

.final__content {
  text-align: center;
  position: relative;
  z-index: 1;
}
.final__content h2 {
  font-family: var(--f-disp);
  font-size: 40px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 16px;
}
.final__content h2 em {
  color: var(--bad);
  font-style: normal;
}
.final__content p {
  font-size: 18px;
  color: rgba(255,255,255,0.7);
  margin-bottom: 32px;
}
.final__content strong { color: #fff; }

/* Mobile responsiveness for Fresha page */
@media (max-width: 1024px) {
  .rtd-fp--fresha .hero__grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .rtd-fp--fresha .hero__content {
    padding-top: 0;
    text-align: center;
  }
  .rtd-fp--fresha .hero__cta {
    justify-content: center;
  }
  .rtd-fp--fresha .hero__fine {
    justify-content: center;
  }
  .calc-card {
    max-width: 520px;
    margin: 0 auto;
  }
  .complaints__grid {
    grid-template-columns: 1fr;
  }
  .costs__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .rtd-fp--fresha .pricing__grid {
    grid-template-columns: 1fr;
    max-width: 400px;
  }
}

@media (max-width: 768px) {
  .rtd-fp--fresha .hero--fresha {
    padding: 60px 0 80px;
  }
  .rtd-fp--fresha .hero h1 {
    font-size: 36px;
  }
  .calc-card {
    padding: 24px;
  }
  .calc-card__inputs {
    grid-template-columns: 1fr;
  }
  .calc-field input {
    font-size: 20px;
  }
  .calc-savings__value {
    font-size: 32px;
  }
  .costs__grid {
    grid-template-columns: 1fr;
  }
  .tl__track {
    padding-left: 60px;
  }
  .tl__track::before {
    left: 23px;
  }
  .tl__num {
    left: -60px;
    width: 36px;
    height: 36px;
    font-size: 12px;
  }
  .final__content h2 {
    font-size: 28px;
  }
}
