/* ============================================================
   PDF Expert — light theme · red+orange brand · Inter
   Each H2 section uniquely styled
   ============================================================ */

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
@media (prefers-reduced-motion: reduce) { *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; scroll-behavior:auto !important; } }

.skip { position:absolute; left:-9999px; top:0; background:#E62734; color:#fff; padding:.7rem 1.1rem; z-index:1000; font-weight:700; font-size:.9rem; border-radius:6px; }
.skip:focus { left:12px; top:12px; }

:root {
  --white:#FFFFFF; --bg:#FFFFFF; --bg-soft:#FAFBFC; --bg-mute:#F1F3F5; --bg-dark:#0F1115;
  --ink:#0B1018; --ink-2:#1A1D24;
  --slate-700:#3F4655; --slate-600:#5C6473; --slate-500:#8A92A0; --slate-400:#B1B7C2; --slate-300:#D4D8DF; --slate-200:#E5E8ED; --slate-100:#F1F3F6;
  --red:#E62734; --red-600:#C92535; --red-400:#FA5D5D; --red-300:#FF8888; --red-light:#FFE5E7; --red-soft:#FFF1F2;
  --orange:#FF7847; --orange-600:#F25A2A; --orange-light:#FFE9DF;
  --yellow:#FBC02D; --yellow-light:#FFF7D1;
  --teal:#0BB39E; --teal-light:#D0F5EF;
  --indigo:#5B6BFF; --indigo-light:#E3E7FF;
  --header-h:56px;
  --font-b:'Inter',system-ui,-apple-system,sans-serif;
  --shadow-sm:0 1px 2px rgba(15,17,21,.06),0 1px 1px rgba(15,17,21,.04);
  --shadow-md:0 6px 16px rgba(15,17,21,.08),0 2px 4px rgba(15,17,21,.04);
  --shadow-lg:0 24px 50px rgba(15,17,21,.10),0 6px 14px rgba(15,17,21,.05);
  --shadow-red:0 0 0 1px rgba(230,39,52,.20),0 18px 44px rgba(230,39,52,.16);
  --shadow-orange:0 0 0 1px rgba(255,120,71,.20),0 18px 44px rgba(255,120,71,.16);
  --grad-red:linear-gradient(135deg,var(--red),var(--orange));
  --grad-red-soft:linear-gradient(180deg,var(--red-soft),#fff);
  --grad-btn:linear-gradient(180deg,var(--red),var(--red-600));
  --grad-orange:linear-gradient(135deg,var(--orange),var(--yellow));
  --grad-hero:radial-gradient(circle at 20% -10%,rgba(230,39,52,.10),transparent 50%),radial-gradient(circle at 95% 20%,rgba(255,120,71,.10),transparent 55%),linear-gradient(180deg,#fff,#FAFBFC);
}
@media (min-width:768px) { :root { --header-h:64px; } }

body { font-family:var(--font-b); background:var(--bg); color:var(--ink); font-size:16px; font-weight:400; line-height:1.65; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden; }
img,svg { display:block; max-width:100%; }
a { color:var(--red); text-decoration:none; transition:color .2s ease; }
a:hover { color:var(--red-600); }
ul { list-style:none; }

:focus { outline:none; }
a:focus-visible, button:focus-visible, summary:focus-visible, .btn:focus-visible, [tabindex]:focus-visible, details:focus-visible { outline:2px solid var(--red); outline-offset:3px; border-radius:6px; }
.btn:focus-visible { outline-offset:4px; }

/* Loader */
.loader { position:fixed; inset:0; z-index:9999; display:flex; align-items:center; justify-content:center; background:#fff; transition:opacity .5s ease, visibility .5s ease; }
.loader__inner { display:flex; flex-direction:column; align-items:center; gap:14px; }
.loader__inner span { font-weight:700; letter-spacing:.04em; color:var(--ink-2); }
.loader__spin { animation:rot 1.05s linear infinite; }
@keyframes rot { to { transform:rotate(360deg); } }
.loader.hide { opacity:0; visibility:hidden; pointer-events:none; }

/* Container */
.container { width:100%; max-width:1200px; margin-inline:auto; padding-inline:20px; }
@media (min-width:768px) { .container { padding-inline:32px; } }

/* Section base */
.section { padding-block:64px; position:relative; scroll-margin-top:calc(var(--header-h) + 12px); }
@media (min-width:768px) { .section { padding-block:96px; } }
#guide,#faq,#features,#screens,#download,#home,#platforms,#pricing { scroll-margin-top:calc(var(--header-h) + 12px); }
.section__head { text-align:center; margin-bottom:48px; max-width:760px; margin-inline:auto; }
.section__label { display:inline-block; font-size:11px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--red-600); margin-bottom:14px; padding:6px 12px; border:1px solid var(--red-light); border-radius:999px; background:var(--red-soft); }
.section__title { font-size:clamp(1.9rem,5vw,3.2rem); font-weight:800; line-height:1.1; color:var(--ink); letter-spacing:-.02em; }
.section__title em { font-style:normal; background:var(--grad-red); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }
.section__sub { margin-top:16px; color:var(--slate-700); font-size:17px; line-height:1.6; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:10px; font-family:var(--font-b); font-size:14px; font-weight:600; cursor:pointer; border:none; padding:12px 22px; border-radius:8px; transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease; white-space:nowrap; text-decoration:none; }
.btn--lg { padding:16px 30px; font-size:16px; border-radius:10px; }
.btn--fill { background:var(--grad-btn); color:#fff; box-shadow:0 6px 20px rgba(230,39,52,.30); }
.btn--fill:hover { transform:translateY(-2px); box-shadow:0 12px 32px rgba(230,39,52,.40); color:#fff; }
.btn--outline { color:var(--ink); background:#fff; border:1px solid var(--slate-300); }
.btn--outline:hover { border-color:var(--red); color:var(--red); background:var(--red-soft); }
.btn--ghost { color:var(--red); background:var(--red-soft); border:1px solid var(--red-light); }
.btn--ghost:hover { background:var(--red-light); }
.btn svg { width:16px; height:16px; flex:0 0 16px; }
.btn--block { width:100%; justify-content:center; }
@media (max-width:599px) { .btn { min-height:44px; } }

/* Header */
.header { position:sticky; top:0; z-index:100; backdrop-filter:saturate(160%) blur(14px); -webkit-backdrop-filter:saturate(160%) blur(14px); background:rgba(255,255,255,.85); border-bottom:1px solid transparent; transition:border-color .25s ease, background .25s ease; }
.header.scrolled { border-bottom-color:var(--slate-200); background:rgba(255,255,255,.96); }
.header__inner { max-width:1200px; margin-inline:auto; padding:12px 20px; display:flex; align-items:center; justify-content:space-between; gap:16px; }
@media (min-width:768px) { .header__inner { padding:14px 32px; } }
.header__logo { display:inline-flex; align-items:center; gap:10px; font-weight:800; font-size:17px; color:var(--ink); letter-spacing:-.01em; }
.header__logo:hover { color:var(--ink); }
.header__logo img { width:32px; height:32px; border-radius:8px; flex:0 0 32px; box-shadow:0 4px 10px rgba(230,39,52,.20); }
.header__nav { display:none; gap:6px; align-items:center; }
@media (min-width:960px) { .header__nav { display:inline-flex; } }
.header__nav a { font-weight:500; font-size:14px; color:var(--slate-700); padding:8px 12px; border-radius:6px; transition:color .15s ease, background .15s ease; }
.header__nav a:hover { color:var(--red); background:var(--red-soft); }
.header__right { display:none; align-items:center; gap:12px; }
@media (min-width:960px) { .header__right { display:inline-flex; } }
.header__burger { display:inline-flex; flex-direction:column; gap:6px; width:44px; height:44px; align-items:center; justify-content:center; background:transparent; border:none; cursor:pointer; border-radius:8px; }
.header__burger span { width:22px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s ease, opacity .25s ease; }
.header__burger[aria-expanded="true"] span:nth-child(1) { transform:translateY(8px) rotate(45deg); }
.header__burger[aria-expanded="true"] span:nth-child(2) { opacity:0; transform:scaleX(0); }
.header__burger[aria-expanded="true"] span:nth-child(3) { transform:translateY(-8px) rotate(-45deg); }
@media (min-width:960px) { .header__burger { display:none; } }

.mobile-nav { position:fixed; top:var(--header-h); left:0; right:0; z-index:99; background:rgba(255,255,255,.98); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); padding:20px; display:flex; flex-direction:column; gap:6px; transform:translateY(-110%); transition:transform .35s cubic-bezier(.16,1,.3,1); border-bottom:1px solid var(--slate-200); max-height:calc(100vh - var(--header-h)); overflow-y:auto; }
.mobile-nav.open { transform:translateY(0); }
.mobile-nav a { padding:14px 12px; font-weight:600; color:var(--ink); border-radius:8px; }
.mobile-nav a:not(.btn):hover { background:var(--red-soft); color:var(--red); }
.mobile-nav__cta { margin-top:8px; }
@media (min-width:960px) { .mobile-nav { display:none; } }

/* ════════════════════════ HERO ════════════════════════ */
.hero { position:relative; padding:56px 20px 60px; background:var(--grad-hero); overflow:hidden; }
@media (min-width:768px) { .hero { padding:88px 32px 88px; } }
@media (min-width:1080px) { .hero { padding:104px 32px 104px; } }
.hero__inner { max-width:1280px; margin-inline:auto; display:grid; gap:48px; grid-template-columns:1fr; align-items:center; position:relative; z-index:2; }
@media (min-width:960px) { .hero__inner { grid-template-columns:1fr 1.1fr; gap:56px; } }
.hero__grid { position:absolute; inset:0; background-image:linear-gradient(rgba(230,39,52,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(230,39,52,.04) 1px,transparent 1px); background-size:60px 60px; mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,#000 30%,transparent 80%); -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,#000 30%,transparent 80%); pointer-events:none; }
.hero__eyebrow { display:inline-flex; align-items:center; gap:10px; padding:6px 14px 6px 8px; background:var(--red-soft); border:1px solid var(--red-light); border-radius:999px; font-size:12px; font-weight:700; color:var(--red-600); margin-bottom:22px; }
.hero__dot { width:8px; height:8px; border-radius:50%; background:var(--red); box-shadow:0 0 0 4px rgba(230,39,52,.15); animation:pulseDot 2s ease-in-out infinite; }
@keyframes pulseDot { 0%,100% { box-shadow:0 0 0 4px rgba(230,39,52,.15); } 50% { box-shadow:0 0 0 8px rgba(230,39,52,0); } }

.hero__title { font-size:clamp(2rem,6vw,3.6rem); font-weight:800; line-height:1.08; letter-spacing:-.02em; color:var(--ink); margin-bottom:16px; }
.hero__title em { font-style:normal; background:var(--grad-red); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }
@media (min-width:600px) { .hero__title em { display:block; } }
.hero__sub { font-size:16px; line-height:1.65; color:var(--slate-700); max-width:560px; margin-bottom:28px; }
@media (min-width:768px) { .hero__sub { font-size:18px; margin-bottom:32px; } }
.hero__actions { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:28px; }
.hero__trust { display:flex; flex-wrap:wrap; align-items:center; gap:14px 22px; font-size:13px; color:var(--slate-600); }
.hero__trust-item { display:inline-flex; align-items:center; gap:8px; }
.hero__trust-item svg { width:16px; height:16px; color:var(--red); }
.hero__stars { display:inline-flex; gap:2px; }
.hero__stars svg { width:14px; height:14px; color:var(--orange); fill:currentColor; }

.hero__visual { position:relative; width:100%; max-width:680px; margin-inline:auto; }
.hero__visual img { width:100%; height:auto; border-radius:12px; box-shadow:0 30px 60px rgba(15,17,21,.18); animation:heroFloat 8s ease-in-out infinite; }
@keyframes heroFloat { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-8px); } }
.hero__badge { position:absolute; background:#fff; border:1px solid var(--slate-200); border-radius:14px; padding:10px 14px; display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:600; color:var(--ink); box-shadow:var(--shadow-md); white-space:nowrap; }
.hero__badge svg { width:18px; height:18px; color:var(--red); }
.hero__badge--1 { top:-10px; left:0%; animation:heroFloat 5s ease-in-out infinite; }
.hero__badge--2 { top:30%; right:-4%; color:var(--orange-600); animation:heroFloat 6s ease-in-out infinite -2s; }
.hero__badge--2 svg { color:var(--orange); }
.hero__badge--3 { bottom:6%; left:6%; color:var(--teal); animation:heroFloat 7s ease-in-out infinite -1s; }
.hero__badge--3 svg { color:var(--teal); }
@media (max-width:559px) { .hero__badge { font-size:11px; padding:8px 10px; max-width:48%; } .hero__badge--1 { top:-4px; left:4%; } .hero__badge--2 { top:32%; right:2%; } .hero__badge--3 { bottom:4%; left:4%; } }

/* TRUST STRIP */
.trust { background:#fff; padding:28px 20px; border-block:1px solid var(--slate-100); }
.trust__inner { max-width:1200px; margin-inline:auto; display:grid; grid-template-columns:repeat(2,1fr); gap:18px 24px; align-items:center; }
@media (min-width:600px) { .trust__inner { grid-template-columns:repeat(4,1fr); } }
.trust-item { display:flex; flex-direction:column; align-items:center; text-align:center; gap:4px; padding:6px 0; border-right:1px solid var(--slate-100); }
.trust-item:nth-child(2n) { border-right:none; }
@media (min-width:600px) { .trust-item:nth-child(2n) { border-right:1px solid var(--slate-100); } .trust-item:nth-child(4n) { border-right:none; } }
.trust-item strong { font-size:22px; font-weight:800; color:var(--ink); letter-spacing:-.02em; }
.trust-item span { font-size:11px; color:var(--slate-600); text-transform:uppercase; letter-spacing:.06em; font-weight:600; }
@media (min-width:600px) { .trust-item strong { font-size:28px; } }

/* FEATURES — bento */
.features { background:var(--bg-mute); position:relative; }
.bento { display:grid; gap:14px; grid-template-columns:1fr; grid-auto-rows:minmax(180px,auto); }
@media (min-width:600px) { .bento { grid-template-columns:repeat(2,1fr); gap:16px; } }
@media (min-width:960px) { .bento { grid-template-columns:repeat(4,1fr); grid-auto-rows:minmax(200px,auto); gap:18px; } }
.bento-card { background:#fff; border:1px solid var(--slate-200); border-radius:18px; padding:24px; position:relative; overflow:hidden; transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease; display:flex; flex-direction:column; justify-content:space-between; }
@media (min-width:768px) { .bento-card { padding:28px; } }
.bento-card:hover { transform:translateY(-4px); border-color:var(--red-light); box-shadow:var(--shadow-red); }
.bento-card__icon { width:48px; height:48px; border-radius:12px; background:var(--red-soft); border:1px solid var(--red-light); display:flex; align-items:center; justify-content:center; color:var(--red); margin-bottom:18px; }
.bento-card__icon svg { width:24px; height:24px; }
.bento-card__top { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:16px; }
.bento-card__num { font-size:11px; font-weight:700; color:var(--slate-500); letter-spacing:.14em; }
.bento-card h3 { font-size:18px; font-weight:700; color:var(--ink); margin-bottom:8px; letter-spacing:-.01em; }
.bento-card p { font-size:14px; color:var(--slate-700); line-height:1.6; }
@media (min-width:960px) {
  .bento-card--xl { grid-column:span 2; grid-row:span 2; padding:32px; background:linear-gradient(135deg,var(--red-soft),#fff); border-color:var(--red-light); }
  .bento-card--lg { grid-column:span 2; }
  .bento-card--orange { background:linear-gradient(135deg,var(--orange-light),#fff); border-color:#FFD3BD; }
  .bento-card--orange .bento-card__icon { background:#FFE9DF; border-color:#FFC7AF; color:var(--orange-600); }
  .bento-card--indigo { background:linear-gradient(135deg,var(--indigo-light),#fff); border-color:#C5CDFF; }
  .bento-card--indigo .bento-card__icon { background:#E3E7FF; border-color:#C5CDFF; color:var(--indigo); }
}
.bento-card--xl h3 { font-size:22px; }
.bento-card--xl p { font-size:15px; }
.bento-card__visual { margin-top:18px; height:100%; min-height:140px; position:relative; border-radius:12px; overflow:hidden; background:#fff; border:1px solid var(--slate-200); display:flex; align-items:center; justify-content:center; }
.bento-card__visual img { width:100%; height:100%; object-fit:cover; }

/* SHOWCASE — large screenshot tabs */
.showcase { background:#fff; }
.showcase__stage { position:relative; max-width:1100px; margin-inline:auto; }
.showcase__frame { position:relative; border-radius:20px; overflow:hidden; background:var(--bg-mute); border:1px solid var(--slate-200); box-shadow:var(--shadow-lg); }
.showcase__chrome { display:flex; align-items:center; gap:8px; padding:14px 18px; background:linear-gradient(180deg,#F7F8FA,#EAEDF1); border-bottom:1px solid var(--slate-200); }
.showcase__chrome span { width:12px; height:12px; border-radius:50%; }
.showcase__chrome span:nth-child(1) { background:#FF5F57; }
.showcase__chrome span:nth-child(2) { background:#FEBC2E; }
.showcase__chrome span:nth-child(3) { background:#28C840; }
.showcase__chrome em { font-style:normal; margin-left:auto; font-size:12px; color:var(--slate-600); font-weight:500; }
.showcase__img-wrap { position:relative; aspect-ratio:16/10; background:#fff; display:flex; align-items:center; justify-content:center; }
.showcase__img-wrap img { max-width:100%; max-height:100%; height:auto; object-fit:contain; display:none; padding:12px; }
@media (min-width:768px) { .showcase__img-wrap img { padding:24px; } }
.showcase__img-wrap img.active { display:block; }
.showcase__tabs { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-top:22px; }
.showcase__tab { padding:12px 18px; font-size:13px; font-weight:600; color:var(--slate-700); background:#fff; border:1px solid var(--slate-200); border-radius:999px; cursor:pointer; transition:all .2s ease; min-height:44px; display:inline-flex; align-items:center; }
.showcase__tab:hover { background:var(--red-soft); border-color:var(--red-light); color:var(--red); }
.showcase__tab.active { background:var(--grad-red); color:#fff; border-color:transparent; box-shadow:0 4px 14px rgba(230,39,52,.30); }

/* PRICING — Free trial / Yearly / Lifetime */
.pricing { background:var(--bg-mute); }
.pricing__grid { display:grid; gap:20px; grid-template-columns:1fr; max-width:1080px; margin-inline:auto; }
@media (min-width:768px) { .pricing__grid { grid-template-columns:repeat(3,1fr); gap:24px; } }
.pricing-card { background:#fff; border:2px solid var(--slate-200); border-radius:20px; padding:28px 24px; position:relative; transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease; }
.pricing-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.pricing-card--featured { border-color:var(--red); background:linear-gradient(180deg,var(--red-soft),#fff); }
.pricing-card--featured::after { content:'Best value'; position:absolute; top:-12px; right:24px; padding:5px 12px; background:var(--grad-red); color:#fff; font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; border-radius:999px; box-shadow:0 6px 14px rgba(230,39,52,.30); }
.pricing-card__name { font-size:13px; font-weight:700; color:var(--red-600); letter-spacing:.10em; text-transform:uppercase; }
.pricing-card__price { display:flex; align-items:baseline; gap:8px; margin:14px 0 4px; }
.pricing-card__price strong { font-size:clamp(32px,5vw,40px); font-weight:800; color:var(--ink); letter-spacing:-.02em; line-height:1; }
.pricing-card__price span { font-size:14px; color:var(--slate-600); font-weight:500; }
.pricing-card__note { font-size:13px; color:var(--slate-600); margin-bottom:18px; }
.pricing-card__list { display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.pricing-card__list li { display:flex; gap:10px; font-size:14px; color:var(--ink); line-height:1.55; }
.pricing-card__list li::before { content:''; width:18px; height:18px; flex:0 0 18px; margin-top:2px; background:var(--red); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/contain no-repeat; }

/* PLATFORMS Mac vs Windows */
.platforms { background:#fff; }
.platforms__grid { display:grid; gap:20px; grid-template-columns:1fr; max-width:1080px; margin-inline:auto; }
@media (min-width:900px) { .platforms__grid { grid-template-columns:1fr 1fr; gap:24px; } }
.platform-card { background:var(--bg-soft); border:1px solid var(--slate-200); border-radius:22px; padding:28px 24px; position:relative; overflow:hidden; }
@media (min-width:768px) { .platform-card { padding:36px 32px; } }
.platform-card--mac::before { content:''; position:absolute; top:-40%; right:-20%; width:70%; height:80%; background:radial-gradient(circle,rgba(230,39,52,.10),transparent 60%); pointer-events:none; }
.platform-card--win::before { content:''; position:absolute; top:-40%; right:-20%; width:70%; height:80%; background:radial-gradient(circle,rgba(91,107,255,.10),transparent 60%); pointer-events:none; }
.platform-card__head { display:flex; align-items:center; gap:14px; margin-bottom:22px; position:relative; }
.platform-card__os { width:48px; height:48px; border-radius:12px; background:#fff; border:1px solid var(--slate-200); display:flex; align-items:center; justify-content:center; color:var(--red); flex:0 0 48px; box-shadow:var(--shadow-sm); }
.platform-card--win .platform-card__os { color:var(--indigo); }
.platform-card__os svg { width:24px; height:24px; }
.platform-card__title { font-size:22px; font-weight:800; color:var(--ink); }
.platform-card__title span { display:block; font-size:11px; font-weight:600; color:var(--slate-600); letter-spacing:.08em; text-transform:uppercase; margin-top:4px; }
.platform-card__body p { color:var(--slate-700); font-size:15px; line-height:1.7; margin-bottom:12px; position:relative; }
.platform-card__list { display:flex; flex-direction:column; gap:10px; margin-top:14px; position:relative; }
.platform-card__list li { display:flex; gap:10px; color:var(--ink); font-size:14px; line-height:1.55; }
.platform-card__list li::before { content:''; width:18px; height:18px; flex:0 0 18px; margin-top:2px; background:var(--grad-red); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/contain no-repeat; }
.platform-card--win .platform-card__list li::before { background:linear-gradient(135deg,var(--indigo),#7C8AFF); }
.platform-card__cta { margin-top:22px; position:relative; }

/* QUOTE */
.quote { background:var(--bg-soft); padding-block:64px; }
.quote__inner { max-width:820px; margin-inline:auto; text-align:center; padding-inline:20px; }
.quote__mark { font-size:72px; line-height:.5; color:var(--red); opacity:.45; font-family:Georgia,serif; }
.quote blockquote { font-size:clamp(1.1rem,2.4vw,1.5rem); line-height:1.5; color:var(--ink); font-weight:500; letter-spacing:-.01em; margin-block:18px 24px; }
.quote blockquote em { font-style:normal; color:var(--red); }
.quote__attr { display:inline-flex; align-items:center; gap:12px; padding:8px 16px; background:#fff; border:1px solid var(--slate-200); border-radius:999px; font-size:13px; color:var(--slate-700); }
.quote__attr strong { color:var(--ink); font-weight:700; }

/* DOWNLOAD CTA */
.download { background:#fff; }
.download__card { max-width:1080px; margin-inline:auto; border-radius:28px; background:radial-gradient(circle at 90% 0%,rgba(230,39,52,.16),transparent 50%),radial-gradient(circle at 0% 100%,rgba(255,120,71,.12),transparent 55%),linear-gradient(180deg,#fff,var(--bg-mute)); border:1px solid var(--red-light); box-shadow:var(--shadow-lg); position:relative; overflow:hidden; padding:36px 22px; }
@media (min-width:768px) { .download__card { padding:48px 40px; } }
.download__inner { display:grid; gap:32px; grid-template-columns:1fr; align-items:center; }
@media (min-width:768px) { .download__inner { grid-template-columns:auto 1fr; gap:40px; } }
.download__icon { width:140px; height:140px; margin-inline:auto; flex:0 0 140px; position:relative; filter:drop-shadow(0 20px 40px rgba(230,39,52,.30)); animation:heroFloat 6s ease-in-out infinite; }
@media (min-width:768px) { .download__icon { width:170px; height:170px; flex-basis:170px; } }
.download__icon img { width:100%; height:100%; border-radius:32px; }
.download__title { font-size:clamp(1.6rem,4vw,2.4rem); font-weight:800; color:var(--ink); margin-bottom:12px; letter-spacing:-.02em; line-height:1.15; }
.download__sub { color:var(--slate-700); margin-bottom:22px; font-size:15px; line-height:1.6; max-width:560px; }
@media (min-width:768px) { .download__sub { font-size:16px; } }
.download__actions { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:20px; }
.download__meta { display:flex; flex-wrap:wrap; gap:10px 22px; font-size:13px; color:var(--slate-600); }
.download__meta-item { display:inline-flex; align-items:center; gap:8px; }
.download__meta-item svg { width:14px; height:14px; color:var(--red); flex:0 0 14px; }

/* ════════════════════════ GUIDE STORY ════════════════════════
   Each H2 = unique full-width section
═══════════════════════════════════════════════════════════════ */

.story { position:relative; overflow:hidden; padding-block:64px; }
@media (min-width:768px) { .story { padding-block:96px; } }
.story__container { max-width:1180px; margin-inline:auto; padding-inline:20px; }
@media (min-width:768px) { .story__container { padding-inline:32px; } }
.story__kicker { display:inline-block; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--red); font-weight:700; padding:6px 12px; border:1px solid var(--red-light); border-radius:999px; background:var(--red-soft); margin-bottom:18px; }
.story h2 { font-size:clamp(1.7rem,4.2vw,2.4rem); font-weight:800; line-height:1.18; color:var(--ink); letter-spacing:-.02em; margin-bottom:18px; }
.story h2 em { font-style:normal; background:var(--grad-red); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; }
.story p { color:var(--slate-700); font-size:16px; line-height:1.7; margin-bottom:14px; }
.story p strong { color:var(--ink); font-weight:700; }
.story a:not(.btn) { color:var(--red); border-bottom:1px solid var(--red-light); }
.story a:not(.btn):hover { color:var(--red-600); border-color:var(--red); }

/* 1. INTRO — soft red-tinted opener */
.story--intro { background:var(--grad-hero); border-block:1px solid var(--slate-100); padding:80px 0 56px; }
@media (min-width:768px) { .story--intro { padding:110px 0 80px; } }
.story--intro::before { content:''; position:absolute; inset:0; background-image:radial-gradient(circle,rgba(230,39,52,.05) 1px,transparent 1px); background-size:30px 30px; mask-image:radial-gradient(ellipse 80% 50% at 50% 30%,#000 30%,transparent 80%); -webkit-mask-image:radial-gradient(ellipse 80% 50% at 50% 30%,#000 30%,transparent 80%); pointer-events:none; }
.story--intro .story__container { position:relative; max-width:820px; text-align:center; }
.story--intro__lede { font-size:clamp(16px,2vw,18px); line-height:1.7; color:var(--ink); margin-bottom:22px; }
.story--intro__lede strong { color:var(--red-600); }
.story--intro__callout { display:flex; gap:14px; align-items:flex-start; text-align:left; max-width:680px; margin:28px auto 0; padding:18px 22px; background:#fff; border:1px solid var(--red-light); border-radius:14px; box-shadow:var(--shadow-sm); }
.story--intro__callout svg { width:22px; height:22px; color:var(--red); flex:0 0 22px; margin-top:2px; }
.story--intro__callout p { margin:0; font-size:14.5px; color:var(--ink-2); }
.story--intro__callout strong { color:var(--red); }

/* 2. WHAT — split with circular badge */
.story--what { background:#fff; border-bottom:1px solid var(--slate-100); }
.story--what .story__container { display:grid; gap:40px; grid-template-columns:1fr; align-items:center; }
@media (min-width:900px) { .story--what .story__container { grid-template-columns:1.2fr .8fr; gap:64px; } }
.story--what__stage { position:relative; aspect-ratio:1/1; max-width:360px; margin-inline:auto; width:100%; display:flex; align-items:center; justify-content:center; }
.story--what__ring { position:absolute; inset:0; border:2px dashed var(--red-light); border-radius:50%; animation:storyOrbit 26s linear infinite; }
.story--what__ring::before, .story--what__ring::after { content:''; position:absolute; width:14px; height:14px; border-radius:50%; }
.story--what__ring::before { top:-7px; left:50%; transform:translateX(-50%); background:var(--red); box-shadow:0 0 14px rgba(230,39,52,.40); }
.story--what__ring::after { bottom:-7px; left:50%; transform:translateX(-50%); background:var(--orange); box-shadow:0 0 14px rgba(255,120,71,.40); }
.story--what__ring2 { position:absolute; inset:14%; border:2px dashed rgba(255,120,71,.20); border-radius:50%; animation:storyOrbit 18s linear infinite reverse; }
@keyframes storyOrbit { to { transform:rotate(360deg); } }
.story--what__core { position:relative; width:70%; aspect-ratio:1/1; border-radius:50%; background:radial-gradient(circle,#fff,var(--red-soft)); border:2px solid var(--red-light); display:flex; flex-direction:column; align-items:center; justify-content:center; box-shadow:0 30px 60px rgba(230,39,52,.20); }
.story--what__num { font-size:clamp(36px,6vw,56px); font-weight:800; background:var(--grad-red); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; letter-spacing:-.03em; line-height:1; }
.story--what__lbl { font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink); font-weight:700; margin-top:8px; }
.story--what__mini { display:flex; gap:18px; margin-top:24px; justify-content:center; }
.story--what__mini > div { text-align:center; }
.story--what__mini strong { display:block; font-size:20px; font-weight:800; color:var(--red); letter-spacing:-.01em; }
.story--what__mini span { font-size:10px; color:var(--slate-600); letter-spacing:.10em; text-transform:uppercase; font-weight:600; }

/* 3. FEATURES STAIR */
.story--features { background:var(--bg-mute); }
.story--features__header { text-align:center; max-width:720px; margin:0 auto 44px; }
.story--features__stair { display:grid; gap:18px; grid-template-columns:1fr; margin-bottom:36px; }
@media (min-width:768px) { .story--features__stair { grid-template-columns:repeat(3,1fr); gap:24px; align-items:start; } .story--features__stair > article:nth-child(2) { transform:translateY(40px); } }
.story--features__card { background:#fff; border:1px solid var(--slate-200); border-radius:18px; padding:26px 22px; transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease; }
.story--features__card:hover { transform:translateY(-4px); border-color:var(--red-light); box-shadow:var(--shadow-red); }
.story--features__card:nth-child(2) { border-color:#FFD3BD; }
.story--features__card:nth-child(2):hover { border-color:var(--orange); box-shadow:var(--shadow-orange); }
.story--features__card:nth-child(3) { border-color:#C5CDFF; }
.story--features__card:nth-child(3):hover { border-color:var(--indigo); box-shadow:0 0 0 1px rgba(91,107,255,.20),0 18px 44px rgba(91,107,255,.16); }
.story--features__icon { width:52px; height:52px; border-radius:14px; background:var(--grad-red); color:#fff; display:flex; align-items:center; justify-content:center; margin-bottom:18px; box-shadow:0 10px 22px rgba(230,39,52,.25); }
.story--features__card:nth-child(2) .story--features__icon { background:var(--grad-orange); box-shadow:0 10px 22px rgba(255,120,71,.25); }
.story--features__card:nth-child(3) .story--features__icon { background:linear-gradient(135deg,var(--indigo),#7C8AFF); box-shadow:0 10px 22px rgba(91,107,255,.25); }
.story--features__icon svg { width:26px; height:26px; }
.story--features__card h3 { font-size:17px; font-weight:700; color:var(--ink); margin-bottom:8px; letter-spacing:-.01em; }
.story--features__card p { font-size:14px; color:var(--slate-700); line-height:1.6; margin:0; }
.story--features__shot { max-width:1000px; margin:36px auto 0; }
.story--features__shot-frame { border-radius:16px; overflow:hidden; background:#fff; border:1px solid var(--slate-200); box-shadow:var(--shadow-lg); }
.story--features__chrome { display:flex; align-items:center; gap:8px; padding:12px 16px; background:linear-gradient(180deg,#F7F8FA,#EAEDF1); border-bottom:1px solid var(--slate-200); }
.story--features__chrome span { width:11px; height:11px; border-radius:50%; }
.story--features__chrome span:nth-child(1) { background:#FF5F57; }
.story--features__chrome span:nth-child(2) { background:#FEBC2E; }
.story--features__chrome span:nth-child(3) { background:#28C840; }
.story--features__chrome em { font-style:normal; margin-left:auto; font-size:11px; color:var(--slate-600); font-weight:500; }
.story--features__shot-frame img { display:block; width:100%; height:auto; }

/* 4. PRICING STORY — 3-tier */
.story--pricing { background:linear-gradient(180deg,#fff,var(--red-soft)); }
.story--pricing__intro { text-align:center; max-width:720px; margin:0 auto 36px; }
.story--pricing__tiers { display:grid; gap:18px; grid-template-columns:1fr; max-width:1000px; margin-inline:auto; }
@media (min-width:768px) { .story--pricing__tiers { grid-template-columns:repeat(3,1fr); gap:22px; } }
.story--pricing__tier { background:#fff; border:2px solid var(--slate-200); border-radius:18px; padding:24px 22px; position:relative; transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease; }
.story--pricing__tier:hover { transform:translateY(-3px); border-color:var(--red-light); box-shadow:var(--shadow-red); }
.story--pricing__tier--best { border-color:var(--red); }
.story--pricing__tier--best::after { content:'Best value'; position:absolute; top:-12px; right:18px; padding:5px 12px; background:var(--grad-red); color:#fff; font-size:10px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; border-radius:999px; box-shadow:0 6px 14px rgba(230,39,52,.30); }
.story--pricing__name { font-size:12px; font-weight:700; color:var(--red-600); letter-spacing:.10em; text-transform:uppercase; }
.story--pricing__amount { display:flex; align-items:baseline; gap:6px; margin:10px 0 4px; }
.story--pricing__amount strong { font-size:28px; font-weight:800; color:var(--ink); letter-spacing:-.02em; line-height:1; }
.story--pricing__amount span { font-size:13px; color:var(--slate-600); }
.story--pricing__note { font-size:12px; color:var(--slate-600); margin-bottom:14px; }
.story--pricing__list { display:flex; flex-direction:column; gap:6px; }
.story--pricing__list li { display:flex; gap:8px; font-size:14px; color:var(--ink); line-height:1.55; }
.story--pricing__list li::before { content:''; width:14px; height:14px; flex:0 0 14px; margin-top:3px; background:var(--red); -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/contain no-repeat; mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/contain no-repeat; }

/* 5. PLATFORM split Mac vs Windows */
.story--platform { background:#fff; }
.story--platform__intro { text-align:center; max-width:720px; margin:0 auto 36px; }
.story--platform__grid { display:grid; gap:20px; grid-template-columns:1fr; max-width:1080px; margin-inline:auto; }
@media (min-width:900px) { .story--platform__grid { grid-template-columns:1fr 1fr; gap:24px; } }
.story--platform__card { background:var(--bg-soft); border:1px solid var(--slate-200); border-radius:20px; padding:28px 24px; position:relative; overflow:hidden; }
.story--platform__card--mac { border-color:var(--red-light); }
.story--platform__card--mac::before { content:''; position:absolute; top:-40%; right:-20%; width:70%; height:80%; background:radial-gradient(circle,rgba(230,39,52,.12),transparent 60%); pointer-events:none; }
.story--platform__card--win { border-color:#C5CDFF; }
.story--platform__card--win::before { content:''; position:absolute; top:-40%; right:-20%; width:70%; height:80%; background:radial-gradient(circle,rgba(91,107,255,.12),transparent 60%); pointer-events:none; }
.story--platform__head { display:flex; align-items:center; gap:14px; margin-bottom:18px; position:relative; }
.story--platform__os { width:48px; height:48px; border-radius:12px; background:#fff; border:1px solid var(--slate-200); display:flex; align-items:center; justify-content:center; color:var(--red); flex:0 0 48px; }
.story--platform__card--win .story--platform__os { color:var(--indigo); }
.story--platform__os svg { width:24px; height:24px; }
.story--platform__title { font-size:19px; font-weight:800; color:var(--ink); }
.story--platform__title span { display:block; font-size:11px; font-weight:600; color:var(--slate-600); letter-spacing:.08em; text-transform:uppercase; margin-top:3px; }
.story--platform__card p { font-size:14px; color:var(--slate-700); line-height:1.65; margin-bottom:10px; position:relative; }
.story--platform__card code { font-family:ui-monospace,Menlo,monospace; font-size:12.5px; padding:2px 6px; background:var(--bg-mute); border:1px solid var(--slate-200); border-radius:4px; color:var(--ink); word-break:break-word; overflow-wrap:anywhere; }

/* 6. COMPARE — vs-rows competitors */
.story--compare { background:var(--bg-mute); }
.story--compare__intro { text-align:center; max-width:720px; margin:0 auto 36px; }
.story--compare__rows { display:flex; flex-direction:column; gap:14px; max-width:920px; margin-inline:auto; }
.story--compare__row { display:grid; grid-template-columns:auto 1fr; gap:18px; padding:18px 22px; background:#fff; border:1px solid var(--slate-200); border-left:4px solid var(--red); border-radius:14px; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; align-items:start; }
.story--compare__row:hover { transform:translateX(4px); box-shadow:var(--shadow-md); }
.story--compare__row:nth-child(2) { border-left-color:var(--orange); }
.story--compare__row:nth-child(3) { border-left-color:var(--indigo); }
.story--compare__row:nth-child(4) { border-left-color:var(--teal); }
.story--compare__row-label { font-size:11px; letter-spacing:.10em; text-transform:uppercase; color:var(--red); font-weight:800; padding:6px 10px; background:var(--red-soft); border-radius:6px; white-space:nowrap; }
.story--compare__row:nth-child(2) .story--compare__row-label { color:var(--orange-600); background:var(--orange-light); }
.story--compare__row:nth-child(3) .story--compare__row-label { color:var(--indigo); background:var(--indigo-light); }
.story--compare__row:nth-child(4) .story--compare__row-label { color:var(--teal); background:var(--teal-light); }
.story--compare__row-body strong { display:block; font-size:15px; color:var(--ink); margin-bottom:4px; font-weight:700; }
.story--compare__row-body span { font-size:14px; color:var(--slate-700); line-height:1.55; display:block; }

/* 7. HOWTO — timeline */
.story--howto { background:#fff; }
.story--howto__header { text-align:center; max-width:720px; margin:0 auto 44px; }
.story--howto__timeline { position:relative; max-width:760px; margin-inline:auto; padding-left:50px; counter-reset:hstep; }
@media (min-width:600px) { .story--howto__timeline { padding-left:64px; } }
.story--howto__timeline::before { content:''; position:absolute; left:20px; top:24px; bottom:24px; width:2px; background:linear-gradient(180deg,var(--red),var(--orange),var(--indigo)); border-radius:2px; }
@media (min-width:600px) { .story--howto__timeline::before { left:26px; } }
.story--howto__step { position:relative; padding:18px 22px; background:#fff; border:1px solid var(--slate-200); border-radius:14px; counter-increment:hstep; margin-bottom:16px; transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease; }
.story--howto__step:hover { transform:translateX(4px); border-color:var(--red-light); box-shadow:var(--shadow-md); }
.story--howto__step::before { content:counter(hstep,decimal-leading-zero); position:absolute; left:-50px; top:50%; transform:translateY(-50%); width:40px; height:40px; border-radius:50%; background:var(--grad-red); color:#fff; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:800; box-shadow:0 8px 20px rgba(230,39,52,.30),0 0 0 4px #fff; }
.story--howto__step:nth-child(2)::before { background:var(--grad-orange); box-shadow:0 8px 20px rgba(255,120,71,.30),0 0 0 4px #fff; }
.story--howto__step:nth-child(3)::before { background:linear-gradient(135deg,var(--indigo),#7C8AFF); box-shadow:0 8px 20px rgba(91,107,255,.30),0 0 0 4px #fff; }
@media (min-width:600px) { .story--howto__step::before { left:-64px; width:52px; height:52px; font-size:15px; } }
.story--howto__step h3 { font-size:16px; font-weight:700; color:var(--ink); margin-bottom:6px; }
.story--howto__step p { margin:0; font-size:14px; color:var(--slate-700); line-height:1.6; }
.story--howto__step strong { color:var(--red); }

/* 8. FINAL — closing CTA */
.story--final { background:radial-gradient(circle at 0% 0%,rgba(230,39,52,.16),transparent 55%),radial-gradient(circle at 100% 100%,rgba(255,120,71,.14),transparent 55%),linear-gradient(180deg,#fff,var(--red-soft)); border-top:1px solid var(--red-light); padding-block:80px; }
@media (min-width:768px) { .story--final { padding-block:120px; } }
.story--final .story__container { max-width:980px; text-align:center; position:relative; }
.story--final__icon { width:150px; height:150px; margin:0 auto 28px; position:relative; filter:drop-shadow(0 30px 50px rgba(230,39,52,.30)); animation:heroFloat 6s ease-in-out infinite; }
@media (min-width:768px) { .story--final__icon { width:180px; height:180px; } }
.story--final__icon img { width:100%; height:100%; border-radius:36px; }
.story--final h2 { font-size:clamp(2rem,5.5vw,3.2rem); margin-bottom:14px; }
.story--final p { font-size:17px; color:var(--slate-700); max-width:620px; margin-inline:auto; margin-bottom:32px; }
.story--final__actions { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-bottom:28px; }
.story--final__meta { display:flex; flex-wrap:wrap; gap:14px 26px; justify-content:center; font-size:13px; color:var(--slate-600); margin-bottom:32px; }
.story--final__meta-item { display:inline-flex; align-items:center; gap:8px; }
.story--final__meta-item svg { width:14px; height:14px; color:var(--red); flex:0 0 14px; }
.story--final__strip { display:grid; gap:14px; grid-template-columns:repeat(2,1fr); padding-top:28px; border-top:1px solid var(--red-light); max-width:760px; margin-inline:auto; }
@media (min-width:600px) { .story--final__strip { grid-template-columns:repeat(4,1fr); } }
.story--final__strip-item { display:flex; flex-direction:column; align-items:center; text-align:center; gap:4px; }
.story--final__strip-item strong { font-size:18px; font-weight:800; color:var(--ink); letter-spacing:-.01em; }
.story--final__strip-item span { font-size:11px; color:var(--slate-600); letter-spacing:.06em; text-transform:uppercase; font-weight:600; }

/* ════════════════════════ FAQ ════════════════════════ */
.faq { background:var(--bg-mute); }
.faq__list { max-width:820px; margin-inline:auto; display:flex; flex-direction:column; gap:12px; }
.faq-item { background:#fff; border:1px solid var(--slate-200); border-radius:14px; transition:border-color .2s ease; }
.faq-item:hover { border-color:var(--red-light); }
.faq-item[open] { border-color:var(--red-light); box-shadow:var(--shadow-sm); }
.faq-item summary { padding:18px 22px; font-size:15px; font-weight:600; color:var(--ink); cursor:pointer; list-style:none; display:flex; align-items:center; justify-content:space-between; gap:12px; }
@media (min-width:768px) { .faq-item summary { font-size:16px; } }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after { content:''; width:12px; height:12px; border-right:2px solid var(--slate-500); border-bottom:2px solid var(--slate-500); transform:rotate(45deg); transition:transform .25s ease, border-color .2s ease; flex:0 0 12px; margin-top:-3px; }
.faq-item[open] summary::after { transform:rotate(-135deg); border-color:var(--red); }
.faq-item__body { padding:0 22px 22px; color:var(--slate-700); font-size:14px; line-height:1.7; }
@media (min-width:768px) { .faq-item__body { font-size:15px; } }
.faq-item__body p { margin:0; }
.faq-item__body p + p { margin-top:10px; }

/* ════════════════════════ FOOTER ════════════════════════ */
.footer { background:linear-gradient(180deg,#fff,var(--bg-mute)); padding:56px 20px 28px; border-top:1px solid var(--slate-200); }
.footer__inner { max-width:1200px; margin-inline:auto; }
.footer__cols { display:grid; gap:36px; grid-template-columns:1fr; padding-bottom:32px; border-bottom:1px solid var(--slate-200); }
@media (min-width:600px) { .footer__cols { grid-template-columns:repeat(2,1fr); gap:32px; } }
@media (min-width:960px) { .footer__cols { grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:48px; } }
.footer__brand-col { display:flex; flex-direction:column; gap:16px; }
.footer__brand { display:inline-flex; align-items:center; gap:10px; font-weight:800; color:var(--ink); font-size:17px; }
.footer__brand img { width:32px; height:32px; border-radius:8px; box-shadow:0 4px 10px rgba(230,39,52,.20); }
.footer__desc { color:var(--slate-700); font-size:14px; line-height:1.6; max-width:340px; margin:0; }
.footer__social { display:flex; gap:10px; margin-top:6px; }
.footer__social a { width:36px; height:36px; display:inline-flex; align-items:center; justify-content:center; background:#fff; border:1px solid var(--slate-200); border-radius:10px; color:var(--slate-700); transition:all .2s ease; }
.footer__social a:hover { background:var(--red-soft); border-color:var(--red-light); color:var(--red); transform:translateY(-2px); }
.footer__social svg { width:16px; height:16px; }
.footer__col h4 { font-size:13px; font-weight:700; color:var(--ink); letter-spacing:.06em; text-transform:uppercase; margin-bottom:16px; }
.footer__col ul { display:flex; flex-direction:column; gap:10px; padding:0; list-style:none; }
.footer__col a { font-size:14px; color:var(--slate-700); display:inline-flex; align-items:center; gap:6px; min-height:44px; padding:6px 0; transition:color .15s ease; text-decoration:none; }
.footer__col a:hover { color:var(--red); }
.footer__sysreq { background:#fff; border:1px solid var(--red-light); border-radius:12px; padding:14px 16px; }
.footer__sysreq-title { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--red); font-weight:700; margin-bottom:8px; display:flex; align-items:center; gap:6px; }
.footer__sysreq-title svg { width:14px; height:14px; }
.footer__sysreq ul { display:flex; flex-direction:column; gap:6px; padding:0; list-style:none; }
.footer__sysreq li { font-size:13px; color:var(--ink); display:flex; gap:8px; align-items:center; padding:0; }
.footer__sysreq li::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--red); flex:0 0 6px; }
.footer__bottom { padding-top:24px; display:flex; flex-direction:column; gap:12px; align-items:center; text-align:center; }
@media (min-width:768px) { .footer__bottom { flex-direction:row; justify-content:space-between; text-align:left; } }
.footer__copy { font-size:13px; color:var(--slate-600); margin:0; }
.footer__legal { display:flex; flex-wrap:wrap; gap:16px 22px; justify-content:center; }
.footer__legal a { font-size:13px; color:var(--slate-600); padding:10px 6px; min-height:44px; display:inline-flex; align-items:center; text-decoration:none; transition:color .15s ease; }
.footer__legal a:hover { color:var(--red); }
.footer__note { font-size:11px; color:var(--slate-500); margin-top:14px; max-width:760px; margin-inline:auto; text-align:center; line-height:1.6; }

/* Reveal stagger */
.reveal { opacity:0; transform:translateY(20px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:translateY(0); }
.bento .reveal:nth-child(1) { transition-delay:0ms; }
.bento .reveal:nth-child(2) { transition-delay:80ms; }
.bento .reveal:nth-child(3) { transition-delay:160ms; }
.bento .reveal:nth-child(4) { transition-delay:240ms; }
.bento .reveal:nth-child(5) { transition-delay:320ms; }
.bento .reveal:nth-child(6) { transition-delay:400ms; }
.story--features__stair .reveal:nth-child(1) { transition-delay:0ms; }
.story--features__stair .reveal:nth-child(2) { transition-delay:100ms; }
.story--features__stair .reveal:nth-child(3) { transition-delay:200ms; }
.story--compare__rows .reveal:nth-child(1) { transition-delay:0ms; }
.story--compare__rows .reveal:nth-child(2) { transition-delay:80ms; }
.story--compare__rows .reveal:nth-child(3) { transition-delay:160ms; }
.story--compare__rows .reveal:nth-child(4) { transition-delay:240ms; }
.story--howto__timeline .reveal:nth-child(1) { transition-delay:0ms; }
.story--howto__timeline .reveal:nth-child(2) { transition-delay:80ms; }
.story--howto__timeline .reveal:nth-child(3) { transition-delay:160ms; }
.faq__list .reveal:nth-child(odd) { transition-delay:0ms; }
.faq__list .reveal:nth-child(even) { transition-delay:80ms; }

@media (prefers-reduced-motion: reduce) {
  .hero__visual img, .hero__badge, .hero__dot, .loader__spin, .story--what__ring, .story--what__ring2, .story--final__icon, .download__icon { animation:none !important; }
}

.section + .section, .story + .story, .section + .story, .story + .section, .trust + .section, .story + .footer, .section + .footer { border-top:1px solid var(--slate-100); }

.hero__content { position:relative; }

.story--pricing__plain { font-size:14px; color:var(--ink); line-height:1.6; margin:0; }
.story--pricing__intro-c { text-align:center; max-width:720px; margin:0 auto 36px; }
.story--platform__sub, .platform-card__sub { font-size:11px; font-weight:600; color:var(--slate-600); letter-spacing:.08em; text-transform:uppercase; margin-top:4px; }
