/* ═══════════════════════════════════════════════════════════════════════════
   Zepy — лендинг (полный редизайн). Самодостаточный файл: свой reset, токены,
   компоненты и CSS-мокапы экранов продукта. Не зависит от site.css.
   JS-хуки совместимы с /js/site.js (id: site-header, mobile-menu-btn,
   mobile-menu, back-to-top, footer-bot-btn; классы: faq-item, animate-in).
   ═══════════════════════════════════════════════════════════════════════════ */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
    --green-50:#ecfdf5; --green-100:#d1fae5; --green-200:#a7f3d0; --green-300:#6ee7b7;
    --green-400:#34d399; --green-500:#10b981; --green-600:#059669; --green-700:#047857;
    --teal-400:#2dd4bf; --teal-500:#14b8a6;
    --blue-400:#60a5fa; --blue-500:#3b82f6; --blue-600:#2563eb;
    --purple-400:#a78bfa; --purple-500:#8b5cf6;
    --amber-400:#fbbf24; --amber-500:#f59e0b;
    --ink-950:#0a0f1c; --ink-900:#0f172a; --ink-800:#1e293b; --ink-700:#334155;
    --gray-50:#f8fafc; --gray-100:#f1f5f9; --gray-200:#e2e8f0; --gray-300:#cbd5e1;
    --gray-400:#94a3b8; --gray-500:#64748b; --gray-600:#475569; --gray-700:#334155;
    --gray-800:#1e293b; --gray-900:#0f172a;
    --white:#ffffff;
    --bg:#f7faf9;
    --radius:22px;
    --radius-lg:28px;
    --shadow-sm:0 1px 2px rgba(15,23,42,.05);
    --shadow:0 2px 8px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
    --shadow-lg:0 18px 50px rgba(15,23,42,.10), 0 6px 16px rgba(15,23,42,.05);
    --shadow-xl:0 40px 90px rgba(15,23,42,.16), 0 12px 30px rgba(15,23,42,.08);
    --shadow-green:0 14px 40px rgba(16,185,129,.32);
    --grad:linear-gradient(135deg,var(--green-500),var(--teal-500));
}

html { scroll-behavior:smooth; }
body {
    font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
    color:var(--gray-800); background:var(--bg);
    line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased;
}

