@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --fs-bg:#faf8fa;
  --fs-surface:#ffffff;
  --fs-surface-soft:#fffafb;
  --fs-blush:#f7e8f1;
  --fs-pink:#e83e8c;
  --fs-pink-dark:#cf2d79;
  --fs-pink-glow:rgba(232,62,140,.12);
  --fs-ink:#0f172a;
  --fs-muted:#64748b;
  --fs-line:#eee6ec;
  --fs-blue:#2563eb;
  --radius:20px;
  --shadow:0 4px 24px rgba(17,24,39,.06),0 1px 2px rgba(17,24,39,.04);
  --shadow-lg:0 20px 60px rgba(17,24,39,.08),0 4px 12px rgba(17,24,39,.04);
  --shadow-soft:0 18px 48px rgba(17,24,39,.06),0 4px 10px rgba(17,24,39,.03);
  --max:1160px;
  --ease:cubic-bezier(.23,1,.32,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overscroll-behavior:none;-webkit-text-size-adjust:100%}
body{font-family:'Inter',ui-sans-serif,system-ui,-apple-system,sans-serif;color:var(--fs-ink);background:radial-gradient(circle at top,rgba(255,255,255,.9),transparent 36%),linear-gradient(180deg,#fbf8fb 0%,#f7f1f5 100%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-top:env(safe-area-inset-top);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);opacity:0;transform:translate3d(0,12px,0);transition:opacity .32s var(--ease),transform .32s var(--ease),background .45s var(--ease)}
body::after{content:'';position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 14%,rgba(232,62,140,.07),transparent 22%),radial-gradient(circle at 82% 20%,rgba(255,255,255,.45),transparent 26%),radial-gradient(circle at 50% 100%,rgba(247,232,241,.5),transparent 34%);opacity:.9;z-index:-1;transition:opacity .25s var(--ease)}
body.page-ready{opacity:1;transform:none}
body.page-transitioning{opacity:0;transform:translate3d(0,18px,0);pointer-events:none}
body.page-transitioning::after{opacity:1}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
button{-webkit-tap-highlight-color:transparent}
img{max-width:100%;display:block}
.container{width:min(var(--max),calc(100% - 48px));margin:0 auto}

/* ===== HEADER ===== */
header{position:sticky;top:0;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--fs-line);z-index:50;transition:box-shadow .3s var(--ease)}
header:hover{box-shadow:0 2px 20px rgba(0,0,0,.04)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}

.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-logo{width:32px;height:32px;object-fit:contain;display:block}
.brand-name{font-weight:900;font-size:1.6rem;letter-spacing:-.03em;color:var(--fs-ink)}
.brand-mark{display:none}

.nav-links{display:flex;flex-wrap:wrap;gap:6px;font-weight:600;font-size:.95rem}
.nav-links a{color:var(--fs-ink);padding:8px 14px;border-radius:12px;transition:transform .2s var(--ease),background-color .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease)}
.nav-links a:hover,.nav-links a.active{background:var(--fs-blush);color:var(--fs-pink)}
.nav-links a:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(232,62,140,.08)}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;line-height:1}
.nav-toggle svg{width:26px;height:26px;stroke:var(--fs-ink);stroke-width:2;stroke-linecap:round}
.nav-toggle .icon-close{display:none}

