/* ────────────────────────────────────────────────────────────
   All Service Leads — FX Amplify Layer
   Adds motion, atmosphere, and tactility on top of site-shell.css.
   Loaded AFTER site-shell.css so selectors win.
   ──────────────────────────────────────────────────────────── */

/* ════════════════════════════════════════════════════
   PALETTE — warm stone neutrals + brand orange
   ════════════════════════════════════════════════════ */
:root {
  --bg: #fafaf9 !important;
  --bg-card: #ffffff !important;
  --bg-card-hover: #fafaf9 !important;
  --bg-surface: #f5f5f4 !important;
  --bg-hero: #fafaf9 !important;
  --text: #1c1917 !important;
  --text-secondary: #57534e !important;
  --text-muted: #a8a29e !important;
  --border: #e7e5e4 !important;
  --border-light: #f5f5f4 !important;
  --border-dark: #d6d3d1 !important;

  --accent: #ea580c !important;
  --accent-hover: #c2410c !important;
  --accent-light: #fff7ed !important;
  --accent-lighter: #fed7aa !important;

  --fx-warm-deep: #1c1917;
  --fx-warm-deep-2: #292524;
  --fx-orange: #ea580c;
  --fx-orange-deep: #c2410c;
  --fx-orange-bright: #f97316;
  --fx-orange-glow: rgba(234,88,12,0.30);
  --fx-orange-mist: rgba(234,88,12,0.06);
  --fx-glass: rgba(250,250,249,0.82);
}

body { background: var(--bg) !important; color: var(--text) !important; }

.dark-cta-section, #pre-footer, .marquee-strip.dark, section[style*="#0f172a"] {
  background-color: var(--fx-warm-deep) !important;
}

.marquee-strip:not(.dark) {
  background: var(--fx-warm-deep) !important;
  border-top: 1px solid rgba(234,88,12,0.18);
  border-bottom: 1px solid rgba(234,88,12,0.18);
}
.marquee-strip:not(.dark) .marquee-track span {
  color: #d6d3d1 !important; font-weight: 600 !important; letter-spacing: 0.12em !important;
}
.marquee-strip:not(.dark) .marquee-track span::before {
  background: var(--fx-orange) !important; opacity: 0.7;
}

/* ── Animated aurora background — warm orange ──── */
.fx-aurora {
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none; overflow: hidden; opacity: 0.85;
}
.fx-aurora::before, .fx-aurora::after, .fx-aurora .fx-blob {
  content: ''; position: absolute; border-radius: 50%;
  filter: blur(110px); will-change: transform;
}
.fx-aurora::before {
  width: 820px; height: 820px;
  background: radial-gradient(circle, rgba(234,88,12,0.14) 0%, transparent 65%);
  top: -20%; left: -14%;
  animation: fx-drift-a 26s ease-in-out infinite;
}
.fx-aurora::after {
  width: 660px; height: 660px;
  background: radial-gradient(circle, rgba(249,115,22,0.12) 0%, transparent 65%);
  bottom: -10%; right: -10%;
  animation: fx-drift-b 32s ease-in-out infinite;
}
.fx-aurora .fx-blob {
  width: 540px; height: 540px;
  background: radial-gradient(circle, rgba(194,65,12,0.08) 0%, transparent 65%);
  top: 38%; right: 28%;
  animation: fx-drift-c 28s ease-in-out infinite;
}
.fx-aurora .fx-blob.b2 {
  width: 440px; height: 440px;
  background: radial-gradient(circle, rgba(234,88,12,0.08) 0%, transparent 65%);
  top: 62%; left: 18%;
  animation: fx-drift-d 34s ease-in-out infinite;
}
body > nav, body > div.page, body > section, body > footer { position: relative; z-index: 1; }

