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

/* CSS RESET (modern minimal) */
*,*::before,*::after{box-sizing:border-box}
body,h1,h2,h3,h4,h5,p,figure,blockquote,dl,dd{margin:0}
ul[role='list'],ol[role='list']{list-style:none}
html:focus-within{scroll-behavior:smooth}
body{min-height:100vh;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;line-height:1.5}
img,picture{max-width:100%;display:block}
input,button,textarea,select{font:inherit}
a{text-decoration:none;color:inherit}

:root {
    --font-sans: 'Inter', 'Montserrat', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
    --font-accent: 'Montserrat', var(--font-sans);
    /* Base greens & neutrals (brand update) */
    --clr-bg: #ffffff;
    --clr-bg-alt: #E8f5e9; /* light mint/green background */
    --clr-surface: #ffffff;
    --clr-surface-alt: #f4faf5; /* softer surface tint */
    --clr-border: #d5eada;
    --clr-border-strong: #b7d7bb;
    --clr-text: #424242; /* provided font color */
    --clr-text-dim: #5d5d5d;
    --clr-primary: #2E7D32; /* deep green */
    --clr-primary-accent: #4CAF50; /* mid green accent */
    --clr-primary-rgb: 46,125,50;
    --clr-accent: #4CAF50; /* reuse accent */
    --clr-warn: #f59e0b;
    --clr-danger: #dc2626;
    --radius-sm: .4rem;
    --radius: .8rem;
    --radius-lg: 1.4rem;
    --shadow-sm: 0 2px 4px rgba(0,0,0,.04),0 1px 2px rgba(0,0,0,.06);
    --shadow: 0 4px 16px -2px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);
    --shadow-lg: 0 20px 48px -12px rgba(0,0,0,.18);
    --container-max: 1180px;
    --space-xs:.4rem;--space-sm:.75rem;--space:.95rem;--space-md:1.5rem;--space-lg:2.4rem;--space-xl:3.5rem;--space-2xl:5.5rem;
    --grad-primary: linear-gradient(120deg,#2E7D32,#4CAF50 55%,#2E7D32);
    --grad-soft: linear-gradient(145deg,#E8f5e9,#ffffff);
}

html, body {font-family: var(--font-sans); background: var(--clr-bg); color: var(--clr-text);}
body {display:flex;flex-direction:column;}

/* Utilities */
.container {width:100%;max-width: var(--container-max);margin-inline:auto;padding-inline: clamp(1rem,2vw,2rem);} 
.flex{display:flex}.between{justify-content:space-between}.center-v{align-items:center}.wrap{flex-wrap:wrap}
.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));align-items:start}
.grid-2.center-v{align-items:center}
@media (max-width:900px){
    .swap-mobile{display:flex;flex-direction:column}
    .swap-mobile > .stack:first-of-type{order:1}
    .swap-mobile > .media-frame:first-of-type{order:2}
}
.gap-xl{gap:var(--space-xl)}
.stack>*,.stack-sm>*,.hero-text>*{margin:0}
.stack>*+*{margin-top:var(--space-md)}
.stack-sm>*+*{margin-top:var(--space-sm)}
.hero-text>*+*{margin-top:var(--space-md)}
.center-text{text-align:center}
.text-sm{font-size:.85rem;line-height:1.4}
.accent{background:linear-gradient(90deg,#2E7D32,#4CAF50);-webkit-background-clip:text;background-clip:text;color:transparent}
.ratio-3-4{aspect-ratio:3/4}
.ratio-16-10{aspect-ratio:16/10}
.rounded-lg{border-radius:var(--radius-lg)}
.shadow-sm{box-shadow:var(--shadow-sm)}
.plain{list-style:none;margin:0;padding:0}
.checklist{list-style:none;padding-left:0;margin:0}
.checklist li{position:relative;padding-left:1.6rem;margin:.4rem 0}
.checklist li:before{content:"";position:absolute;left:0;top:.4rem;width:.9rem;height:.9rem;border-radius:50%;background:var(--grad-primary);box-shadow:0 0 0 3px rgba(var(--clr-primary-rgb),.22)}

/* Header / Nav */
.site-header{position:sticky;top:0;background:linear-gradient(90deg,var(--clr-primary) 0%,var(--clr-primary-accent) 70%);color:#fff;z-index:50;box-shadow:0 4px 16px -6px rgba(0,0,0,.25);padding-block:.35rem}
.site-header a{color:#fff}
.brand{font-family:var(--font-accent);font-weight:700;font-size:1.25rem;letter-spacing:.18em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.6rem;line-height:1}
.brand .logo{display:block;height:80px;width:auto;max-width:260px}
@media (max-width:600px){.brand .logo{height:60px}}
.brand.small{font-size:.95rem;letter-spacing:.15em}
.primary-nav{position:relative}
.nav-toggle{display:none;background:none;border:0;padding:.6rem;cursor:pointer}
.nav-toggle span{display:block;width:26px;height:3px;background:#fff;margin:5px 0;border-radius:2px;transition:.4s}
.nav-list{display:flex;gap:1.2rem;align-items:center;margin:0;padding:0;list-style:none}
.nav-list a{display:inline-block;padding:.45rem .9rem;border-radius:var(--radius-sm);font-weight:600;font-size:1rem;line-height:1.2;color:rgba(255,255,255,.9);transition:.25s}
.nav-list a:hover,.nav-list a:focus{color:#fff;background:rgba(255,255,255,.18)}
.nav-list a.active{color:#fff;background:rgba(255,255,255,.25);font-weight:600}
.has-sub{position:relative}
.has-sub>.sub-toggle{display:none}
.sub-menu{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--clr-border);padding:.4rem;display:none;flex-direction:column;min-width:220px;border-radius:var(--radius);box-shadow:var(--shadow)}
.has-sub:hover .sub-menu{display:flex}
.sub-menu a{padding:.55rem .75rem;font-size:.85rem;border-radius:var(--radius-sm);color:var(--clr-text)}
.sub-menu a:hover{background:var(--clr-surface-alt);color:var(--clr-text)}

/* Hero */
.hero{padding-block:clamp(3rem,8vw,5.5rem)}
.hero-title{font-size:clamp(2.2rem,4.6vw,3.4rem);line-height:1.1;font-family:var(--font-accent);font-weight:700;letter-spacing:-.02em}
.lead{font-size:clamp(1.05rem,1.15vw + .7rem,1.3rem);color:var(--clr-text-dim);max-width:58ch}
.badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:var(--space-md);padding:0}
.badges li{list-style:none;background:var(--clr-bg-alt);padding:.45rem .75rem;font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border-radius:2rem;color:var(--clr-primary)}
.hero-media{position:relative}
.media-frame{overflow:hidden;position:relative;background:var(--grad-soft)}
.media-frame img{width:100%;height:100%;object-fit:cover;display:block}
.media-frame.ratio-16-10 img{object-position:center center}
/* Front page hero image 20% smaller */
body[data-page="home"] .hero .hero-media .media-frame{max-width:80%;margin-inline:auto}
/* Mobile hero reorder: image between badges and motivation boxes */
@media (max-width:900px){
    .hero.container{display:flex;flex-direction:column}
    .hero .hero-text{order:1}
    .hero .hero-text .badges{order:unset}
    .hero .hero-media{order:2;margin-top:1.4rem}
    .hero .motivation-boxes{order:3;margin-top:1.6rem}
}

/* Expert page specific (20% larger than previous 308px / 346px) */
.expert-photo{max-width:370px;width:100%;}
@media (min-width:900px){.expert-photo{max-width:416px}}

/* Cards */
.strip{padding:var(--space-2xl) 0}
.highlight{background:var(--grad-soft);border-top:1px solid var(--clr-border);border-bottom:1px solid var(--clr-border)}
.trio{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:var(--space-lg)}
.card{background:var(--clr-surface);padding:var(--space-lg);border:1px solid var(--clr-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.6rem}
.card.small{padding:var(--space-md)}
.card h3{font-size:1.1rem;line-height:1.2}
.card p{font-size:.9rem;color:var(--clr-text-dim)}

/* Numbered reasons badges */
.reasons-numbered .reason{position:relative;padding-top:calc(var(--space-md) + .85rem)}
.reason-num{position:absolute;top:var(--space-md);left:var(--space-md);width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;font-family:var(--font-accent);background:linear-gradient(135deg,var(--clr-primary) 0%,var(--clr-primary-accent) 90%);color:#fff;box-shadow:0 2px 6px -2px rgba(0,0,0,.25)}
/* Smaller font for reasons headings */
/* Slightly lowered heading text under number badge (font-size reduced) */
.reasons-numbered .reason h3{margin-top:.45rem;padding-left:calc(38px + var(--space-md) + .4rem);font-size:.92rem;line-height:1.22;position:relative;top:.2rem}
@media (max-width:600px){
    .reason-num{width:32px;height:32px;font-size:.85rem}
    /* Mobile: font-size slightly reduced */
    .reasons-numbered .reason h3{padding-left:calc(32px + var(--space-md) + .35rem);font-size:.86rem;margin-top:.4rem;line-height:1.22;top:.17rem}
}
/* Reasons split layout */
.reasons-split .reasons-left{align-self:start}
.reasons-split .reasons-image{align-self:stretch;display:flex;align-items:center;justify-content:center}
.reasons-split .reasons-image .media-frame{width:100%;max-width:520px}
@media (max-width:900px){
    .reasons-split{grid-template-columns:1fr}
    .reasons-split .reasons-image{margin-top:2rem}
}
@media (min-width:901px){
    .reasons-split .reasons-image{margin-top:3.2rem}
}
/* Vertical reasons layout */
.reasons-vertical{display:flex;flex-direction:column;gap:1.1rem;max-width:520px}
.reasons-vertical .reason{padding:calc(var(--space-md) + .4rem) var(--space-md) var(--space-md) var(--space-md);min-height:86px;display:flex;align-items:center;gap:1rem}
.reasons-vertical .reason h3{flex:1;margin:0;font-size:1.05rem;padding:0;text-align:left}
.reasons-section{padding-top:clamp(2.2rem,5vw,3rem);padding-bottom:clamp(2.2rem,5vw,3rem)}
@media (max-width:600px){
    .reasons-vertical .reason{gap:.85rem}
}
.reasons-section{padding-top:clamp(2.2rem,5vw,3rem);padding-bottom:clamp(2.2rem,5vw,3rem)}

/* Motivation boxes under hero (updated: removed left line) */
.motivation-boxes .card{position:relative;border:1px solid var(--clr-border);background:#ffffff;padding:var(--space-md);display:flex;justify-content:center;align-items:center;text-align:center;min-height:150px}
.motivation-boxes .card:before{display:none}
.motivation-boxes p{margin:0;font-size:.82rem;line-height:1.45;color:var(--clr-text);text-align:center}
.motivation-boxes strong{font-weight:600;color:var(--clr-text-dim)}
/* Uniform row of three motivation boxes (text already centered) */
/* Shift the third box ~5cm to the right on wide screens (approx visual centering) */
/* Removed special centering of third motivation box; all three align equally now */
@media (min-width:900px){
    /* Arrange first two motivation boxes side-by-side and center the third beneath them spanning full width */
    .motivation-boxes{display:grid;grid-template-columns:repeat(2,minmax(200px,1fr));justify-content:center;align-items:start;gap:var(--space-lg);}
    .motivation-boxes > .card:nth-child(3){grid-column:1 / span 2;justify-self:center;}
}

/* CTA */
.cta{padding:clamp(3rem,6vw,4rem) 0;text-align:center}
.cta.gradient{background:var(--grad-primary);color:#fff}
.cta .btn{--btn-bg:#fff;--btn-color:var(--clr-primary)}
/* Smaller variant for compact gradient sections */
.cta.cta-sm{padding:2rem 0}

/* Qualifications section (expert page) - remove custom bullets */
.qualifications .checklist li{padding-left:0;margin:.35rem 0}
.qualifications .checklist li:before{display:none}
/* Contact callout box on expert page */
.contact-box{margin-top:3rem;margin-bottom:2rem;background:linear-gradient(135deg,var(--clr-primary) 0%,var(--clr-primary-accent) 90%);padding:1.25rem 1.55rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;max-width:340px;margin-inline:auto;text-align:center}
.contact-box:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,rgba(255,255,255,.25),transparent 60%);mix-blend-mode:overlay;pointer-events:none}
.contact-box-link{display:inline-flex;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#fff;font-size:.95rem}
.contact-box-link:hover,.contact-box-link:focus{text-decoration:underline}
/* Contact page two-column layout adjustments */
/* Enlarge Yhteystiedot (contact) section: wider text column and slightly wider media */
/* Photo column increased from 1fr to 1.5fr (~20%+ more space relative to text) */
body[data-page="contact"] .contact-layout{grid-template-columns:minmax(480px,1.4fr) minmax(340px,1.5fr);align-items:start}
/* Maksutavat section spacing & heading size to match Yhteystiedot */
/* Contact page inline Maksutavat spacing tweaks */
body[data-page="contact"] .contact-details h2{margin-bottom:.35rem}
body[data-page="contact"] .contact-details ul{margin-top:.5rem}
body[data-page="contact"] .contact-details ul + h2{margin-top:1.7rem}
/* Slight extra space before Maksutavat heading */
body[data-page="contact"] .contact-details ul + h2 + ul{margin-top:.85rem}
/* Icon list styling for main contact details */
body[data-page="contact"] .contact-list-enhanced{list-style:none;padding:0;margin:0 0 .75rem;display:flex;flex-direction:column;gap:.55rem}
body[data-page="contact"] .contact-list-enhanced li{display:flex;align-items:flex-start;gap:.55rem;line-height:1.45}
body[data-page="contact"] .contact-list-enhanced li .icon{font-size:1.05rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;margin-top:.15rem}
body[data-page="contact"] .contact-list-enhanced a{color:var(--clr-text);font-weight:600;text-decoration:none;position:relative}
body[data-page="contact"] .contact-list-enhanced a:after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:linear-gradient(90deg,var(--clr-primary),var(--clr-primary-accent));transition:.35s}
body[data-page="contact"] .contact-list-enhanced a:hover:after,body[data-page="contact"] .contact-list-enhanced a:focus:after{width:100%}
/* Adjust features list when reused in contact details for Maksutavat */
body[data-page="contact"] .payment-methods-list.features li{font-size:.85rem;color:var(--clr-text)}
/* Darker text color for contact detail lists */
body[data-page="contact"] .contact-list-enhanced li{color:var(--clr-text)}
body[data-page="contact"] .contact-list-enhanced li strong,
body[data-page="contact"] .contact-list-enhanced li em{color:var(--clr-text)}
/* Unbold labels for Puhelin / Sähköposti / Osoite */
body[data-page="contact"] .contact-list-enhanced li strong{font-weight:500}
body[data-page="contact"] .contact-layout .contact-image,
body[data-page="contact"] .contact-layout .contact-image .media-frame{max-width:100%;margin-left:0}
body[data-page="contact"] .contact-layout .contact-details{padding-right:1rem}
/* Smaller headings for Yhteystiedot & Maksutavat */
body[data-page="contact"] .contact-layout .contact-details h2{font-size:clamp(1.55rem,2.2vw,1.95rem);font-weight:700}
body[data-page="contact"] .contact-layout .contact-details ul{margin-top:.8rem}
@media (max-width:900px){
    body[data-page="contact"] .contact-layout{grid-template-columns:1fr}
    body[data-page="contact"] .contact-layout .contact-image{order:2;margin-top:1.5rem}
    body[data-page="contact"] .contact-layout .contact-details h2{font-size:clamp(2rem,6vw,2.4rem)}
}

/* Expert name highlight */
.expert-name{font-size:clamp(2.4rem,4vw,3rem);line-height:1.05;position:relative;font-family:var(--font-accent);font-weight:700;letter-spacing:-.01em}
.expert-name:after{content:"";position:absolute;left:0;bottom:.15em;width:100%;height:.35em;background:linear-gradient(90deg,rgba(var(--clr-primary-rgb),.22),rgba(var(--clr-primary-rgb),.05));border-radius:.25em;z-index:-1}

/* Simple sub-page hero band */
.sub-hero{padding:2rem 0 1.2rem}
.sub-hero + section{padding-top:1.6rem !important}
.sub-hero-text{margin:.75rem 0 0;max-width:60ch;font-size:.95rem;line-height:1.45;color:var(--clr-text-dim)}
.sub-hero h1{margin:0;font-family:var(--font-accent);font-weight:700;font-size:clamp(2.4rem,4.2vw,3.1rem);line-height:1.04;letter-spacing:-.018em;color:var(--clr-text);position:relative;display:inline-block;padding-bottom:.65rem}
.sub-hero h1:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:4px;border-radius:2px;background:linear-gradient(90deg,var(--clr-primary) 0%,var(--clr-primary-accent) 100%)}
.sub-hero ~ section h2{color:var(--clr-primary)}
.cta.gradient h2{color:#fff}
/* Larger section title variant on services page */
.section-title-lg{font-size:clamp(2rem,3.4vw,2.6rem);line-height:1.06;font-family:var(--font-accent);letter-spacing:-.012em;margin-bottom:.55rem}
/* Specific adjustments for fysioterapia section now without checklist */
.services-fysioterapia .stack p + p{margin-top:1rem}
/* Tighten vertical gap after first services section */
.services-fysioterapia{padding-bottom:var(--space-xl)}
.services-fysioterapia + section{padding-top:var(--space-lg)}
/* Tighten gap between coaching description and examples */
.coaching-section{padding-bottom:var(--space-xl)}
.coaching-section + .coaching-examples{padding-top:var(--space-lg)}
/* Tighten gap between group coaching sections */
.group-coaching{padding-bottom:var(--space-xl)}
.group-coaching + .group-coaching-examples{padding-top:var(--space-lg)}
@media (min-width:900px){
    /* Raise/lower fysioterapia section image relative to h3; adjust value if still off */
    .services-fysioterapia .media-frame{margin-top:2.8rem}
    /* Adjust coaching section image vertical position */
        .coaching-section .media-frame{margin-top:calc(3.4rem + 3cm)}
}
/* Expert biography text spacing */
body[data-page="expert"] .grid-2 .stack p{line-height:1.65}
body[data-page="expert"] .grid-2 .stack p+p{margin-top:1.25rem}
/* Compact padding for biography section */
body[data-page="expert"] .bio-section{padding-top:2.2rem;padding-bottom:1.8rem}
/* Center the expert photo vertically relative to text */
body[data-page="expert"] .bio-section .expert-photo{align-self:center}
/* Values (Arvot) enhanced cards */
.values .trio{align-items:stretch}
.values .card{position:relative;overflow:hidden;transition:.45s cubic-bezier(.4,.2,.2,1);isolation:isolate;background:var(--clr-surface);box-shadow:0 3px 10px -6px rgba(0,0,0,.25),0 1px 3px rgba(0,0,0,.08);border-radius:14px;padding-top:clamp(1.1rem,1.2rem + .3vw,1.6rem)}
.values .card::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--clr-primary) 0%,var(--clr-primary-accent) 60%,#66bb6a 100%);box-shadow:0 0 0 1px rgba(255,255,255,.4);z-index:2}
.values .card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 120% -10%,rgba(var(--clr-primary-rgb),.18),transparent 60%);opacity:.65;pointer-events:none;transition:.5s}
.values .card:after{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--clr-primary) 0%,var(--clr-primary-accent) 60%,var(--clr-primary) 100%);opacity:.9}
.values .card:hover:before{transform:scale(1.2);opacity:.9}
.values .card:hover{transform:translateY(-8px);box-shadow:0 14px 34px -14px rgba(0,0,0,.55),0 6px 16px -8px rgba(46,125,50,.45)}
.values .card h3{font-size:1.05rem;margin-top:.15rem;letter-spacing:.01em}
/* Ensure reasons headings are smaller than generic .card h3 */
/* Final size enforcement after reductions above */
.reasons-numbered .reason h3{font-size:.86rem !important;line-height:1.18}
.values .card p{font-size:.85rem}
.values .card .value-icon{display:none}
.values .card:focus-within{outline:2px solid var(--clr-primary-accent);outline-offset:3px}
.values .card:active{transform:translateY(-2px)}
@media (prefers-reduced-motion:reduce){
    .values .card,.values .card:before{transition:none}
}

/* Buttons */
.btn{--btn-bg:var(--clr-primary);--btn-color:#fff;--btn-bg-hover:#256628;--btn-border:var(--btn-bg);cursor:pointer;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--btn-color);padding:.85rem 1.35rem;border-radius:var(--radius-sm);font-weight:600;font-size:.92rem;line-height:1;display:inline-flex;align-items:center;gap:.55rem;transition:.25s}
.btn:hover,.btn:focus{background:var(--btn-bg-hover)}
.btn-outline{--btn-bg:transparent;--btn-color:var(--clr-primary);--btn-border:var(--clr-primary);--btn-bg-hover:rgba(var(--clr-primary-rgb),.07)}
.btn-light{--btn-bg:#fff;--btn-color:var(--clr-primary);--btn-bg-hover:#f0fbf2;--btn-border:#fff}
.btn-sm{padding:.6rem .85rem;font-size:.8rem}

/* Links */
.link-arrow{display:inline-flex;align-items:center;font-weight:600;font-size:.9rem;color:var(--clr-primary);position:relative}
.link-arrow:after{content:"→";margin-left:.5ch;transition:.25s}
.link-arrow:hover:after{transform:translateX(4px)}

/* Footer */
.site-footer{margin-top:auto;background:var(--clr-bg-alt);border-top:1px solid var(--clr-border);padding-top:var(--space-lg)}
.footer-grid{display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));padding-bottom:var(--space-lg);align-items:start}
.footer-main{gap:var(--space-2xl)}
.footer-logo{display:block;height:70px;width:auto;margin-bottom:.7rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}
@media (max-width:650px){.footer-logo{height:60px}}
.sub-footer{background:#e2e8f0;padding: .9rem 0}

/* Footer symmetry adjustments (Option A + D) */
@media (min-width:700px){
    /* Force exactly two equal columns for consistent alignment */
    .footer-grid{grid-template-columns:1fr 1fr}
    .footer-grid p{max-width:42ch}
}
/* Wider screen refinement: give brand a constrained column and push contacts further right */
@media (min-width:1000px){
    .footer-grid{grid-template-columns:minmax(300px,420px) 1fr}
    .footer-grid > :nth-child(2){justify-self:end;text-align:right}
    .footer-grid > :nth-child(2) ul{display:inline-block;text-align:left}
}
@media (max-width:699px){
    /* Stack and center on small screens */
    .footer-grid{grid-template-columns:1fr;text-align:center}
    .footer-grid ul{margin-inline:auto}
    .footer-grid p{margin-inline:auto;max-width:48ch}
}

/* Page Layouts */
main{flex:1;}
section{padding-block:var(--space-2xl)}
section:first-of-type:not(.hero){padding-top:var(--space-xl)}
.page-hero{padding-block:clamp(3.2rem,8vw,5rem);background:var(--grad-soft);border-bottom:1px solid var(--clr-border)}
.breadcrumb{font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:var(--clr-text-dim);margin-bottom:1rem}

/* Pricing tables */
.pricing-grid{display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:stretch}
.price-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:.8rem;box-shadow:var(--shadow-sm);position:relative}
.price-card.highlight{border:1px solid var(--clr-primary);box-shadow:0 0 0 3px rgba(var(--clr-primary-rgb),.18);background:linear-gradient(180deg,#ffffff,#f3faf4)}
@media (min-width:900px){
    /* Constrain the lone Pienryhmävalmennus card width on desktop without affecting multi-card sections */
    #hyvinvointi .pricing-grid{justify-content:start}
    #hyvinvointi .pricing-grid .price-card{max-width:350px}
}
.price-tag{font-size:1.9rem;font-weight:700;font-family:var(--font-accent);line-height:1.1}
.price-period{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--clr-text-dim)}
.features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}
.features li{font-size:.8rem;padding-left:1.1rem;position:relative;color:var(--clr-text-dim)}
.features li:before{content:"";width:.55rem;height:.55rem;border-radius:50%;background:var(--clr-primary);position:absolute;left:0;top:.4rem}

/* Forms */
form{display:grid;gap:var(--space-md);max-width:620px}
label{font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.07em;color:var(--clr-text-dim)}
input[type=text],input[type=email],input[type=tel],textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--clr-border);border-radius:var(--radius-sm);background:#fff;font-size:.9rem;transition:.25s}
textarea{min-height:140px;resize:vertical}
input:focus,textarea:focus{outline:2px solid var(--clr-primary-accent);outline-offset:2px}

/* Tables (if needed) */
table{border-collapse:collapse;width:100%;font-size:.85rem}
th,td{padding:.75rem .9rem;text-align:left;border-bottom:1px solid var(--clr-border)}
th{background:var(--clr-surface-alt);font-weight:600}

/* Accessibility helpers */
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;background:#000;color:#fff;padding:.6rem .9rem;border-radius:var(--radius-sm);z-index:999}

/* ================= Page-specific spacing refinements ================= */
/* Tighten spacing after h2 and before following text on prices & services */
body[data-page="prices"] .stack > h2 + .text-sm,
body[data-page="services"] .stack > h2 + p,
body[data-page="services"] .stack > h2 + .text-sm{margin-top:var(--space-sm)}

/* Reduce overall vertical padding for content sections (exclude sub-hero & CTA) */
body[data-page="prices"] section:not(.sub-hero):not(.cta),
body[data-page="services"] section:not(.sub-hero):not(.cta){padding-top:var(--space-xl);padding-bottom:var(--space-xl)}

/* Further tighten the gap specifically between consecutive content sections */
body[data-page="prices"] section:not(.sub-hero):not(.cta) + section:not(.sub-hero):not(.cta),
body[data-page="services"] section:not(.sub-hero):not(.cta) + section:not(.sub-hero):not(.cta){padding-top:var(--space-lg)}

@media (min-width:900px){
    /* Slightly more generous on desktop but still tighter than default */
    body[data-page="prices"] section:not(.sub-hero):not(.cta),
    body[data-page="services"] section:not(.sub-hero):not(.cta){padding-top:calc(var(--space-xl) + .4rem);padding-bottom:calc(var(--space-xl) + .4rem)}
}

/* Media queries */
@media (max-width: 880px){
    .primary-nav{display:flex;align-items:center}
    .nav-toggle{display:inline-block;position:relative;z-index:120}
    .nav-list{position:fixed;top:0;right:0;flex-direction:column;align-items:stretch;background:linear-gradient(145deg,var(--clr-primary) 0%,var(--clr-primary-accent) 85%);padding:1.25rem 1rem 1.05rem;border-radius:0 0 0 var(--radius-lg);box-shadow:0 16px 32px -8px rgba(0,0,0,.35);min-width:200px;max-width:220px;display:flex;transform:translateY(-6px) translateX(6px) scale(.9);opacity:0;pointer-events:none;transition:.45s cubic-bezier(.4,.2,.2,1);border:1px solid rgba(255,255,255,.15);border-top:none;z-index:110}
    .nav-list li:first-child a{margin-top:0}
    .site-header{overflow:visible}
    .nav-list:before{display:none}
    .nav-list.open{opacity:1;pointer-events:auto;transform:translateY(0) translateX(0) scale(1)}
    /* Keep hamburger visible (no morph) */
    .nav-toggle[aria-expanded="true"] span{background:#fff}
    .nav-toggle span{transition:background .3s,transform .4s}
    /* Optional subtle pulse when open */
    .nav-toggle[aria-expanded="true"] span:nth-child(2){transform:scaleX(.85)}
    /* Larger touch target */
    .nav-toggle{padding:.85rem .75rem;margin-right:-.4rem}
    .nav-list a{font-size:.95rem}
    .nav-list li + li{margin-top:.2rem}
    .has-sub>.sub-toggle{display:inline-flex;position:absolute;right:.25rem;top:.3rem;background:none;border:0;width:2rem;height:2rem;align-items:center;justify-content:center;cursor:pointer;color:#fff}
    .has-sub:hover .sub-menu{display:none}
    .sub-menu{position:static;display:none;padding-left:.8rem;margin-top:.4rem;border:none;box-shadow:none;background:#fff;border-radius:var(--radius-sm)}
    .sub-menu a{padding:.4rem 0;color:var(--clr-text)}
    .has-sub.open>.sub-menu{display:flex}
}

/* Blurred background when mobile menu open */
@media (max-width:880px){
    /* Blur only content area, never header or nav list */
    body.menu-open main, body.menu-open .site-footer{filter:blur(4px);transition:filter .35s ease}
    body.menu-open:before{content:"";position:fixed;inset:0;backdrop-filter:blur(2px);background:rgba(0,0,0,.25);z-index:60;pointer-events:none;transition:.35s}
    .site-header, .site-header *{filter:none !important}
    .nav-list{filter:none !important}
    .site-header{z-index:130}
}

@media (max-width:600px){
    .hero{padding-top:3.2rem}
    .brand{font-size:1rem}
    .card{padding:var(--space-md)}
}

@media (prefers-reduced-motion:reduce){
    *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* === Redesigned Footer Override (appended) === */
.site-footer{background:var(--clr-bg);color:var(--clr-text);font-size:.9rem;position:relative;overflow:hidden;margin-top:auto;border-top:1px solid var(--clr-border);padding-top:0}
.site-footer:before{display:none}
.footer-inner{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(2rem,5vw,4.2rem);padding:clamp(2.4rem,5vw,3.9rem) 0 2.2rem;align-items:start;background:transparent;border-top:none;box-shadow:none}
.footer-brand-block{max-width:520px}
.footer-title{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin:0 0 1rem;position:relative;color:var(--clr-primary);padding-left:1px;display:inline-block}
.footer-title:after{content:"";position:absolute;left:0;bottom:-.5rem;width:100%;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--clr-primary),var(--clr-primary-accent))}
.footer-description{margin:0;line-height:1.55;font-size:.92rem;color:var(--clr-text-dim);max-width:56ch}
.footer-contact-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}
.footer-contact-list li{display:flex;align-items:flex-start;gap:.55rem;line-height:1.45}
.footer-contact-list a{color:var(--clr-text);text-decoration:none;position:relative;font-weight:600}
.footer-contact-list a:after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:linear-gradient(90deg,var(--clr-primary),var(--clr-primary-accent));transition:.35s}
.footer-contact-list a:hover:after,.footer-contact-list a:focus:after{width:100%}
.footer-bottom{border-top:1px solid #b7d7bb;background:linear-gradient(90deg,#dff6e6,#e8f9ee)}
.footer-bottom-inner{display:flex;justify-content:center;align-items:center;padding:.9rem 0;font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#2d6235}
/* Custom adjustable horizontal shift for Yhteystiedot column */
@media (min-width:900px){
    .footer-inner{position:relative}
    .footer-inner .footer-contact-block{position:relative;left:250px} /* Adjust px value as needed */
}
@media (min-width:900px){
    .footer-inner{grid-template-columns:minmax(300px,480px) 260px}
    .footer-contact-list li{justify-content:flex-start}
}
@media (max-width:640px){
    .footer-inner{text-align:center}
    /* Remove centering shift; underline now matches exact text width */
    .footer-contact-list{align-items:center}
    .footer-contact-list li{justify-content:center}
    .footer-description{margin-inline:auto}
}
.site-footer a:focus-visible{outline:2px solid #2E7D32;outline-offset:3px;border-radius:4px;background:rgba(76,175,80,.08)}