/* ─── Фоновый мэш ─────────────────────────────────────────────── */
.bg-mesh { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.bg-mesh::before, .bg-mesh::after {
    content:''; position:absolute; border-radius:50%; filter:blur(90px); opacity:.5;
}
.bg-mesh::before { width:620px; height:620px; background:radial-gradient(circle,var(--green-200),transparent 70%); top:-200px; left:-120px; }
.bg-mesh::after  { width:520px; height:520px; background:radial-gradient(circle,#cdeafe,transparent 70%); top:280px; right:-160px; }
.bg-grid {
    position:fixed; inset:0; z-index:0; pointer-events:none;
    background-image:linear-gradient(var(--gray-200) 1px,transparent 1px),linear-gradient(90deg,var(--gray-200) 1px,transparent 1px);
    background-size:64px 64px;
    -webkit-mask-image:radial-gradient(circle at 50% 0,#000,transparent 60%);
            mask-image:radial-gradient(circle at 50% 0,#000,transparent 60%);
    opacity:.35;
}

.container { max-width:1200px; margin:0 auto; padding:0 24px; position:relative; z-index:10; }

/* ─── Header / nav ────────────────────────────────────────────── */
.site-header {
    position:sticky; top:0; z-index:200;
    backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
    background:rgba(247,250,249,.72);
    border-bottom:1px solid transparent; transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-header.scrolled { border-bottom-color:var(--gray-200); box-shadow:0 6px 24px rgba(15,23,42,.05); background:rgba(247,250,249,.9); }
nav { display:flex; align-items:center; justify-content:space-between; padding:15px 0; }
.logo { display:flex; align-items:center; gap:9px; font-size:20px; font-weight:800; color:var(--gray-900); text-decoration:none; letter-spacing:-.02em; }
.nav-links { display:flex; align-items:center; gap:2px; }
.nav-link { font-size:14.5px; font-weight:600; color:var(--gray-600); text-decoration:none; padding:9px 14px; border-radius:11px; transition:background .2s,color .2s; }
.nav-link:hover { background:rgba(15,23,42,.05); color:var(--gray-900); }
.nav-btn { background:var(--grad); color:var(--white); padding:10px 22px; border-radius:12px; font-size:14.5px; font-weight:700; text-decoration:none; transition:transform .25s,box-shadow .25s; margin-left:10px; box-shadow:var(--shadow-green); }
.nav-btn:hover { transform:translateY(-2px); box-shadow:0 18px 40px rgba(16,185,129,.42); }

.mobile-menu-btn { display:none; flex-direction:column; gap:5px; padding:8px; background:none; border:none; cursor:pointer; }
.mobile-menu-btn span { display:block; width:22px; height:2px; background:var(--gray-700); border-radius:2px; transition:all .3s; }
.mobile-menu-btn.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.mobile-menu-btn.open span:nth-child(2) { opacity:0; }
.mobile-menu-btn.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.mobile-menu { display:none; flex-direction:column; padding:8px 24px 18px; border-top:1px solid var(--gray-100); background:rgba(247,250,249,.96); }
.mobile-menu.open { display:flex; }
.mobile-nav-link { font-size:16px; font-weight:600; color:var(--gray-700); text-decoration:none; padding:13px 0; border-bottom:1px solid var(--gray-100); }
.mobile-nav-link:last-child { border-bottom:none; }
.mobile-nav-cta { color:var(--green-600); }

/* ─── Buttons ─────────────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:10px; font-weight:700; text-decoration:none; border:none; border-radius:14px; cursor:pointer; font-family:inherit; transition:transform .3s,box-shadow .3s,background .3s,border-color .3s; }
.btn-lg { padding:16px 32px; font-size:16px; }
.btn-primary { background:var(--grad); color:var(--white); box-shadow:var(--shadow-green); }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 22px 54px rgba(16,185,129,.45); }
.btn-ghost { background:var(--white); color:var(--gray-700); border:1.5px solid var(--gray-200); box-shadow:var(--shadow-sm); }
.btn-ghost:hover { color:var(--gray-900); border-color:var(--gray-300); transform:translateY(-2px); box-shadow:var(--shadow); }
.btn-light { background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.22); }
.btn-light:hover { background:rgba(255,255,255,.2); transform:translateY(-2px); }
.btn:disabled { opacity:.55; cursor:not-allowed; transform:none !important; }

/* ─── Section headings ───────────────────────────────────────── */
section { position:relative; z-index:10; }
.eyebrow { display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:var(--green-700); background:var(--green-50); border:1px solid var(--green-100); padding:6px 13px; border-radius:30px; }
.section-head { text-align:center; max-width:680px; margin:0 auto 56px; display:flex; flex-direction:column; align-items:center; gap:18px; }
.section-title { font-size:clamp(28px,3.4vw,44px); font-weight:900; color:var(--gray-900); letter-spacing:-.03em; line-height:1.1; }
.section-sub { font-size:18px; color:var(--gray-500); line-height:1.6; }
.gradient-text { background:linear-gradient(120deg,var(--green-600),var(--teal-500),var(--blue-500)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }

/* ─── Hero ────────────────────────────────────────────────────── */
.hero { display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; padding:72px 0 56px; }
.hero-content { display:flex; flex-direction:column; align-items:flex-start; animation:fadeUp .8s ease; }
.hero-badge { display:inline-flex; align-items:center; gap:9px; background:var(--white); border:1px solid var(--gray-200); border-radius:30px; padding:7px 16px; font-size:13px; font-weight:600; color:var(--gray-600); margin-bottom:22px; box-shadow:var(--shadow-sm); }
.badge-dot { width:8px; height:8px; background:var(--green-500); border-radius:50%; box-shadow:0 0 0 0 rgba(16,185,129,.5); animation:pulse 2s infinite; }
.hero h1 { font-size:clamp(34px,4.6vw,58px); font-weight:900; letter-spacing:-.04em; line-height:1.05; color:var(--gray-900); margin-bottom:20px; }
.hero p { font-size:18px; color:var(--gray-600); max-width:500px; margin-bottom:30px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; }
.hero-proof { display:flex; align-items:center; gap:12px; margin-top:26px; }
.proof-dots { display:flex; }
.proof-dot { width:30px; height:30px; border-radius:50%; border:2.5px solid var(--bg); margin-right:-10px; box-shadow:var(--shadow-sm); }
.proof-text { font-size:13px; color:var(--gray-500); font-weight:500; padding-left:14px; }

.hero-visual { position:relative; display:flex; justify-content:center; animation:fadeUp 1s ease .1s both; }
.hero-glow { position:absolute; inset:-12% -6%; background:radial-gradient(circle at 60% 40%,rgba(45,212,191,.32),transparent 62%); filter:blur(20px); z-index:0; }

/* ─── Device: phone frame ─────────────────────────────────────── */
.phone { position:relative; z-index:2; width:300px; background:#0b1220; border-radius:42px; padding:11px; box-shadow:var(--shadow-xl); border:1px solid rgba(255,255,255,.08); }
.phone::before { content:''; position:absolute; top:16px; left:50%; transform:translateX(-50%); width:110px; height:22px; background:#0b1220; border-radius:0 0 16px 16px; z-index:5; }
.phone-screen { background:#eef2f6; border-radius:32px; overflow:hidden; }
.ph-top { background:linear-gradient(135deg,#0f172a,#1e293b); color:#fff; padding:30px 16px 12px; display:flex; align-items:center; gap:11px; }
.ph-ava { width:38px; height:38px; border-radius:50%; background:var(--grad); display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:18px; }
.ph-name { font-size:14px; font-weight:700; }
.ph-status { font-size:11px; color:var(--green-300); display:flex; align-items:center; gap:5px; margin-top:1px; }
.ph-status::before { content:''; width:6px; height:6px; background:var(--green-400); border-radius:50%; }
.ph-body { padding:14px 12px; display:flex; flex-direction:column; gap:8px; min-height:300px; }
.bub { max-width:85%; padding:9px 13px; border-radius:16px; font-size:13px; line-height:1.45; }
.bub-in { background:#fff; color:var(--gray-800); align-self:flex-start; border-bottom-left-radius:4px; box-shadow:var(--shadow-sm); }
.bub-out { background:linear-gradient(135deg,#25d366,#0ea371); color:#fff; align-self:flex-end; border-bottom-right-radius:4px; box-shadow:0 4px 12px rgba(16,185,129,.28); }
.bub-time { display:block; font-size:9.5px; opacity:.7; margin-top:3px; }
.typing { align-self:flex-start; background:#fff; border-radius:16px; border-bottom-left-radius:4px; padding:11px 14px; display:flex; gap:4px; box-shadow:var(--shadow-sm); }
.typing span { width:6px; height:6px; background:var(--gray-400); border-radius:50%; animation:typing 1.4s infinite; }
.typing span:nth-child(2){animation-delay:.2s} .typing span:nth-child(3){animation-delay:.4s}

/* Плавающий чип «запись подтверждена» */
.float-chip { position:absolute; z-index:3; background:var(--white); border:1px solid var(--gray-200); border-radius:16px; padding:12px 15px; box-shadow:var(--shadow-lg); display:flex; align-items:center; gap:11px; }
.float-chip .fc-ic { width:34px; height:34px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:17px; flex-shrink:0; }
.float-chip .fc-t { font-size:13px; font-weight:700; color:var(--gray-900); line-height:1.2; }
.float-chip .fc-s { font-size:11px; color:var(--gray-500); }
.float-chip--tl { top:18px; left:-46px; animation:floaty 5s ease-in-out infinite; }
.float-chip--br { bottom:40px; right:-40px; animation:floaty 5.5s ease-in-out infinite reverse; }

/* ─── Trust strip ─────────────────────────────────────────────── */
.trust { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin:8px 0 24px; }
.trust-item { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius); padding:22px; text-align:center; box-shadow:var(--shadow-sm); }
.trust-num { font-size:34px; font-weight:900; color:var(--gray-900); letter-spacing:-.03em; line-height:1; }
.trust-num span { font-size:20px; }
.trust-label { font-size:11.5px; color:var(--gray-400); font-weight:700; text-transform:uppercase; letter-spacing:.08em; margin-top:8px; }

/* ─── Feature rows (alternating) ─────────────────────────────── */
.feature-row { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; padding:54px 0; }
.feature-row.reverse .feature-text { order:2; }
.feature-row.reverse .feature-media { order:1; }
.feature-text h3 { font-size:clamp(24px,2.6vw,34px); font-weight:900; color:var(--gray-900); letter-spacing:-.03em; line-height:1.15; margin:16px 0 14px; }
.feature-text p { font-size:17px; color:var(--gray-600); margin-bottom:20px; }
.feature-list { list-style:none; display:flex; flex-direction:column; gap:11px; }
.feature-list li { display:flex; align-items:flex-start; gap:11px; font-size:15px; color:var(--gray-700); }
.feature-list li::before { content:'✓'; flex-shrink:0; width:22px; height:22px; border-radius:7px; background:var(--green-100); color:var(--green-700); font-weight:800; font-size:12px; display:flex; align-items:center; justify-content:center; margin-top:1px; }
.eyebrow--blue { color:var(--blue-600); background:#eff6ff; border-color:#dbeafe; }
.eyebrow--purple { color:#7c3aed; background:#f5f3ff; border-color:#ede9fe; }
.eyebrow--amber { color:#b45309; background:#fffbeb; border-color:#fef3c7; }

/* медиа-обёртка: «устройство» с подсветкой */
.feature-media { position:relative; display:flex; justify-content:center; }
.feature-media .glow { position:absolute; inset:-8%; border-radius:40px; background:radial-gradient(circle at 50% 40%,rgba(16,185,129,.14),transparent 65%); z-index:0; }

/* ── Browser-mock (общий каркас экранов кабинета) ── */
.mock { position:relative; z-index:1; width:100%; max-width:470px; background:var(--white); border:1px solid var(--gray-200); border-radius:18px; box-shadow:var(--shadow-lg); overflow:hidden; }
.mock-bar { display:flex; align-items:center; gap:6px; padding:11px 14px; background:var(--gray-50); border-bottom:1px solid var(--gray-100); }
.mock-bar i { width:10px; height:10px; border-radius:50%; display:inline-block; }
.mock-bar i:nth-child(1){background:#ff5f57} .mock-bar i:nth-child(2){background:#febc2e} .mock-bar i:nth-child(3){background:#28c840}
.mock-bar .mock-url { margin-left:10px; font-size:11px; color:var(--gray-400); font-weight:600; }
.mock-body { padding:16px; }

/* ── Мокап: недельный календарь ── */
.mk-cal-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.mk-cal-title { font-size:13px; font-weight:800; color:var(--gray-900); }
.mk-cal-nav { display:flex; gap:5px; }
.mk-cal-nav b { width:22px; height:22px; border-radius:7px; background:var(--gray-100); color:var(--gray-500); font-size:12px; display:flex; align-items:center; justify-content:center; }
.mk-cal-grid { display:grid; grid-template-columns:26px repeat(5,1fr); gap:5px; }
.mk-cal-grid .d { font-size:9.5px; font-weight:700; color:var(--gray-400); text-align:center; text-transform:uppercase; }
.mk-cal-grid .h { font-size:9px; color:var(--gray-300); text-align:right; padding-right:3px; }
.mk-cal-col { display:flex; flex-direction:column; gap:5px; }
.ev { border-radius:7px; padding:5px 7px; font-size:9.5px; font-weight:700; line-height:1.25; }
.ev small { display:block; font-weight:600; opacity:.75; font-size:8.5px; }
.ev.g { background:var(--green-100); color:var(--green-700); }
.ev.b { background:#dbeafe; color:#1d4ed8; }
.ev.p { background:#ede9fe; color:#6d28d9; }
.ev.a { background:#fef3c7; color:#92400e; }
.ev.empty { background:var(--gray-50); border:1px dashed var(--gray-200); height:22px; }

/* ── Мокап: CRM-карточка клиента ── */
.mk-crm-head { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.mk-crm-ava { width:46px; height:46px; border-radius:14px; background:var(--grad); color:#fff; font-size:18px; font-weight:800; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.mk-crm-name { font-size:15px; font-weight:800; color:var(--gray-900); }
.mk-crm-phone { font-size:12px; color:var(--gray-400); }
.mk-tags { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:14px; }
.mk-tag { font-size:10.5px; font-weight:700; padding:3px 10px; border-radius:20px; background:var(--green-50); color:var(--green-700); }
.mk-tag.b { background:#eff6ff; color:#1d4ed8; }
.mk-tag.a { background:#fffbeb; color:#b45309; }
.mk-crm-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:14px; }
.mk-crm-stat { background:var(--gray-50); border-radius:12px; padding:9px; text-align:center; }
.mk-crm-stat b { display:block; font-size:18px; font-weight:900; color:var(--gray-900); }
.mk-crm-stat span { font-size:9.5px; color:var(--gray-400); font-weight:600; }
.mk-note { font-size:11.5px; color:var(--gray-600); background:#fffdf5; border:1px solid #fef3c7; border-radius:10px; padding:9px 11px; }
.mk-note b { color:#92400e; }

/* ── Мокап: выбор мастера ── */
.mk-staff-row { display:flex; align-items:center; gap:11px; padding:11px; border:1px solid var(--gray-200); border-radius:14px; margin-bottom:8px; transition:.2s; }
.mk-staff-row.sel { border-color:var(--green-400); background:var(--green-50); box-shadow:0 0 0 3px rgba(16,185,129,.12); }
.mk-staff-ava { width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:17px; flex-shrink:0; }
.mk-staff-ava.g{background:var(--green-100)} .mk-staff-ava.b{background:#dbeafe} .mk-staff-ava.p{background:#ede9fe}
.mk-staff-name { font-size:13px; font-weight:700; color:var(--gray-900); }
.mk-staff-meta { font-size:11px; color:var(--gray-400); }
.mk-staff-slot { margin-left:auto; font-size:11px; font-weight:700; color:var(--green-600); background:var(--green-50); padding:4px 9px; border-radius:8px; }

/* ── Мокап: запись в календаре телефона (мини) ── */
.mk-phone-ev { background:var(--gray-50); border-left:3px solid var(--green-500); border-radius:8px; padding:10px 12px; margin-bottom:8px; }
.mk-phone-ev .t { font-size:12.5px; font-weight:700; color:var(--gray-900); }
.mk-phone-ev .s { font-size:11px; color:var(--gray-500); }
.mk-phone-ev.b { border-left-color:var(--blue-500); }

/* ─── Bento grid (мелкие фичи) ───────────────────────────────── */
.bento { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.bento-card { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius); padding:26px 24px; box-shadow:var(--shadow-sm); transition:transform .35s,box-shadow .35s,border-color .35s; position:relative; overflow:hidden; }
.bento-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:transparent; }
.bento-ic { width:48px; height:48px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:23px; margin-bottom:16px; }
.ic-green{background:linear-gradient(135deg,var(--green-100),var(--green-200))} .ic-blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe)} .ic-purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe)} .ic-amber{background:linear-gradient(135deg,#fef3c7,#fde68a)}
.bento-card h4 { font-size:17px; font-weight:800; color:var(--gray-900); margin-bottom:7px; letter-spacing:-.01em; }
.bento-card p { font-size:14px; color:var(--gray-600); line-height:1.6; }

/* ─── Steps ───────────────────────────────────────────────────── */
.steps { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; counter-reset:step; }
.step { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius); padding:30px 28px; box-shadow:var(--shadow-sm); position:relative; transition:transform .35s,box-shadow .35s; }
.step:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.step-num { width:42px; height:42px; border-radius:13px; background:var(--grad); color:#fff; font-size:19px; font-weight:900; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-green); margin-bottom:18px; }
.step h4 { font-size:17px; font-weight:800; color:var(--gray-900); margin-bottom:9px; }
.step p { font-size:14px; color:var(--gray-600); margin-bottom:16px; }
.step-tag { display:inline-flex; font-size:12px; font-weight:700; color:var(--green-700); background:var(--green-50); border:1px solid var(--green-100); border-radius:8px; padding:4px 10px; }
.step-connector { position:absolute; top:50px; right:-12px; color:var(--gray-300); font-size:20px; z-index:5; }

/* ─── Testimonials ───────────────────────────────────────────── */
.tgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.tcard { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow-sm); transition:transform .35s,box-shadow .35s; }
.tcard:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.tstars { color:var(--amber-500); font-size:14px; letter-spacing:2px; margin-bottom:12px; }
.ttext { font-size:14px; color:var(--gray-700); line-height:1.7; margin-bottom:16px; }
.tfoot { display:flex; align-items:center; gap:11px; }
.tava { width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.tname { font-size:13.5px; font-weight:700; color:var(--gray-900); }
.trole { font-size:11.5px; color:var(--gray-400); }

/* ─── Pricing ─────────────────────────────────────────────────── */
.pricing-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; max-width:760px; margin:0 auto; }
.pcard { background:var(--white); border:1px solid var(--gray-200); border-radius:var(--radius-lg); padding:36px 32px; box-shadow:var(--shadow); position:relative; transition:transform .35s,box-shadow .35s; }
.pcard:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.pcard--feat { border-color:var(--green-300); box-shadow:0 0 0 2px var(--green-300),0 24px 60px rgba(16,185,129,.14); background:linear-gradient(165deg,var(--green-50),var(--white) 55%); }
.pbadge { position:absolute; top:18px; right:20px; background:var(--green-100); color:var(--green-700); font-size:11.5px; font-weight:800; padding:4px 11px; border-radius:20px; }
.plabel { font-size:13px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--gray-500); margin-bottom:12px; }
.pamount { font-size:48px; font-weight:900; color:var(--gray-900); letter-spacing:-.04em; line-height:1; }
.pamount span { font-size:28px; }
.pperiod { font-size:14px; color:var(--gray-400); margin:4px 0 28px; }
.plist { list-style:none; margin-bottom:30px; display:flex; flex-direction:column; gap:1px; }
.plist li { font-size:14.5px; color:var(--gray-700); padding:9px 0; border-bottom:1px solid var(--gray-100); display:flex; gap:10px; align-items:flex-start; }
.plist li::before { content:'✓'; color:var(--green-500); font-weight:800; flex-shrink:0; }
.plist li.base { color:var(--gray-400); font-size:13px; }
.plist li.base::before { content:'★'; color:var(--gray-300); }
.pbtn { width:100%; }

/* ─── FAQ ─────────────────────────────────────────────────────── */
.faq-list { max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.faq-item { background:var(--white); border:1px solid var(--gray-200); border-radius:18px; box-shadow:var(--shadow-sm); overflow:hidden; transition:box-shadow .3s; }
.faq-item.open { box-shadow:var(--shadow); }
.faq-q { width:100%; background:none; border:none; text-align:left; padding:20px 24px; font-size:16px; font-weight:700; color:var(--gray-900); cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:12px; font-family:inherit; }
.faq-q:hover { color:var(--green-600); }
.faq-q::after { content:'+'; font-size:22px; color:var(--gray-400); transition:transform .3s; flex-shrink:0; }
.faq-item.open .faq-q::after { content:'−'; }
.faq-a { max-height:0; overflow:hidden; transition:max-height .35s ease,padding .35s ease; }
.faq-item.open .faq-a { max-height:400px; padding:0 24px 22px; }
.faq-a p { font-size:15px; color:var(--gray-600); line-height:1.7; }
.faq-a a { color:var(--green-600); }

/* ─── CTA ─────────────────────────────────────────────────────── */
.cta { padding:60px 0 100px; }
.cta-card { background:linear-gradient(150deg,var(--ink-900),var(--ink-800)); border-radius:32px; padding:64px 40px; max-width:840px; margin:0 auto; text-align:center; position:relative; overflow:hidden; box-shadow:var(--shadow-xl); }
.cta-card::before { content:''; position:absolute; top:-40%; left:50%; transform:translateX(-50%); width:600px; height:600px; background:radial-gradient(circle,rgba(16,185,129,.28),transparent 60%); }
.cta-card > * { position:relative; z-index:1; }
.cta-card h2 { font-size:clamp(26px,3.2vw,38px); font-weight:900; color:#fff; letter-spacing:-.03em; margin-bottom:14px; }
.cta-card p { font-size:17px; color:rgba(255,255,255,.66); line-height:1.6; margin-bottom:28px; }
.cta-feats { display:flex; flex-wrap:wrap; justify-content:center; gap:10px 22px; margin-bottom:32px; }
.cta-feat { display:flex; align-items:center; gap:8px; font-size:14.5px; color:rgba(255,255,255,.8); }
.cta-feat .ck { color:var(--green-400); font-weight:800; }
.cta-disclaimer { margin-top:16px; font-size:13px; color:rgba(255,255,255,.4); }

/* ─── Footer ──────────────────────────────────────────────────── */
footer { border-top:1px solid var(--gray-200); padding:34px 0; display:flex; justify-content:space-between; align-items:center; color:var(--gray-400); font-size:14px; flex-wrap:wrap; gap:16px; }
.footer-link { color:var(--green-600); text-decoration:none; font-weight:600; }
.footer-link:hover { color:var(--green-500); }

/* ─── Back to top ─────────────────────────────────────────────── */
.back-to-top { position:fixed; bottom:24px; right:24px; z-index:300; width:46px; height:46px; background:var(--ink-900); color:#fff; border:none; border-radius:13px; font-size:18px; cursor:pointer; display:none; align-items:center; justify-content:center; box-shadow:var(--shadow-lg); transition:transform .3s; }
.back-to-top.visible { display:flex; }
.back-to-top:hover { transform:translateY(-3px); }

/* ─── Animations ──────────────────────────────────────────────── */
@keyframes fadeUp { from { opacity:0; transform:translateY(34px); } to { opacity:1; transform:translateY(0); } }
@keyframes pulse { 0%,100% { box-shadow:0 0 0 0 rgba(16,185,129,.5); } 50% { box-shadow:0 0 0 9px rgba(16,185,129,0); } }
@keyframes typing { 0%,60%,100% { transform:translateY(0); opacity:.5; } 30% { transform:translateY(-5px); opacity:1; } }
@keyframes floaty { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-12px); } }
.animate-in { opacity:0; transform:translateY(26px); }
.animate-in.visible { opacity:1; transform:translateY(0); transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1); }

/* ─── Section spacing helper ─────────────────────────────────── */
.section { padding:64px 0; }
.section-tight { padding:28px 0; }

/* ─── Responsive ──────────────────────────────────────────────── */
@media (max-width:980px) {
    .hero { grid-template-columns:1fr; gap:40px; text-align:center; padding:48px 0 36px; }
    .hero-content { align-items:center; }
    .hero p { margin-left:auto; margin-right:auto; }
    .hero-visual { order:-1; }
    .feature-row { grid-template-columns:1fr; gap:36px; padding:40px 0; }
    .feature-row.reverse .feature-text { order:0; }
    .feature-row.reverse .feature-media { order:0; }
    .feature-text { text-align:center; }
    .feature-text .eyebrow { align-self:center; }
    .feature-list { max-width:440px; margin:0 auto; text-align:left; }
    .bento { grid-template-columns:repeat(2,1fr); }
    .steps { grid-template-columns:1fr; }
    .step-connector { display:none; }
    .tgrid { grid-template-columns:1fr 1fr; }
}

@media (max-width:768px) {
    .nav-links { display:none; }
    .mobile-menu-btn { display:flex; }
}

@media (max-width:640px) {
    .container { padding:0 18px; }
    .section, .cta { padding:40px 0; }
    .hero h1 { font-size:32px; }
    .hero p { font-size:15.5px; }
    .hero-actions { width:100%; flex-direction:column; }
    .hero-actions .btn { width:100%; }
    .section-head { margin-bottom:34px; }
    .section-sub { font-size:15.5px; }
    .trust { grid-template-columns:1fr 1fr; gap:12px; }
    .trust-num { font-size:26px; }
    .bento { grid-template-columns:1fr; }
    .tgrid { grid-template-columns:1fr; }
    .pricing-grid { grid-template-columns:1fr; }
    .pcard { padding:28px 24px; }
    .float-chip--tl { left:-10px; top:6px; transform:scale(.85); }
    .float-chip--br { right:-6px; bottom:18px; transform:scale(.85); }
    .feature-media .mock { max-width:340px; }
    .btn-lg { padding:14px 24px; font-size:15px; }
    footer { flex-direction:column; align-items:flex-start; }
}
