/* ============================================================
   home.css — homepage sections (dark premium)
   ============================================================ */

/* ── HERO ── */
.hero {
  position: relative; min-height: 100svh;
  display: flex; align-items: center;
  padding-top: 120px; padding-bottom: 80px;
  max-width: var(--maxw); margin-inline: auto;
  isolation: isolate;
}
#aliveHero { z-index: 0; }
.hero-copy { position: relative; z-index: 3; width: min(100%, 640px); }

.hero-scrollcue {
  display: inline-flex; align-items: center; gap: 10px; margin-top: 46px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint);
}
.hero-scrollcue span {
  width: 22px; height: 34px; border: 1px solid var(--line-strong); border-radius: 12px; position: relative;
}
.hero-scrollcue span::after {
  content: ''; position: absolute; left: 50%; top: 7px; width: 3px; height: 7px; margin-left: -1.5px; border-radius: 2px; background: var(--gold);
  animation: scroll-cue 1.8s var(--ease-in-out) infinite;
}
@keyframes scroll-cue { 0%,100%{ opacity: 0; transform: translateY(0); } 40%{ opacity: 1; } 80%{ opacity: 0; transform: translateY(10px); } }

.hero-badge {
  display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
  font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft);
  padding: 8px 16px; border-radius: var(--r-pill);
  background: var(--glass); border: 1px solid var(--line-strong); backdrop-filter: blur(10px);
  margin-bottom: 28px;
}
.hero-badge::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--green-soft); box-shadow: 0 0 10px var(--green-soft); animation: pulse-dot 2.4s var(--ease-in-out) infinite; }
@keyframes pulse-dot { 0%,100%{ opacity: 1; transform: scale(1); } 50%{ opacity: .45; transform: scale(.7); } }

.hero h1 {
  font-size: clamp(2.5rem, 1.4rem + 4vw, 4.6rem); font-weight: 800; letter-spacing: var(--tracking-tight);
  max-width: 13ch; margin-bottom: 26px;
}
.hero h1 .accent {
  position: relative; color: var(--gold);
  background: linear-gradient(120deg, var(--gold-soft), var(--gold), var(--gold-deep));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.hero h1 .accent::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: 0.04em; height: 0.5em;
  background: radial-gradient(60% 100% at 50% 100%, var(--glow-gold), transparent 75%);
  filter: blur(14px); z-index: -1; opacity: 0.6;
}
.hero-sub { font-size: var(--text-lg); color: var(--ink-soft); max-width: 50ch; margin-bottom: 38px; line-height: 1.55; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }

/* Hero automation-flow node graph (kept, restyled for dark) */
.hero-visual.auto-flow { position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0.5; }
@media (min-width: 981px){ .hero-visual.auto-flow { left: 48%; right: 0; width: auto; opacity: 0.92; } }
.auto-beams { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.auto-beam-base { fill: none; stroke: rgba(255,255,255,0.06); stroke-width: 1.4; stroke-dasharray: 3 7; }
.auto-beam-path { fill: none; stroke-linecap: round; filter: drop-shadow(0 0 4px var(--glow-gold)); }
.auto-node {
  position: absolute; left: var(--x, 0); top: var(--y, 0); transform: translate(-50%, -50%);
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  width: 78px; text-align: center;
}
.auto-node > span:first-child {
  width: 46px; height: 46px; display: grid; place-items: center; font-size: 20px;
  border-radius: 13px; background: var(--bg-3); border: 1px solid var(--line-strong);
  box-shadow: var(--shadow); transition: transform .4s var(--ease-spring), box-shadow .4s, border-color .4s;
}
.auto-node-note { font-family: var(--font-mono); font-size: 9px; color: var(--ink-faint); text-transform: uppercase; letter-spacing: 0.08em; }
.auto-node-label { font-size: 11px; font-weight: 600; color: var(--ink-soft); }
.auto-node.is-active > span:first-child {
  transform: scale(1.16); border-color: var(--node-color, var(--gold));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--node-color, var(--gold)) 22%, transparent), 0 0 28px color-mix(in srgb, var(--node-color, var(--gold)) 50%, transparent);
}
@media (max-width: 980px){ .hero-visual.auto-flow { opacity: 0.22; } }

