/* =========================================================================
   LISTLEY — PAGE SECTIONS  (hero · story · pricing · safety · faq · bento)
   ========================================================================= */

/* ===================== HERO ===================== */
.hero { position: relative; padding-top: clamp(120px, 15vh, 180px); padding-bottom: 0; overflow: hidden; }
.hero-glow { position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(48% 40% at 50% 8%, rgba(230,57,70,.16), transparent 70%),
    radial-gradient(40% 38% at 82% 30%, rgba(124,58,237,.14), transparent 70%),
    radial-gradient(40% 38% at 16% 36%, rgba(37,99,235,.12), transparent 70%); }
[data-theme="dark"] .hero-glow { background:
    radial-gradient(48% 40% at 50% 8%, rgba(230,57,70,.22), transparent 70%),
    radial-gradient(40% 38% at 82% 30%, rgba(124,58,237,.2), transparent 70%),
    radial-gradient(40% 38% at 16% 36%, rgba(37,99,235,.18), transparent 70%); }

.hero-inner { position: relative; z-index: 2; text-align: center; }

/* floating stage */
.hero-stage { position: relative; height: clamp(360px, 46vw, 560px); margin: 8px auto 0; max-width: 1080px; }
.hero-center { position:absolute; inset:0; display:grid; place-content:center; z-index:5; text-align:center; }
.hero-logo {
  width: clamp(124px, 16vw, 188px); aspect-ratio: 380 / 442; height: auto;
  margin: 0 auto 22px; position: relative;
  background-image: url(../img/logo-red.png);
  background-size: contain; background-repeat: no-repeat; background-position: center;
  filter: drop-shadow(0 22px 44px rgba(230,57,70,.28));
  animation: logoFloat calc(7s / max(var(--motion),.35)) var(--ease-soft) infinite;
}
[data-theme="dark"] .hero-logo { background-image: url(../img/logo-white.png); filter: drop-shadow(0 22px 50px rgba(0,0,0,.5)); }
.hero-logo b { display: none; }
@keyframes logoFloat { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-12px); } }

/* floating tool cards */
.float-card {
  position: absolute; z-index: 3;
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px 12px 12px; border-radius: var(--r-md);
  background: var(--glass); -webkit-backdrop-filter: blur(14px) saturate(170%); backdrop-filter: blur(14px) saturate(170%);
  border: 1px solid var(--glass-brd); box-shadow: var(--shadow-lg);
  transform: translate(var(--px,0), var(--py,0)) perspective(700px) rotateX(var(--rx,0)) rotateY(var(--ry,0));
  transition: box-shadow var(--t-med) var(--ease-out);
  will-change: transform; cursor: default;
  animation: cardDrift var(--drift,9s) var(--ease-soft) infinite; animation-delay: var(--ddelay,0s);
}
.float-card .fc-ic { width: 38px; height: 38px; border-radius: 11px; display:grid; place-items:center; flex:none; }
.float-card .fc-ic svg { width:19px; height:19px; }
.float-card .fc-tx { line-height:1.15; }
.float-card .fc-tx .l { font-weight:600; font-size:.92rem; letter-spacing:-.01em; }
.float-card .fc-tx .s { font-size:.72rem; color: var(--muted); }
.float-card:hover { box-shadow: var(--shadow-xl); }
@keyframes cardDrift { 0%,100%{ translate: 0 0; } 50%{ translate: 0 calc(-1 * var(--driftamt, 14px)); } }
[data-motion="off"] .float-card, [data-motion="off"] .hero-logo { animation: none !important; }

/* ===================== HERO ORBIT (smooth, click-to-takeover) ===================== */
/* narrative bridge from CTA into the universe */
.orbit-intro { text-align: center; margin-top: clamp(22px, 3.4vw, 44px); position: relative; z-index: 4; }
.orbit-intro .eyebrow { display: inline-flex; }
.orbit-conn { display: block; width: 1px; height: clamp(30px, 4.5vw, 54px); margin: 0 auto clamp(16px, 2vw, 24px);
  background: linear-gradient(to bottom, transparent, var(--border-strong)); position: relative; overflow: hidden; }
.orbit-conn::after { content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 45%;
  background: linear-gradient(to bottom, transparent, var(--brand-red));
  animation: connFlow calc(2.6s / max(var(--motion), .35)) var(--ease-soft) infinite; }
@keyframes connFlow { 0% { transform: translateY(-110%); opacity: 0; } 25% { opacity: 1; } 100% { transform: translateY(360%); opacity: 0; } }
[data-motion="off"] .orbit-conn::after { display: none; }
.orbit-lead { color: var(--muted); font-size: 1.02rem; margin-top: 10px; }
.orbit-lead strong { color: var(--ink); font-weight: 600; }

.hero-orbit { position: relative; width: 100%; height: clamp(420px, 52vw, 600px); margin-top: clamp(14px, 2.5vw, 34px);
  perspective: 1200px; touch-action: pan-y; }