/* ===== BUTTONS ===== */
.btn-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.62rem;padding:14px 24px;border-radius:14px;font-weight:700;font-size:.95rem;border:1px solid transparent;cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background-color .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease)}
.btn.primary{background:var(--fs-pink);color:#fff;box-shadow:0 2px 12px rgba(232,62,140,.2)}
.btn.primary:hover{background:var(--fs-pink-dark);box-shadow:0 10px 28px rgba(232,62,140,.26);transform:translateY(-2px) scale(1.01)}
.btn.ghost{background:#fff;border-color:var(--fs-line);color:var(--fs-ink)}
.btn.ghost:hover{background:var(--fs-blush);border-color:#f0cfe0;transform:translateY(-2px)}
.btn.dark,.btn.dark:visited{background:var(--fs-ink);color:#fff;border-color:var(--fs-ink)}
.btn.dark:hover,.btn.dark:focus-visible{background:#1e293b;color:#fff;box-shadow:0 12px 32px rgba(15,23,42,.22);transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.99)}

.icon-sprite{position:absolute;width:0;height:0;overflow:hidden}
.ui-icon{width:1em;height:1em;display:block;flex:none}

#cta-list,#cta-list:visited{background:var(--fs-ink);color:#fff !important;border:1px solid var(--fs-ink);box-shadow:0 10px 28px rgba(15,23,42,.16)}
#cta-list:hover,#cta-list:focus-visible{background:#1e293b;color:#fff !important;border-color:#1e293b;box-shadow:0 14px 36px rgba(15,23,42,.24)}

/* ===== SECTIONS & CARDS ===== */
.section{padding:clamp(74px,8vw,108px) 0;position:relative;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,0) 100%);transition:background .45s var(--ease)}
.section::before{content:'';position:absolute;inset:0;pointer-events:none;background:linear-gradient(135deg,rgba(255,255,255,.36),transparent 35%,rgba(247,232,241,.2) 100%);opacity:.85}
.section > .container{position:relative;z-index:1}
body > section.section:nth-of-type(odd){background:linear-gradient(180deg,rgba(255,255,255,.6) 0%,rgba(247,232,241,.34) 100%)}
body > section.section:nth-of-type(even){background:linear-gradient(180deg,rgba(255,255,255,.34) 0%,rgba(252,246,249,.92) 42%,rgba(255,255,255,.58) 100%)}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.pricing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
.card{background:linear-gradient(180deg,var(--fs-surface) 0%,var(--fs-surface-soft) 100%);border:1px solid rgba(238,230,236,.95);border-radius:24px;padding:32px 28px;box-shadow:var(--shadow-soft);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.95),rgba(255,255,255,0));opacity:.9}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-8px);border-color:#f4cadd;background:linear-gradient(180deg,#ffffff 0%,#fff6fa 100%)}
.card h3{margin:18px 0 10px;font-size:1.22rem;font-weight:800;letter-spacing:-.02em;line-height:1.2}
.card p{margin:0;color:#556273;line-height:1.78;font-size:.98rem}
.icon-badge{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,#fff6fa,#f8e7f1);display:grid;place-items:center;color:var(--fs-pink);box-shadow:inset 0 1px 0 rgba(255,255,255,.75),0 12px 24px rgba(232,62,140,.08)}
.feature-icon{width:24px;height:24px}

.band{background:linear-gradient(180deg,rgba(255,255,255,.96) 0%,rgba(249,241,246,.92) 100%);border-top:1px solid var(--fs-line);border-bottom:1px solid var(--fs-line)}
.band .container{padding:28px 0}
.chips{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.chip{border:1px solid var(--fs-line);background:#fff;border-radius:999px;padding:8px 14px;font-weight:600;color:#374151;font-size:.9rem}

.page-head{padding:34px 34px 28px;position:relative;border:1px solid rgba(238,230,236,.95);border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.88) 0%,rgba(255,250,252,.98) 100%);box-shadow:var(--shadow-soft);overflow:hidden}
.page-head::before{content:'';position:absolute;right:-60px;top:-70px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(232,62,140,.12),transparent 70%);pointer-events:none}
.page-head::after{content:'';display:block;width:84px;height:1px;margin-top:18px;background:linear-gradient(90deg,var(--fs-pink),transparent);opacity:.55}
.page-head .eyebrow{margin-bottom:16px}
.page-head h1{margin:0 0 10px;font-size:clamp(2.1rem,3.6vw,3.2rem);letter-spacing:-.045em;line-height:1.02;max-width:13ch;position:relative;z-index:1}
.page-head p{margin:0;color:var(--fs-muted);line-height:1.82;max-width:760px;font-size:1.04rem;position:relative;z-index:1}
.page-head-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;position:relative;z-index:1}