/* ── STATS BAR ── */
.stats-bar {
  position: relative; z-index: 4; max-width: var(--maxw); margin: -10px auto 0;
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: var(--line); border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden;
}
.stat-item { background: var(--bg-1); padding: 30px 26px; transition: background var(--dur); }
.stat-item:hover { background: var(--bg-2); }
.stat-number {
  font-family: var(--font-display); font-weight: 800; font-size: clamp(1.8rem, 1.2rem + 2vw, 2.8rem);
  letter-spacing: var(--tracking-tight);
  background: linear-gradient(135deg, var(--ink), var(--gold)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  margin-bottom: 6px;
}
.stat-label { font-size: 13px; color: var(--ink-mute); }
@media (max-width: 720px){ .stats-bar { grid-template-columns: 1fr 1fr; } }

/* ── SERVICES ── */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-card {
  position: relative; padding: 30px; border-radius: var(--r-lg); overflow: hidden;
  background: var(--bg-2); border: 1px solid var(--line);
  transition: transform var(--dur) var(--ease-out), border-color var(--dur), background var(--dur);
}
.service-card::before {
  content: ''; position: absolute; inset: 0; opacity: 0; transition: opacity var(--dur);
  background: radial-gradient(380px 260px at var(--gx,50%) var(--gy,0%), rgba(255,184,28,0.10), transparent 70%);
}
.service-card:hover { transform: translateY(-6px); border-color: var(--line-gold); background: var(--bg-3); }
.service-card:hover::before { opacity: 1; }
.service-icon {
  width: 52px; height: 52px; display: grid; place-items: center; font-size: 24px; margin-bottom: 20px;
  border-radius: 14px; background: linear-gradient(160deg, var(--bg-4), var(--bg-3)); border: 1px solid var(--line-strong);
  transition: transform var(--dur) var(--ease-spring);
}
.service-card:hover .service-icon { transform: scale(1.08) rotate(-4deg); }
.service-card h3 { font-size: var(--text-lg); margin-bottom: 12px; }
.service-card p { color: var(--ink-mute); font-size: 14.5px; line-height: 1.6; margin-bottom: 18px; }
.service-tag { font-family: var(--font-mono); font-size: 11px; color: var(--gold); letter-spacing: 0.02em; opacity: 0.85; }
@media (max-width: 920px){ .services-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px){ .services-grid { grid-template-columns: 1fr; } }

/* ── PROCESS ── */
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; counter-reset: step; }
.process-step {
  position: relative; padding: 28px 24px; border-radius: var(--r-lg);
  background: var(--bg-2); border: 1px solid var(--line); transition: transform var(--dur), border-color var(--dur);
}
.process-step::after {
  content: ''; position: absolute; top: 50%; right: -10px; width: 20px; height: 1px; background: var(--line-gold);
}
.process-step:last-child::after { display: none; }
.process-step:hover { transform: translateY(-5px); border-color: var(--line-gold); }
.step-num { font-family: var(--font-mono); font-size: 13px; font-weight: 600; color: var(--gold); margin-bottom: 18px; letter-spacing: 0.1em; }
.process-step h4 { font-size: var(--text-lg); margin-bottom: 10px; }
.process-step p { color: var(--ink-mute); font-size: 14px; line-height: 1.6; }
@media (max-width: 920px){ .process-grid { grid-template-columns: 1fr 1fr; } .process-step::after { display: none; } }
@media (max-width: 520px){ .process-grid { grid-template-columns: 1fr; } }

