/* ==========================================================================
   ePoukazy.eu – Design System 2026
   Barva: rgb(16,185,129) · čistý, lékařsky laděný, prémiový
   ========================================================================== */

/* ---------- Self-hosted Inter font (volitelný – pokud soubor chybí, fallback na system stack) ---------- */
/* Pro aktivaci stáhněte Inter variable font z https://rsms.me/inter/ a nahrajte do /assets/fonts/inter/ */
@font-face {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url('/assets/fonts/inter/InterVariable.woff2') format('woff2-variations');
}
@font-face {
    font-family: 'Inter';
    font-style: italic;
    font-weight: 100 900;
    font-display: swap;
    src: url('/assets/fonts/inter/InterVariable-Italic.woff2') format('woff2-variations');
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body,h1,h2,h3,h4,h5,h6,p,ul,ol,dl,dd,blockquote,figure{margin:0}
ul,ol{padding:0;list-style:none}
a{color:inherit;text-decoration:none}
img,svg,video{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,select,textarea{font:inherit;color:inherit}
code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9em;background:var(--gray-100);padding:.1em .4em;border-radius:.3em}

/* ---------- Tokens ---------- */
:root{
    /* Barvy */
    --primary:#10b981;
    --primary-600:#059669;
    --primary-700:#047857;
    --primary-50:#ecfdf5;
    --primary-100:#d1fae5;
    --primary-200:#a7f3d0;

    --ink:#0b1220;
    --ink-700:#1f2937;
    --muted:#5b6472;
    --muted-2:#8b94a3;

    --white:#ffffff;
    --gray-50:#f8fafc;
    --gray-100:#f1f5f9;
    --gray-150:#eef2f6;
    --gray-200:#e5e7eb;
    --gray-300:#cbd5e1;

    --amber:#f59e0b;
    --blue:#3b82f6;
    --red:#ef4444;

    /* Radius / shadow */
    --r-sm:.5rem;
    --r:1rem;
    --r-lg:1.5rem;
    --r-xl:2rem;
    --r-pill:999rem;

    --shadow-xs:0 1px 2px rgb(15 23 42 / .06);
    --shadow-sm:0 2px 6px rgb(15 23 42 / .06),0 1px 2px rgb(15 23 42 / .04);
    --shadow:0 10px 30px -12px rgb(15 23 42 / .18),0 4px 10px -4px rgb(15 23 42 / .08);
    --shadow-lg:0 30px 60px -20px rgb(16 185 129 / .25),0 10px 20px -10px rgb(15 23 42 / .12);

    /* Typography – Inter (self-hosted) s fallbackem na system stack */
    --font-sans: "Inter","Inter var",-apple-system,BlinkMacSystemFont,"Segoe UI Variable","Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
    --font-display: "Inter","Inter var",-apple-system,BlinkMacSystemFont,"Segoe UI Variable","Segoe UI",Roboto,sans-serif;

    /* Fluid typography */
    --fs-1: clamp(2.25rem, 1.4rem + 3.6vw, 4.25rem);
    --fs-2: clamp(1.75rem, 1.2rem + 2.4vw, 3rem);
    --fs-3: clamp(1.25rem, 1rem + 1vw, 1.75rem);
    --fs-lead: clamp(1.05rem, .95rem + .5vw, 1.25rem);
    --fs-base: 1rem;
    --fs-small:.9rem;

    /* Layout */
    --container: 1200px;
    --container-narrow: 820px;
    --section-y: clamp(4rem, 6vw, 7rem);
}

html{font-size:16px}
body{
    font-family:var(--font-sans);
    font-size:var(--fs-base);
    line-height:1.6;
    color:var(--ink);
    background:var(--white);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
    font-feature-settings:"cv11","ss01","ss03","cv02";
    letter-spacing:-.005em;
}

::selection{background:var(--primary-100);color:var(--primary-700)}

/* ---------- Accessibility ---------- */
.skip-link{
    position:absolute;left:-9999px;top:1rem;z-index:1000;
    background:var(--ink);color:#fff;padding:.5rem 1rem;border-radius:var(--r-sm);
}
.skip-link:focus{left:1rem}
:focus-visible{outline:3px solid var(--primary);outline-offset:3px;border-radius:.4rem}

/* ---------- Typography helpers ---------- */
.h1{font-family:var(--font-display);font-size:var(--fs-1);line-height:1.05;font-weight:800;letter-spacing:-.035em;color:var(--ink);text-wrap:balance}
.h2{font-family:var(--font-display);font-size:var(--fs-2);line-height:1.12;font-weight:800;letter-spacing:-.03em;color:var(--ink);text-wrap:balance}
.h3{font-family:var(--font-display);font-size:var(--fs-3);line-height:1.2;font-weight:700;letter-spacing:-.02em;color:var(--ink);text-wrap:balance}
.lead{font-size:var(--fs-lead);line-height:1.6;color:var(--muted);max-width:62ch;text-wrap:pretty}
.lead--light{color:rgba(255,255,255,.8)}
.eyebrow{
    display:inline-flex;align-items:center;gap:.5rem;
    font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
    font-weight:700;color:var(--primary-700);
    background:var(--primary-50);
    padding:.4rem .75rem;border-radius:var(--r-pill);
}
.eyebrow--light{background:rgba(255,255,255,.08);color:var(--primary-200)}
.muted{color:var(--muted)}
.small{font-size:var(--fs-small)}
.text-center{text-align:center}
.accent{color:var(--primary-600)}
/* ---- Elegantní cenový badge v hero (nahrazuje starý .price-tag) ---- */
.price-badge{
    display:inline-flex;align-items:center;gap:.9rem;
    padding:.6rem 1rem .6rem .75rem;
    background:#fff;
    border:1px solid var(--primary-100);
    border-radius:var(--r-pill);
    box-shadow:0 8px 30px -12px rgb(16 185 129 / .35), inset 0 0 0 1px rgb(255 255 255 / .6);
    margin:1.25rem 0 1.75rem;
    position:relative;
}
.price-badge::before{
    content:"";position:absolute;inset:-2px;border-radius:inherit;padding:2px;
    background:linear-gradient(135deg, rgb(16 185 129 / .35), rgb(16 185 129 / 0));
    -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
            mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;
    pointer-events:none;
}
.price-badge__amount{
    font-family:var(--font-display);
    font-size:1.75rem;font-weight:900;
    letter-spacing:-.03em;line-height:1;
    color:var(--primary-700);
    background:linear-gradient(135deg, var(--primary), var(--primary-700));
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;
    padding:.25rem .65rem;
    background-color:var(--primary-50);
    border-radius:.7rem;
    white-space:nowrap;
}
.price-badge__unit{
    display:flex;flex-direction:column;gap:.05rem;
    font-weight:600;font-size:.92rem;color:var(--ink);
    line-height:1.25;
}
.price-badge__unit em{
    font-style:normal;font-weight:500;font-size:.78rem;color:var(--muted);
}

/* zpětná kompatibilita – kdyby price-tag někde zůstal */
.price-tag{
    white-space:nowrap;
    background:linear-gradient(135deg,var(--primary),var(--primary-600));
    color:#fff;padding:0 .5rem;border-radius:.6rem;
}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1rem,3vw,2rem)}
.container--narrow{max-width:var(--container-narrow)}
.section{padding-block:var(--section-y)}
.section--gray{background:var(--gray-50)}
.section--dark{background:linear-gradient(180deg,#0b1220,#0f1a2d);color:#fff}
.section--dark .h2,.section--dark .h3,.section--dark h4{color:#fff}
.section--cta{background:
    radial-gradient(1200px 400px at 10% 0%, rgba(16,185,129,.08), transparent 60%),
    radial-gradient(900px 400px at 100% 100%, rgba(16,185,129,.08), transparent 60%),
    var(--white)}
.section--pad{padding-block:clamp(5rem,10vw,9rem)}
.section__head{max-width:840px;margin-inline:auto;text-align:center;margin-bottom:clamp(2rem,4vw,3.5rem);display:flex;flex-direction:column;align-items:center;gap:1rem}
.section__head .lead{margin-top:.25rem}
.section__head--light .h2{color:#fff}
.two-col{display:grid;grid-template-columns:1fr;gap:clamp(2rem,4vw,4rem);align-items:start}
@media(min-width:960px){.two-col{grid-template-columns:1.05fr .95fr}}
.two-col--reverse > *:first-child{order:2}
@media(min-width:960px){.two-col--reverse > *:first-child{order:0}}

/* ---------- Buttons ---------- */
.btn{
    --bg:var(--primary);--fg:#fff;--bd:var(--primary);
    display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
    padding:.85rem 1.35rem;border-radius:var(--r-pill);
    background:var(--bg);color:var(--fg);border:1px solid var(--bd);
    font-weight:600;letter-spacing:-.01em;
    transition:transform .2s ease,box-shadow .25s ease,background .2s ease,color .2s ease,border-color .2s ease;
    white-space:nowrap;
    box-shadow:var(--shadow-xs);
    cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn--primary{box-shadow:0 12px 24px -10px rgb(16 185 129 / .5)}
.btn--primary:hover{background:var(--primary-600);border-color:var(--primary-600);box-shadow:0 18px 32px -12px rgb(16 185 129 / .55)}
.btn--ghost{--bg:transparent;--fg:var(--ink);--bd:var(--gray-200)}
.btn--ghost:hover{--bg:var(--gray-100);--bd:var(--gray-300)}
.btn--outline{--bg:transparent;--fg:var(--primary-700);--bd:var(--primary)}
.btn--outline:hover{--bg:var(--primary-50)}
.btn--lg{padding:1.05rem 1.6rem;font-size:1.05rem}
.btn--sm{padding:.55rem .95rem;font-size:.9rem}
.btn--block{width:100%}

/* ---------- Pill / badges ---------- */
.badge{
    display:inline-flex;align-items:center;gap:.55rem;
    padding:.45rem .9rem;border-radius:var(--r-pill);
    font-size:.82rem;font-weight:600;color:var(--primary-700);
    background:var(--primary-50);border:1px solid var(--primary-100);
}
.badge .dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px rgb(16 185 129 / .18);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgb(16 185 129 / .18)}50%{box-shadow:0 0 0 8px rgb(16 185 129 / 0)}}
.pill{display:inline-flex;align-items:center;padding:.18rem .55rem;border-radius:var(--r-pill);font-size:.78rem;font-weight:600}
.pill--green{background:var(--primary-50);color:var(--primary-700)}
.pill--amber{background:#fef3c7;color:#92400e}
.pill--blue{background:#dbeafe;color:#1d4ed8}
.pill--dark{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.12);padding:.35rem .7rem}
.dot{width:.55rem;height:.55rem;border-radius:50%;background:var(--muted-2);display:inline-block}
.dot--green{background:var(--primary)}
.dot--amber{background:var(--amber)}
.dot--blue{background:var(--blue)}

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header{
    position:sticky;top:0;z-index:50;
    background:rgba(255,255,255,.72);
    backdrop-filter:saturate(180%) blur(20px);
    -webkit-backdrop-filter:saturate(180%) blur(20px);
    border-bottom:1px solid transparent;
    transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;
}
.site-header.is-scrolled{
    background:rgba(255,255,255,.92);
    border-color:rgb(15 23 42 / .06);
    box-shadow:0 1px 0 rgb(15 23 42 / .04),0 8px 24px -16px rgb(15 23 42 / .08);
}
.header__inner{display:flex;align-items:center;gap:.75rem;min-height:72px}
.brand{display:flex;align-items:center;gap:.55rem;font-weight:700;letter-spacing:-.015em;flex-shrink:0}
.brand__text{font-size:1.05rem;color:var(--ink);white-space:nowrap}
.brand__text strong{font-weight:800}
.brand__tld{color:var(--primary-600)}
.brand--light .brand__text{color:#fff}
.brand--light .brand__tld{color:var(--primary-200)}

.nav{margin-left:auto;margin-right:auto}
.nav__list{display:flex;gap:.15rem;align-items:center}
.nav__list a{
    padding:.5rem .75rem;border-radius:var(--r-sm);
    font-weight:500;color:var(--ink-700);font-size:.94rem;
    white-space:nowrap;
    transition:color .2s ease,background .2s ease;
}
.nav__list a:hover{color:var(--primary-700);background:var(--primary-50)}

.header__cta{display:flex;align-items:center;gap:.6rem;margin-left:auto;flex-shrink:0}
.header__phone{display:none;align-items:center;gap:.35rem;font-weight:600;color:var(--ink-700);font-size:.9rem;white-space:nowrap}
.header__phone:hover{color:var(--primary-700)}
@media(min-width:1280px){.header__phone{display:inline-flex}}

.nav__toggle{
    display:inline-flex;flex-direction:column;gap:5px;
    width:44px;height:44px;justify-content:center;align-items:center;
    border-radius:.6rem;background:var(--gray-100);
}
.nav__toggle span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s ease,opacity .2s ease}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* burger se aktivuje pod 1100px, aby se nic nelámalo */
@media(min-width:1100px){
    .nav__toggle{display:none}
}
@media(max-width:1099px){
    .nav{
        position:fixed;inset:72px 0 0 0;background:#fff;
        padding:1.25rem clamp(1rem,3vw,2rem) 2rem;
        transform:translateY(-110%);transition:transform .3s ease;
        border-top:1px solid var(--gray-200);
        overflow-y:auto;
        margin:0;
    }
    .nav.is-open{transform:translateY(0)}
    .nav__list{flex-direction:column;gap:.25rem;align-items:stretch}
    .nav__list a{display:block;padding:.9rem 1rem;font-size:1.05rem}
}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{position:relative;overflow:hidden;padding-top:clamp(2rem,4vw,3.5rem)}
.hero__bg{
    position:absolute;inset:-10% -10% 30% -10%;z-index:-1;
    background:
        radial-gradient(600px 400px at 85% 10%, rgba(16,185,129,.18), transparent 60%),
        radial-gradient(700px 500px at 0% 30%, rgba(16,185,129,.10), transparent 60%),
        linear-gradient(180deg,#fff 0%, #f6fbf9 100%);
}
.hero__bg::after{
    content:"";position:absolute;inset:0;
    background-image:
        linear-gradient(to right, rgba(15,23,42,.04) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(15,23,42,.04) 1px, transparent 1px);
    background-size:44px 44px;
    mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
    -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
    opacity:.55;
}
.hero__inner{display:grid;grid-template-columns:1fr;gap:clamp(2.5rem,5vw,4rem);padding-block:clamp(2rem,5vw,4rem) clamp(3rem,6vw,5rem);align-items:center}
@media(min-width:1000px){.hero__inner{grid-template-columns:1.05fr 1fr}}

.hero__content .h1{margin-top:1rem}
.hero__content .lead{margin-top:1.25rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.75rem}
.hero__bullets{margin-top:1.75rem;display:flex;flex-direction:column;gap:.55rem}
.hero__bullets li{display:flex;align-items:center;gap:.55rem;color:var(--ink-700);font-weight:500}
.hero__bullets svg{color:var(--primary)}

/* Hero visual – app mock */
.hero__visual{position:relative;min-height:380px}
.mock{
    position:relative;border-radius:var(--r-lg);overflow:hidden;
    background:#fff;border:1px solid var(--gray-200);
    box-shadow:var(--shadow-lg);
    transform:perspective(1400px) rotateY(-4deg) rotateX(2deg);
    transition:transform .6s ease;
}
.mock:hover{transform:perspective(1400px) rotateY(-2deg) rotateX(0deg)}
.mock__bar{display:flex;align-items:center;gap:.4rem;padding:.75rem 1rem;background:#f6f8fb;border-bottom:1px solid var(--gray-200)}
.mock__bar > span{width:10px;height:10px;border-radius:50%;background:#e2e8f0}
.mock__bar > span:nth-child(1){background:#fca5a5}
.mock__bar > span:nth-child(2){background:#fcd34d}
.mock__bar > span:nth-child(3){background:#86efac}
.mock__url{margin-left:1rem;padding:.3rem .7rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-pill);font-size:.75rem;color:var(--muted);font-family:ui-monospace,Menlo,monospace}
.mock__body{display:grid;grid-template-columns:180px 1fr;min-height:340px}
@media(max-width:520px){.mock__body{grid-template-columns:1fr}.mock__sidebar{display:none}}
.mock__sidebar{padding:1rem .75rem;background:#fbfcfe;border-right:1px solid var(--gray-200);display:flex;flex-direction:column;gap:.25rem}
.mock__logo{display:flex;align-items:center;gap:.5rem;padding:.5rem;margin-bottom:.5rem;font-size:.95rem}
.mock__item{padding:.55rem .7rem;border-radius:.55rem;font-size:.85rem;color:var(--muted)}
.mock__item--active{background:var(--primary-50);color:var(--primary-700);font-weight:600}
.mock__content{padding:1rem}
.mock__kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-bottom:1rem}
.kpi{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;padding:.75rem}
.kpi span{display:block;font-size:.72rem;color:var(--muted);margin-bottom:.25rem}
.kpi strong{font-size:1.2rem;font-weight:800;letter-spacing:-.01em;color:var(--ink)}
.kpi em{display:block;margin-top:.25rem;font-style:normal;font-size:.75rem;color:var(--primary-700);font-weight:700}
.mock__chart{background:#fff;border:1px solid var(--gray-200);border-radius:.75rem;padding:.75rem;margin-bottom:1rem}
.mock__rows{display:flex;flex-direction:column;gap:.45rem}
.mock__rows .row{
    display:grid;grid-template-columns:auto 1fr auto auto;gap:.6rem;align-items:center;
    padding:.55rem .7rem;background:#fff;border:1px solid var(--gray-200);border-radius:.7rem;font-size:.85rem;
    white-space:nowrap;
}
.mock__rows b{font-weight:700;letter-spacing:.02em;font-family:ui-monospace,Menlo,monospace;font-size:.82rem;white-space:nowrap}
.mock__rows em{font-style:normal;font-size:.74rem;color:var(--muted);white-space:nowrap}
.mock__rows .pill{white-space:nowrap;font-size:.7rem}

.floaty{
    position:absolute;display:inline-flex;align-items:center;gap:.5rem;
    padding:.55rem .85rem;background:#fff;border:1px solid var(--gray-200);
    border-radius:var(--r-pill);font-weight:600;font-size:.88rem;color:var(--ink-700);
    box-shadow:var(--shadow);
    animation:floaty 6s ease-in-out infinite;
}
.floaty svg{color:var(--primary)}
.floaty--1{top:-12px;left:-20px}
.floaty--2{bottom:22px;right:-10px;animation-delay:-3s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Trustbar */
.trustbar{border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);background:#fff;margin-top:clamp(2rem,4vw,3rem)}
.trustbar__inner{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding-block:1.25rem}
@media(min-width:800px){.trustbar__inner{grid-template-columns:repeat(4,1fr)}}
.trust{display:flex;flex-direction:column;gap:.15rem;padding-inline:.5rem}
.trust strong{font-size:clamp(1.5rem,1.2rem+1vw,2rem);font-weight:800;letter-spacing:-.02em;color:var(--primary-700);line-height:1}
.trust span{font-size:.88rem;color:var(--muted)}

/* ==========================================================================
   STEPS
   ========================================================================== */
.steps{display:grid;grid-template-columns:1fr;gap:1rem;counter-reset:step}
@media(min-width:640px){.steps{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{
    position:relative;padding:1.5rem;border:1px solid var(--gray-200);border-radius:var(--r);
    background:#fff;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--primary-200)}
.step__num{
    display:inline-flex;align-items:center;justify-content:center;
    width:40px;height:40px;border-radius:12px;
    background:var(--primary-50);color:var(--primary-700);
    font-weight:800;font-size:1.1rem;margin-bottom:.75rem;
    border:1px solid var(--primary-100);
}
.step h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:.35rem}
.step p{color:var(--muted)}

/* ==========================================================================
   JOURNEY – Jak začít spolupráci (5 kroků)
   ========================================================================== */
.journey{
    list-style:none;margin:0 0 2.5rem;padding:0;
    display:grid;grid-template-columns:1fr;gap:1rem;
    counter-reset:jrn;position:relative;
}
@media(min-width:640px){.journey{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.journey{grid-template-columns:repeat(5,1fr);gap:.75rem}}

.journey__step{
    position:relative;
    background:#fff;border:1px solid var(--gray-200);
    border-radius:var(--r-lg);padding:1.5rem 1.25rem;
    display:flex;flex-direction:column;gap:.65rem;
    transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.journey__step:hover{
    transform:translateY(-4px);
    border-color:var(--primary-200);
    box-shadow:var(--shadow);
}

/* spojovací čára mezi kroky (desktop) */
@media(min-width:980px){
    .journey__step:not(:last-child)::after{
        content:"";position:absolute;top:2.6rem;right:-.55rem;
        width:1.1rem;height:2px;
        background:linear-gradient(90deg, var(--primary-200), transparent);
        z-index:1;
    }
}

.journey__num{
    font-family:var(--font-display);
    font-size:2.2rem;font-weight:900;
    letter-spacing:-.04em;line-height:1;
    background:linear-gradient(135deg, var(--primary), var(--primary-600));
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    margin-bottom:.25rem;
}
.journey__icon{
    width:44px;height:44px;border-radius:12px;
    display:inline-flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg, var(--primary-50), #fff);
    color:var(--primary-700);
    border:1px solid var(--primary-100);
    margin-bottom:.25rem;
}
.journey__icon svg{width:22px;height:22px}

.journey__step h3{
    font-family:var(--font-display);
    font-size:1.05rem;font-weight:700;
    letter-spacing:-.015em;
    color:var(--ink);margin:0;
    line-height:1.3;
}
.journey__step p{
    margin:0;color:var(--muted);font-size:.92rem;line-height:1.55;
}
.journey__step a{
    color:var(--primary-700);font-weight:600;
    text-decoration:none;
    border-bottom:1px dashed currentColor;
}
.journey__step a:hover{color:var(--primary-600)}

.journey__cta{
    display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;
    padding-top:.5rem;
}

/* ==========================================================================
   FEATURES
   ========================================================================== */
.features{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:700px){.features{grid-template-columns:1fr 1fr}}
@media(min-width:1040px){.features{grid-template-columns:repeat(3,1fr)}}
.feature{
    background:#fff;border:1px solid var(--gray-200);border-radius:var(--r);
    padding:1.5rem;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--primary-200)}
.feature__icon{
    width:48px;height:48px;border-radius:14px;
    display:inline-flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--primary-50),#fff);
    color:var(--primary-700);border:1px solid var(--primary-100);
    margin-bottom:1rem;
}
.feature h3{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--ink);margin-bottom:.4rem}
.feature p{color:var(--muted)}

/* ==========================================================================
   SEGMENTS
   ========================================================================== */
.segments{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:760px){.segments{grid-template-columns:1fr 1fr}}
.segment{
    background:#fff;border:1px solid var(--gray-200);border-radius:var(--r);
    padding:1.75rem;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
    position:relative;overflow:hidden;
}
.segment::before{
    content:"";position:absolute;top:0;left:0;right:0;height:4px;
    background:linear-gradient(90deg,var(--primary),var(--primary-600));
    transform:scaleX(0);transform-origin:left;transition:transform .35s ease;
}
.segment:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--primary-200)}
.segment:hover::before{transform:scaleX(1)}
.segment__head{display:flex;align-items:center;gap:.9rem;margin-bottom:1rem}
.segment__head h3{font-family:var(--font-display);font-size:1.3rem;font-weight:700}
.segment__icon{
    width:52px;height:52px;border-radius:14px;
    display:inline-flex;align-items:center;justify-content:center;
    background:var(--primary-50);color:var(--primary-700);
    border:1px solid var(--primary-100);
}
.segment__list{display:flex;flex-direction:column;gap:.55rem;color:var(--ink-700)}
.segment__list li{position:relative;padding-left:1.5rem;line-height:1.55}
.segment__list li::before{
    content:"";position:absolute;left:0;top:.55rem;width:.6rem;height:.6rem;
    background:var(--primary);border-radius:50%;box-shadow:0 0 0 4px rgb(16 185 129 / .12)
}

/* ==========================================================================
   ETAPY
   ========================================================================== */
.etapy{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:900px){.etapy{grid-template-columns:repeat(3,1fr)}}
.etapa{
    position:relative;padding:1.75rem;
    background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
    border:1px solid rgba(255,255,255,.10);border-radius:var(--r);
    backdrop-filter:blur(4px);
}
.etapa__badge{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .7rem;border-radius:var(--r-pill);font-size:.78rem;font-weight:700;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);margin-bottom:.9rem}
.etapa h3{font-size:1.35rem;margin-bottom:.25rem}
.etapa__when{font-size:.88rem;color:rgba(255,255,255,.6);margin-bottom:1rem}
.etapa ul{display:flex;flex-direction:column;gap:.5rem;color:rgba(255,255,255,.82);font-size:.95rem}
.etapa li{position:relative;padding-left:1.4rem;line-height:1.5}
.etapa li::before{
    content:"";position:absolute;left:0;top:.55rem;width:.5rem;height:.5rem;border-radius:50%;
    background:var(--primary);box-shadow:0 0 0 4px rgb(16 185 129 / .18)
}
.etapa--live{border-color:rgb(16 185 129 / .45);background:linear-gradient(180deg, rgb(16 185 129 / .09), rgb(16 185 129 / .02))}
.etapa--live .etapa__badge{color:var(--primary);background:rgb(16 185 129 / .12);border-color:rgb(16 185 129 / .3)}

/* ==========================================================================
   CATEGORIES
   ========================================================================== */

/* ---- Featured grid s top kategoriemi ---- */
.cats{
    display:grid;gap:1rem;
    grid-template-columns:1fr;
    margin-bottom:1.5rem;
}
@media(min-width:640px){.cats{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.cats{grid-template-columns:repeat(4,1fr)}}

.cat-card{
    position:relative;background:#fff;border:1px solid var(--gray-200);
    border-radius:var(--r-lg);padding:1.5rem 1.25rem;
    display:flex;flex-direction:column;gap:.85rem;
    transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.cat-card:hover{transform:translateY(-3px);border-color:var(--primary-200);box-shadow:var(--shadow)}

.cat-card__icon{
    width:46px;height:46px;border-radius:12px;
    display:inline-flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--primary-50),#fff);
    color:var(--primary-700);border:1px solid var(--primary-100);
}
.cat-card__icon svg{width:24px;height:24px}

.cat-card__head{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.cat-card__code{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:36px;height:26px;padding:0 .5rem;
    background:var(--gray-100);color:var(--ink-700);
    font-weight:800;font-family:ui-monospace,Menlo,monospace;
    font-size:.78rem;border-radius:.5rem;letter-spacing:.02em;
}
.cat-card__name{
    font-family:var(--font-display);
    font-size:1.05rem;font-weight:700;color:var(--ink);
    letter-spacing:-.015em;margin:0;line-height:1.25;
}
.cat-card__note{margin:0;color:var(--muted);font-size:.88rem;line-height:1.5}
.cat-card__link{
    margin-top:auto;color:var(--primary-700);font-weight:600;font-size:.9rem;
    text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;
}
.cat-card__link:hover{color:var(--primary-600)}

/* zvýrazněná INKO karta */
.cat-card--hot{
    border:1.5px solid var(--primary);
    background:
        radial-gradient(400px 200px at 100% 0%, rgb(16 185 129 / .12), transparent 70%),
        #fff;
}
.cat-card--hot .cat-card__icon{
    background:linear-gradient(135deg,var(--primary),var(--primary-600));
    color:#fff;border-color:transparent;
}
.cat-card--hot .cat-card__code{background:var(--primary);color:#fff}
.cat-card__ribbon{
    position:absolute;top:-11px;right:1rem;
    background:linear-gradient(135deg,var(--primary),var(--primary-600));color:#fff;
    padding:.3rem .7rem;border-radius:var(--r-pill);
    font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
    box-shadow:0 10px 20px -8px rgb(16 185 129 / .55);
    white-space:nowrap;
}

/* CTA karta – přes celou šířku posledního řádku */
.cat-card--cta{
    background:linear-gradient(180deg,#fff,var(--primary-50));
    border-style:dashed;border-color:var(--primary-200);
    flex-direction:row;align-items:center;gap:1.25rem;
    flex-wrap:wrap;
}
@media(min-width:980px){
    .cat-card--cta{grid-column:1 / -1}
}
.cat-card--cta .cat-card__icon{background:#fff;color:var(--primary-700);flex-shrink:0}
.cat-card--cta .cat-card__head{flex:1 1 auto;min-width:180px}
.cat-card--cta .cat-card__note{flex:2 1 300px;margin:0}
.cat-card--cta .cat-card__link{margin:0 0 0 auto;flex-shrink:0}

/* ---- Expandable: všech 46 ---- */
.cat-all{
    background:#fff;border:1px solid var(--gray-200);
    border-radius:var(--r);overflow:hidden;
    transition:border-color .2s ease,box-shadow .2s ease;
}
.cat-all[open]{border-color:var(--primary-200);box-shadow:var(--shadow-sm)}
.cat-all summary{
    display:flex;align-items:center;justify-content:space-between;gap:1rem;
    padding:1.1rem 1.25rem;cursor:pointer;
    font-weight:600;color:var(--ink);list-style:none;
    user-select:none;
}
.cat-all summary::-webkit-details-marker{display:none}
.cat-all summary:hover{background:var(--gray-50)}
.cat-all__label{font-size:.98rem}
.cat-all__chev{color:var(--primary-700);transition:transform .25s ease;flex-shrink:0}
.cat-all[open] .cat-all__chev{transform:rotate(180deg)}
.cat-all__body{padding:1rem 1.25rem 1.5rem;border-top:1px solid var(--gray-100)}

/* Varianta: CTA karta jako přepínač */
.cat-all--cta{background:transparent;border:0;border-radius:0;overflow:visible;margin-top:.75rem}
.cat-all--cta[open]{border:0;box-shadow:none}
.cat-all--cta > summary{display:flex;padding:0;background:transparent}
.cat-all--cta > summary:hover{background:transparent}
.cat-all--cta > summary:hover .cat-card__link{color:var(--primary-600)}
.cat-all--cta[open] > summary .cat-all__chev{transform:rotate(180deg)}
.cat-all--cta .cat-all__body{margin-top:1rem;border-top:0;padding:1.25rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--r)}

.cat-grid{
    display:grid;gap:.5rem;
    grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
    margin-bottom:1rem;
}
.cat{
    display:flex;align-items:center;gap:.75rem;
    padding:.65rem .85rem;background:var(--gray-50);border:1px solid var(--gray-200);
    border-radius:.65rem;font-size:.88rem;color:var(--ink-700);
    transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.cat:hover{transform:translateY(-2px);border-color:var(--primary-200);box-shadow:var(--shadow-sm);background:#fff}
.cat__code{
    display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:24px;padding:0 .45rem;
    background:#fff;color:var(--ink-700);font-weight:700;font-family:ui-monospace,Menlo,monospace;
    border-radius:.4rem;font-size:.75rem;border:1px solid var(--gray-200);
}
.cat--hot{border-color:var(--primary);background:var(--primary-50)}
.cat--hot .cat__code{background:var(--primary);color:#fff;border-color:transparent}
.cat--hot .cat__name{font-weight:600;color:var(--primary-700)}

/* ==========================================================================
   PRICING
   ========================================================================== */
.pricing{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media(min-width:700px){.pricing{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.pricing{grid-template-columns:repeat(4,1fr)}}

.plan{
    position:relative;padding:1.75rem 1.5rem;background:#fff;border:1px solid var(--gray-200);
    border-radius:var(--r-lg);
    display:grid;
    grid-template-rows:auto auto auto 1fr auto;
    gap:1.1rem;
    transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.plan:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--primary-200)}

.plan__head h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;letter-spacing:-.015em;line-height:1.25;margin:0}
.plan__tagline{margin:.35rem 0 0;color:var(--muted);font-size:.82rem;font-weight:500;letter-spacing:.01em}

.plan__price{
    display:flex;flex-direction:column;gap:.25rem;
    padding:.25rem 0;
    min-height:96px;
    justify-content:center;
}
.plan__amount{
    font-family:var(--font-display);
    font-size:clamp(2.25rem,1.8rem+1.2vw,2.75rem);
    font-weight:900;
    letter-spacing:-.035em;
    color:var(--ink);
    line-height:1;
    white-space:nowrap;
    font-variant-numeric:tabular-nums;
}
.plan__period{
    color:var(--muted);font-weight:600;font-size:.9rem;line-height:1.3;
    letter-spacing:.005em;
}

.plan__desc{margin:0;color:var(--muted);font-size:.92rem;line-height:1.55;min-height:3.3em}

.plan__list{display:flex;flex-direction:column;gap:.45rem;color:var(--ink-700);font-size:.92rem;margin:0;padding:0;list-style:none}
.plan__list li{position:relative;padding-left:1.4rem;line-height:1.45}
.plan__list li::before{
    content:"";position:absolute;left:.1rem;top:.55rem;width:.45rem;height:.45rem;
    background:var(--primary);border-radius:50%;
    box-shadow:0 0 0 3px rgb(16 185 129 / .14);
}

.plan--featured{
    border:1.5px solid var(--primary);
    box-shadow:0 30px 60px -30px rgb(16 185 129 / .45);
    background:
        radial-gradient(400px 200px at 100% 0%, rgb(16 185 129 / .10), transparent 70%),
        #fff;
}
.plan--featured .plan__amount{color:var(--primary-700)}

.plan__ribbon{
    position:absolute;top:-13px;left:50%;transform:translateX(-50%);
    background:linear-gradient(135deg,var(--primary),var(--primary-600));color:#fff;
    padding:.35rem .9rem;border-radius:var(--r-pill);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
    box-shadow:0 10px 20px -8px rgb(16 185 129 / .55);
    white-space:nowrap;
}

.pricing__extras{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:2rem;margin-bottom:1rem}
@media(min-width:760px){.pricing__extras{grid-template-columns:repeat(3,1fr)}}
.extra{padding:1.25rem;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--r)}
.extra h4{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:.35rem;color:var(--primary-700)}
.extra p{color:var(--ink-700);font-size:.92rem}

/* ==========================================================================
   CHECKLIST / SHIELD
   ========================================================================== */
.checklist{display:grid;grid-template-columns:1fr;gap:.6rem;margin-top:1.5rem}
@media(min-width:640px){.checklist{grid-template-columns:1fr 1fr}}
.checklist li{position:relative;padding-left:2rem;color:var(--ink-700);line-height:1.55}
.checklist li::before{
    content:"";position:absolute;left:0;top:.3rem;width:1.25rem;height:1.25rem;
    background:var(--primary);border-radius:50%;
    mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.17 5.53 12.7l-1.41 1.41L9 19l12-12-1.41-1.41z'/></svg>") center/68% no-repeat;
    -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.17 5.53 12.7l-1.41 1.41L9 19l12-12-1.41-1.41z'/></svg>") center/68% no-repeat;
}

.shield-card{
    background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-lg);
    padding:1.75rem;box-shadow:var(--shadow-sm);
}
.shield-card__head{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;color:var(--primary-700)}
.shield-card__head h3{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--ink)}
.shield-card dl{display:flex;flex-direction:column;gap:.75rem}
.shield-card dl div{display:grid;grid-template-columns:130px 1fr;gap:.75rem;align-items:start;padding-bottom:.75rem;border-bottom:1px dashed var(--gray-200)}
.shield-card dl div:last-child{border:0;padding-bottom:0}
.shield-card dt{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.shield-card dd{color:var(--ink);font-weight:500}

/* ==========================================================================
   ABOUT
   ========================================================================== */
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.5rem 0}
@media(max-width:560px){.about-stats{grid-template-columns:1fr}}
.about-stat{padding:1rem;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--r)}
.about-stat strong{display:block;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:900;color:var(--primary-700);line-height:1;letter-spacing:-.02em}
.about-stat span{display:block;color:var(--ink-700);font-size:.88rem;margin-top:.35rem}

.card-quote{
    position:relative;padding:2rem;background:linear-gradient(135deg,var(--ink) 0%, #132035 100%);
    color:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow);
    overflow:hidden;
}
.card-quote::after{content:"";position:absolute;inset:auto -40px -40px auto;width:200px;height:200px;background:radial-gradient(circle,rgb(16 185 129 / .3),transparent 70%);}
.card-quote svg{color:var(--primary);margin-bottom:1rem;opacity:.9}
.card-quote blockquote p{font-size:1.15rem;line-height:1.55;font-weight:500}
.card-quote footer{margin-top:1rem;display:flex;flex-direction:column}
.card-quote footer span{color:rgba(255,255,255,.6);font-size:.88rem}

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq{display:flex;flex-direction:column;gap:.55rem}
.faq__item{
    background:#fff;border:1px solid var(--gray-200);border-radius:var(--r);
    overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease;
}
.faq__item:hover{border-color:var(--primary-200)}
.faq__item[open]{box-shadow:var(--shadow-sm);border-color:var(--primary-200)}
.faq__item summary{
    display:flex;align-items:center;justify-content:space-between;gap:1rem;
    padding:1.15rem 1.25rem;cursor:pointer;
    font-weight:600;color:var(--ink);list-style:none;
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__chev{transition:transform .25s ease;color:var(--primary-700);flex-shrink:0}
.faq__item[open] .faq__chev{transform:rotate(180deg)}
.faq__body{padding:0 1.25rem 1.25rem;color:var(--muted);line-height:1.65}
.faq__body p strong{color:var(--ink-700)}

/* ==========================================================================
   CONTACT FORM
   ========================================================================== */
.contact-list{display:flex;flex-direction:column;gap:.85rem;margin-top:1.25rem;margin-bottom:1rem}
.contact-list li{display:flex;align-items:center;gap:.75rem;color:var(--ink-700)}
.contact-list li svg{color:var(--primary-700);flex-shrink:0}
.contact-list address.inline{font-style:normal}

.form{background:#fff;border:1px solid var(--gray-200);border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2rem);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}
.form__row{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:640px){.form__row{grid-template-columns:1fr 1fr}}
.form__field{display:flex;flex-direction:column;gap:.35rem}
.form__field > span{font-size:.88rem;font-weight:600;color:var(--ink-700)}
.form__field input,
.form__field select,
.form__field textarea{
    width:100%;padding:.85rem 1rem;border:1px solid var(--gray-200);
    border-radius:.7rem;background:#fff;color:var(--ink);
    transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;
}
.form__field input:focus,
.form__field select:focus,
.form__field textarea:focus{
    outline:0;border-color:var(--primary);
    box-shadow:0 0 0 4px rgb(16 185 129 / .15);
}
.form__field textarea{resize:vertical;min-height:120px}
.form__check{display:flex;align-items:flex-start;gap:.65rem;font-size:.9rem;color:var(--muted)}
.form__check input{margin-top:.25rem;accent-color:var(--primary)}
.form__check a{color:var(--primary-700);text-decoration:underline}
.form__status{min-height:1.4em;font-size:.9rem;margin:0;color:var(--primary-700);font-weight:600}
.form__status.is-error{color:var(--red)}
.hp{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:#0b1220;color:rgba(255,255,255,.78);padding-top:clamp(3rem,5vw,5rem)}
.footer__grid{display:grid;grid-template-columns:1fr;gap:2rem;padding-bottom:2.5rem}
@media(min-width:720px){.footer__grid{grid-template-columns:1.3fr 1fr 1fr 1.4fr}}
.footer__col h4{font-family:var(--font-display);font-size:1rem;font-weight:700;color:#fff;margin-bottom:.85rem}
.footer__col ul{display:flex;flex-direction:column;gap:.5rem}
.footer__col ul a{color:rgba(255,255,255,.7);transition:color .2s}
.footer__col ul a:hover{color:var(--primary-200)}
.footer__brand p{color:rgba(255,255,255,.65)}
.footer__compliance{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.75rem}
.footer__col address{font-style:normal;color:rgba(255,255,255,.7);line-height:1.7;margin-bottom:.75rem}
.footer__col address .muted{color:rgba(255,255,255,.5)}
.footer__contact a{color:#fff}
.footer__contact a:hover{color:var(--primary-200)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding-block:1.25rem}
.footer__bottom-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;color:rgba(255,255,255,.55)}

/* ==========================================================================
   COOKIE CONSENT
   ========================================================================== */
.cookie{
    position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:80;
    background:#fff;border:1px solid var(--gray-200);border-radius:var(--r);
    box-shadow:var(--shadow);
    animation:cookie-in .35s ease both;
}
@keyframes cookie-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.cookie__inner{display:grid;grid-template-columns:1fr;gap:1rem;padding:1rem 1.25rem}
@media(min-width:820px){.cookie__inner{grid-template-columns:1fr auto;align-items:center}.cookie{max-width:920px;left:auto;right:1rem;bottom:1rem}}
.cookie__text strong{color:var(--ink);font-weight:700}
.cookie__text p{color:var(--muted);font-size:.92rem;margin-top:.2rem}
.cookie__text a{color:var(--primary-700);text-decoration:underline}
.cookie__actions{display:flex;flex-wrap:wrap;gap:.5rem}
.cookie__panel{border-top:1px solid var(--gray-200)}
.cookie__panel-inner{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.65rem}
.cookie__row{display:flex;align-items:center;gap:.6rem;font-size:.92rem;color:var(--ink-700)}
.cookie__row input{accent-color:var(--primary)}
.cookie__panel-actions{display:flex;justify-content:flex-end}

/* ==========================================================================
   STICKY CTA (mobile)
   ========================================================================== */
.sticky-cta{
    position:fixed;z-index:60;left:0;right:0;bottom:0;
    padding:.75rem 1rem calc(.75rem + env(safe-area-inset-bottom));
    background:linear-gradient(180deg,rgba(255,255,255,.0),rgba(255,255,255,.92));
    display:none;pointer-events:none;
}
.sticky-cta__btn{
    pointer-events:auto;display:flex;align-items:center;justify-content:center;gap:.5rem;
    background:linear-gradient(135deg,var(--primary),var(--primary-600));color:#fff;
    font-weight:700;padding:.95rem 1.25rem;border-radius:var(--r-pill);
    box-shadow:0 20px 40px -20px rgb(16 185 129 / .6);
}
@media(max-width:760px){
    .sticky-cta{display:block}
    body{padding-bottom:5rem}
}

/* ==========================================================================
   PROSE (GDPR/Terms)
   ========================================================================== */
.prose h1{margin-bottom:.75rem}
.prose h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin:2rem 0 .65rem;color:var(--ink)}
.prose p{color:var(--ink-700);margin-bottom:1rem;line-height:1.75}
.prose ul{list-style:disc;padding-left:1.25rem;color:var(--ink-700);margin-bottom:1rem;display:block}
.prose ul li{margin-bottom:.35rem}
.prose a{color:var(--primary-700);text-decoration:underline}

/* ==========================================================================
   Reveal-on-scroll
   ========================================================================== */
[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
[data-reveal].is-visible{opacity:1;transform:none}

@media (prefers-reduced-motion: reduce){
    *,*::before,*::after{animation:none !important;transition:none !important}
    [data-reveal]{opacity:1;transform:none}
    html{scroll-behavior:auto}
}