@keyframes fx-drift-a {
  0%, 100% { transform: translate(0,0) scale(1); }
  33% { transform: translate(120px, -60px) scale(1.15); }
  66% { transform: translate(-80px, 80px) scale(0.95); }
}
@keyframes fx-drift-b {
  0%, 100% { transform: translate(0,0) scale(1); }
  50% { transform: translate(-100px, -60px) scale(1.2); }
}
@keyframes fx-drift-c {
  0%, 100% { transform: translate(0,0) scale(1); }
  40% { transform: translate(-60px, 40px) scale(1.1); }
  80% { transform: translate(80px, -50px) scale(0.9); }
}
@keyframes fx-drift-d {
  0%, 100% { transform: translate(0,0) scale(0.9); }
  50% { transform: translate(60px, -40px) scale(1.15); }
}

/* ── Scroll progress bar ─────────────────────────── */
.fx-progress {
  position: fixed; top: 0; left: 0; height: 2px;
  background: linear-gradient(90deg, var(--fx-orange-deep), var(--fx-orange-bright));
  width: 0; z-index: 99999; pointer-events: none;
  box-shadow: 0 0 10px rgba(234,88,12,0.40);
  transition: width 0.08s linear;
}

/* ── Marquee band ────────────────────────────────── */
.fx-marquee {
  background: var(--fx-warm-deep); color: #f5f5f4;
  overflow: hidden; padding: 26px 0;
  border-top: 1px solid rgba(234,88,12,0.20);
  border-bottom: 1px solid rgba(234,88,12,0.20);
  position: relative; z-index: 2;
}
.fx-marquee::before, .fx-marquee::after {
  content: ''; position: absolute; top: 0; bottom: 0;
  width: 160px; z-index: 3; pointer-events: none;
}
.fx-marquee::before { left: 0; background: linear-gradient(90deg, var(--fx-warm-deep), transparent); }
.fx-marquee::after { right: 0; background: linear-gradient(-90deg, var(--fx-warm-deep), transparent); }
.fx-marquee-track {
  display: inline-flex; white-space: nowrap;
  animation: fx-marquee 40s linear infinite;
  gap: 56px; padding-right: 56px; align-items: center;
}
.fx-marquee-track > span {
  font-size: 22px; font-weight: 700; letter-spacing: 0.04em;
  display: inline-flex; align-items: center; gap: 56px;
  text-transform: uppercase; color: #d6d3d1;
}
.fx-marquee-track .accent { color: var(--fx-orange); font-weight: 800; }
.fx-marquee-track .sep {
  width: 6px; height: 6px; background: var(--fx-orange);
  border-radius: 50%; display: inline-block; flex-shrink: 0; opacity: 0.6;
}
@keyframes fx-marquee { to { transform: translateX(-50%); } }

/* ── Gradient text utility ───────────────────────── */
.fx-gradient-text {
  background: linear-gradient(135deg, var(--fx-orange-deep) 0%, var(--fx-orange) 100%);
  -webkit-background-clip: text; background-clip: text;
  color: transparent; display: inline-block; padding-right: 4px;
}

/* ── Hero enhancements ───────────────────────────── */
#hero-headline { perspective: 800px; }
#hero-headline .fx-char {
  display: inline-block; opacity: 0;
  transform: translateY(80px) rotateX(-90deg);
  transform-origin: 50% 100%; will-change: opacity, transform;
}
#hero-headline.fx-typed .fx-char {
  animation: fx-char-in 0.7s cubic-bezier(0.16,1,0.3,1) forwards;
}
@keyframes fx-char-in { to { opacity: 1; transform: translateY(0) rotateX(0); } }

.hero-phone-mockup { animation: fx-float 6s ease-in-out infinite; will-change: transform; }
@keyframes fx-float {
  0%, 100% { transform: translateY(0) rotate(0); }
  50% { transform: translateY(-14px) rotate(0.6deg); }
}

.hero-price-chip { position: relative; overflow: visible; }
.hero-price-chip::after {
  content: ''; position: absolute; inset: -3px; border-radius: 999px;
  border: 2px solid rgba(234,88,12,0.4); opacity: 0;
  animation: fx-chip-pulse 2.6s ease-out infinite; pointer-events: none;
}
@keyframes fx-chip-pulse {
  0% { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.35); }
}