/* ── AUTOMATION FLOWS ── */
.flows-tabs { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 36px; }
.flows-tab {
  display: inline-flex; align-items: center; gap: 9px; font-size: 14px; font-weight: 600; color: var(--ink-soft);
  padding: 12px 20px; border-radius: var(--r-pill); background: var(--bg-2); border: 1px solid var(--line-strong);
  transition: all var(--dur);
}
.flows-tab:hover { border-color: var(--line-gold); color: var(--ink); }
.flows-tab.active { background: linear-gradient(135deg, var(--gold), var(--gold-soft)); color: var(--ink-on-gold); border-color: transparent; box-shadow: var(--shadow-gold); }
.flow-diagram { display: none; }
.flow-diagram.active { display: block; animation: flow-in .5s var(--ease-out); }
@keyframes flow-in { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.flow-header { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 8px; }
.flow-scenario { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; }
.flow-saving { display: flex; flex-direction: column; align-items: flex-end; }
.saving-num { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: var(--green-soft); }
.saving-label { font-size: 11px; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.08em; }
.flow-hint { font-size: 13px; color: var(--ink-faint); margin-bottom: 24px; font-family: var(--font-mono); }

.flow-track { display: flex; align-items: stretch; gap: 0; overflow-x: auto; padding-bottom: 14px; margin-bottom: 30px; scrollbar-width: thin; }
.flow-node {
  position: relative; flex: 0 0 auto; width: 170px; padding: 18px; cursor: pointer;
  border-radius: var(--r); background: var(--bg-2); border: 1px solid var(--line);
  transition: transform var(--dur), border-color var(--dur), background var(--dur);
}
.flow-node:hover, .flow-node.tt-open { transform: translateY(-4px); border-color: var(--line-gold); background: var(--bg-3); }
.flow-node.fn-accent { border-color: var(--line-gold); background: linear-gradient(160deg, var(--bg-3), rgba(255,184,28,0.04)); }
.fn-icon { font-size: 24px; margin-bottom: 12px; }
.fn-label { font-family: var(--font-display); font-weight: 700; font-size: 15px; margin-bottom: 5px; }
.fn-desc { font-size: 12.5px; color: var(--ink-mute); line-height: 1.45; margin-bottom: 10px; }
.fn-tool { font-family: var(--font-mono); font-size: 10px; color: var(--gold); opacity: 0.85; }
.fn-hint { font-size: 10px; color: var(--ink-faint); margin-top: 8px; opacity: 0.7; }
.flow-arrow { flex: 0 0 auto; width: 40px; display: grid; place-items: center; }
.fa-line { position: relative; width: 100%; height: 2px; background: var(--line-strong); border-radius: 2px; overflow: hidden; }
.fa-dot { position: absolute; top: 50%; left: 0; width: 6px; height: 6px; margin-top: -3px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 8px var(--gold); animation: fa-travel 2.4s linear infinite; }
@keyframes fa-travel { from { left: -8px; } to { left: 100%; } }

.fn-tooltip {
  position: absolute; bottom: calc(100% + 12px); left: 50%; transform: translateX(-50%) translateY(8px);
  width: 280px; padding: 16px; border-radius: var(--r); z-index: 20;
  background: var(--bg-4); border: 1px solid var(--line-gold); box-shadow: var(--shadow-lg);
  opacity: 0; visibility: hidden; transition: opacity .28s var(--ease-out), transform .28s var(--ease-out);
  pointer-events: none;
}
.flow-node:hover .fn-tooltip, .flow-node.tt-open .fn-tooltip { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.fn-tooltip-title { font-family: var(--font-display); font-weight: 700; font-size: 14px; color: var(--gold); margin-bottom: 7px; }
.fn-tooltip-body { font-size: 12.5px; color: var(--ink-soft); line-height: 1.55; }

.flow-before-after { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 20px; }
.ba-card { padding: 24px; border-radius: var(--r-lg); border: 1px solid var(--line); }
.ba-before { background: rgba(222,56,49,0.05); border-color: rgba(222,56,49,0.22); }
.ba-after { background: rgba(31,164,99,0.06); border-color: rgba(31,164,99,0.26); }
.ba-label { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 8px; }
.ba-before .ba-label { color: var(--red); } .ba-after .ba-label { color: var(--green-soft); }
.ba-time { font-family: var(--font-display); font-weight: 700; font-size: 17px; margin-bottom: 16px; }
.ba-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.ba-list li { font-size: 13.5px; color: var(--ink-mute); padding-left: 22px; position: relative; }
.ba-before .ba-list li::before { content: '✕'; position: absolute; left: 0; color: var(--red); opacity: 0.7; }
.ba-after .ba-list li::before { content: '✓'; position: absolute; left: 0; color: var(--green-soft); }
.ba-arrow { font-size: 28px; color: var(--gold); }
.flows-cta { margin-top: 44px; text-align: center; }
.flows-cta p { color: var(--ink-mute); margin-bottom: 16px; }
@media (max-width: 720px){ .flow-before-after { grid-template-columns: 1fr; } .ba-arrow { transform: rotate(90deg); justify-self: center; } }

/* ── INDUSTRIES ── */
.industries-grid { display: flex; flex-wrap: wrap; gap: 12px; }
.industry-tag {
  font-size: 14px; font-weight: 500; color: var(--ink-soft);
  padding: 11px 20px; border-radius: var(--r-pill); background: var(--bg-2); border: 1px solid var(--line-strong);
  transition: all var(--dur) var(--ease-out);
}
.industry-tag:hover { color: var(--ink); border-color: var(--line-gold); transform: translateY(-3px); }
.industry-tag.featured { background: linear-gradient(135deg, rgba(255,184,28,0.14), rgba(200,112,42,0.08)); border-color: var(--line-gold); color: var(--gold); }

/* ── CASE STUDIES ── */
.case-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.case-card {
  position: relative; padding: 36px; border-radius: var(--r-xl); overflow: hidden;
  background: linear-gradient(165deg, var(--bg-3), var(--bg-2)); border: 1px solid var(--line);
  transition: transform var(--dur), border-color var(--dur);
}
.case-card::after { content: ''; position: absolute; top: -40%; right: -20%; width: 320px; height: 320px; border-radius: 50%; background: radial-gradient(circle, rgba(255,184,28,0.10), transparent 70%); pointer-events: none; }
.case-card:hover { transform: translateY(-6px); border-color: var(--line-gold); }
.case-industry { font-family: var(--font-mono); font-size: 12px; color: var(--gold); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 16px; }
.case-card h3 { font-size: var(--text-lg); line-height: 1.25; margin-bottom: 14px; }
.case-card p { color: var(--ink-mute); font-size: 14.5px; line-height: 1.6; margin-bottom: 26px; }
.case-stats { display: flex; gap: 40px; }
.case-stat-val { font-family: var(--font-display); font-weight: 800; font-size: 2rem; color: var(--ink); }
.case-stat-label { font-size: 12px; color: var(--ink-mute); }
@media (max-width: 720px){ .case-grid { grid-template-columns: 1fr; } }

/* ── PRICING ── */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: start; }
.pricing-card {
  position: relative; padding: 34px 28px; border-radius: var(--r-xl);
  background: var(--bg-2); border: 1px solid var(--line); transition: transform var(--dur), border-color var(--dur);
}
.pricing-card:hover { transform: translateY(-6px); border-color: var(--line-gold); }
.pricing-card.popular {
  background: linear-gradient(170deg, var(--bg-3), var(--bg-2));
  border-color: var(--line-gold); box-shadow: 0 30px 70px -34px var(--glow-gold);
}
.popular-badge {
  position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink-on-gold); padding: 6px 16px; border-radius: var(--r-pill);
  background: linear-gradient(135deg, var(--gold), var(--gold-soft)); box-shadow: var(--shadow-gold);
}
.pricing-tier { font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 14px; }
.pricing-price { font-family: var(--font-display); font-weight: 800; font-size: 2.6rem; letter-spacing: var(--tracking-tight); margin-bottom: 14px; }
.pricing-card.popular .pricing-price { color: var(--gold); }
.pricing-desc { color: var(--ink-mute); font-size: 14px; line-height: 1.55; margin-bottom: 26px; }
.pricing-features { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-bottom: 30px; }
.pricing-feature { font-size: 14px; color: var(--ink-soft); padding-left: 26px; position: relative; }
.pricing-feature::before { content: '✓'; position: absolute; left: 0; color: var(--gold); font-weight: 700; }
.pricing-card .btn-primary, .pricing-card .btn-secondary { width: 100%; justify-content: center; }
@media (max-width: 880px){ .pricing-grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; } }