.stack{display:grid;gap:20px}
.panel{background:linear-gradient(180deg,var(--fs-surface) 0%,var(--fs-surface-soft) 100%);border:1px solid rgba(238,230,236,.95);border-radius:22px;padding:24px 24px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease);box-shadow:0 12px 34px rgba(17,24,39,.035)}
.panel h2{margin:0 0 12px;font-size:1.22rem;letter-spacing:-.02em;line-height:1.2;display:flex;align-items:center}
.panel h3{margin:12px 0 6px;font-size:1rem}
.panel p,.panel li{color:#374151;line-height:1.75}
.panel ol{margin:8px 0 0 20px;padding:0}
.panel ol li + li{margin-top:8px}
.panel ul{margin:8px 0 0 18px;padding:0}
.panel li + li{margin-top:8px}
.panel:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(17,24,39,.07);border-color:#f0d6e4;background:linear-gradient(180deg,#ffffff 0%,#fff8fb 100%)}
.panel-title-icon{display:inline-grid;place-items:center;width:30px;height:30px;margin-right:10px;border-radius:10px;background:linear-gradient(135deg,var(--fs-blush),#fce4ec);color:var(--fs-pink);vertical-align:middle}
.panel-title-icon .ui-icon{width:16px;height:16px}

.notice{background:linear-gradient(180deg,#ffffff 0%,#f4fcf7 100%);border-color:#c8e7d3;box-shadow:0 16px 40px rgba(16,185,129,.05)}
.notice strong{color:#0f6a4b}

.plan-card{position:relative}
.plan-kicker{display:inline-flex;align-items:center;gap:8px;margin-bottom:12px;padding:7px 12px;border-radius:999px;background:rgba(232,62,140,.08);color:var(--fs-pink);font-size:.75rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.plan-kicker::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.75}
.plan-price{display:block;margin-top:8px;color:var(--fs-pink);font-size:1rem;font-weight:700;letter-spacing:-.01em}
.featured-plan{border-color:rgba(232,62,140,.22);box-shadow:0 18px 44px rgba(232,62,140,.09)}
.featured-plan::after{content:'Recommended';position:absolute;top:18px;right:18px;padding:6px 10px;border-radius:999px;background:var(--fs-ink);color:#fff;font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase}

.kv{display:grid;grid-template-columns:220px 1fr;gap:10px 18px}
.kv div{padding:12px 0;border-bottom:1px dashed rgba(238,230,236,.95)}
.kv .k{font-weight:700;color:#253041;letter-spacing:-.01em}

footer{margin-top:52px;background:linear-gradient(180deg,rgba(255,255,255,.95) 0%,rgba(247,232,241,.5) 100%);border-top:1px solid var(--fs-line)}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:18px;padding:28px 0}
.footer-col h4{margin:0 0 10px}
.footer-col a{display:block;color:#374151;padding:4px 0}
.footer-col a:hover{color:var(--fs-pink)}
.muted{color:var(--fs-muted)}
.small{font-size:.93rem}
.footer-bottom{border-top:1px solid var(--fs-line);padding:14px 0;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--fs-muted)}

.table-wrap{border:1px solid rgba(238,230,236,.95);border-radius:22px;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#fff8fb 100%);box-shadow:0 12px 30px rgba(17,24,39,.03)}
.table{width:100%;border-collapse:collapse;font-size:.96rem}
.table th,.table td{border:1px solid rgba(238,230,236,.95);padding:14px 16px;vertical-align:top;line-height:1.7}
.table th{background:#fdf7fa;text-align:left;color:#273244;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
.table tbody tr:hover{background:rgba(247,232,241,.28)}

#legal-content{display:grid;gap:18px}
.legal-loading,.legal-empty,.legal-error{text-align:center}
.legal-document{padding:30px 28px}
.legal-document-title{margin:0;font-size:clamp(1.45rem,2vw,1.75rem);letter-spacing:-.03em;line-height:1.08;color:var(--fs-ink)}
.legal-document-meta{margin-top:8px;color:var(--fs-muted);font-size:.96rem}
.legal-document-intro{margin-top:10px;color:#556273;line-height:1.82}
.legal-divider{height:1px;background:linear-gradient(90deg,rgba(232,62,140,.28),rgba(238,230,236,.7),transparent);margin:22px 0}
.legal-section-title{margin:26px 0 10px;font-size:1.08rem;letter-spacing:-.02em;color:var(--fs-ink)}
.legal-section-text{margin-bottom:10px;color:#556273;line-height:1.82}
.legal-error p{color:#b42318}

/* ===== HERO v2 — Premium Marketplace (Booksy × GlossGenius) ===== */
.hero-v2{background:linear-gradient(175deg,#fdf2f8 0%,#f7e8f1 40%,#faf5f9 100%);border-bottom:1px solid var(--fs-line);overflow:hidden;position:relative;isolation:isolate}
.hero-v2::before{content:'';position:absolute;inset:auto auto -120px -120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.92),rgba(255,255,255,0) 70%);filter:blur(12px);opacity:.9;animation:float-orb 16s ease-in-out infinite;pointer-events:none;z-index:0}
.hero-v2::after{content:'';position:absolute;right:-120px;top:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(232,62,140,.08),transparent 70%);pointer-events:none;animation:float-orb 18s ease-in-out infinite reverse;z-index:0}
.hero-backdrop{position:absolute;inset:0;z-index:0;transform:translate3d(0,0,0);will-change:transform}
.hero-video{position:absolute;inset:-5%;width:110%;height:110%;object-fit:cover;filter:saturate(.92) contrast(1.03) brightness(.82) blur(1px);opacity:.24;transform:scale(1.06)}
.hero-backdrop-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(250,248,250,.92) 0%,rgba(250,248,250,.82) 42%,rgba(250,248,250,.7) 62%,rgba(250,248,250,.82) 100%)}
.hero-orb{position:absolute;border-radius:50%;filter:blur(10px);opacity:.55;animation:float-orb 14s ease-in-out infinite}
.hero-orb-a{right:8%;top:16%;width:180px;height:180px;background:radial-gradient(circle,rgba(232,62,140,.24),rgba(232,62,140,0) 72%)}
.hero-orb-b{left:3%;bottom:8%;width:220px;height:220px;background:radial-gradient(circle,rgba(255,255,255,.82),rgba(255,255,255,0) 68%);animation-duration:20s}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:36px;align-items:stretch;padding:80px 0 72px}
.hero-grid > *{position:relative;z-index:1}
.hero-left h1{margin:18px 0 14px;font-size:clamp(2.4rem,4vw,3.8rem);letter-spacing:-.03em;font-weight:900;line-height:1.08}
.hero-left p{margin:0;max-width:540px;color:var(--fs-muted);font-size:1.1rem;line-height:1.7}
.btn-row.left{justify-content:flex-start}
.trust-row{margin-top:20px;display:flex;flex-wrap:wrap;gap:10px}
.trust-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--fs-line);background:rgba(255,255,255,.8);backdrop-filter:blur(6px);border-radius:999px;padding:8px 14px;font-weight:600;color:#475569;font-size:.88rem;transition:transform .25s var(--ease),background-color .25s var(--ease),border-color .25s var(--ease)}
.trust-chip:hover{background:#fff;border-color:#f0cfe0;transform:translateY(-2px)}
.trust-icon{width:16px;height:16px;color:var(--fs-pink)}
.pill{display:inline-flex;align-items:center;gap:10px;border:1px solid #f0cfe0;background:rgba(255,255,255,.7);backdrop-filter:blur(6px);border-radius:999px;padding:8px 16px;font-weight:700;color:var(--fs-pink);font-size:.88rem;letter-spacing:.01em}
.pill-dot{width:8px;height:8px;border-radius:99px;background:var(--fs-pink);display:inline-block;animation:pulse-dot 2s ease infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
@keyframes float-orb{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(0,-16px,0) scale(1.05)}}

.hero-live-note{margin-top:18px;display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.88);backdrop-filter:blur(8px);border-radius:999px;padding:10px 14px;color:#475569;font-size:.9rem;box-shadow:0 10px 30px rgba(17,24,39,.06)}
.hero-live-dot{width:10px;height:10px;border-radius:50%;background:var(--fs-pink);box-shadow:0 0 0 0 rgba(232,62,140,.35);animation:live-pulse 1.8s ease-out infinite}
@keyframes live-pulse{0%{box-shadow:0 0 0 0 rgba(232,62,140,.34)}70%{box-shadow:0 0 0 12px rgba(232,62,140,0)}100%{box-shadow:0 0 0 0 rgba(232,62,140,0)}}

/* Search card */
.search-card{background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.86);border-radius:24px;padding:24px;box-shadow:var(--shadow-lg);backdrop-filter:blur(12px);position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.search-card::before{content:'';position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.95),transparent);opacity:.75}
.search-card:hover{transform:translateY(-6px);box-shadow:0 24px 64px rgba(17,24,39,.12),0 6px 18px rgba(17,24,39,.06)}
.search-card h3{margin:0 0 4px;font-size:1.15rem;font-weight:800}
.search-form{display:grid;gap:12px;margin-top:12px}
.field span{display:block;font-size:.82rem;font-weight:700;color:#475569;margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}
.field input,.field select{width:100%;padding:13px 14px;border:1px solid var(--fs-line);border-radius:14px;background:#fafafa;font:inherit;font-size:16px;transition:all .2s var(--ease)}
.field input:focus,.field select:focus{outline:none;border-color:var(--fs-pink);background:#fff;box-shadow:0 0 0 4px var(--fs-pink-glow)}
.btn.full{width:100%}
.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.mini-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--fs-line);background:#fafafa;border-radius:999px;padding:8px 12px;font-weight:600;color:#475569;cursor:pointer;font-size:.88rem;transition:all .2s var(--ease)}
.mini-chip:hover{background:var(--fs-blush);color:var(--fs-pink);border-color:#f0cfe0;transform:translateY(-1px)}
.mini-chip-icon{width:15px;height:15px;color:var(--fs-pink)}
.search-note{margin-top:12px;border-top:1px dashed var(--fs-line);padding-top:12px;color:var(--fs-muted);font-size:.9rem}
.search-note strong{color:var(--fs-ink)}

/* Section headers */
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:30px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid rgba(232,62,140,.14);background:rgba(255,255,255,.72);color:var(--fs-pink);font-size:.76rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;box-shadow:0 10px 24px rgba(17,24,39,.04)}
.eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.75}
.section-head h2{margin:0;font-size:clamp(2rem,3.3vw,2.85rem);font-weight:900;letter-spacing:-.045em;line-height:1.02;max-width:12ch}
.section-head.center{flex-direction:column;align-items:center;text-align:center}
.section-head.center p{max-width:700px;font-size:1.04rem;line-height:1.8}

/* Category grid */
.cat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:24px}
.cat{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;min-height:160px;background:linear-gradient(180deg,var(--fs-surface) 0%,#fff8fb 100%);border:1px solid rgba(238,230,236,.95);border-radius:22px;padding:22px 18px 18px;box-shadow:0 8px 24px rgba(17,24,39,.04);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease),background .3s var(--ease),color .3s var(--ease);position:relative;overflow:hidden;isolation:isolate}
.cat-body{display:flex;flex-direction:column;align-items:flex-start;position:relative;z-index:2}
.cat-icon{width:44px;height:44px;margin-bottom:10px;border-radius:14px;background:linear-gradient(135deg,#fff,#fdf1f6);border:1px solid #f6d9e7;display:grid;place-items:center;color:var(--fs-pink);box-shadow:0 8px 18px rgba(232,62,140,.08)}
.cat-icon .ui-icon{width:20px;height:20px}
.cat span.cat-name{display:block;font-weight:800;color:var(--fs-ink);font-size:1.04rem;letter-spacing:-.02em}
.cat-sub{display:block;margin-top:6px;color:#667487;font-size:.9rem;line-height:1.65}
.cat:hover{border-color:#f0cfe0;transform:translateY(-5px);box-shadow:0 16px 34px rgba(232,62,140,.09);background:linear-gradient(180deg,#ffffff 0%,#fff7fa 100%)}
.cat-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.02);transition:opacity .35s var(--ease),transform .6s var(--ease);z-index:0;pointer-events:none}
.cat-video-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.08) 0%,rgba(15,23,42,.36) 58%,rgba(15,23,42,.62) 100%);opacity:0;transition:opacity .35s var(--ease);z-index:1;pointer-events:none}
.cat.has-video{justify-content:flex-end;background:linear-gradient(180deg,#f7e9ef 0%,#efd6e1 52%,#e7c2d3 100%);border-color:#e7cad8;box-shadow:0 10px 26px rgba(64,32,54,.08)}
.cat.has-video .cat-icon{background:rgba(255,255,255,.82);border-color:rgba(151,94,123,.18);color:#a34d77;box-shadow:0 10px 20px rgba(64,32,54,.08)}
.cat.has-video .cat-name{color:#322434;text-shadow:none}
.cat.has-video .cat-sub{color:#6b5568;text-shadow:none}
.cat.has-video .cat-video-overlay{opacity:.28;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,rgba(127,72,102,.18) 52%,rgba(53,30,46,.28) 100%)}
.cat.has-video:hover,.cat.has-video:focus-visible,.cat.has-video.is-playing{border-color:rgba(255,255,255,.4);background:#141c2f;box-shadow:0 20px 40px rgba(15,23,42,.16),0 12px 28px rgba(232,62,140,.16)}
.cat.has-video:hover .cat-icon,.cat.has-video:focus-visible .cat-icon,.cat.has-video.is-playing .cat-icon{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.3);color:#fff;box-shadow:none;backdrop-filter:blur(6px)}
.cat.has-video:hover .cat-name,.cat.has-video:hover .cat-sub,.cat.has-video:focus-visible .cat-name,.cat.has-video:focus-visible .cat-sub,.cat.has-video.is-playing .cat-name,.cat.has-video.is-playing .cat-sub{color:#fff;text-shadow:0 2px 18px rgba(15,23,42,.28)}
.cat.has-video:hover .cat-video,.cat.has-video:focus-visible .cat-video,.cat.has-video.is-playing .cat-video{opacity:1;transform:scale(1.06)}
.cat.has-video:hover .cat-video-overlay,.cat.has-video:focus-visible .cat-video-overlay,.cat.has-video.is-playing .cat-video-overlay{opacity:1;background:linear-gradient(180deg,rgba(15,23,42,.08) 0%,rgba(15,23,42,.36) 58%,rgba(15,23,42,.62) 100%)}

/* Two-col panels */
.bandish{background:linear-gradient(180deg,rgba(255,255,255,.96) 0%,rgba(250,245,248,.94) 100%);border-top:1px solid var(--fs-line);border-bottom:1px solid var(--fs-line)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px}

/* Stats band — GlossGenius style */
.stats-band{background:linear-gradient(135deg,#11192c,#17233a 60%,#1d2d47 100%);color:#fff;padding:72px 0;overflow:hidden;position:relative}
.stats-band::before{content:'';position:absolute;left:-200px;top:-200px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(232,62,140,.12),transparent 70%);pointer-events:none}
.stats-band::after{content:'';position:absolute;right:-120px;bottom:-160px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 68%);pointer-events:none}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;text-align:center}
.stat-item{display:flex;flex-direction:column;align-items:center;gap:8px}
.stat-number{font-size:clamp(2.2rem,4vw,3.6rem);font-weight:900;letter-spacing:-.03em;background:linear-gradient(135deg,#fff,#f9a8d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-label{color:rgba(255,255,255,.74);font-size:.98rem;font-weight:500;max-width:240px;line-height:1.65}

/* Quotes / testimonials */
.quotes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;margin-top:28px}
.quote{background:linear-gradient(180deg,var(--fs-surface) 0%,#fff8fb 100%);border:1px solid rgba(238,230,236,.95);border-radius:24px;padding:28px 24px 22px;box-shadow:0 10px 28px rgba(17,24,39,.04);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease),background .3s var(--ease);position:relative}
.quote:hover{box-shadow:var(--shadow-lg);transform:translateY(-7px);border-color:#f0d6e4;background:linear-gradient(180deg,#ffffff 0%,#fff7fa 100%)}
.quote-stars{color:#fbbf24;font-size:.88rem;letter-spacing:2px;margin-bottom:14px}
.quote p{margin:0 0 16px;color:#334155;line-height:1.82;font-weight:500;font-size:1rem}
.quote-author{display:flex;align-items:center;gap:10px}
.quote-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--fs-blush),#fce4ec);display:grid;place-items:center;font-weight:800;color:var(--fs-pink);font-size:.88rem;box-shadow:0 8px 18px rgba(232,62,140,.08)}

/* FAQ */
.faq details{background:linear-gradient(180deg,var(--fs-surface) 0%,#fff9fc 100%);border:1px solid rgba(238,230,236,.95);border-radius:20px;padding:0;margin-bottom:12px;transition:all .2s var(--ease);box-shadow:0 10px 24px rgba(17,24,39,.03)}
.faq details:hover{border-color:#f0cfe0}
.faq details[open]{box-shadow:0 2px 12px rgba(17,24,39,.04)}
.faq summary{cursor:pointer;font-weight:800;color:var(--fs-ink);padding:20px 22px;list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:1.01rem;letter-spacing:-.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.4rem;font-weight:600;color:var(--fs-muted);transition:transform .2s var(--ease)}
.faq details[open] summary::after{content:'−'}
.faq p{margin:0;color:#475569;line-height:1.78;padding:0 22px 20px}

/* Final CTA */
.final-cta{margin-top:32px;background:linear-gradient(135deg,var(--fs-ink),#1e293b);border:1px solid rgba(255,255,255,.08);border-radius:28px;padding:38px 40px;display:flex;justify-content:space-between;align-items:center;gap:24px;box-shadow:var(--shadow-lg);color:#fff;position:relative;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:auto -70px -110px auto;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(232,62,140,.18),transparent 70%);pointer-events:none}
.final-cta h3{margin:0;font-size:clamp(1.5rem,2vw,1.85rem);font-weight:800;color:#fff;letter-spacing:-.03em;line-height:1.05;position:relative;z-index:1}
.final-cta p{margin:8px 0 0;color:rgba(255,255,255,.74);line-height:1.72;max-width:44ch;position:relative;z-index:1}
.final-cta .btn.primary{box-shadow:0 4px 20px rgba(232,62,140,.3)}
.final-cta-secondary,
.final-cta-secondary:visited{background:rgba(255,255,255,.08) !important;border-color:rgba(255,255,255,.24) !important;color:#fff !important;box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.final-cta-secondary:hover,
.final-cta-secondary:focus-visible{background:rgba(255,255,255,.14) !important;border-color:rgba(255,255,255,.38) !important;color:#fff !important;box-shadow:0 14px 36px rgba(15,23,42,.24),inset 0 1px 0 rgba(255,255,255,.08)}
.final-cta .btn-row{position:relative;z-index:1}
.cta-icon{width:16px;height:16px;opacity:.92}

/* Feature marquee — scrolling feature list */
.marquee-band{padding:20px 0;background:linear-gradient(180deg,rgba(255,255,255,.92) 0%,rgba(247,232,241,.34) 100%);border-bottom:1px solid var(--fs-line);overflow:hidden}
.marquee-track{display:flex;gap:32px;animation:marquee-scroll 30s linear infinite;width:max-content}
.marquee-track span{white-space:nowrap;font-weight:700;color:var(--fs-muted);font-size:.95rem;display:flex;align-items:center;gap:8px}
.marquee-track span::before{content:'';width:6px;height:6px;border-radius:2px;background:var(--fs-pink);display:inline-block;transform:rotate(45deg)}
@keyframes marquee-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Reveal system */
.reveal{opacity:0;transform:translate3d(0,28px,0) scale(.985);transition:opacity .7s var(--ease),transform .8s var(--ease)}
.reveal.is-visible{opacity:1;transform:translate3d(0,0,0) scale(1)}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  body{opacity:1;transform:none}
  .reveal{opacity:1;transform:none}
  .hero-video{display:none}
}

@media (min-width:768px){
  .brand-logo{width:34px;height:34px}
  .brand-name{font-size:1.85rem}
}

/* ===== TABLET (max 980px) — hamburger nav, single-col hero ===== */
@media (max-width:980px){
  .grid-3{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .kv{grid-template-columns:1fr}

  .nav{flex-wrap:wrap}
  .nav-toggle{display:block}
  .nav-links{display:none;width:100%;flex-direction:column;gap:4px;padding:8px 0 4px}
  .nav-links a{padding:12px 14px;border-radius:10px;min-height:44px;display:flex;align-items:center}
  .nav-links.open{display:flex}
  .nav-toggle[aria-expanded="true"] .icon-open{display:none}
  .nav-toggle[aria-expanded="true"] .icon-close{display:block}

  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -4px;padding:0 4px}
  .table{min-width:480px}

  .hero-grid{grid-template-columns:1fr;gap:24px;padding:56px 0 50px}
  .hero-backdrop-overlay{background:linear-gradient(180deg,rgba(250,248,250,.9) 0%,rgba(250,248,250,.82) 55%,rgba(250,248,250,.9) 100%)}
  .two-col{grid-template-columns:1fr}
  .final-cta{flex-direction:column;align-items:flex-start;text-align:left}
}

/* ===== iPAD PORTRAIT (768–980px) — optimized intermediate layouts ===== */
@media (min-width:561px) and (max-width:980px){
  .cat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
  .stats-grid{grid-template-columns:repeat(3,1fr);gap:24px}
  .quotes{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .search-card{max-width:520px;margin:0 auto}
  .hero-left{text-align:center}
  .btn-row.left{justify-content:center}
  .trust-row{justify-content:center}
  .hero-live-note{margin-inline:auto}
  .section{padding:60px 0}
  .section-head h2{max-width:none}
}

/* ===== MOBILE (max 560px) — phone-optimized ===== */
@media (max-width:560px){
  .container{width:min(var(--max),calc(100% - 32px))}
  .footer-grid{grid-template-columns:1fr}
  .brand-name{font-size:1.3rem}
  .section{padding:48px 0}
  .page-head{padding:24px 22px 20px}
  .page-head h1{font-size:1.7rem}
  .page-head p{font-size:.98rem}
  .panel{padding:18px 18px}
  .panel h2{font-size:1.08rem}
  .btn{padding:12px 18px;font-size:.9rem;min-height:44px}
  .chips{gap:8px}
  .chip{padding:8px 12px;font-size:.88rem;min-height:44px;display:inline-flex;align-items:center}
  .footer-bottom{flex-direction:column;text-align:center;gap:6px;font-size:.88rem;padding-bottom:calc(14px + env(safe-area-inset-bottom))}
  .footer-grid{gap:24px;padding:20px 0}

  .pill{font-size:.78rem;padding:6px 12px}
  .hero-left p{font-size:1rem}
  .hero-live-note{font-size:.84rem;padding:9px 12px}
  .search-card{padding:18px}
  .cat-grid{grid-template-columns:1fr 1fr;gap:10px}
  .cat{padding:14px 12px;min-height:140px}
  .cat-icon{width:40px;height:40px}
  .section-head h2{font-size:1.45rem}
  .stats-band{padding:48px 0}
  .stats-grid{grid-template-columns:1fr;gap:20px}
  .stat-number{font-size:2rem}
  .quotes{grid-template-columns:1fr}
  .faq summary{padding:14px 16px;font-size:.93rem;min-height:44px}
  .faq p{padding:0 16px 14px}
  .final-cta{padding:24px;text-align:center;align-items:center}
  .mini-chip{padding:10px 14px;min-height:44px;display:inline-flex;align-items:center}
  .trust-chip{padding:10px 14px;min-height:44px;display:inline-flex;align-items:center}
  .trust-row{justify-content:center}
  .hero-grid{padding:40px 0 36px}
  .hero-video{opacity:.18}
  .featured-plan::after{position:static;display:inline-flex;margin-top:14px}
}