/* ── Glassy nav on scroll ────────────────────────── */
.site-nav {
  transition: background 0.35s ease, padding 0.3s, box-shadow 0.35s, border-color 0.3s !important;
  background: var(--fx-glass) !important;
  border-bottom-color: rgba(231,229,228,0.6) !important;
}
.site-nav.fx-scrolled {
  background: rgba(250,250,249,0.92) !important;
  box-shadow: 0 6px 30px rgba(28,25,23,0.05);
  border-bottom-color: rgba(214,211,209,0.7) !important;
}

/* ── Buttons — glow + shine ──────────────────────── */
.btn-hero, .btn-add {
  position: relative; z-index: 1;
  background: var(--fx-orange) !important;
  letter-spacing: -0.005em !important;
}
.btn-hero:hover, .btn-add:hover { background: var(--fx-orange-deep) !important; }
.btn-hero::before, .btn-add::before {
  content: ''; position: absolute; inset: -2px;
  background: linear-gradient(135deg, var(--fx-orange), var(--fx-orange-deep));
  border-radius: inherit; z-index: -1; opacity: 0;
  filter: blur(18px); transition: opacity 0.4s ease; pointer-events: none;
}
.btn-hero:hover::before, .btn-add:hover::before { opacity: 0.55; }
.btn-hero::after, .btn-add::after {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.4) 50%, transparent 70%);
  opacity: 0; transform: translateX(-100%); pointer-events: none;
}
.btn-hero:hover::after, .btn-add:hover::after {
  opacity: 1; animation: fx-shine 0.9s ease-out forwards;
}
@keyframes fx-shine { to { transform: translateX(100%); } }