/* ── FOUNDER ── */
.founder-layout { display: grid; grid-template-columns: 320px 1fr; gap: 48px; align-items: center; }
.founder-photo { position: relative; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--line-strong); aspect-ratio: 4/5; }
.founder-photo img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.2) contrast(1.04); transition: transform .7s var(--ease-out), filter .7s; }
.founder-photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(7,8,10,0.55)); }
.founder-layout:hover .founder-photo img { transform: scale(1.04); filter: grayscale(0) contrast(1.06); }
.founder-content blockquote {
  font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem, 1rem + 1.4vw, 2rem);
  line-height: 1.3; letter-spacing: var(--tracking-snug); color: var(--ink); margin-bottom: 26px; position: relative; padding-left: 26px;
}
.founder-content blockquote::before { content: ''; position: absolute; left: 0; top: 6px; bottom: 6px; width: 3px; border-radius: 3px; background: linear-gradient(var(--gold), var(--gold-deep)); }
.founder-name { font-family: var(--font-display); font-weight: 800; font-size: 19px; margin-bottom: 4px; }
.founder-title { font-family: var(--font-mono); font-size: 12px; color: var(--gold); margin-bottom: 20px; letter-spacing: 0.02em; }
.founder-bio { color: var(--ink-mute); font-size: 15px; line-height: 1.7; max-width: 56ch; }
@media (max-width: 760px){ .founder-layout { grid-template-columns: 1fr; gap: 28px; } .founder-photo { max-width: 280px; } }