.hero-orbit::before {
  content: ""; position: absolute; left: 50%; top: 47%; width: min(80%, 720px); aspect-ratio: 1.2 / 1;
  transform: translate(-50%, -50%); pointer-events: none; z-index: 0;
  background: radial-gradient(closest-side, rgba(230,57,70,.13), rgba(124,58,237,.09) 48%, transparent 74%);
  filter: blur(28px);
}
[data-theme="dark"] .hero-orbit::before {
  background: radial-gradient(closest-side, rgba(230,57,70,.2), rgba(124,58,237,.14) 48%, transparent 74%);
}
.orbit-center { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 60; }
.orbit-tool {
  position: absolute; left: 50%; top: 50%; z-index: 10;
  display: flex; align-items: center; gap: 11px;
  padding: 11px 17px 11px 11px; border-radius: var(--r-md);
  background: var(--surface); border: 1px solid var(--border); box-shadow: var(--shadow-md);
  cursor: pointer; white-space: nowrap; will-change: transform, opacity;
  transition: box-shadow .25s var(--ease-out), border-color .2s;
  transform: translate(-50%,-50%);
}
.orbit-tool:hover { box-shadow: var(--shadow-lg); border-color: var(--border-strong); }
.orbit-tool .ot-ic { width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; flex: none; }
.orbit-tool .ot-ic svg { width: 19px; height: 19px; }
.orbit-tool .ot-l { font-weight: 600; font-size: .95rem; letter-spacing: -.01em; }
.orbit-tool .ot-pro { font-size: .56rem; font-weight: 800; color: #fff; background: var(--pro-blue); padding: 2px 6px; border-radius: 5px; letter-spacing: .04em; margin-left: 2px; }
@media (max-width: 600px){ .orbit-tool { padding: 9px 13px 9px 9px; gap: 8px; } .orbit-tool .ot-ic { width: 32px; height: 32px; } .orbit-tool .ot-l { font-size: .84rem; } }
@media (max-width: 820px){ .orbit-tool.opt { display: none; } }
.orbit-hint { display: inline-flex; align-items: center; gap: 8px; margin: clamp(10px,2vw,22px) auto 0;
  max-width: 90%; padding: 9px 18px; border-radius: var(--r-pill);
  font-size: .85rem; font-weight: 500; color: var(--muted); background: var(--surface-2); border: 1px solid var(--border); }
.orbit-hint svg { width: 15px; height: 15px; color: var(--brand-red); }

/* ===================== TOOLKIT TAKEOVER ===================== */
.toolkit-ov { position: fixed; inset: 0; z-index: 200; padding: 24px;
  background: rgba(8,8,11,.62); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  display: grid; place-items: center; overflow-y: auto;
  opacity: 0; pointer-events: none; transition: opacity .35s var(--ease-out); }
[data-theme="light"] .toolkit-ov { background: rgba(20,18,26,.5); }
.toolkit-ov.open { opacity: 1; pointer-events: auto; }
.ov-inner { display: grid; grid-template-columns: 1fr auto; gap: clamp(28px,5vw,72px); align-items: center;
  max-width: 1000px; width: 100%; margin: auto;
  transform: scale(.95) translateY(14px); opacity: .6; transition: transform .42s var(--ease-out), opacity .42s; }
.toolkit-ov.open .ov-inner { transform: none; opacity: 1; }
@media (max-width: 800px){ .ov-inner { grid-template-columns: 1fr; justify-items: center; text-align: center; gap: 28px; padding: 60px 0 20px; } }
.ov-head { color: #fff; max-width: 420px; transition: opacity .22s var(--ease-out), transform .22s var(--ease-out); }
.ov-head.swapping { opacity: 0; transform: translateY(8px); }
.ov-head .eyebrow { color: rgba(255,255,255,.6); }
.ov-head h2 { font-size: clamp(2.2rem,5vw,3.6rem); font-weight: 800; letter-spacing: -.04em; line-height: 1; margin: 14px 0 16px; color:#fff; }
.ov-head p { color: rgba(255,255,255,.72); font-size: 1.05rem; line-height: 1.5; }
.ov-head .ov-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 22px; }
@media (max-width: 800px){ .ov-head .ov-tags { justify-content: center; } }
.ov-mock { position: relative; }
.ov-mock .glowpad { position: absolute; inset: -12% -16%; z-index: 0; pointer-events: none; filter: blur(26px);
  background: radial-gradient(60% 60% at 50% 30%, rgba(124,58,237,.34), transparent 70%); }
.ov-mock .ext-pop { position: relative; z-index: 1; }
.ov-close { position: fixed; top: 20px; right: 22px; z-index: 210; width: 46px; height: 46px; border-radius: 50%;
  display: grid; place-items: center; font-size: 1.1rem; color: #fff;
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  transition: background .2s, transform .2s; }
.ov-close:hover { background: rgba(255,255,255,.22); transform: rotate(90deg); }

/* mockup showcase */
.mock-wrap { max-width: 460px; margin: 0 auto; position: relative; }
.mock-wrap .glowpad { position:absolute; inset:-10% -14% -12%; z-index:0; pointer-events:none;
  background: radial-gradient(60% 60% at 50% 30%, rgba(124,58,237,.22), transparent 70%); filter: blur(24px); }
.mock-wrap .ext-pop { position: relative; z-index: 1; }

/* workspace: extension beside copy + stats */
.workspace-grid { display: grid; grid-template-columns: 1fr 460px; gap: clamp(36px, 6vw, 84px); align-items: center; }
@media (max-width: 920px){ .workspace-grid { grid-template-columns: 1fr; gap: 44px; justify-items: center; text-align: center; }
  .workspace-grid .workspace-copy { max-width: 560px; } }
.workspace-copy .eyebrow { }
.workspace-copy .lead { margin-top: 18px; }
.workspace-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 40px 32px; margin-top: clamp(36px,4vw,52px); padding-top: clamp(32px,4vw,48px); border-top: 1px solid var(--border); max-width: 460px; }
@media (max-width: 920px){ .workspace-stats { margin-inline: auto; } }
@media (max-width: 420px){ .workspace-stats { gap: 26px 18px; } }
.workspace-stats .stat-num { font-weight: 800; letter-spacing: -.04em; line-height: 1; font-size: clamp(2.3rem, 4.6vw, 3.4rem);
  background: var(--grad-accent); background-size: 200% 100%; -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: gradShift calc(10s / max(var(--motion),.35)) linear infinite; }
.workspace-stats .stat-label { color: var(--muted); font-size: .97rem; margin-top: 7px; }
.workspace-mock { position: relative; }

/* wide stage to float the popup on (home demo) */
.popup-stage { max-width: 940px; margin-inline: auto; border-radius: var(--r-2xl); position: relative; overflow: hidden;
  padding: clamp(40px, 7vw, 84px) clamp(20px,4vw,40px); display: grid; place-items: center;
  background: radial-gradient(110% 130% at 50% -10%, rgba(230,57,70,.12), transparent 55%),
              radial-gradient(110% 130% at 90% 120%, rgba(124,58,237,.16), transparent 55%), var(--surface-2);
  border: 1px solid var(--border); box-shadow: var(--shadow-lg); }
.popup-stage::before { content:""; position:absolute; inset:0; background-image: radial-gradient(var(--dot) 1px, transparent 1px); background-size: 26px 26px; opacity:.6; }
.popup-stage .mock-wrap { position: relative; z-index: 1; }

/* ===================== STAT BAND ===================== */
.stat-band { display:grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px,4vw,48px); text-align:center; }
@media (max-width: 760px){ .stat-band { grid-template-columns: 1fr 1fr; gap: 32px 20px; } }
.stat-band .stat-num { background: var(--grad-accent); background-size:200% 100%; -webkit-background-clip:text; background-clip:text; color:transparent; animation: gradShift calc(10s/max(var(--motion),.35)) linear infinite; }