/* ── Cards — spotlight + 3D ──────────────────────── */
.feature-card, .product-highlight-card, .dash-stat {
  transform-style: preserve-3d;
  transition: transform 0.5s cubic-bezier(0.16,1,0.3,1), box-shadow 0.4s ease, border-color 0.3s, background 0.3s !important;
  position: relative; overflow: hidden;
}
.feature-card::after {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), rgba(234,88,12,0.10), transparent 60%);
  opacity: 0; transition: opacity 0.3s; pointer-events: none;
}
.feature-card:hover::after { opacity: 1; }
.feature-card { background: #ffffff !important; border-color: var(--border) !important; }
.feature-card:hover { border-color: rgba(234,88,12,0.20) !important; }
.feature-card .feature-icon {
  display: inline-flex; width: 46px; height: 46px;
  background: rgba(234,88,12,0.06); border-radius: 12px;
  align-items: center; justify-content: center; margin-bottom: 18px;
  transition: transform 0.4s cubic-bezier(0.16,1,0.3,1), background 0.3s;
}
.feature-card:hover .feature-icon {
  transform: rotate(-4deg) scale(1.08); background: rgba(234,88,12,0.10);
}

/* ── Section reveal ──────────────────────────────── */
.fx-reveal {
  opacity: 0; transform: translateY(60px);
  transition: opacity 0.9s cubic-bezier(0.16,1,0.3,1), transform 0.9s cubic-bezier(0.16,1,0.3,1);
}
.fx-reveal.fx-in { opacity: 1; transform: translateY(0); }

/* ── Stats band ──────────────────────────────────── */
.fx-stats-band {
  padding: 100px 0;
  background: radial-gradient(ellipse at 30% 0%, rgba(234,88,12,0.04), transparent 60%), linear-gradient(180deg, var(--bg) 0%, #f5f5f4 100%);
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  position: relative; overflow: hidden; z-index: 2;
}
.fx-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; text-align: center; }
.fx-stat { padding: 20px 16px; border-right: 1px solid var(--border); position: relative; }
.fx-stat:last-child { border-right: none; }
.fx-stat-num {
  font-size: clamp(48px, 6.5vw, 88px); font-weight: 800; color: var(--text);
  line-height: 1; letter-spacing: -0.055em; margin-bottom: 14px;
  font-feature-settings: 'tnum', 'ss01'; font-variant-numeric: tabular-nums;
  position: relative; display: inline-block;
  font-family: 'Instrument Serif', serif;
}
.fx-stat-num::after {
  content: ''; position: absolute; left: 50%; bottom: -10px;
  width: 36px; height: 2px; background: var(--fx-orange);
  transform: translateX(-50%); opacity: 0.7;
}
.fx-stat-lbl {
  font-size: 11px; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.18em; margin-top: 6px;
}
@media (max-width: 800px) {
  .fx-stats-grid { grid-template-columns: 1fr 1fr; gap: 0; }
  .fx-stat:nth-child(2) { border-right: none; }
  .fx-stat { border-bottom: 1px solid var(--border); padding: 28px 12px; }
  .fx-stat:nth-last-child(-n+2) { border-bottom: none; }
}

/* ── Live activity ticker ────────────────────────── */
.fx-ticker {
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(28,25,23,0.04); border: 1px solid rgba(28,25,23,0.10);
  color: var(--text); padding: 8px 16px; border-radius: 999px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.02em;
  margin-bottom: 22px; backdrop-filter: blur(6px);
}
.fx-ticker-text {
  transition: opacity 0.2s; white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis; max-width: 320px;
}
.fx-ticker-pulse {
  width: 7px; height: 7px; background: var(--fx-orange);
  border-radius: 50%; position: relative; flex-shrink: 0;
}
.fx-ticker-pulse::before {
  content: ''; position: absolute; inset: -3px;
  background: var(--fx-orange); border-radius: 50%; opacity: 0.45;
  animation: fx-pulse-ring 1.6s ease-out infinite;
}
@keyframes fx-pulse-ring {
  0% { transform: scale(1); opacity: 0.45; }
  100% { transform: scale(2.6); opacity: 0; }
}

/* ── Hover lift ──────────────────────────────────── */
.fx-lift { transition: transform 0.4s cubic-bezier(0.16,1,0.3,1), box-shadow 0.4s ease; }
.fx-lift:hover { transform: translateY(-6px); box-shadow: 0 24px 60px rgba(234,88,12,0.18); }

/* ── Word ring emphasis ──────────────────────────── */
.fx-ring { position: relative; display: inline-block; padding: 0 6px; }
.fx-ring::after {
  content: ''; position: absolute; inset: -8px -10px;
  border: 2px solid #ea580c; border-radius: 999px;
  transform: rotate(-2deg); pointer-events: none; opacity: 0;
  animation: fx-ring-in 0.8s 1.4s cubic-bezier(0.16,1,0.3,1) forwards;
}
@keyframes fx-ring-in {
  0% { opacity: 0; transform: rotate(-2deg) scale(1.4); }
  100% { opacity: 1; transform: rotate(-2deg) scale(1); }
}

/* ── Dot-grid backdrop ───────────────────────────── */
.fx-grid {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image: radial-gradient(circle, rgba(28,25,23,0.045) 1px, transparent 1px);
  background-size: 28px 28px; background-position: 0 0;
  animation: fx-grid-drift 80s linear infinite;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
}
@keyframes fx-grid-drift { to { background-position: 28px 28px; } }

/* ── Cursor spotlight (desktop) ──────────────────── */
@media (hover: hover) and (pointer: fine) {
  .fx-spotlight {
    position: fixed; width: 420px; height: 420px;
    border-radius: 50%; pointer-events: none; z-index: 0;
    background: radial-gradient(circle, rgba(234,88,12,0.06) 0%, transparent 70%);
    transform: translate(-50%, -50%);
    transition: opacity 0.3s;
    will-change: left, top;
  }
}

/* ── Nav-link underline draw ─────────────────────── */
.site-nav .nav-link { position: relative; padding-bottom: 4px; }
.site-nav .nav-link::after {
  content: ''; position: absolute; left: 0; right: 100%; bottom: 0;
  height: 2px; background: var(--fx-orange);
  transition: right 0.35s cubic-bezier(0.16,1,0.3,1); border-radius: 2px;
}
.site-nav .nav-link:hover::after, .site-nav .nav-link.active::after { right: 0; }

/* ── Animated chevron on CTAs ────────────────────── */
.btn-hero span, .btn-add span, .btn-hero .arrow, button[onclick*="Page"] span {
  display: inline-block;
  transition: transform 0.4s cubic-bezier(0.16,1,0.3,1);
  will-change: transform;
}
.btn-hero:hover span, .btn-add:hover span, .btn-hero:hover .arrow { transform: translateX(6px); }

/* ── Section heading underline draw ──────────────── */
.section-heading, .section-heading-plain {
  position: relative; display: inline-block; padding-bottom: 10px;
}
.section-heading::after, .section-heading-plain::after {
  content: ''; position: absolute; left: 0; bottom: 0;
  width: 0; height: 3px;
  background: linear-gradient(90deg, var(--fx-orange), var(--fx-orange-bright));
  border-radius: 3px;
  transition: width 1.4s cubic-bezier(0.16,1,0.3,1) 0.2s;
}
.section-heading.fx-in::after, .section-heading-plain.fx-in::after { width: 72px; }

/* ── CTA halo pulse ──────────────────────────────── */
.hero .btn-hero { animation: fx-cta-pulse 3.4s ease-in-out infinite; }
@keyframes fx-cta-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(234,88,12,0.0), 0 8px 24px rgba(234,88,12,0.12); }
  50% { box-shadow: 0 0 0 14px rgba(234,88,12,0.0), 0 8px 36px rgba(234,88,12,0.25); }
}