/* ── FINAL CTA ── */
.cta-section { text-align: center; position: relative; }
.cta-section::before {
  content: ''; position: absolute; left: 50%; top: 40%; transform: translate(-50%,-50%);
  width: min(680px, 90%); aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, var(--glow-ochre), transparent 65%); filter: blur(40px); z-index: -1;
}
.cta-section .section-title { max-width: 20ch; margin-inline: auto; }
.cta-section .section-desc { margin-inline: auto; }
.cta-actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }

/* ── In-flow CTA panels keep readable on dark ── */
.flows-cta .btn-primary { margin-inline: auto; }

/* ============================================================
   v2 — full-bleed bands, stronger CTAs, less-empty wide screens
   ============================================================ */

/* Full-bleed background bands so sections reach the screen edges
   (box-shadow + clip trick — no markup change, content stays centered).
   Avoided on flows (tooltips/h-scroll) to prevent clipping. */
.services-section, .case-section, .pricing-section {
  --band: rgba(255,255,255,0.016);
  box-shadow: 0 0 0 100vw var(--band);
  clip-path: inset(0 -100vw);
}
.pricing-section { --band: rgba(255,184,28,0.025); }

/* Service cards: persistent corner arrow that lights up — signals they're actionable */
.service-card { cursor: pointer; }
.service-card::after {
  content: '→'; position: absolute; top: 24px; right: 26px; font-size: 18px;
  color: var(--ink-faint); transition: color var(--dur), transform var(--dur) var(--ease-out);
}
.service-card:hover::after { color: var(--gold); transform: translateX(4px); }

/* Section-level CTA row (drops under a grid to push toward packages) */
.section-cta {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 14px 22px;
  margin-top: 44px; padding: 22px 28px; border-radius: var(--r-lg);
  background: linear-gradient(120deg, var(--bg-2), rgba(255,184,28,0.04));
  border: 1px solid var(--line-gold);
}
.section-cta p { color: var(--ink-soft); font-size: var(--text-base); margin: 0; }
.section-cta p b { color: var(--ink); font-weight: 700; }
.section-cta-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.section-cta .btn-secondary { padding: 12px 22px; }

/* Mini price hint on pricing tiers + clearer package link */
.pricing-card .pricing-tier { display: flex; align-items: center; justify-content: space-between; }
.pricing-card .tier-from { font-family: var(--font-mono); font-size: 10px; color: var(--ink-faint); letter-spacing: 0.06em; }

/* ── STICKY CTA BAR (reveals after hero) ── */
.sticky-cta {
  position: fixed; left: 50%; bottom: 22px; transform: translate(-50%, 140%);
  z-index: var(--z-nav);
  display: flex; align-items: center; gap: 18px;
  padding: 12px 14px 12px 24px; border-radius: var(--r-pill);
  background: rgba(16,18,22,0.82); backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  border: 1px solid var(--line-gold); box-shadow: var(--shadow-lg), 0 0 40px -18px var(--glow-gold);
  transition: transform .5s var(--ease-out), opacity .4s; opacity: 0;
  max-width: calc(100vw - 24px);
}
.sticky-cta.show { transform: translate(-50%, 0); opacity: 1; }
.sticky-cta-text { font-family: var(--font-display); font-weight: 600; font-size: 14px; color: var(--ink); white-space: nowrap; }
.sticky-cta-text b { color: var(--gold); }
.sticky-cta-actions { display: flex; gap: 8px; }
.sticky-cta .btn-primary { padding: 11px 18px; font-size: 13px; }
.sticky-cta .sticky-ghost {
  font-family: var(--font-display); font-weight: 600; font-size: 13px; color: var(--ink-soft);
  padding: 11px 16px; border-radius: var(--r-pill); border: 1px solid var(--line-strong);
  transition: color var(--dur), border-color var(--dur), background var(--dur); white-space: nowrap;
}
.sticky-cta .sticky-ghost:hover { color: var(--gold); border-color: var(--line-gold); background: var(--bg-3); }
@media (max-width: 620px) {
  .sticky-cta { left: 12px; right: 12px; transform: translateY(140%); bottom: 14px; gap: 10px; padding: 10px 10px 10px 18px; }
  .sticky-cta.show { transform: translateY(0); }
  .sticky-cta-text { font-size: 12px; white-space: normal; }
  .sticky-cta-text .sc-long { display: none; }
}
