/* ==========================================================================
   Kotisivutheti.fi — Modern theme · Light bg · Emerald + Charcoal
   ========================================================================== */

:root{
    --bg: #ffffff;
    --bg-soft: #f0fbff;
    --bg-alt: #ffffff;
    --surface: #ffffff;
    --ink: #0a1929;
    --ink-soft: #2a3f5c;
    --ink-mute: #5a7290;
    --line: #cffafe;
    --line-soft: #ecfeff;

    --blue-50:  #ecfeff;
    --blue-100: #cffafe;
    --blue-200: #a5f3fc;
    --blue-300: #67e8f9;
    --blue-400: #22d3ee;
    --blue-500: #06b6d4;   /* cyan */
    --blue-600: #0891b2;
    --blue-700: #0e7490;
    --cyan-400: #4BFFFF;
    --cyan-500: #22d3ee;

    --grad: linear-gradient(135deg, #4BFFFF 0%, #22d3ee 50%, #06b6d4 100%);
    --grad-soft: linear-gradient(135deg, #ecfeff 0%, #fce7f3 100%);

    --radius-sm: 10px;
    --radius:    16px;
    --radius-lg: 22px;
    --radius-xl: 28px;

    --shadow-sm: 0 2px 8px rgba(10,25,41,.05);
    --shadow:    0 12px 40px rgba(6,182,212,.15), 0 2px 8px rgba(99,102,241,.06);
    --shadow-lg: 0 30px 80px rgba(6,182,212,.28), 0 14px 30px -8px rgba(236,72,153,.18);
    --glow:      0 0 40px rgba(75,255,255,.45);

    --t: 320ms cubic-bezier(.2,.7,.2,1);
}

/* ---------- base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
    margin:0;
    font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
    color:var(--ink);
    background:var(--bg);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    /* overflow-x:clip — EI hidden — jotta position:sticky toimii lapsielementeissä */
    overflow-x:clip;
}
html{ overflow-x:clip; }
img{ max-width:100%; display:block; }
a{ color:var(--blue-600); text-decoration:none; transition:color var(--t); }
a:hover{ color:var(--blue-500); }
h1,h2,h3,h4{
    font-family:'Space Grotesk','Inter',sans-serif;
    color:var(--ink);
    line-height:1.15;
    letter-spacing:-.02em;
    margin:0 0 .5em;
    font-weight:700;
}
h1{ font-size:clamp(2.2rem,5vw,3.8rem); font-weight:800; }
h2{ font-size:clamp(1.8rem,3.5vw,2.6rem); }
h3{ font-size:1.3rem; }
p{ margin:0 0 1em; color:var(--ink-soft); }

.container{ width:min(1180px,92%); margin:0 auto; }

/* ---------- background orbs ---------- */
.bg-orbs{
    position:fixed; inset:0; z-index:-1; pointer-events:none; overflow:hidden;
}
.orb{
    position:absolute; border-radius:50%; filter:blur(80px); opacity:.55;
    animation:float 20s ease-in-out infinite;
}
.orb-1{ width:520px;height:520px; background:radial-gradient(circle,#4BFFFF,transparent 70%); top:-160px; left:-120px; }
.orb-2{ width:600px;height:600px; background:radial-gradient(circle,#22d3ee,transparent 70%); top:30%; right:-200px; animation-delay:-7s; }
.orb-3{ width:480px;height:480px; background:radial-gradient(circle,#06b6d4,transparent 70%); bottom:-160px; left:30%; animation-delay:-14s; }
@keyframes float{
    0%,100%{ transform:translate(0,0) scale(1); }
    50%{ transform:translate(40px,-30px) scale(1.08); }
}
.grid-overlay{
    position:absolute; inset:0;
    background-image:
        linear-gradient(to right, rgba(75,255,255,.05) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(75,255,255,.05) 1px, transparent 1px);
    background-size:48px 48px;
    mask-image:radial-gradient(ellipse at center, black 30%, transparent 75%);
    -webkit-mask-image:radial-gradient(ellipse at center, black 30%, transparent 75%);
}

/* ---------- buttons ---------- */
.btn{
    display:inline-flex; align-items:center; gap:.55em;
    padding:.85em 1.5em;
    border-radius:999px;
    font-weight:600; font-size:.98rem;
    border:1.5px solid transparent;
    cursor:pointer; text-decoration:none;
    transition:transform var(--t), box-shadow var(--t), background var(--t), color var(--t), border-color var(--t);
    white-space:nowrap;
}
.btn-sm{ padding:.6em 1.1em; font-size:.9rem; }
.btn-lg{ padding:1em 1.7em; font-size:1.05rem; }
.btn-block{ display:flex; justify-content:center; width:100%; }
.btn-primary{
    background:var(--grad); color:#fff;
    box-shadow:0 10px 24px rgba(75,255,255,.35), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 36px rgba(75,255,255,.45), inset 0 1px 0 rgba(255,255,255,.25); color:#fff; }
.btn-outline{
    background:transparent; color:var(--blue-600); border-color:var(--blue-500);
}
.btn-outline:hover{ background:var(--blue-500); color:#fff; transform:translateY(-2px); }
.btn-ghost{
    background:rgba(255,255,255,.65); color:var(--ink); border-color:var(--line);
    backdrop-filter:blur(8px);
}
.btn-ghost:hover{ background:#fff; border-color:var(--blue-300); color:var(--blue-600); transform:translateY(-2px); }

/* Kysely-CTA — sekundäärinen "Tee kysely" -nappi headerissa */
.btn-kysely{
    background:#fff; color:var(--blue-700, #0e7490);
    border:1.5px solid var(--blue-300, #67e8f9);
    box-shadow:0 2px 8px rgba(75,255,255,.12), inset 0 1px 0 rgba(255,255,255,.6);
    position:relative;
}
.btn-kysely::before{
    content:''; position:absolute; inset:-2px; border-radius:inherit;
    background:linear-gradient(135deg, rgba(75,255,255,.4), rgba(6,182,212,.25));
    opacity:0; transition:opacity var(--t); z-index:-1;
    filter:blur(8px);
}
.btn-kysely:hover{
    color:var(--blue-700, #0e7490);
    border-color:var(--blue-500, #06b6d4);
    background:linear-gradient(180deg, #fff 0%, #ecfeff 100%);
    transform:translateY(-2px);
    box-shadow:0 8px 20px rgba(6,182,212,.18), inset 0 1px 0 rgba(255,255,255,.7);
}
.btn-kysely:hover::before{ opacity:1; }
.btn-kysely:active{ transform:translateY(0); }
.btn-kysely:focus-visible{
    outline:2px solid var(--blue-500, #06b6d4); outline-offset:2px;
}
.btn-kysely-icon{ font-size:1.05em; line-height:1; }
.btn-kysely-label{ font-weight:600; }

/* Header-CTAt ryhmitettynä */
.header-ctas{
    display:inline-flex; align-items:center; gap:.6rem;
}

/* ---------- glass ---------- */
.glass{
    background:rgba(255,255,255,.7);
    backdrop-filter:blur(18px) saturate(140%);
    -webkit-backdrop-filter:blur(18px) saturate(140%);
    border:1px solid rgba(255,255,255,.7);
    box-shadow:var(--shadow);
}

/* ---------- header ---------- */
.site-header{
    position:sticky; top:0; z-index:50;
    background:rgba(255,255,255,.78);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid transparent;
    transition:border-color var(--t), background var(--t), box-shadow var(--t);
}
.site-header.scrolled{
    border-color:var(--line);
    background:rgba(255,255,255,.92);
    box-shadow:0 4px 20px rgba(10,25,41,.04);
}
.header-inner{
    display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
    padding:.9rem 0;
}
.brand{
    display:inline-flex; align-items:center; gap:.65rem;
    color:var(--ink); font-weight:700;
}
.brand-mark{ width:38px; height:38px; display:inline-block; }
.brand-mark svg{ width:100%; height:100%; }
.brand-text{ font-family:'Space Grotesk',sans-serif; font-size:1.15rem; line-height:1; }
.brand-text strong{ font-weight:700; }
.brand-text span{ color:var(--blue-500); font-weight:600; }
.brand-text em{ font-style:normal; color:var(--ink-mute); font-weight:500; font-size:.85em; margin-left:1px; }

.primary-nav ul{ display:flex; gap:1.6rem; list-style:none; padding:0; margin:0; }
.primary-nav a{
    color:var(--ink-soft); font-weight:500; font-size:.95rem;
    padding:.4em 0; position:relative;
}
.primary-nav a::after{
    content:''; position:absolute; left:0; right:100%; bottom:0;
    height:2px; background:var(--grad); border-radius:2px;
    transition:right var(--t);
}
.primary-nav a:hover{ color:var(--ink); }
.primary-nav a:hover::after{ right:0; }

.nav-toggle{
    display:none; background:transparent; border:0; cursor:pointer;
    width:40px; height:40px; padding:8px; flex-direction:column; gap:5px; justify-content:center;
}
.nav-toggle span{ display:block; height:2px; width:100%; background:var(--ink); border-radius:2px; transition:transform var(--t), opacity var(--t); }
.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); }

/* HUOM: EI body-scroll-lukkoa.
   Aiemmin käytimme `position:fixed` tai `overflow:hidden`, mutta
   nämä rikkoivat .site-header :n position:sticky -toiminnan, jolloin
   hampurilainen "katosi" valikon sulkemisen jälkeen.
   Backdrop kattaa koko ruudun ja estää klikkaukset, ja siihen on
   asetettu touch-action:none jotta käyttäjä ei voi vahingossa rullata
   sormella valikon ulkopuolelta. Valikon sisällä rullaus toimii. */

/* ---------- hero ---------- */
.hero{ padding:6rem 0 3rem; position:relative; }
.hero-grid{
    display:grid; grid-template-columns:1.1fr 1fr; gap:4rem; align-items:center;
}
.eyebrow{
    display:inline-flex; align-items:center; gap:.5em;
    padding:.4em 1em; border-radius:999px;
    background:rgba(75,255,255,.08);
    color:var(--blue-600);
    font-size:.82rem; font-weight:600; letter-spacing:.02em;
    border:1px solid rgba(75,255,255,.15);
    margin-bottom:1.2rem;
}
.eyebrow .dot{
    width:7px; height:7px; border-radius:50%; background:var(--blue-500);
    box-shadow:0 0 0 4px rgba(75,255,255,.18);
    animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
    0%,100%{ box-shadow:0 0 0 4px rgba(75,255,255,.18); }
    50%{ box-shadow:0 0 0 8px rgba(75,255,255,.06); }
}
.hero-title{ margin-bottom:1.2rem; }
.gradient-text{
    background:var(--grad);
    -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent; color:transparent;
}
.hero-sub{ font-size:1.15rem; color:var(--ink-soft); max-width:560px; margin-bottom:1.8rem; }
.hero-cta{ display:flex; gap:.8rem; flex-wrap:wrap; margin-bottom:2rem; }
.hero-bullets{
    list-style:none; padding:0; margin:0;
    display:grid; grid-template-columns:repeat(2,1fr); gap:.6rem 1.2rem;
}
.hero-bullets li{ font-size:.95rem; color:var(--ink-soft); display:flex; align-items:center; gap:.5em; }
.check{
    display:inline-grid; place-items:center;
    width:22px; height:22px; border-radius:50%;
    background:var(--grad); color:#fff; font-size:.8rem; font-weight:700;
    box-shadow:0 4px 12px rgba(75,255,255,.3);
}

/* hero visual */
.hero-visual{ position:relative; min-height:440px; }
.hero-card{
    border-radius:var(--radius-lg);
    padding:0; overflow:hidden;
    box-shadow:var(--shadow-lg);
    transform:perspective(1200px) rotateY(-7deg) rotateX(4deg);
    transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
.hero-card:hover{ transform:perspective(1200px) rotateY(0) rotateX(0); }
.card-bar{
    display:flex; align-items:center; gap:.4rem;
    padding:.7rem 1rem;
    background:rgba(255,255,255,.6);
    border-bottom:1px solid var(--line-soft);
    font-size:.85rem;
}
.card-bar span{ width:11px; height:11px; border-radius:50%; background:var(--line); }
.card-bar span:first-child{ background:#ff5f57; }
.card-bar span:nth-child(2){ background:#febc2e; }
.card-bar span:nth-child(3){ background:#28c840; }
.card-bar b{ margin-left:auto; color:var(--ink-mute); font-weight:500; }
.card-body{ padding:1.6rem; }
.metric{ margin-bottom:1.1rem; }
.metric-label{ font-size:.85rem; color:var(--ink-mute); margin-bottom:.25rem; }
.metric-value{ font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:1.5rem; color:var(--ink); margin-bottom:.4rem; }
.bar{
    height:8px; border-radius:999px; background:var(--line-soft); overflow:hidden;
}
.bar i{
    display:block; height:100%; width:0;
    background:var(--grad); border-radius:999px;
    box-shadow:0 0 12px rgba(75,255,255,.5);
    animation:fill 1.6s ease-out forwards;
}
@keyframes fill{ to{ width:var(--w); } }
.card-foot{ display:flex; gap:.5rem; flex-wrap:wrap; margin-top:1rem; }
.pill{
    padding:.35em .8em; border-radius:999px;
    background:var(--blue-50); color:var(--blue-700);
    font-size:.8rem; font-weight:600;
}

.floating{
    position:absolute; padding:.8rem 1.1rem; border-radius:var(--radius);
    box-shadow:var(--shadow);
    display:flex; flex-direction:column; gap:.1rem;
    animation:bob 5s ease-in-out infinite;
}
.floating strong{ font-family:'Space Grotesk',sans-serif; font-size:1.4rem; color:var(--blue-600); }
.floating small{ font-size:.78rem; color:var(--ink-mute); }
.floating-1{ top:8%; left:-40px; animation-delay:-2s; }
.floating-2{ bottom:8%; right:-30px; }
@keyframes bob{
    0%,100%{ transform:translateY(0); }
    50%{ transform:translateY(-12px); }
}

/* marquee */
.marquee{
    margin-top:3.5rem; overflow:hidden; padding:1.4rem 0;
    border-top:1px solid var(--line-soft);
    border-bottom:1px solid var(--line-soft);
    -webkit-mask-image:linear-gradient(to right, transparent, #000 10%, #000 90%, transparent);
    mask-image:linear-gradient(to right, transparent, #000 10%, #000 90%, transparent);
}
.marquee-track{
    display:flex; gap:3rem; width:max-content;
    animation:scroll 40s linear infinite;
}
.marquee-track span{
    font-family:'Space Grotesk',sans-serif; font-weight:600; font-size:1.05rem;
    color:var(--ink-mute); white-space:nowrap;
}
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ---------- sections ---------- */
.section{ padding:6rem 0; position:relative; }
.section-alt{ background:var(--bg-soft); }
.section-head{ text-align:center; max-width:760px; margin:0 auto 3.5rem; }
.section-head p{ font-size:1.1rem; }

/* features */
.features-grid{
    display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem;
}
.feature-card{
    padding:2rem 1.6rem;
    background:var(--surface); border-radius:var(--radius-lg);
    border:1px solid var(--line-soft);
    transition:transform var(--t), box-shadow var(--t), border-color var(--t);
    position:relative; overflow:hidden;
}
.feature-card::before{
    content:''; position:absolute; inset:0;
    background:radial-gradient(600px circle at var(--mx,50%) var(--my,0%), rgba(75,255,255,.08), transparent 40%);
    opacity:0; transition:opacity var(--t); pointer-events:none;
}
.feature-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:var(--blue-200); }
.feature-card:hover::before{ opacity:1; }
.feature-icon{
    width:54px; height:54px; border-radius:14px;
    display:grid; place-items:center;
    background:var(--grad); color:#fff;
    box-shadow:0 10px 24px rgba(75,255,255,.3);
    margin-bottom:1.1rem;
}
.feature-icon svg{ width:26px; height:26px; }
.feature-card h3{ margin-bottom:.5rem; }
.feature-card p{ margin:0; font-size:.97rem; }

/* services */
.services-grid{
    display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem;
}
.service-card{
    position:relative; overflow:hidden;
    padding:1.6rem 1.4rem;
    border-radius:var(--radius);
    background:var(--surface); border:1px solid var(--line-soft);
    transition:transform var(--t), box-shadow var(--t), border-color var(--t);
}
.service-card:hover{ transform:translateY(-5px); border-color:var(--blue-200); box-shadow:var(--shadow); }
.service-emoji{ font-size:2rem; margin-bottom:.5rem; filter:drop-shadow(0 4px 8px rgba(75,255,255,.18)); }
.service-card h3{ font-size:1.05rem; margin-bottom:.3rem; }
.service-card p{ font-size:.9rem; margin:0; }
.service-shine{
    position:absolute; top:0; left:-60%; width:50%; height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);
    transform:skewX(-20deg); transition:left .8s ease;
}
.service-card:hover .service-shine{ left:130%; }
.services-note{ text-align:center; margin-top:2.5rem; color:var(--ink-mute); }
.services-note a{ font-weight:600; }

/* pricing */
.pricing-grid{
    display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem;
    align-items:stretch;
}
.pricing-grid--2col{
    grid-template-columns:repeat(2,1fr);
    max-width:900px; margin-left:auto; margin-right:auto;
}
.price-card{
    position:relative;
    padding:2rem 1.8rem;
    border-radius:var(--radius-lg);
    background:var(--surface); border:1px solid var(--line);
    display:flex; flex-direction:column;
    transition:transform var(--t), box-shadow var(--t), border-color var(--t);
}
.price-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.price-card.featured{
    border:2px solid transparent;
    background:
        linear-gradient(var(--surface),var(--surface)) padding-box,
        var(--grad) border-box;
    box-shadow:var(--shadow);
}
.price-card.featured::before{
    content:none;
}
.price-head{ margin-bottom:1rem; }
.badge{
    display:inline-block; padding:.3em .8em; border-radius:999px;
    background:var(--blue-50); color:var(--blue-700);
    font-size:.78rem; font-weight:700; letter-spacing:.02em;
    margin-bottom:.6rem;
}
.badge-blue{ background:var(--grad); color:#fff; box-shadow:0 6px 14px rgba(75,255,255,.3); }
.badge-soft{ background:#ecfeff; color:#0e7490; }
.price-amount{ display:flex; align-items:baseline; gap:.4rem; margin-bottom:.6rem; }
.price-amount .amount{
    font-family:'Space Grotesk',sans-serif; font-weight:700;
    font-size:2.8rem; color:var(--ink);
    background:var(--grad);
    -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent;
}
.price-amount .period{ color:var(--ink-mute); font-size:.95rem; }
.price-tag{ color:var(--ink-soft); font-size:.95rem; min-height:2.6em; }
.price-list{ list-style:none; padding:0; margin:1rem 0 1.5rem; flex:1; }
.price-list li{ padding:.45rem 0; color:var(--ink-soft); font-size:.95rem; border-bottom:1px dashed var(--line-soft); }
.price-list li:last-child{ border-bottom:0; }
.price-list li.price-list-extra{
    color:var(--ink-mute); font-size:.88rem; font-style:italic;
    margin-top:.4rem; padding-top:.7rem;
    border-top:1px dashed var(--line-soft); border-bottom:0;
}
.price-note{
    margin-top:2rem; padding:1.2rem 1.4rem;
    background:var(--blue-50); border:1px solid var(--blue-100); border-left:4px solid var(--blue-500);
    border-radius:var(--radius);
    color:var(--ink); font-size:.97rem;
}

/* Stripe-maksuosio: badge-rivi ja maksunappi */
.pay-badges{
    display:flex; flex-wrap:wrap; justify-content:center; gap:.6rem;
    margin:0 auto 2.4rem; max-width:760px;
}
.pay-badge{
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.55rem 1rem; border-radius:999px;
    background:var(--surface); border:1px solid var(--line-soft);
    color:var(--ink-soft); font-size:.88rem; font-weight:500;
    box-shadow:0 1px 2px rgba(0,0,0,.03);
}
.pay-badge svg{ color:var(--blue-500); flex-shrink:0; }

/* Hinnasto: 7 päivän tyytyväisyystakuu — näyttävä luottamusnauha */
.trust-guarantee-banner{
    display:flex; align-items:flex-start; gap:1.25rem;
    margin:-.4rem auto 2.2rem; max-width:820px;
    padding:1.35rem 1.55rem;
    border-radius:var(--radius-lg);
    background:linear-gradient(145deg, rgba(236,254,255,.97), rgba(255,255,255,.9));
    border:1px solid rgba(6,182,212,.38);
    box-shadow:
        0 10px 40px rgba(6,182,212,.12),
        0 1px 0 rgba(255,255,255,.85) inset;
}
.trust-guarantee-icon{
    flex-shrink:0;
    width:52px; height:52px; border-radius:14px;
    display:grid; place-items:center;
    background:var(--grad); color:#fff;
    box-shadow:0 6px 22px rgba(6,182,212,.38);
}
.trust-guarantee-icon svg{ stroke-width:2.1; }
.trust-guarantee-title{
    display:block; font-size:1.06rem; font-weight:700;
    color:var(--ink); letter-spacing:-.015em; line-height:1.25;
}
.trust-guarantee-copy p{
    margin:.55rem 0 0; font-size:.96rem; color:var(--ink-soft);
    line-height:1.58;
}
.trust-guarantee-link{
    display:inline-block; margin-top:.85rem;
    font-weight:600; font-size:.93rem; color:var(--blue-600);
    text-decoration:none;
    border-bottom:2px solid rgba(6,182,212,.45);
    transition:color var(--t), border-color var(--t);
}
.trust-guarantee-link:hover{
    color:var(--blue-700);
    border-bottom-color:var(--blue-500);
}

.btn-pay{
    display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
}
.btn-pay svg{ flex-shrink:0; opacity:.9; }

.invoice-note{
    margin-top:1.2rem; padding:1.1rem 1.4rem;
    display:flex; align-items:flex-start; gap:1rem;
    background:linear-gradient(135deg, #fff7e6 0%, #fffdf5 100%);
    border:1px solid #f3d99e; border-left:4px solid #e0a83b;
    border-radius:var(--radius);
    color:var(--ink); font-size:.97rem;
}
.invoice-note svg{ color:#c98a1f; flex-shrink:0; margin-top:.15rem; }
.invoice-note a{ color:var(--blue-600); font-weight:600; text-decoration:underline; }
.invoice-note a:hover{ color:var(--blue-700); }

@media (max-width:640px){
    .pay-badges{ gap:.4rem; margin-bottom:1.8rem; }
    .pay-badge{ font-size:.82rem; padding:.45rem .8rem; }
    .invoice-note{ flex-direction:column; gap:.6rem; }
    .trust-guarantee-banner{
        flex-direction:column; align-items:center; text-align:center;
        padding:1.2rem 1.15rem; margin-bottom:1.85rem;
    }
    .trust-guarantee-copy p{ font-size:.93rem; }
}

/* process */
.process-grid{
    display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem;
    counter-reset:step;
}
.process-step{
    position:relative;
    padding:2rem 1.5rem 1.5rem;
    background:var(--surface); border:1px solid var(--line-soft);
    border-radius:var(--radius-lg);
    transition:transform var(--t), box-shadow var(--t);
}
.process-step:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
.step-num{
    font-family:'Space Grotesk',sans-serif; font-weight:700;
    font-size:2.4rem;
    background:var(--grad);
    -webkit-background-clip:text; background-clip:text;
    -webkit-text-fill-color:transparent;
    margin-bottom:.4rem;
}
.process-step h3{ font-size:1.1rem; margin-bottom:.4rem; }
.process-step p{ font-size:.95rem; margin:0; }

/* about */
.about-grid{
    display:grid; grid-template-columns:1fr 1.2fr; gap:4rem; align-items:center;
}
.about-frame{
    border-radius:var(--radius-xl);
    padding:2rem;
    text-align:center;
}
.about-avatar{
    width:160px; height:160px; border-radius:50%; margin:0 auto 1.2rem;
    background:var(--grad); color:#fff;
    display:grid; place-items:center;
    font-family:'Space Grotesk',sans-serif; font-size:3.4rem; font-weight:700;
    box-shadow:0 20px 40px rgba(75,255,255,.4), inset 0 -10px 30px rgba(0,0,0,.15);
    position:relative;
}
.about-avatar::after{
    content:''; position:absolute; inset:-6px; border-radius:50%;
    border:2px dashed rgba(75,255,255,.35);
    animation:spin 18s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
.about-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:.6rem; margin-top:1.4rem; }
.about-stats div{ padding:.8rem .4rem; border-radius:var(--radius-sm); background:var(--blue-50); }
.about-stats strong{ display:block; font-family:'Space Grotesk',sans-serif; font-size:1.1rem; color:var(--blue-700); }
.about-stats small{ color:var(--ink-mute); font-size:.78rem; }

/* faq */
.faq-list{ max-width:800px; margin:0 auto; display:grid; gap:.8rem; }
.faq-item{
    background:var(--surface); border:1px solid var(--line-soft);
    border-radius:var(--radius); padding:1rem 1.4rem;
    transition:border-color var(--t), box-shadow var(--t);
}
.faq-item[open]{ border-color:var(--blue-200); box-shadow:var(--shadow); }
.faq-item summary{
    cursor:pointer; font-weight:600; font-family:'Space Grotesk',sans-serif;
    font-size:1.05rem; color:var(--ink);
    list-style:none; padding:.4rem 0;
    display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
    content:'+'; font-size:1.6rem; color:var(--blue-500); font-weight:300;
    transition:transform var(--t);
}
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ margin:.5rem 0 0; color:var(--ink-soft); }

/* CTA */
.cta-section{ padding-bottom:7rem; }
.cta-card{
    display:grid; grid-template-columns:1fr 1fr; gap:3rem;
    padding:3rem;
    background:linear-gradient(135deg,#4BFFFF 0%, #22d3ee 50%, #06b6d4 100%);
    border-radius:var(--radius-xl);
    color:#fff;
    position:relative; overflow:hidden;
    box-shadow:var(--shadow-lg);
}
.cta-card::before{
    content:''; position:absolute; top:-50%; right:-20%;
    width:600px; height:600px;
    background:radial-gradient(circle, rgba(75,255,255,.5), transparent 60%);
    pointer-events:none;
}
.cta-card::after{
    content:''; position:absolute; inset:0;
    background-image:
        linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
    background-size:32px 32px;
    mask-image:radial-gradient(ellipse at top right, black, transparent 70%);
    -webkit-mask-image:radial-gradient(ellipse at top right, black, transparent 70%);
    pointer-events:none;
}
.cta-content,.cta-form{ position:relative; z-index:1; }
.cta-content h2{ color:var(--ink); }
.cta-content p{ color:var(--ink-soft); font-size:1.1rem; }
.eyebrow-light{ background:rgba(0,0,0,.08); color:var(--ink); border-color:rgba(0,0,0,.12); }
.eyebrow-light .dot{ background:var(--ink); box-shadow:0 0 0 4px rgba(0,0,0,.12); }
.cta-list{ list-style:none; padding:0; margin-top:1.4rem; display:grid; gap:.5rem; }
.cta-list li{ color:var(--ink); }

.cta-form{
    background:rgba(255,255,255,.96);
    color:var(--ink);
    padding:2rem;
    border-radius:var(--radius-lg);
    display:grid; gap:.9rem;
}
.cta-form h3{ margin:0 0 .3rem; }
.cta-form label{ display:grid; gap:.3rem; font-size:.9rem; font-weight:500; color:var(--ink-soft); }
.cta-form input,
.cta-form select,
.cta-form textarea{
    width:100%; padding:.8rem 1rem;
    border-radius:var(--radius-sm);
    border:1.5px solid var(--line);
    background:#fff; color:var(--ink);
    font:inherit; font-size:.97rem;
    transition:border-color var(--t), box-shadow var(--t);
}
.cta-form input:focus,
.cta-form select:focus,
.cta-form textarea:focus{
    outline:none; border-color:var(--blue-500);
    box-shadow:0 0 0 4px rgba(75,255,255,.15);
}
.cta-form textarea{ resize:vertical; min-height:80px; }
.form-note{ color:var(--ink-mute); font-size:.82rem; text-align:center; }

/* Multi-select pakettilista */
.cta-form .package-choices{
    border:1.5px solid var(--line);
    border-radius:var(--radius-sm);
    padding:.9rem 1rem 1rem;
    margin:0;
    background:#fff;
    display:grid; gap:.45rem;
}
.cta-form .package-choices legend{
    padding:0 .4rem;
    font-size:.9rem; font-weight:600;
    color:var(--ink-soft);
}
.cta-form .package-choices legend small{
    font-weight:400; color:var(--ink-mute); margin-left:.3em;
}
.cta-form .pkg-opt{
    display:flex; align-items:center; gap:.6rem;
    padding:.55rem .75rem;
    border:1.5px solid var(--line);
    border-radius:var(--radius-sm);
    cursor:pointer;
    font-size:.92rem; font-weight:500;
    color:var(--ink);
    background:#fff;
    transition:border-color var(--t), background var(--t), box-shadow var(--t);
}
.cta-form .pkg-opt:hover{ border-color:var(--blue-500); background:rgba(75,255,255,.05); }
.cta-form .pkg-opt input[type=checkbox]{
    width:18px; height:18px; flex:0 0 18px;
    margin:0; padding:0;
    accent-color:var(--blue-500);
    cursor:pointer;
}
.cta-form .pkg-opt:has(input:checked){
    border-color:var(--blue-500);
    background:linear-gradient(135deg, rgba(75,255,255,.10), rgba(75,255,255,.04));
    box-shadow:0 0 0 3px rgba(75,255,255,.12);
}
.cta-form .pkg-opt span{ flex:1; }

/* Räätälöity rivi: nimi + määräkenttä */
.cta-form .pkg-opt--qty{ flex-wrap:wrap; }
.cta-form .pkg-qty-wrap{
    display:inline-flex; align-items:center; gap:.35rem;
    margin-left:auto; flex:0 0 auto;
}
.cta-form .pkg-qty-wrap input[type=number]{
    width:64px; padding:.35rem .5rem;
    border:1.5px solid var(--line); border-radius:8px;
    text-align:center; font-weight:600; font-size:.95rem;
    background:#fff;
}
.cta-form .pkg-qty-wrap input[type=number]:focus{
    outline:none; border-color:var(--blue-500);
    box-shadow:0 0 0 3px rgba(75,255,255,.15);
}
.cta-form .pkg-qty-suffix{
    font-size:.82rem; color:var(--ink-mute); font-weight:500;
}

/* SEO-laskuri kortilla */
.seo-counter{
    display:flex; align-items:center; gap:.6rem;
    margin:1rem 0 1.2rem;
    padding:.6rem;
    background:var(--bg-soft, #f5f8f5);
    border:1.5px solid var(--line);
    border-radius:var(--radius-sm);
}
.seo-counter-btn{
    width:38px; height:38px;
    border:1.5px solid var(--line); background:#fff;
    border-radius:8px; font-size:1.4rem; font-weight:700; line-height:1;
    color:var(--ink); cursor:pointer;
    display:grid; place-items:center;
    transition:border-color var(--t), background var(--t), color var(--t), transform var(--t);
}
.seo-counter-btn:hover{ border-color:var(--blue-500); color:var(--blue-500); background:rgba(75,255,255,.06); }
.seo-counter-btn:active{ transform:scale(.94); }
.seo-counter input[type=number]{
    flex:1; max-width:80px;
    padding:.55rem .6rem;
    border:1.5px solid var(--line); border-radius:8px;
    text-align:center; font-weight:700; font-size:1.05rem;
    background:#fff;
    -moz-appearance:textfield; appearance:textfield;
}
.seo-counter input[type=number]::-webkit-outer-spin-button,
.seo-counter input[type=number]::-webkit-inner-spin-button{
    -webkit-appearance:none; margin:0;
}
.seo-counter input[type=number]:focus{
    outline:none; border-color:var(--blue-500);
    box-shadow:0 0 0 3px rgba(75,255,255,.15);
}
.seo-counter-label{
    font-size:.88rem; color:var(--ink-mute); font-weight:500;
    margin-left:auto;
}

/* ---------- footer ---------- */
.site-footer{
    margin-top:4rem;
    padding:4rem 0 1.5rem;
    background:linear-gradient(180deg, transparent, var(--bg-soft) 30%);
    border-top:1px solid var(--line-soft);
}
.footer-grid{
    display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem;
    padding-bottom:2.5rem; border-bottom:1px solid var(--line-soft);
}
.footer-col h4{ font-size:.95rem; margin-bottom:.9rem; color:var(--ink); }
.footer-col ul{ list-style:none; padding:0; margin:0; display:grid; gap:.5rem; }
.footer-col a{ color:var(--ink-soft); font-size:.92rem; }
.footer-col a:hover{ color:var(--blue-600); }
.footer-tag{ color:var(--ink-soft); font-size:.92rem; margin-top:.8rem; max-width:340px; }
.footer-bottom{
    display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
    padding-top:1.5rem; color:var(--ink-mute); font-size:.85rem;
}

/* ---------- legal pages ---------- */
.legal-wrap{ padding-bottom:4rem; }
.legal-hero{
    padding:5rem 0 3rem;
    background:linear-gradient(180deg, var(--bg-soft), transparent);
}
.legal-hero h1{ font-size:clamp(2rem,4vw,3rem); margin-bottom:.6rem; }
.legal-hero p{ max-width:680px; color:var(--ink-soft); }
.legal-inner{ max-width:880px; }
.legal-article{
    padding:2.5rem;
    border-radius:var(--radius-xl);
    background:rgba(255,255,255,.85);
}
.legal-article h2{
    font-size:1.4rem; margin-top:2rem; margin-bottom:.6rem;
    padding-bottom:.4rem;
    border-bottom:2px solid var(--blue-100);
}
.legal-article section:first-of-type h2{ margin-top:.5rem; }
.legal-article p,.legal-article li{ color:var(--ink-soft); }
.legal-article ul{ padding-left:1.2rem; }
.legal-article li{ margin-bottom:.4rem; }
.legal-toc{
    padding:1rem 1.4rem;
    background:var(--blue-50); border-radius:var(--radius);
    margin-bottom:1.5rem;
}
.legal-toc h2{ border:0; margin:0 0 .5rem; font-size:1rem; padding:0; }
.legal-toc ol{ margin:0; padding-left:1.2rem; columns:2; column-gap:1.4rem; }
.legal-toc a{ color:var(--blue-700); font-size:.92rem; }
.cookie-table-wrap{ overflow-x:auto; margin:1rem 0; }
.cookie-table{ width:100%; border-collapse:collapse; font-size:.92rem; }
.cookie-table th, .cookie-table td{ padding:.7rem .8rem; text-align:left; border-bottom:1px solid var(--line-soft); }
.cookie-table th{ background:var(--blue-50); color:var(--blue-700); font-weight:600; }

/* ============================================================
   BLOGI — Hero, hakukenttä, postauskortit, single, sticky sidebar
   ============================================================ */

/* ---------- Blogin yleinen wrap ---------- */
.blog-wrap{ padding-bottom:5rem; }

/* ---------- Hero ---------- */
.blog-hero{
    padding:5rem 0 3rem;
    position:relative;
    background:linear-gradient(180deg, var(--bg-soft) 0%, transparent 100%);
}
.blog-hero-inner{
    display:grid;
    grid-template-columns:1.4fr 1fr;
    gap:3rem;
    align-items:center;
}
.blog-hero-content h1{
    font-size:clamp(2rem, 4.2vw, 3.4rem);
    line-height:1.1;
    margin:.4rem 0 1rem;
    letter-spacing:-.025em;
}
.gradient-text{
    background:var(--grad);
    -webkit-background-clip:text;
    background-clip:text;
    -webkit-text-fill-color:transparent;
}
.blog-hero-lead{
    font-size:1.1rem;
    color:var(--ink-soft);
    line-height:1.6;
    max-width:580px;
    margin:0 0 1.6rem;
}

/* ---------- Hakukenttä ---------- */
.blog-search{
    display:flex;
    align-items:stretch;
    gap:.5rem;
    background:rgba(255,255,255,.85);
    border:1.5px solid var(--line);
    border-radius:999px;
    padding:6px;
    box-shadow:0 8px 28px rgba(6,182,212,.12);
    max-width:560px;
    transition:border-color var(--t), box-shadow var(--t);
}
.blog-search:focus-within{
    border-color:var(--blue-500);
    box-shadow:0 12px 36px rgba(6,182,212,.22), 0 0 0 4px rgba(75,255,255,.15);
}
.blog-search-label{
    flex:1;
    display:flex;
    align-items:center;
    gap:.5rem;
    padding:0 .5rem 0 1rem;
}
.blog-search-icon{
    color:var(--blue-500);
    display:inline-flex;
    flex-shrink:0;
}
.blog-search-input{
    flex:1;
    width:100%;
    padding:.9rem .2rem;
    border:none;
    background:transparent;
    color:var(--ink);
    font:inherit;
    font-size:1rem;
    outline:none;
}
.blog-search-input::placeholder{ color:var(--ink-mute); }
.blog-search-btn{
    display:inline-flex;
    align-items:center;
    gap:.4rem;
    padding:.7rem 1.3rem;
    background:var(--grad);
    color:#fff;
    border:none;
    border-radius:999px;
    font-weight:600;
    cursor:pointer;
    font-size:.95rem;
    transition:transform var(--t), box-shadow var(--t);
    box-shadow:0 6px 16px rgba(6,182,212,.3);
}
.blog-search-btn:hover{
    transform:translateY(-1px);
    box-shadow:0 10px 24px rgba(6,182,212,.4);
}
.blog-search-btn-arrow{ transition:transform var(--t); }
.blog-search-btn:hover .blog-search-btn-arrow{ transform:translateX(3px); }

.screen-reader-text{
    position:absolute;
    width:1px; height:1px;
    overflow:hidden;
    clip:rect(0,0,0,0);
    white-space:nowrap;
}

/* ---------- Tags-rivi ---------- */
.blog-tags-row{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:.5rem;
    margin-top:1.4rem;
}
.blog-tags-label{
    color:var(--ink-mute);
    font-size:.88rem;
    font-weight:500;
    margin-right:.3rem;
}
.blog-tag-chip{
    display:inline-flex;
    align-items:center;
    gap:.4rem;
    padding:.4rem .85rem;
    background:rgba(255,255,255,.7);
    border:1.5px solid var(--line);
    border-radius:999px;
    color:var(--ink-soft);
    font-size:.85rem;
    font-weight:500;
    transition:all var(--t);
}
.blog-tag-chip:hover{
    background:#fff;
    border-color:var(--blue-500);
    color:var(--blue-700);
    transform:translateY(-1px);
}
.blog-tag-count{
    background:var(--blue-50);
    color:var(--blue-700);
    font-size:.72rem;
    padding:1px 7px;
    border-radius:999px;
    font-weight:700;
}

/* ---------- Hero-stats ---------- */
.blog-hero-stats{
    display:grid;
    gap:1rem;
}
.blog-stat{
    background:rgba(255,255,255,.75);
    backdrop-filter:blur(10px);
    border:1.5px solid var(--line);
    border-radius:var(--radius);
    padding:1.2rem 1.4rem;
    display:flex;
    align-items:baseline;
    justify-content:space-between;
    gap:1rem;
}
.blog-stat strong{
    font-family:'Space Grotesk', sans-serif;
    font-size:1.8rem;
    color:var(--blue-600);
    line-height:1;
    font-weight:800;
}
.blog-stat span{
    color:var(--ink-mute);
    font-size:.9rem;
    font-weight:500;
}

/* ---------- Featured post ---------- */
.blog-featured-wrap{ margin:1.5rem auto 3rem; }
.blog-featured-card{
    display:grid;
    grid-template-columns:1.2fr 1fr;
    gap:0;
    background:#fff;
    border-radius:var(--radius-xl);
    overflow:hidden;
    border:1px solid var(--line-soft);
    box-shadow:var(--shadow);
    transition:transform var(--t), box-shadow var(--t);
}
.blog-featured-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow-lg);
    color:inherit;
}
.blog-featured-media{
    position:relative;
    aspect-ratio:16/10;
    overflow:hidden;
    background:linear-gradient(135deg, var(--blue-100), var(--blue-50));
}
.blog-featured-media img{
    width:100%; height:100%; object-fit:cover;
    transition:transform .8s ease;
}
.blog-featured-card:hover .blog-featured-media img{ transform:scale(1.05); }
.blog-featured-placeholder{
    width:100%; height:100%;
    display:grid; place-items:center;
    font-size:5rem;
    background:var(--grad);
    color:#fff;
    text-shadow:0 6px 20px rgba(0,0,0,.18);
}
.blog-featured-badge{
    position:absolute;
    top:1rem; left:1rem;
    background:rgba(255,255,255,.95);
    color:var(--blue-700);
    padding:.4rem .9rem;
    border-radius:999px;
    font-size:.8rem;
    font-weight:700;
    backdrop-filter:blur(10px);
    box-shadow:0 4px 12px rgba(6,182,212,.18);
}
.blog-featured-body{
    padding:2.2rem;
    display:flex;
    flex-direction:column;
    justify-content:center;
}
.blog-featured-title{
    font-size:clamp(1.3rem, 2vw, 1.8rem);
    margin:.5rem 0 .8rem;
    line-height:1.25;
    color:var(--ink);
}
.blog-featured-excerpt{
    color:var(--ink-soft);
    margin:0 0 1.2rem;
    line-height:1.6;
}
.blog-featured-cta{
    display:inline-flex;
    align-items:center;
    gap:.4rem;
    color:var(--blue-600);
    font-weight:600;
    font-size:.95rem;
    align-self:flex-start;
}
.blog-featured-card:hover .blog-featured-cta{ color:var(--blue-700); gap:.7rem; }

/* ---------- Postausgrid ---------- */
.blog-grid-wrap{ margin-top:2rem; }
.blog-grid-head{
    text-align:center;
    margin:0 auto 2.5rem;
    max-width:600px;
}
.blog-grid-head h2{
    font-size:clamp(1.6rem, 3vw, 2.2rem);
    margin:0 0 .4rem;
}
.blog-grid-head p{
    color:var(--ink-soft);
    font-size:1.02rem;
    margin:0;
}
.blog-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:1.8rem;
    margin-bottom:3rem;
}
.blog-card{
    background:#fff;
    border-radius:var(--radius-lg);
    overflow:hidden;
    border:1px solid var(--line-soft);
    box-shadow:0 2px 12px rgba(10,25,41,.04);
    transition:transform var(--t), box-shadow var(--t), border-color var(--t);
    display:flex;
    flex-direction:column;
}
.blog-card:hover{
    transform:translateY(-6px);
    border-color:var(--blue-200);
    box-shadow:var(--shadow);
}
.blog-card-link{
    display:flex;
    flex-direction:column;
    height:100%;
    color:inherit;
    text-decoration:none;
}
.blog-card-media{
    position:relative;
    aspect-ratio:16/10;
    overflow:hidden;
    background:linear-gradient(135deg, var(--blue-50), var(--blue-100));
}
.blog-card-media img{
    width:100%; height:100%; object-fit:cover;
    transition:transform .7s ease;
}
.blog-card:hover .blog-card-media img{ transform:scale(1.07); }
.blog-card-placeholder{
    width:100%; height:100%;
    display:grid; place-items:center;
    font-size:3rem;
    background:var(--grad);
    color:#fff;
}
.blog-card-body{
    padding:1.3rem 1.4rem 1.5rem;
    display:flex;
    flex-direction:column;
    flex:1;
}
.blog-meta{
    display:flex;
    flex-wrap:wrap;
    gap:.5rem .9rem;
    align-items:center;
    font-size:.8rem;
    color:var(--ink-mute);
    margin-bottom:.6rem;
}
.blog-meta-cat{
    display:inline-block;
    padding:3px 10px;
    background:linear-gradient(135deg, var(--blue-50), var(--blue-100));
    color:var(--blue-700);
    border-radius:999px;
    font-weight:700;
    font-size:.72rem;
    letter-spacing:.02em;
    text-transform:uppercase;
}
.blog-meta-read{ color:var(--ink-mute); }
.blog-card-title{
    font-size:1.18rem;
    line-height:1.3;
    margin:0 0 .55rem;
    color:var(--ink);
}
.blog-card-excerpt{
    color:var(--ink-soft);
    font-size:.94rem;
    line-height:1.55;
    margin:0 0 1rem;
    flex:1;
}
.blog-card-cta{
    color:var(--blue-600);
    font-weight:600;
    font-size:.9rem;
    transition:color var(--t), transform var(--t);
    align-self:flex-start;
}
.blog-card:hover .blog-card-cta{
    color:var(--blue-700);
    transform:translateX(3px);
}

/* ---------- Sivutus ---------- */
.blog-pagination{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:.4rem;
    margin:2rem 0 0;
}
.blog-pagination .page-numbers{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:42px;
    padding:.55rem .9rem;
    background:#fff;
    border:1.5px solid var(--line);
    border-radius:10px;
    color:var(--ink-soft);
    font-weight:600;
    font-size:.92rem;
    text-decoration:none;
    transition:all var(--t);
}
.blog-pagination .page-numbers:hover{
    border-color:var(--blue-500);
    color:var(--blue-600);
    transform:translateY(-1px);
}
.blog-pagination .page-numbers.current{
    background:var(--grad);
    color:#fff;
    border-color:transparent;
    box-shadow:0 6px 16px rgba(6,182,212,.3);
}
.blog-pagination .page-numbers.dots{ background:none; border:0; }

/* ---------- Tyhjä tila ---------- */
.blog-empty-wrap{ padding:3rem 0; }
.blog-empty{
    text-align:center;
    background:#fff;
    border:2px dashed var(--line);
    border-radius:var(--radius-xl);
    padding:4rem 2rem;
    max-width:540px;
    margin:0 auto;
}
.blog-empty-icon{ font-size:4rem; margin-bottom:1rem; }
.blog-empty h2{ margin:0 0 .6rem; }
.blog-empty p{ color:var(--ink-mute); margin:0 0 1.5rem; }

/* ============================================================
   SINGLE POST — Yksittäisen postauksen näkymä
   ============================================================ */

/* ---------- Lukuetenemispalkki ---------- */
.reading-progress{
    position:fixed;
    top:0; left:0; right:0;
    height:3px;
    background:rgba(207,250,254,.4);
    z-index:60;
    pointer-events:none;
}
.reading-progress-fill{
    height:100%;
    width:0%;
    background:var(--grad);
    box-shadow:0 0 12px rgba(75,255,255,.6);
    transition:width .1s linear;
}

.single-wrap{ padding-bottom:4rem; }

/* ---------- Single hero ---------- */
.single-hero{
    padding:3rem 0 2.5rem;
    background:linear-gradient(180deg, var(--bg-soft) 0%, transparent 100%);
}
.single-hero-inner{
    max-width:840px;
}
.single-back{
    display:inline-block;
    color:var(--ink-mute);
    font-size:.9rem;
    font-weight:500;
    margin-bottom:1.5rem;
    transition:color var(--t), transform var(--t);
}
.single-back:hover{
    color:var(--blue-600);
    transform:translateX(-2px);
}
.single-meta{
    display:flex;
    flex-wrap:wrap;
    gap:.7rem 1rem;
    align-items:center;
    margin-bottom:1.2rem;
    font-size:.88rem;
    color:var(--ink-mute);
}
.single-meta-cat{
    display:inline-block;
    padding:5px 14px;
    background:linear-gradient(135deg, var(--blue-50), var(--blue-100));
    color:var(--blue-700);
    border-radius:999px;
    font-weight:700;
    font-size:.78rem;
    letter-spacing:.02em;
    text-transform:uppercase;
}
.single-meta-cat:hover{
    background:linear-gradient(135deg, var(--blue-100), var(--blue-200));
    color:var(--blue-700);
}
.single-title{
    font-size:clamp(2rem, 4.5vw, 3.4rem);
    line-height:1.1;
    margin:0 0 1rem;
    letter-spacing:-.02em;
}
.single-lead{
    font-size:1.2rem;
    color:var(--ink-soft);
    line-height:1.55;
    margin:0 0 1.5rem;
    max-width:680px;
    font-weight:400;
}
.single-author{
    display:flex;
    align-items:center;
    gap:.85rem;
    padding-top:1.2rem;
    border-top:1px solid var(--line-soft);
}
.single-author-avatar img{
    border-radius:50%;
    width:48px; height:48px;
    box-shadow:0 4px 12px rgba(6,182,212,.18);
}
.single-author-meta{
    display:flex;
    flex-direction:column;
    line-height:1.25;
}
.single-author-meta strong{
    font-size:.95rem;
    color:var(--ink);
}
.single-author-meta span{
    font-size:.82rem;
    color:var(--ink-mute);
}

/* ---------- Featured image ---------- */
.single-featured-wrap{
    margin:0 auto 3rem;
    max-width:1100px;
}
.single-featured-img{
    width:100%;
    height:auto;
    aspect-ratio:16/9;
    object-fit:cover;
    border-radius:var(--radius-xl);
    box-shadow:var(--shadow);
}

/* ---------- Sisältö-grid (sisältö + sidebar) ---------- */
.single-grid{
    display:grid;
    grid-template-columns:minmax(0, 1fr) 340px;
    gap:3rem;
    /* EI align-items:start — jotta sidebar venyy content-korkeudelle ja sisäinen sticky toimii */
}

.single-content{
    min-width:0;
}

/* ---------- Prose-styles (sisältö) ---------- */
.single-prose{
    color:var(--ink-soft);
    font-size:1.06rem;
    line-height:1.75;
}
.single-prose h2{
    font-size:clamp(1.5rem, 2.5vw, 2rem);
    margin:2.2rem 0 1rem;
    color:var(--ink);
}
.single-prose h3{
    font-size:1.3rem;
    margin:1.8rem 0 .8rem;
    color:var(--ink);
}
.single-prose h4{
    font-size:1.1rem;
    margin:1.4rem 0 .6rem;
    color:var(--ink);
}
.single-prose p{ margin:0 0 1.2rem; }
.single-prose a{
    color:var(--blue-600);
    border-bottom:1.5px solid var(--blue-200);
    transition:color var(--t), border-color var(--t);
}
.single-prose a:hover{
    color:var(--blue-700);
    border-color:var(--blue-500);
}
.single-prose ul,
.single-prose ol{
    padding-left:1.4rem;
    margin:0 0 1.4rem;
}
.single-prose li{ margin-bottom:.4rem; }
.single-prose blockquote{
    margin:1.8rem 0;
    padding:1.2rem 1.5rem;
    background:linear-gradient(135deg, var(--blue-50), rgba(255,255,255,.5));
    border-left:4px solid var(--blue-500);
    border-radius:var(--radius);
    color:var(--ink);
    font-style:italic;
    font-size:1.05rem;
}
.single-prose blockquote p:last-child{ margin-bottom:0; }
.single-prose code{
    background:var(--blue-50);
    color:var(--blue-700);
    padding:2px 7px;
    border-radius:6px;
    font-size:.92em;
    font-family:'Consolas', monospace;
}
.single-prose pre{
    background:var(--ink);
    color:#cffafe;
    padding:1.2rem 1.4rem;
    border-radius:var(--radius);
    overflow-x:auto;
    margin:1.5rem 0;
}
.single-prose pre code{
    background:transparent;
    color:inherit;
    padding:0;
}
.single-prose img,
.single-prose figure{
    max-width:100%;
    height:auto;
    border-radius:var(--radius);
    margin:1.5rem 0;
}
.single-prose hr{
    border:none;
    border-top:2px solid var(--line-soft);
    margin:2.5rem 0;
}

/* ---------- Tagit ---------- */
.single-tags{
    margin:2.5rem 0 1.5rem;
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:.5rem;
}
.single-tags-label{
    color:var(--ink-mute);
    font-size:.88rem;
    margin-right:.4rem;
    font-weight:500;
}
.single-tag{
    display:inline-block;
    padding:.35rem .8rem;
    background:#fff;
    border:1.5px solid var(--line);
    border-radius:999px;
    color:var(--ink-soft);
    font-size:.84rem;
    font-weight:500;
    transition:all var(--t);
}
.single-tag:hover{
    background:var(--blue-50);
    border-color:var(--blue-300);
    color:var(--blue-700);
    transform:translateY(-1px);
}

/* ---------- Jakopainikkeet ---------- */
.single-share{
    margin:2rem 0;
    padding:1.2rem 1.4rem;
    background:rgba(255,255,255,.6);
    backdrop-filter:blur(8px);
    border:1px solid var(--line-soft);
    border-radius:var(--radius);
    display:flex;
    flex-wrap:wrap;
    gap:.6rem;
    align-items:center;
}
.single-share-label{
    margin-right:auto;
    font-weight:600;
    color:var(--ink-soft);
    font-size:.92rem;
}
.single-share-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:40px; height:40px;
    border:1.5px solid var(--line);
    background:#fff;
    border-radius:50%;
    color:var(--ink-soft);
    cursor:pointer;
    transition:all var(--t);
}
.single-share-btn:hover{
    border-color:var(--blue-500);
    color:var(--blue-600);
    transform:translateY(-2px);
    box-shadow:0 6px 14px rgba(6,182,212,.2);
}
.single-share-btn.copied{
    border-color:#10b981;
    color:#10b981;
    background:#ecfdf5;
}

/* ---------- Edellinen/seuraava navi ---------- */
.single-nav{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:1rem;
    margin:2.5rem 0 1rem;
}
.single-nav-prev,
.single-nav-next{
    display:flex;
    flex-direction:column;
    gap:.3rem;
    padding:1.2rem 1.4rem;
    background:#fff;
    border:1.5px solid var(--line);
    border-radius:var(--radius);
    color:var(--ink);
    transition:all var(--t);
}
.single-nav-prev:hover,
.single-nav-next:hover{
    border-color:var(--blue-500);
    transform:translateY(-2px);
    box-shadow:var(--shadow);
    color:var(--ink);
}
.single-nav-next{ text-align:right; }
.single-nav-label{
    color:var(--blue-600);
    font-size:.8rem;
    font-weight:600;
    letter-spacing:.04em;
    text-transform:uppercase;
}
.single-nav-prev strong,
.single-nav-next strong{
    color:var(--ink);
    font-size:.95rem;
    line-height:1.3;
}

/* ============================================================
   STICKY SIDEBAR
   ============================================================ */
.single-sidebar{
    min-width:0;
    /* Sidebar venyy grid-rivin korkeudelle (default stretch) — antaa tilaa stickylle */
}
.single-sidebar-sticky{
    position:sticky;
    position:-webkit-sticky;
    top:90px;
    display:flex;
    flex-direction:column;
    gap:1.2rem;
    /* Ei max-height/overflow:auto — ne leikkaisivat CTA-kortin piiloon viewportin alapuolelle.
       Sticky tarttuu yläreunaan kunnes content loppuu, sitten valuu sivun mukana normaalisti. */
}
.single-sidebar-sticky::-webkit-scrollbar{ width:6px; }
.single-sidebar-sticky::-webkit-scrollbar-thumb{
    background:var(--line);
    border-radius:3px;
}

.sidebar-card{
    background:#fff;
    border:1px solid var(--line-soft);
    border-radius:var(--radius-lg);
    padding:1.3rem 1.4rem;
    box-shadow:0 2px 10px rgba(10,25,41,.03);
}
.sidebar-card-title{
    font-size:1rem;
    margin:0 0 1rem;
    padding-bottom:.7rem;
    border-bottom:2px solid var(--line-soft);
    color:var(--ink);
}

/* Hakukenttä sidebarissa: kompakti */
.sidebar-card .blog-search{
    flex-direction:column;
    border-radius:var(--radius);
    padding:4px;
    box-shadow:none;
    max-width:100%;
}
.sidebar-card .blog-search-label{
    padding:.4rem .8rem;
}
.sidebar-card .blog-search-btn{
    width:100%;
    justify-content:center;
    margin-top:.4rem;
    border-radius:var(--radius-sm);
}

/* 5 uusinta */
.sidebar-posts{
    list-style:none;
    padding:0;
    margin:0;
    display:flex;
    flex-direction:column;
    gap:.8rem;
}
.sidebar-post-link{
    display:flex;
    gap:.8rem;
    align-items:center;
    color:var(--ink);
    text-decoration:none;
    padding:.4rem;
    border-radius:var(--radius-sm);
    transition:background var(--t), transform var(--t);
}
.sidebar-post-link:hover{
    background:var(--blue-50);
    transform:translateX(2px);
    color:var(--ink);
}
.sidebar-post-media{
    width:64px; height:64px;
    flex-shrink:0;
    border-radius:10px;
    overflow:hidden;
    background:linear-gradient(135deg, var(--blue-100), var(--blue-50));
}
.sidebar-post-media img{
    width:100%; height:100%; object-fit:cover;
}
.sidebar-post-placeholder{
    width:100%; height:100%;
    display:grid; place-items:center;
    font-size:1.6rem;
    background:var(--grad);
}
.sidebar-post-text{
    flex:1;
    min-width:0;
    display:flex;
    flex-direction:column;
    gap:.2rem;
}
.sidebar-post-text strong{
    font-size:.9rem;
    line-height:1.35;
    color:var(--ink);
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}
.sidebar-post-link:hover .sidebar-post-text strong{ color:var(--blue-700); }
.sidebar-post-meta{
    color:var(--ink-mute);
    font-size:.75rem;
}
.sidebar-empty{
    color:var(--ink-mute);
    font-size:.88rem;
    margin:0;
    text-align:center;
    padding:1rem 0;
}

/* Sidebar CTA */
.sidebar-cta{
    background:linear-gradient(135deg, #06b6d4 0%, #22d3ee 60%, #4BFFFF 100%);
    border:none;
    color:#fff;
    position:relative;
    overflow:hidden;
}
.sidebar-cta::before{
    content:'';
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(to right, rgba(255,255,255,.08) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255,255,255,.08) 1px, transparent 1px);
    background-size:24px 24px;
    mask-image:radial-gradient(ellipse at top right, black, transparent 70%);
    -webkit-mask-image:radial-gradient(ellipse at top right, black, transparent 70%);
    pointer-events:none;
}
.sidebar-cta h3{
    color:#fff;
    margin:0 0 .5rem;
    font-size:1.1rem;
    position:relative;
}
.sidebar-cta p{
    color:rgba(255,255,255,.92);
    font-size:.9rem;
    margin:0 0 1rem;
    position:relative;
}
.sidebar-cta .btn{
    position:relative;
    background:#fff;
    color:var(--blue-600);
    box-shadow:0 6px 16px rgba(0,0,0,.15);
}
.sidebar-cta .btn:hover{
    background:#fff;
    color:var(--blue-700);
    transform:translateY(-2px);
    box-shadow:0 10px 24px rgba(0,0,0,.2);
}

/* ============================================================
   AIHEESEEN LIITTYVÄT POSTAUKSET
   ============================================================ */
.single-related-wrap{ margin:4rem auto 2rem; }
.single-related-title{
    font-size:clamp(1.4rem, 2.5vw, 2rem);
    margin:0 0 1.6rem;
    text-align:center;
}
.single-related-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:1.5rem;
}
.related-card{
    background:#fff;
    border-radius:var(--radius-lg);
    overflow:hidden;
    border:1px solid var(--line-soft);
    box-shadow:0 2px 10px rgba(10,25,41,.04);
    color:inherit;
    transition:all var(--t);
}
.related-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow);
    border-color:var(--blue-200);
    color:inherit;
}
.related-card-media{
    aspect-ratio:16/10;
    overflow:hidden;
    background:linear-gradient(135deg, var(--blue-50), var(--blue-100));
}
.related-card-media img{
    width:100%; height:100%; object-fit:cover;
    transition:transform .6s ease;
}
.related-card:hover .related-card-media img{ transform:scale(1.06); }
.related-card-placeholder{
    width:100%; height:100%;
    display:grid; place-items:center;
    font-size:2.4rem;
    background:var(--grad);
    color:#fff;
}
.related-card-body{
    padding:1.1rem 1.2rem 1.3rem;
}
.related-card-date{
    color:var(--ink-mute);
    font-size:.78rem;
}
.related-card-body h3{
    font-size:1rem;
    margin:.3rem 0 0;
    line-height:1.35;
    color:var(--ink);
}

/* ============================================================
   NÄYTTÄVÄ MOBIILI-VALIKKOKORTTI (hamburger card)
   ============================================================ */

/* OLETUS: täysin piilossa kaikilla näytöillä (display:none).
   Mobiilissa @media-säännöllä aktivoidaan vain kun body.menu-open. */
.mobile-menu-backdrop,
.mobile-menu-card{
    display:none !important;
}

/* ── Mobiili: kortti renderöidään VAIN kun valikko on auki ── */
@media (max-width: 820px){
    body.menu-open .mobile-menu-backdrop{
        display:block !important;
        position:fixed;
        inset:0;
        background:rgba(10,25,41,.55);
        z-index:80;
        animation:menuBackdropIn .3s ease forwards;
        /* Estä sormella tausta-vieritys backdrop:in läpi (mobiilissa) */
        touch-action:none;
        -ms-touch-action:none;
    }
    @keyframes menuBackdropIn{
        from{ opacity:0; }
        to  { opacity:1; }
    }

    body.menu-open .mobile-menu-card{
        display:flex !important;
        flex-direction:column;
        position:fixed;
        top:0; right:0;
        width:min(400px, 92vw);
        height:100vh;
        height:100dvh;
        z-index:90;
        background:#ffffff;
        box-shadow:-20px 0 60px rgba(10,25,41,.22), -8px 0 18px rgba(6,182,212,.18);
        border-left:1px solid var(--line);
        overflow:hidden;
        animation:menuCardIn .4s cubic-bezier(.2,.7,.2,1) forwards;
    }
    @keyframes menuCardIn{
        from{ transform:translateX(100%); }
        to  { transform:translateX(0); }
    }
}

/* Koristeelliset orbit taustalla */
.mobile-menu-orbs{
    position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden;
}
.mobile-menu-orb{
    position:absolute; border-radius:50%; filter:blur(60px); opacity:.4;
}
.mobile-menu-orb-1{
    width:240px; height:240px;
    background:#4BFFFF;
    top:-80px; right:-70px;
}
.mobile-menu-orb-2{
    width:180px; height:180px;
    background:#06b6d4;
    bottom:-50px; left:-60px;
    opacity:.28;
}

/* Kaikki kortin sisältö orbien yläpuolelle */
.mobile-menu-card-head,
.mobile-menu-greeting,
.mobile-menu-nav,
.mobile-menu-cta{
    position:relative;
    z-index:1;
}

/* ── Head (brand + close) ────────────────────────────────── */
.mobile-menu-card-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.8rem;
    padding:1.1rem 1.3rem;
    border-bottom:1px solid var(--line-soft);
    background:linear-gradient(135deg, rgba(236,254,255,.85), rgba(255,255,255,.4));
    flex-shrink:0;
}
.mobile-menu-card-head .brand{
    font-size:1.1rem;
}
.mobile-menu-card-head .brand-mark{
    width:34px; height:34px;
}
.mobile-menu-close{
    flex-shrink:0;
    width:38px; height:38px;
    border:1.5px solid var(--line);
    background:#fff;
    border-radius:50%;
    color:var(--ink-soft);
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    transition:transform var(--t), background var(--t), color var(--t), border-color var(--t), box-shadow var(--t);
}
.mobile-menu-close:hover,
.mobile-menu-close:focus-visible{
    border-color:var(--blue-500);
    color:var(--blue-600);
    transform:rotate(90deg);
    box-shadow:0 4px 12px rgba(6,182,212,.18);
    outline:none;
}

/* ── Greeting ────────────────────────────────────────────── */
.mobile-menu-greeting{
    padding:.9rem 1.3rem .4rem;
    flex-shrink:0;
}
.mobile-menu-greeting-eyebrow{
    display:inline-flex; align-items:center; gap:.4rem;
    font-size:.72rem; font-weight:700; letter-spacing:.1em;
    color:var(--blue-600); text-transform:uppercase;
    padding:.25rem .6rem;
    background:var(--blue-50);
    border:1px solid var(--blue-100);
    border-radius:999px;
    margin-bottom:.5rem;
}
.mobile-menu-greeting-dot{
    width:6px; height:6px; border-radius:50%;
    background:var(--blue-500);
    box-shadow:0 0 0 3px rgba(6,182,212,.18);
    animation:menuDotPulse 2s ease-in-out infinite;
}
@keyframes menuDotPulse{
    0%,100%{ box-shadow:0 0 0 3px rgba(6,182,212,.18); }
    50%{ box-shadow:0 0 0 6px rgba(6,182,212,.06); }
}
.mobile-menu-greeting-text{
    margin:0;
    font-family:'Space Grotesk','Inter',sans-serif;
    font-size:1.05rem; font-weight:700; color:var(--ink);
    letter-spacing:-.01em;
}

/* ── Nav-links ───────────────────────────────────────────── */
.mobile-menu-nav{
    flex:1 1 auto;
    min-height:0;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    padding:.4rem 1rem 1rem;
    display:flex;
    flex-direction:column;
    gap:.45rem;
}
.mobile-menu-link{
    display:flex;
    align-items:center;
    gap:.85rem;
    padding:.78rem .95rem;
    background:#fff;
    border:1.5px solid var(--line-soft);
    border-radius:14px;
    color:var(--ink);
    text-decoration:none;
    transition:transform var(--t), border-color var(--t), background var(--t), box-shadow var(--t);
    position:relative;
    overflow:hidden;
}
.mobile-menu-link::before{
    content:'';
    position:absolute; left:0; top:0; bottom:0; width:3px;
    background:var(--grad);
    transform:scaleY(0);
    transform-origin:center;
    transition:transform var(--t);
    border-radius:0 3px 3px 0;
}
.mobile-menu-link:hover,
.mobile-menu-link:active,
.mobile-menu-link:focus-visible{
    border-color:var(--blue-300);
    background:linear-gradient(135deg, var(--blue-50), #fff 60%);
    transform:translateX(2px);
    box-shadow:0 6px 16px rgba(6,182,212,.12);
    color:var(--ink);
    outline:none;
}
.mobile-menu-link:hover::before,
.mobile-menu-link:focus-visible::before{
    transform:scaleY(1);
}

/* Stagger-animation kun valikko avautuu (linkit OVAT näkyvissä oletuksena;
   tämä on vain "kerros päälle" -tehoste eikä rikkoudu jos jää pelaamatta) */
body.menu-open .mobile-menu-link{
    animation:menuItemIn .45s cubic-bezier(.2,.7,.2,1) both;
}
body.menu-open .mobile-menu-link:nth-child(1){ animation-delay:.08s; }
body.menu-open .mobile-menu-link:nth-child(2){ animation-delay:.12s; }
body.menu-open .mobile-menu-link:nth-child(3){ animation-delay:.16s; }
body.menu-open .mobile-menu-link:nth-child(4){ animation-delay:.20s; }
body.menu-open .mobile-menu-link:nth-child(5){ animation-delay:.24s; }
body.menu-open .mobile-menu-link:nth-child(6){ animation-delay:.28s; }
@keyframes menuItemIn{
    from{ opacity:0; transform:translateX(24px); }
    to  { opacity:1; transform:translateX(0); }
}

/* Ikoni-chip (gradient eri varianttien mukaan) */
.mobile-menu-icon{
    flex-shrink:0;
    width:44px; height:44px;
    display:grid; place-items:center;
    font-size:1.4rem;
    background:linear-gradient(135deg, var(--blue-50), var(--blue-100));
    border:1px solid var(--blue-100);
    border-radius:13px;
    transition:transform var(--t), box-shadow var(--t);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
}
.mobile-menu-link:hover .mobile-menu-icon{
    transform:scale(1.08) rotate(-4deg);
    box-shadow:0 4px 10px rgba(6,182,212,.18), inset 0 1px 0 rgba(255,255,255,.7);
}
/* Värivariantit per linkki */
.mobile-menu-link[data-color="cyan"] .mobile-menu-icon{
    background:linear-gradient(135deg, #ecfeff, #cffafe);
    border-color:#a5f3fc;
}
.mobile-menu-link[data-color="violet"] .mobile-menu-icon{
    background:linear-gradient(135deg, #f5f3ff, #ede9fe);
    border-color:#ddd6fe;
}
.mobile-menu-link[data-color="amber"] .mobile-menu-icon{
    background:linear-gradient(135deg, #fffbeb, #fef3c7);
    border-color:#fde68a;
}
.mobile-menu-link[data-color="emerald"] .mobile-menu-icon{
    background:linear-gradient(135deg, #ecfdf5, #d1fae5);
    border-color:#a7f3d0;
}
.mobile-menu-link[data-color="rose"] .mobile-menu-icon{
    background:linear-gradient(135deg, #fff1f2, #ffe4e6);
    border-color:#fecdd3;
}
.mobile-menu-link[data-color="sky"] .mobile-menu-icon{
    background:linear-gradient(135deg, #f0f9ff, #e0f2fe);
    border-color:#bae6fd;
}

.mobile-menu-label{
    flex:1;
    display:flex;
    flex-direction:column;
    line-height:1.25;
    min-width:0;
}
.mobile-menu-label strong{
    font-family:'Space Grotesk','Inter',sans-serif;
    font-size:.98rem;
    font-weight:600;
    color:var(--ink);
    letter-spacing:-.005em;
}
.mobile-menu-label small{
    font-size:.78rem;
    color:var(--ink-mute);
    line-height:1.3;
    margin-top:2px;
}

.mobile-menu-arrow{
    flex-shrink:0;
    color:var(--blue-500);
    display:inline-flex; align-items:center; justify-content:center;
    transition:transform var(--t), color var(--t);
    opacity:.7;
}
.mobile-menu-link:hover .mobile-menu-arrow{
    transform:translateX(5px);
    color:var(--blue-600);
    opacity:1;
}

/* ── CTA-osa alalaidassa ─────────────────────────────────── */
.mobile-menu-cta{
    padding:1rem 1.2rem 1.3rem;
    border-top:1px solid var(--line-soft);
    background:linear-gradient(180deg, transparent, rgba(236,254,255,.6));
    display:flex;
    flex-direction:column;
    gap:.55rem;
    flex-shrink:0;
}
.mobile-menu-cta-btn{
    justify-content:center;
}
.mobile-menu-promise{
    text-align:center;
    margin:.5rem 0 0;
    font-size:.78rem;
    color:var(--ink-mute);
    line-height:1.4;
    display:flex; align-items:center; justify-content:center; gap:.35rem;
    flex-wrap:wrap;
}
.mobile-menu-promise > span:first-child{
    width:14px; height:14px;
    background:var(--blue-500);
    color:#fff;
    border-radius:50%;
    display:inline-flex; align-items:center; justify-content:center;
    font-size:.6rem; font-weight:700;
    flex-shrink:0;
}

/* ============================================================
   BLOGIN RESPONSIIVISUUS
   ============================================================ */
@media (max-width:980px){
    .blog-hero{ padding:3.5rem 0 2rem; }
    .blog-hero-inner{ grid-template-columns:1fr; gap:2rem; }
    .blog-hero-stats{ grid-template-columns:repeat(3,1fr); }
    .blog-grid{ grid-template-columns:repeat(2,1fr); gap:1.4rem; }
    .blog-featured-card{ grid-template-columns:1fr; }
    .blog-featured-body{ padding:1.5rem 1.6rem 1.8rem; }
    .single-grid{ grid-template-columns:1fr; gap:2rem; }
    .single-sidebar-sticky{
        position:static;
        max-height:none;
        overflow:visible;
    }
    .single-related-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:720px){
    .blog-hero{ padding:2.5rem 0 1.5rem; }
    .blog-hero-content h1{ font-size:1.85rem; }
    .blog-hero-lead{ font-size:1rem; }
    .blog-hero-stats{ grid-template-columns:1fr; gap:.7rem; }
    .blog-stat{ padding:1rem 1.1rem; }
    .blog-stat strong{ font-size:1.5rem; }

    .blog-search{
        padding:5px;
        border-radius:18px;
        flex-direction:column;
    }
    .blog-search-label{ padding:.4rem .9rem; }
    .blog-search-input{ padding:.7rem .2rem; font-size:.95rem; }
    .blog-search-btn{ width:100%; justify-content:center; border-radius:14px; padding:.85rem 1rem; }

    .blog-tags-row{ gap:.4rem; }
    .blog-tag-chip{ font-size:.8rem; padding:.3rem .7rem; }

    .blog-featured-body{ padding:1.3rem 1.3rem 1.5rem; }
    .blog-featured-title{ font-size:1.3rem; }

    .blog-grid{ grid-template-columns:1fr; gap:1.2rem; }
    .blog-grid-head h2{ font-size:1.5rem; }

    .single-hero{ padding:2rem 0 1.5rem; }
    .single-title{ font-size:1.8rem; }
    .single-lead{ font-size:1.05rem; }
    .single-featured-img{ border-radius:var(--radius-lg); }
    .single-prose{ font-size:1rem; line-height:1.7; }
    .single-prose h2{ font-size:1.35rem; }
    .single-prose h3{ font-size:1.15rem; }
    .single-nav{ grid-template-columns:1fr; }
    .single-share{ padding:1rem; gap:.5rem; }
    .single-share-label{ flex:1 1 100%; margin-right:0; margin-bottom:.3rem; }
    .single-share-btn{ width:38px; height:38px; }

    .single-related-grid{ grid-template-columns:1fr; }

    .sidebar-card{ padding:1.1rem 1.2rem; }
    .sidebar-post-media{ width:54px; height:54px; }
    .sidebar-post-text strong{ font-size:.86rem; }
}
@media (max-width:480px){
    .mobile-menu-card{ width:100vw; }
    .mobile-menu-link{ padding:.75rem .85rem; gap:.7rem; }
    .mobile-menu-icon{ width:40px; height:40px; font-size:1.25rem; }
    .mobile-menu-label strong{ font-size:.95rem; }
    .mobile-menu-label small{ font-size:.76rem; }
    .mobile-menu-card-head{ padding:1rem 1.1rem; }
    .mobile-menu-greeting{ padding:.7rem 1.1rem .3rem; }
    .mobile-menu-nav{ padding:.3rem .9rem .9rem; }
    .mobile-menu-cta{ padding:.9rem 1.1rem 1.1rem; }
}

/* ---------- reveal animation ---------- */
.reveal{
    opacity:0; transform:translateY(24px);
    transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1);
}
.reveal.in{ opacity:1; transform:none; }

/* ---------- responsive ---------- */
@media (max-width: 980px){
    .hero{ padding:4rem 0 2rem; }
    .hero-grid{ grid-template-columns:1fr; gap:3rem; }
    .hero-visual{ min-height:380px; max-width:480px; margin:0 auto; }
    .features-grid{ grid-template-columns:repeat(2,1fr); }
    .services-grid{ grid-template-columns:repeat(2,1fr); }
    .pricing-grid{ grid-template-columns:1fr; }
    .process-grid{ grid-template-columns:repeat(2,1fr); }
    .about-grid{ grid-template-columns:1fr; gap:2.5rem; }
    .cta-card{ grid-template-columns:1fr; padding:2rem; }
    .footer-grid{ grid-template-columns:1fr 1fr; }
    .legal-toc ol{ columns:1; }
}
@media (max-width: 820px){
    .primary-nav,.hide-mobile{ display:none; }
    .nav-toggle{ display:flex; }
}
@media (max-width: 720px){
    .hero-bullets{ grid-template-columns:1fr; }
    .features-grid{ grid-template-columns:1fr; }
    .services-grid{ grid-template-columns:1fr 1fr; }
    .process-grid{ grid-template-columns:1fr; }
    .footer-grid{ grid-template-columns:1fr; }
    .section{ padding:4rem 0; }
    .legal-article{ padding:1.5rem; }
}
@media (prefers-reduced-motion: reduce){
    *,*::before,*::after{ animation:none !important; transition:none !important; }
    .reveal{ opacity:1; transform:none; }
}