/* ===================== STORY (pinned scroll) ===================== */
@property --story-accent { syntax: "<color>"; inherits: true; initial-value: #E63946; }
[data-story] { --story-accent: #E63946; transition: --story-accent .7s var(--ease-out); }
[data-motion="off"] [data-story] { transition: none; }
.story-grid { position: relative; }
[data-story] .mock-wrap { position: relative; }
[data-story] .mock-wrap::before {
  content: ""; position: absolute; left: 50%; top: 50%; width: min(320%, 1500px); aspect-ratio: 1.05;
  transform: translate(-50%, -50%); pointer-events: none; z-index: 0;
  background: radial-gradient(closest-side, color-mix(in srgb, var(--story-accent) 26%, transparent), color-mix(in srgb, var(--story-accent) 8%, transparent) 45%, transparent 72%);
  filter: blur(76px); opacity: .95;
}
[data-story] .mock-wrap .glowpad, [data-story] .mock-wrap .ext-pop { position: relative; z-index: 1; }
[data-story] .mock-wrap .glowpad {
  background: radial-gradient(60% 60% at 50% 32%, color-mix(in srgb, var(--story-accent) 32%, transparent), transparent 70%);
}
.story-grid { display: grid; grid-template-columns: 1fr 1.02fr; gap: clamp(40px,6vw,90px); align-items: start; }
@media (max-width: 920px){ .story-grid { grid-template-columns: 1fr; gap: 0; } }
.story-mock { position: sticky; top: clamp(90px, 13vh, 120px); }
@media (max-width: 920px){ .story-mock { position: sticky; top: 78px; margin-bottom: 36px; z-index: 4; } }

.story-steps { display: flex; flex-direction: column; }
.story-step { min-height: 62vh; display: flex; flex-direction: column; justify-content: center; padding: 18px 0;
  opacity: .42; transition: opacity .45s var(--ease-out); }
.story-step.active { opacity: 1; }
[data-motion="off"] .story-step { opacity: 1; }
@media (max-width: 920px){ .story-step { min-height: 46vh; } }
.story-step .num { font-size:.8rem; font-weight:700; letter-spacing:.1em; color: var(--muted-2); margin-bottom: 14px; }
.story-step .feature-ic { margin-bottom: 20px; }
.story-step h3 { font-size: clamp(1.5rem, 2.6vw, 2.2rem); font-weight:700; letter-spacing:-.025em; line-height:1.1; }
.story-step p { margin-top: 14px; color: var(--muted); font-size: 1.06rem; max-width: 42ch; }
.story-step .chips { display:flex; flex-wrap:wrap; gap:8px; margin-top:20px; }

/* ===================== BENTO feature grid ===================== */
.bento { display:grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.bento > * { grid-column: span 2; }
.bento .span3 { grid-column: span 3; } .bento .span4 { grid-column: span 4; } .bento .span6 { grid-column: span 6; }
@media (max-width: 880px){ .bento { grid-template-columns: 1fr 1fr; } .bento > *, .bento .span3, .bento .span4, .bento .span6 { grid-column: span 1; } .bento .wide { grid-column: span 2; } }

/* ===================== PRICING ===================== */
.price-toggle { position:relative; display:inline-flex; align-items:center; gap:4px; padding:5px; border-radius:var(--r-pill);
  background: var(--surface-2); border:1px solid var(--border); }
.price-toggle .tgl-pill { position:absolute; top:5px; bottom:5px; left:0; border-radius:var(--r-pill);
  background:var(--surface); box-shadow:var(--shadow-sm); z-index:0; opacity:0;
  transition: transform .44s var(--ease-out), width .44s var(--ease-out), opacity .2s; }
.price-toggle.pill-ready .tgl-pill { opacity:1; }
.price-toggle button { position:relative; z-index:1; padding:9px 20px; border-radius: var(--r-pill); font-weight:600; font-size:.9rem; color: var(--muted); transition: color .25s var(--ease-out); }
.price-toggle button.on { color: var(--ink); }
.price-toggle .save { font-size:.7rem; color: var(--success); font-weight:700; margin-left:5px; }
[data-motion="off"] .price-toggle .tgl-pill { transition: opacity .2s; }

.price-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: 22px; align-items: stretch; }
@media (max-width: 940px){ .price-grid { grid-template-columns: 1fr; max-width: 440px; margin-inline:auto; } }
.price-card { position: relative; padding: clamp(26px,3vw,36px); border-radius: var(--r-xl); background: var(--surface);
  border:1px solid var(--border); box-shadow: var(--shadow-sm); display:flex; flex-direction:column;
  transition: transform var(--t-med) var(--ease-out), box-shadow var(--t-med) var(--ease-out), border-color var(--t-med); }
.price-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.price-card.premium { border-color: rgba(230,57,70,.35); box-shadow: var(--shadow-md); }
.price-card.pro { border-color: rgba(37,99,235,.5); box-shadow: var(--glow-blue); }
.price-card.pro::before { content:""; position:absolute; inset:-1px; border-radius:inherit; padding:1px; pointer-events:none;
  background: linear-gradient(160deg, rgba(37,99,235,.6), transparent 40%); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; }
.price-name { font-weight:700; font-size:1.2rem; letter-spacing:-.02em; display:flex; align-items:center; gap:10px; }
.price-amt { display:flex; align-items:baseline; gap:4px; margin:18px 0 6px; position:relative; }
.price-amt .cur { font-size:1.3rem; font-weight:600; color: var(--muted); }
.price-amt .num { font-size: clamp(2.6rem,4vw,3.2rem); font-weight:800; letter-spacing:-.04em; line-height:1;
  display:inline-block; position:relative; will-change:transform,opacity,filter;
  transition: transform .3s var(--ease-out), opacity .3s var(--ease-out), filter .3s var(--ease-out); }
.price-amt .num::after { content:""; position:absolute; left:-4%; right:-4%; top:54%; height:5px; border-radius:5px;
  background:var(--brand-red); box-shadow:0 0 14px rgba(230,57,70,.65); transform:scaleX(0); transform-origin:left center; }
.price-amt .num.px-out { transform:translateY(-34%) rotate(-1.5deg); opacity:0; filter:blur(5px); }
.price-amt .num.px-out::after { transform:scaleX(1); transition:transform .22s var(--ease-out); }
.price-amt .num.px-in { transform:translateY(48%); opacity:0; filter:blur(5px); transition:none; }
[data-motion="off"] .price-amt .num { transition:none !important; }
[data-motion="off"] .price-amt .num::after { display:none; }
.price-amt .per { font-size:.92rem; color: var(--muted); }
.price-sub { color: var(--muted); font-size:.92rem; min-height: 2.6em; transition: opacity .2s var(--ease-out); }
.price-sub.note-fade { opacity:0; }
.price-feats { list-style:none; padding:0; margin: 22px 0; display:flex; flex-direction:column; gap:11px; flex:1; }
.price-feats li { display:flex; gap:11px; font-size:.92rem; color: var(--ink-2); align-items:flex-start; }
.price-feats li svg { width:18px; height:18px; flex:none; margin-top:2px; }
.price-feats li.muted { color: var(--muted-2); } .price-feats li.muted svg { opacity:.5; }
.tier-tag { position:absolute; top:1px; left:50%; transform:translate(-50%,-100%); white-space:nowrap; z-index:3; }
.tier-tag .badge { color:#fff; font-weight:700; padding:5px 30px 6px; font-size:.72rem; letter-spacing:.04em; border-radius:10px 10px 0 0; }
.price-card.premium .tier-tag .badge { background:var(--brand-red); }
.price-card.pro .tier-tag .badge { background:var(--pro-blue); }

/* comparison table */
.cmp { width:100%; border-collapse: collapse; font-size:.92rem; }
.cmp th, .cmp td { padding: 15px 16px; text-align:center; border-bottom:1px solid var(--border); }
.cmp th:first-child, .cmp td:first-child { text-align:left; color: var(--ink-2); font-weight:500; }
.cmp thead th { font-weight:700; letter-spacing:-.01em; font-size:1rem; }
.cmp tbody tr:hover { background: var(--surface-2); }
.cmp .yes { color: var(--success); } .cmp .no { color: var(--faint); }
.cmp .colpro { background: rgba(37,99,235,.05); }
[data-theme="dark"] .cmp .colpro { background: rgba(37,99,235,.09); }
.cmp svg { width:18px; height:18px; }

/* ===== pricing compare — gold Premium · blue Pro · animated reveal ===== */
/* column identity (Free=2 · Premium=3 · Pro=4) */
.cmp thead th:nth-child(3) { color: var(--gold); }
.cmp thead th:nth-child(4) { color: var(--pro-blue); }
[data-theme="dark"] .cmp thead th:nth-child(4) { color:#7aa2ff; }
.cmp td:nth-child(3).yes { color: var(--gold); }
.cmp td:nth-child(4).yes { color: var(--pro-blue); }
[data-theme="dark"] .cmp td:nth-child(4).yes { color:#7aa2ff; }
/* soft column bands */
.cmp th:nth-child(3), .cmp td:nth-child(3) { background: var(--gold-tint); }
.cmp .colpro { background: rgba(37,99,235,.06); }
[data-theme="dark"] .cmp .colpro { background: rgba(37,99,235,.1); }
.cmp thead th:nth-child(3), .cmp thead th:nth-child(4) { font-weight:800; }
/* keep row-hover from washing the colored bands away */
.cmp tbody tr:hover td:nth-child(3) { background: var(--gold-tint); }
.cmp tbody tr:hover td.colpro { background: rgba(37,99,235,.1); }

/* drawn mark icons */
.cmp .mk-ic { display:inline-grid; place-items:center; }
.cmp .mk-ic svg { fill:none; stroke:currentColor; stroke-width:2.6; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:26; stroke-dashoffset:26; }
/* highlight Pro-only advantages with a soft blue ring on the check */
.cmp tr[data-pro-only] td.colpro .mk-ic { border-radius:50%; box-shadow:0 0 0 5px rgba(37,99,235,.12); }

/* staggered reveal (driven by JS adding .cmp-in / row .cmp-pop) */
.cmp tbody tr.cmp-pop td { animation: rowIn .5s var(--ease-out) backwards; animation-delay: var(--d,0s); }
.cmp tbody tr.cmp-pop .mk-ic { animation: mkPop .42s var(--ease-out) both; animation-delay: var(--d,0s); }
.cmp tbody tr.cmp-pop .mk-ic svg { animation: drawMk .45s var(--ease-out) forwards; animation-delay: calc(var(--d,0s) + .12s); }
@keyframes mkPop { 0%{ transform:scale(.2); opacity:0; } 62%{ transform:scale(1.14); } 100%{ transform:scale(1); opacity:1; } }
@keyframes rowIn { from{ opacity:0; transform:translateX(-8px); } to{ opacity:1; transform:none; } }
.cmp tbody tr td .mk-ic { transition: transform .22s var(--ease-out); }
.cmp tbody tr:hover td:nth-child(3) .mk-ic,
.cmp tbody tr:hover td.colpro .mk-ic { transform: scale(1.18); }
[data-motion="off"] .cmp tbody tr.cmp-pop td,
[data-motion="off"] .cmp tbody tr.cmp-pop .mk-ic,
[data-motion="off"] .cmp tbody tr.cmp-pop .mk-ic svg { animation:none; stroke-dashoffset:0; }

/* ===================== SAFETY ===================== */
.safety-board { display:grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(28px,4vw,56px); align-items:center; }
@media (max-width: 880px){ .safety-board { grid-template-columns: 1fr; } }
.safety-ring-card { background: #131620; border:1px solid rgba(255,255,255,.08); border-radius: var(--r-xl); padding: 36px; box-shadow: var(--shadow-lg); color:#e8ebf2; }
.safety-feature { display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
@media (max-width:520px){ .safety-feature{ grid-template-columns:1fr; } }
.safety-feature .feature-ic { margin-bottom:14px; }

/* ===================== FAQ ===================== */
.faq-list { max-width: 760px; margin-inline:auto; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; gap:20px; text-align:left;
  padding: 20px 4px; font-weight:600; font-size: clamp(1.02rem,1.6vw,1.18rem); letter-spacing:-.01em; color: var(--ink); }
.faq-q .pm { width:30px; height:30px; border-radius:50%; border:1px solid var(--border); display:grid; place-items:center; flex:none; transition: transform .3s var(--ease-out), background .2s; }
.faq-q .pm svg { width:16px; height:16px; }
.faq-item.open .faq-q .pm { transform: rotate(45deg); background: var(--grad-accent); color:#fff; border-color:transparent; }
.faq-a { overflow:hidden; max-height:0; transition: max-height .42s var(--ease-out); }
.faq-a .inner { padding: 0 4px 26px; color: var(--muted); font-size: 1.02rem; line-height:1.6; max-width: 64ch; }

/* ===================== STEPS (how it works) ===================== */
.howstep { display:grid; grid-template-columns: 64px 1fr; gap: 24px; padding: 6px 0; }
.howstep .ringnum { width:56px; height:56px; border-radius:50%; display:grid; place-items:center; font-weight:800; font-size:1.3rem;
  background: var(--surface); border:1px solid var(--border); box-shadow: var(--shadow-sm); letter-spacing:-.03em; }
.howstep .ringnum.r { color: var(--brand-red); } .howstep .ringnum.b { color: var(--pro-blue); }
.howstep .ringnum.g { color: var(--success); } .howstep .ringnum.p { color: var(--purple); }

/* logos marquee */
.logos { display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap: clamp(28px,5vw,64px); opacity:.7; }
.logo-word { font-weight:700; font-size: clamp(1.05rem,1.8vw,1.4rem); letter-spacing:-.02em; color: var(--muted); }

/* ===================== HOME RHYTHM & COHESION ===================== */
/* numbered chapter kicker — consistent across sections */
.kicker { display:inline-flex; align-items:center; gap:13px; }
.kicker .ix { font-size:.8rem; font-weight:800; color:var(--brand-red); letter-spacing:.04em; font-variant-numeric:tabular-nums; display:inline-flex; align-items:center; gap:13px; }
.kicker .ix::after { content:""; width:28px; height:1px; background:var(--border-strong); }
.kicker .lb { font-size:.78rem; font-weight:600; letter-spacing:.15em; text-transform:uppercase; color:var(--muted); }
.sec-head.center .kicker, .center > .kicker { justify-content:center; }

/* consistent home section cadence */
.home-flow { padding-block: clamp(58px, 7.5vw, 110px); position: relative; }
.home-flow.lead { padding-top: clamp(36px, 4.5vw, 68px); }    /* section that follows the hero */

/* alternating tone band groups a chapter without a hard cut */
.tone { position: relative; background: var(--bg-2); }
.tone::before, .tone::after { content:""; position:absolute; left:0; right:0; height:1px; background:var(--border); }
.tone::before { top:0; } .tone::after { bottom:0; }

/* gentle seam: fade the band edges into neighbours so nothing hard-cuts */
.seam-top { -webkit-mask-image: linear-gradient(to bottom, transparent, #000 64px); mask-image: linear-gradient(to bottom, transparent, #000 64px); }

/* page hero (interior pages) */
.page-hero { padding-top: clamp(128px,16vh,180px); padding-bottom: clamp(36px,5vw,64px); text-align:center; position:relative; overflow:hidden; }
.page-hero .hero-glow { opacity:.7; }

/* quick navigator strip (features) */
.qnav { display:flex; flex-wrap:wrap; gap:10px; }
.qnav-item { display:inline-flex; align-items:center; gap:9px; padding:11px 16px; border-radius:var(--r-pill);
  background:var(--surface-2); border:1px solid var(--border); font-weight:600; font-size:.9rem; color:var(--ink-2); }
.qnav-item svg { width:17px; height:17px; color:var(--brand-red); }

/* role cards footer (features) */
.role-foot { margin-top:16px; padding-top:14px; border-top:1px solid var(--border); font-size:.8rem; font-weight:600;
  color:var(--muted); letter-spacing:.005em; line-height:1.5; }

/* ===================== VS COMPARISON ===================== */
.vs-board { max-width: 1000px; margin-inline: auto; }
.vs-score { display:grid; grid-template-columns: 1fr auto 1fr; align-items:center; gap:18px; margin-bottom:30px; }
.vs-side { text-align:center; padding: 22px; border-radius: var(--r-lg); border:1px solid var(--border); background: var(--surface); }
.vs-side.win { border-color: rgba(230,57,70,.4); box-shadow: var(--shadow-md); background:
  radial-gradient(120% 140% at 50% 0%, rgba(230,57,70,.08), transparent 60%), var(--surface); }
.vs-side .nm { font-weight:700; font-size:1.18rem; letter-spacing:-.03em; display:flex; align-items:center; justify-content:center; gap:0; }
.vs-side.win .nm { color: var(--ink); }
.vs-side .nm .dot-ai{ color:var(--brand-red);} [data-theme="dark"] .vs-side.win .nm{ color:var(--ink); } [data-theme="dark"] .vs-side .nm .dot-ai{ color:#ff6470; }
.vs-side .big { font-size: clamp(2.4rem,5vw,3.4rem); font-weight:800; letter-spacing:-.04em; line-height:1; margin-top:8px; }
.vs-side.win .big { background: var(--grad-accent); background-size:200% 100%; -webkit-background-clip:text; background-clip:text; color:transparent; animation:gradShift 10s linear infinite; }
.vs-side .cap { font-size:.78rem; color:var(--muted); margin-top:6px; text-transform:uppercase; letter-spacing:.08em; }
.vs-vs { font-weight:800; color:var(--muted-2); font-size:1.1rem; }

.vs-chips { display:flex; flex-wrap:wrap; justify-content:center; gap:8px; margin-bottom:22px; }
.vs-chip { padding:8px 16px; border-radius: var(--r-pill); font-size:.86rem; font-weight:600; color:var(--muted); background:var(--surface-2); border:1px solid var(--border); transition: all .2s; }
.vs-chip.on { color:#fff; background: var(--grad-accent); border-color: transparent; box-shadow: var(--shadow-sm); }

.vs-table { border:1px solid var(--border); border-radius: var(--r-lg); overflow:hidden; background: var(--surface); }
.vs-row { display:grid; grid-template-columns: 1.5fr 1fr 1fr; align-items:center; border-bottom:1px solid var(--border); transition: opacity .3s, background .2s; }
.vs-row:last-child { border-bottom:none; }
.vs-row.head { background: var(--surface-2); font-weight:700; font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); }
.vs-row.head .vs-c.l { color: var(--ink); text-transform:none; letter-spacing:-.02em; font-weight:800; font-size:.98rem; }
.vs-row.head .vs-c { display:block; }
.vs-row.head .vs-c.l .dot-ai { color: var(--brand-red); }
.vs-row .vs-f { padding:16px 18px; font-size:.95rem; font-weight:500; }
.vs-row .vs-f .ct { display:block; font-size:.76rem; color:var(--muted-2); font-weight:400; margin-top:2px; }
.vs-c { padding:16px 14px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:5px; font-size:.8rem; }
.vs-c .mk { display:inline-grid; place-items:center; }
.vs-c .mk svg { width:20px; height:20px; }
.vs-c .mk.yes { color: var(--success); }
.vs-c .mk.no { color: var(--faint); }
.vs-c .mk.part { color: var(--muted-2); }
.vs-c .note { font-size:.72rem; color: var(--muted-2); }
.vs-row.hidden { display:none; }
.vs-row.clamped { display:none; }

/* collapse / show-more toggle */
.vs-table { position:relative; }
.vs-table.clamped-fade::after { content:""; position:absolute; left:0; right:0; bottom:0; height:84px; pointer-events:none;
  background:linear-gradient(to bottom, transparent, var(--surface)); border-radius:0 0 var(--r-lg) var(--r-lg); }
.vs-more { display:flex; justify-content:center; margin-top:20px; }
.vs-more button { display:inline-flex; align-items:center; gap:8px; padding:11px 22px; border-radius:var(--r-pill);
  font-weight:600; font-size:.9rem; color:var(--ink-2); background:var(--surface); border:1px solid var(--border);
  box-shadow:var(--shadow-sm); transition: transform var(--t-fast) var(--ease-out), box-shadow var(--t-med) var(--ease-out), border-color var(--t-fast); }
.vs-more button:hover { border-color:var(--border-strong); box-shadow:var(--shadow-md); transform:translateY(-1px); }
.vs-more button svg { width:16px; height:16px; transition: transform .25s var(--ease-out); }
.vs-more.open button svg { transform:rotate(180deg); }

/* ===================== VS — animated polish ===================== */
/* dominance fill bars inside each scoreboard card */
.vs-side { position:relative; overflow:hidden; }
.vs-fill { height:7px; border-radius:999px; background:var(--surface-3); margin-top:14px; overflow:hidden; }
.vs-fill i { display:block; height:100%; width:0; border-radius:999px; transition: width 1.1s var(--ease-out); }
.vs-side.win .vs-fill i { background:var(--grad-accent); }
.vs-side:not(.win) .vs-fill i { background:var(--muted-2); opacity:.5; }

/* the "+N more" gap callout */
.vs-gap { text-align:center; margin:20px auto 26px; font-size:.9rem; color:var(--muted); font-weight:500;
  display:flex; align-items:center; justify-content:center; gap:9px; }
.vs-gap b { font-weight:800; font-size:1.05rem;
  background:var(--grad-accent); background-size:200% 100%; -webkit-background-clip:text; background-clip:text; color:transparent; animation: gradShift 9s linear infinite; }
.vs-gap .arw { width:18px; height:18px; color:var(--brand-red); }

/* drawn SVG mark icons (no tacky filled circles) */
.vs-c .mk { transition: transform .25s var(--ease-out); }
.vs-c .mk svg { width:20px; height:20px; fill:none; stroke:currentColor; stroke-width:2.4; stroke-linecap:round; stroke-linejoin:round; }

/* calm reveal — gentle fade-in + check draw (no bounce/glow) */
.vs-row.vs-pop .mk { animation: vsFade .42s var(--ease-out) backwards; animation-delay: var(--d,0s); }
.vs-row.vs-pop .vs-f { animation: vsFade .42s var(--ease-out) backwards; animation-delay: var(--d,0s); }
.vs-row.vs-pop .mk.yes svg {
  stroke-dasharray:26; stroke-dashoffset:26; animation: drawMk .45s var(--ease-out) forwards; animation-delay: calc(var(--d,0s) + .1s); }
@keyframes vsFade { from{ opacity:0; } to{ opacity:1; } }
@keyframes drawMk { to { stroke-dashoffset:0; } }
[data-motion="off"] .vs-row.vs-pop .mk,
[data-motion="off"] .vs-row.vs-pop .vs-f,
[data-motion="off"] .vs-row.vs-pop .mk svg { animation:none; stroke-dashoffset:0; }

/* subtle row hover */
.vs-row[data-cat] { transition: background .22s var(--ease-out); }
.vs-row[data-cat]:hover { background:var(--surface-2); }
@media (max-width: 620px){ .vs-row .vs-f{ padding:13px; font-size:.86rem;} .vs-c{ padding:13px 6px; } .vs-score{ gap:10px; } }

/* =========================================================================
   MOBILE POLISH  (mobile-only — desktop layout untouched)
   Targets the "crammed / cut-off at the edges" issues on real phones.
   ========================================================================= */
@media (max-width: 680px) {
  /* a touch more breathing room from the screen edge everywhere */
  :root { --gutter: 22px; }

  /* hero: tighten the stack so it doesn't feel sparse, keep the orbit tidy */
  .hero { padding-top: clamp(104px, 22vw, 132px); }
  .hero-orbit { height: clamp(360px, 84vw, 460px); }
  .orbit-lead { font-size: .95rem; padding-inline: 6px; }

  /* primary action rows: stack full-width, easy thumb targets */
  .hero-inner .row,
  .cta-band .row { flex-direction: column; align-items: stretch; gap: 12px; }
  .hero-inner .row .btn,
  .cta-band .row .btn { width: 100%; }

  /* section rhythm: trim the big vertical gaps a little on small screens */
  .home-flow { padding-block: clamp(46px, 12vw, 80px); }
  .section { padding-block: clamp(54px, 14vw, 96px); }
}

@media (max-width: 560px) {
  /* VS comparison: the densest grid — relax it so nothing collides */
  .vs-score { grid-template-columns: 1fr auto 1fr; gap: 8px; margin-bottom: 24px; }
  .vs-side { padding: 16px 10px; border-radius: var(--r-md); }
  .vs-side .big { font-size: 2.1rem; }
  .vs-side .cap { font-size: .68rem; letter-spacing: .05em; }
  .vs-vs { font-size: .9rem; }

  .vs-row { grid-template-columns: 1.45fr .85fr .85fr; }
  .vs-row .vs-f { padding: 12px 11px; font-size: .82rem; }
  .vs-row .vs-f .ct { font-size: .7rem; line-height: 1.35; }
  .vs-c { padding: 12px 4px; font-size: .72rem; }
  .vs-c .mk svg { width: 17px; height: 17px; }
  .vs-c .note { font-size: .64rem; line-height: 1.3; }
  .vs-chip { padding: 7px 13px; font-size: .8rem; }

  /* pricing teaser proof logos: keep them from cramming on one line */
  .logos { gap: 14px 20px; }

  /* footer: simpler 2-up that doesn't crowd */
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 14px; }
}

@media (max-width: 400px) {
  :root { --gutter: 18px; }
  /* squeeze the comparison feature notes out of the way on tiny screens
     so the ✓ / – columns stay readable rather than wrapping into a mess */
  .vs-c .note { display: none; }
  .vs-row { grid-template-columns: 1.5fr .75fr .75fr; }
  .cta-band { padding: 40px 22px; }
}

/* bento layout modifiers — replace hard-coded inline column counts that
   ignored the responsive bento rule and crammed/cut-off on small screens */
.bento-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 880px){ .bento-4 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 440px){ .bento-4 { grid-template-columns: 1fr; } }
.bento-2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 620px){ .bento-2 { grid-template-columns: 1fr; } }