/* ── Card shimmer sweep ──────────────────────────── */
.feature-card, .product-highlight-card, .dash-stat { position: relative; overflow: hidden; }
.feature-card .fx-shimmer, .product-highlight-card .fx-shimmer, .dash-stat .fx-shimmer {
  position: absolute; top: 0; bottom: 0; left: -75%; width: 50%;
  background: linear-gradient(120deg, transparent 0%, rgba(234,88,12,0.10) 50%, transparent 100%);
  transform: skewX(-18deg); pointer-events: none;
  transition: left 0.85s cubic-bezier(0.16,1,0.3,1); z-index: 1;
}
.feature-card:hover .fx-shimmer, .product-highlight-card:hover .fx-shimmer, .dash-stat:hover .fx-shimmer { left: 125%; }

/* ── Phone mockup glow ───────────────────────────── */
.phone-frame {
  box-shadow: 0 30px 80px rgba(234,88,12,0.15), 0 12px 24px rgba(28,25,23,0.10) !important;
  transition: box-shadow 0.5s ease;
}
.phone-frame:hover {
  box-shadow: 0 40px 100px rgba(234,88,12,0.25), 0 16px 32px rgba(28,25,23,0.15) !important;
}

/* ── Logo letter cascade ─────────────────────────── */
.site-nav .logo .fx-lchar {
  display: inline-block; opacity: 0; transform: translateY(-12px);
  animation: fx-letter-in 0.55s cubic-bezier(0.16,1,0.3,1) forwards;
}
@keyframes fx-letter-in { to { opacity: 1; transform: translateY(0); } }

/* ── Typography: serif headlines ─────────────────── */
.hero h1, .section-heading, .section-heading-plain, .dark-cta-content h2 {
  font-family: 'Instrument Serif', 'Inter Tight', serif !important;
  font-style: italic;
}

/* ══════════════════════════════════════════════════
   SEAMLESS SINGLE-PAGE SCROLL — papiai.co style
   No section borders, no background swaps, flowing
   typographic layout, scroll-triggered reveals.
   ══════════════════════════════════════════════════ */

/* Kill every section boundary */
.hero, .how-it-works, .features, .product-highlight, .dash-preview,
#testimonials-section, #faq-section, .fx-stats-band, .marquee-strip,
#section-order, #section-signup {
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
}
.section-wave-divider, .flow-line { display: none !important; }

/* Unified transparent backgrounds — no alternating bands */
.how-it-works, .features, .product-highlight, .dash-preview,
#testimonials-section, #faq-section, #section-order, #section-signup {
  background: transparent !important;
}
.fx-stats-band {
  border: none !important;
  background: transparent !important;
  padding: 80px 0 !important;
}

/* Tighter vertical rhythm — sections feel like one stream */
.how-it-works { padding: 40px 0 60px !important; }
.product-highlight { padding: 20px 0 40px !important; }
.dash-preview { padding: 40px 0 60px !important; }
.features { padding: 40px 0 60px !important; }
#section-order { padding: 40px 0 60px !important; }
#section-signup { padding: 40px 0 60px !important; }

/* ── Steps: vertical timeline, not 4-col grid ──── */
.steps-row {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  max-width: 580px !important;
}
.steps-row::before { display: none !important; }
.step-item {
  display: flex !important;
  gap: 20px !important;
  align-items: flex-start !important;
  padding: 24px 0 !important;
  text-align: left !important;
  border-bottom: 1px solid var(--border) !important;
}
.step-item:last-child { border-bottom: none !important; }
.step-num {
  width: 44px !important; height: 44px !important;
  font-size: 15px !important; flex-shrink: 0;
  margin-bottom: 0 !important;
}

/* ── Features: clean list, not card grid ────────── */
.features-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  max-width: 640px !important;
}
.feature-card {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 28px 0 !important;
  display: flex !important;
  gap: 18px !important;
  align-items: flex-start !important;
}
.feature-card:last-child { border-bottom: none !important; }
.feature-card:hover {
  transform: none !important;
  box-shadow: none !important;
  background: transparent !important;
}
.feature-card .feature-icon { margin-bottom: 0 !important; flex-shrink: 0; }
.feature-card::after { display: none !important; }

/* ── Product highlight: inline prose, not boxed card ── */
.product-highlight-card {
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  max-width: 640px !important;
}
.product-highlight-card::before { display: none !important; }
.product-highlight-card:hover { box-shadow: none !important; }

/* ── Dashboard preview: no chrome, just the mockup ── */
.dash-preview .section-heading-plain,
.dash-preview .section-label { text-align: left !important; }
.dash-preview .container { text-align: left !important; }
.dash-mockup { max-width: 820px !important; }

/* ── Testimonials: seamless ─────────────────────── */
#testimonials-section { padding: 60px 0 40px !important; }

/* ── FAQ: seamless ──────────────────────────────── */
#faq-section { padding: 40px 0 60px !important; }

/* ── Section labels: subtle, flowing ────────────── */
.section-label {
  font-size: 11px !important;
  letter-spacing: 0.14em !important;
  opacity: 0.6;
}

/* ── Scroll-triggered reveal (used by IO in fx-amplify.js) ── */
.rv {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s cubic-bezier(0.16,1,0.3,1),
              transform 0.7s cubic-bezier(0.16,1,0.3,1);
}
.rv.in {
  opacity: 1;
  transform: translateY(0);
}
.rv-left {
  opacity: 0;
  transform: translateX(-32px);
  transition: opacity 0.7s cubic-bezier(0.16,1,0.3,1),
              transform 0.7s cubic-bezier(0.16,1,0.3,1);
}
.rv-left.in {
  opacity: 1;
  transform: translateX(0);
}

/* ── Mobile optimizations ────────────────────────── */
@media (max-width: 768px) {
  .fx-aurora, .fx-grid { display: none !important; }
  .fx-marquee { padding: 18px 0; }
  .fx-marquee-track > span { font-size: 16px; gap: 32px; }
  .fx-marquee-track { gap: 32px; padding-right: 32px; }
  .fx-stats-band { padding: 40px 0 !important; }
  .fx-stat-num { font-size: clamp(36px, 10vw, 56px) !important; }
  .hero h1 { font-size: clamp(32px, 8vw, 48px) !important; }
  .section-heading, .section-heading-plain { font-size: clamp(24px, 6vw, 36px) !important; }
  .fx-ticker { font-size: 11px; padding: 6px 12px; }
  .phone-frame { box-shadow: 0 16px 40px rgba(234,88,12,0.12), 0 8px 16px rgba(28,25,23,0.08) !important; }
  .steps-row, .features-grid, .product-highlight-card { max-width: 100% !important; }
}

/* ── Reduced motion ──────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .fx-aurora, .fx-marquee-track, .hero-phone-mockup, .hero-price-chip::after,
  .fx-gradient-text, .fx-ticker-pulse::before { animation: none !important; }
  #hero-headline .fx-char { opacity: 1 !important; transform: none !important; }
  .fx-reveal { opacity: 1 !important; transform: none !important; }
  .rv, .rv-left { opacity: 1 !important; transform: none !important; }
}
