/* Talox Turku — design system
   Concept: seamless troweled microcement surfaces. Warm mineral stone base,
   one deep "wet-room" petrol accent, troweled (asymmetric) corner signature. */

:root{
  --stone:#EFEAE1;        /* warm ivory page bg */
  --stone-2:#E7E1D5;      /* deeper ivory / alt surface */
  --stone-3:#D8D0C1;      /* hairline borders */
  --paper:#F7F3EC;        /* lightest surface (cards) */
  --ink:#18150F;          /* espresso near-black */
  --ink-2:#544D41;        /* muted warm taupe text */
  --petrol:#1C1812;       /* dark accent (primary buttons / dark sections) */
  --petrol-2:#322A20;     /* hover */
  --sand:#A9844C;         /* antique brass accent */
  --brass:#A9844C;
  --brass-2:#8C6A38;
  --maxw:1200px;
  --gap:clamp(1rem,4vw,2.5rem);
  --radius:4px;
  --radius-lg:8px;
  --shadow:0 1px 2px rgba(24,21,15,.05),0 14px 36px -22px rgba(24,21,15,.40);
  --ff-display:"Fraunces",Georgia,"Times New Roman",serif;
  --ff-body:"Hanken Grotesk",system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--ff-body);color:var(--ink);background:var(--stone);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--petrol);text-underline-offset:3px}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;line-height:1.08;
  letter-spacing:-.02em;margin:0 0 .5em;color:var(--ink)}
h1{font-size:clamp(2.3rem,6vw,4rem)}
h2{font-size:clamp(1.7rem,4vw,2.7rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.5rem)}
p{margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gap)}
.eyebrow{font-family:var(--ff-body);font-weight:600;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--sand);margin:0 0 1rem}
.lead{font-size:clamp(1.05rem,2vw,1.25rem);color:var(--ink-2);max-width:60ch}
.muted{color:var(--ink-2)}
section{padding:clamp(3.5rem,8vw,6rem) 0}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:600;
  font-family:var(--ff-body);text-decoration:none;border-radius:var(--radius);
  padding:.95rem 1.6rem;border:1.5px solid transparent;cursor:pointer;
  transition:transform .15s ease,background .2s ease,color .2s ease;font-size:1rem}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--petrol);color:var(--paper)}
.btn-primary:hover{background:var(--petrol-2)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-lg{padding:1.1rem 2rem;font-size:1.08rem}

/* header */
.site-head{position:sticky;top:0;z-index:50;background:rgba(236,232,225,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--stone-3)}
.nav{display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:.9rem var(--gap);max-width:var(--maxw);margin:0 auto}
.brand{font-family:var(--ff-display);font-weight:800;font-size:1.45rem;
  letter-spacing:-.03em;color:var(--ink);text-decoration:none;display:flex;
  align-items:baseline;gap:.4rem}
.brand span{font-family:var(--ff-body);font-weight:600;font-size:.7rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--sand)}
.nav-links{display:flex;gap:1.4rem;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--ink);text-decoration:none;font-weight:500;font-size:.97rem}
.nav-links a:hover{color:var(--petrol)}
.nav-cta{background:var(--petrol);color:var(--paper)!important;padding:.55rem 1.1rem;
  border-radius:var(--radius);font-weight:600}
.nav-cta:hover{background:var(--petrol-2)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:.3rem;
  flex-direction:column;gap:5px}
.burger span{width:26px;height:2px;background:var(--ink);display:block;transition:.25s}

/* hero */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(120% 80% at 80% 0%,rgba(42,107,102,.16),transparent 60%),
    radial-gradient(90% 70% at 0% 100%,rgba(181,137,79,.14),transparent 55%),
    linear-gradient(180deg,var(--stone),var(--stone-2));
  border-bottom:1px solid var(--stone-3)}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/></svg>")}
.hero-inner{position:relative;z-index:1;display:grid;gap:2.5rem;align-items:center;
  padding:clamp(3rem,7vw,5.5rem) var(--gap);max-width:var(--maxw);margin:0 auto;
  grid-template-columns:1.15fr .85fr}
.hero h1{margin-bottom:.4em}
.hero .lead{margin-bottom:2rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.6rem}
.hero-trust{display:flex;gap:1.4rem;flex-wrap:wrap;font-size:.9rem;color:var(--ink-2)}
.hero-trust b{color:var(--ink)}
.hero-card{background:var(--ink);color:var(--paper);border-radius:var(--radius-lg);
  padding:2rem;box-shadow:var(--shadow)}
.hero-card h3{color:var(--paper)}
.hero-card ul{list-style:none;margin:0;padding:0;display:grid;gap:.9rem}
.hero-card li{display:flex;gap:.7rem;align-items:flex-start;font-size:.97rem;color:#e9e6df}
.hero-card .tick{color:#8fd0c8;font-weight:700;flex:none}

/* generic grids */
.grid{display:grid;gap:1.4rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--paper);border:1px solid var(--stone-3);border-radius:var(--radius);
  padding:1.8rem;box-shadow:var(--shadow);transition:transform .18s ease}
.card:hover{transform:translateY(-3px)}
.card h3{margin-bottom:.4em}
.card p{font-size:.97rem;color:var(--ink-2);margin-bottom:1rem}
.card a.more{font-weight:600;text-decoration:none;display:inline-flex;gap:.4rem}
.card a.more:hover{gap:.7rem}
.card-link{text-decoration:none;color:inherit;display:block}

.section-head{max-width:62ch;margin-bottom:2.5rem}
.dark{background:var(--ink);color:#e9e6df}
.dark h1,.dark h2,.dark h3{color:var(--paper)}
.dark .eyebrow{color:var(--sand)}
.dark .lead{color:#cfccc4}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;text-align:left}
.stats .n{font-family:var(--ff-display);font-size:clamp(2rem,4vw,2.8rem);
  font-weight:700;color:var(--petrol);line-height:1}
.dark .stats .n{color:#8fd0c8}
.stats .l{font-size:.9rem;color:var(--ink-2);margin-top:.4rem}
.dark .stats .l{color:#cfccc4}

/* process / steps */
.steps{counter-reset:s;display:grid;gap:1.2rem}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:start;
  padding:1.4rem 0;border-top:1px solid var(--stone-3)}
.step::before{counter-increment:s;content:counter(s,decimal-leading-zero);
  font-family:var(--ff-display);font-weight:700;color:var(--sand);font-size:1.4rem}
.step h3{margin:0 0 .2em}
.step p{margin:0;font-size:.97rem;color:var(--ink-2)}

/* prose pages */
.prose{max-width:72ch}
.prose h2{margin-top:2.2em}
.prose h3{margin-top:1.6em}
.prose ul{padding-left:1.2em}
.prose li{margin:.35em 0}
.prose .callout{background:var(--stone-2);border-left:3px solid var(--petrol);
  border-radius:0 var(--radius) var(--radius) 0;padding:1.2rem 1.4rem;margin:1.6em 0}
.prose .callout p:last-child{margin:0}

/* area chips */
.chips{display:flex;flex-wrap:wrap;gap:.6rem}
.chips a{background:var(--paper);border:1px solid var(--stone-3);border-radius:99px;
  padding:.45rem 1rem;text-decoration:none;color:var(--ink);font-size:.92rem;font-weight:500}
.chips a:hover{border-color:var(--petrol);color:var(--petrol)}

/* faq */
.faq details{border-top:1px solid var(--stone-3);padding:1.1rem 0}
.faq summary{font-family:var(--ff-display);font-weight:700;font-size:1.1rem;
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--sand);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{margin:.8em 0 0;color:var(--ink-2)}

/* CTA band */
.cta-band{background:var(--petrol);color:var(--paper);border-radius:var(--radius-lg);
  padding:clamp(2rem,5vw,3.2rem);display:grid;gap:1.5rem;align-items:center;
  grid-template-columns:1.4fr auto;box-shadow:var(--shadow)}
.cta-band h2{color:var(--paper);margin:0}
.cta-band p{color:#d6ece9;margin:.5rem 0 0;max-width:48ch}
.cta-band .btn-primary{background:var(--paper);color:var(--petrol)}
.cta-band .btn-primary:hover{background:#fff}

/* before/after gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.shot{background:var(--stone-2);border:1px solid var(--stone-3);border-radius:var(--radius);
  aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
  color:var(--ink-2);text-align:center;font-size:.85rem;padding:1rem;overflow:hidden}
.shot span{opacity:.7}

/* form */
.form{display:grid;gap:1rem;background:var(--paper);border:1px solid var(--stone-3);
  border-radius:var(--radius-lg);padding:clamp(1.5rem,4vw,2.4rem);box-shadow:var(--shadow)}
.form label{font-weight:600;font-size:.92rem;display:grid;gap:.4rem}
.form input,.form textarea,.form select{font:inherit;font-size:16px;padding:.8rem .9rem;
  border:1px solid var(--stone-3);border-radius:var(--radius);background:var(--stone);
  color:var(--ink)}
.form input:focus,.form textarea:focus,.form select:focus{outline:2px solid var(--petrol);
  outline-offset:1px;border-color:var(--petrol)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* footer */
.site-foot{background:var(--ink);color:#cfccc4;padding:clamp(3rem,6vw,4rem) 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
.site-foot h4{color:var(--paper);font-size:1rem;margin-bottom:1rem}
.site-foot a{color:#cfccc4;text-decoration:none;display:block;margin:.4rem 0;font-size:.93rem}
.site-foot a:hover{color:var(--paper)}
.foot-brand{font-family:var(--ff-display);font-weight:800;font-size:1.5rem;color:var(--paper)}
.foot-bottom{border-top:1px solid #38362f;margin-top:2.5rem;padding-top:1.5rem;
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#8d8a82}

/* social media boxes (footer + Meistä) */
.socials{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.1rem}
.socials a{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:9px;border:1px solid var(--stone-3,#e0d8ca);color:var(--ink);margin:0;transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease}
.socials a:hover{background:var(--brass);border-color:var(--brass);color:#fff;transform:translateY(-2px)}
.socials a svg{width:20px;height:20px;display:block}
.site-foot .socials a{border-color:rgba(255,255,255,.2);color:#cfccc4}
.site-foot .socials a:hover{background:var(--brass);border-color:var(--brass);color:#fff}
.soc-band{background:var(--stone-2,#efeae1);border-top:1px solid var(--stone-3);border-bottom:1px solid var(--stone-3)}

/* breadcrumbs */
.crumbs{font-size:.85rem;color:var(--ink-2);padding:1.2rem 0 0}
.crumbs a{color:var(--ink-2);text-decoration:none}
.crumbs a:hover{color:var(--petrol)}

/* sticky mobile call bar */
.callbar{display:none}

@media(max-width:860px){
  .hero-inner{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .cta-band{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .nav-links{position:fixed;inset:64px 0 auto 0;background:var(--stone);
    flex-direction:column;align-items:flex-start;gap:0;padding:1rem var(--gap);
    border-bottom:1px solid var(--stone-3);transform:translateY(-120%);
    transition:transform .25s ease;box-shadow:var(--shadow)}
  .nav-links.open{transform:translateY(0)}
  .nav-links li{width:100%;border-top:1px solid var(--stone-3)}
  .nav-links li:first-child{border-top:0}
  .nav-links a{display:block;padding:.9rem 0;width:100%}
  .burger{display:flex}
  .callbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;
    background:var(--petrol);box-shadow:0 -6px 20px -10px rgba(0,0,0,.5)}
  .callbar a{flex:1;text-align:center;color:var(--paper);text-decoration:none;
    font-weight:600;padding:.85rem;font-size:.95rem}
  .callbar a+a{border-left:1px solid rgba(255,255,255,.2)}
  body{padding-bottom:52px}
}
@media(max-width:560px){
  .grid-3,.grid-2,.row,.stats,.foot-grid,.gallery{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}

/* ===== Typography scale-up (larger text, mobile + desktop) ===== */
html{font-size:112.5%}                 /* root 16 -> 18px; rem scales everything up */
body{font-size:1.05rem;line-height:1.7}
.lead{font-size:clamp(1.12rem,2vw,1.35rem)}
.nav-links a{font-size:1rem}
.card p{font-size:1rem}
.hero-card li{font-size:1rem}
.hero-card p{font-size:1rem!important}
.step p{font-size:1rem}
.chips a{font-size:1rem}
.hero-trust{font-size:1rem}
.stats .l{font-size:1rem}
.site-foot a{font-size:1rem}
.site-foot p{font-size:1rem}
.form label{font-size:1rem}
.form input,.form textarea,.form select{font-size:1.05rem}
.faq summary{font-size:1.18rem}
.crumbs{font-size:.95rem}
.callbar a{font-size:1.05rem}
.eyebrow{font-size:.85rem}

/* ===== Palvelut mega menu ===== */
.nav-links .has-mega{position:relative}
.mega-toggle{display:inline-flex;align-items:center;gap:.35rem}
.mega-toggle .caret{font-size:.8em;transition:transform .2s ease}
.has-mega.open .mega-toggle .caret{transform:rotate(180deg)}
.mega{position:absolute;top:calc(100% + .55rem);left:0;background:var(--paper);
  border:1px solid var(--stone-3);border-radius:var(--radius-lg);box-shadow:var(--shadow);
  padding:1.5rem 1.6rem;display:none;grid-template-columns:repeat(4,minmax(170px,1fr));
  gap:1.2rem 1.6rem;z-index:60;width:max-content;max-width:min(92vw,880px)}
.has-mega:focus-within .mega,.has-mega.open .mega{display:grid}
.mega-col{display:flex;flex-direction:column;gap:.15rem;min-width:165px}
.mega-h{font-family:var(--ff-display);font-weight:700;font-size:.82rem;color:var(--sand);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}
.mega-col a{color:var(--ink);text-decoration:none;font-size:1rem;font-weight:500;
  padding:.32rem 0;line-height:1.3}
.mega-col a:hover{color:var(--petrol)}
.mega-foot{grid-column:1/-1;border-top:1px solid var(--stone-3);padding-top:.9rem;margin-top:.2rem}
.mega-all{font-weight:600;color:var(--petrol)!important}

@media(max-width:860px){
  .mega{position:static;display:none;grid-template-columns:1fr 1fr;width:auto;max-width:none;
    box-shadow:none;border:0;background:transparent;padding:.2rem 0 .8rem;gap:.5rem 1rem}
  .has-mega.open .mega{display:grid}
  .mega-h{color:var(--ink-2)}
  .mega-col a{padding:.45rem 0}
  .mega-foot{padding-top:.6rem}
  .mega-toggle{justify-content:space-between;width:100%}
}
@media(max-width:560px){ .mega{grid-template-columns:1fr} }

/* ===== grouped service grid (homepage + palvelut hub) ===== */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));
  gap:1.4rem;align-items:start}
.svc-group-h{grid-column:1/-1;font-family:var(--ff-display);font-weight:700;
  font-size:1.05rem;color:var(--sand);text-transform:uppercase;letter-spacing:.05em;
  margin:1.6rem 0 .1rem}
.svc-group-h:first-child{margin-top:0}
@media(max-width:560px){ .svc-grid{grid-template-columns:1fr} }

/* ===== project photos: figures + varied layouts ===== */
figure.ph{margin:0}
.ph img{width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow);display:block}
.ph figcaption{font-size:.95rem;color:var(--ink-2);margin-top:.6rem;font-weight:500}
.media-stack{display:grid;gap:2rem}
.media-band .ph img{border-radius:var(--radius-lg)}
.media-feature{max-width:580px;margin-inline:auto}
.media-duo{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;align-items:start}
.media-trip{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;align-items:start}
/* zig-zag vertical: images alternate left / right down the page */
.zigzag{display:grid;gap:1.8rem}
.zz-item{width:min(64%,520px)}
.zz-item:nth-child(even){justify-self:end}
/* referenssit masonry */
.gallery-rich{columns:3;column-gap:1.4rem}
.gallery-rich figure.ph{break-inside:avoid;margin:0 0 1.4rem}
@media(max-width:860px){
  .media-duo,.media-trip{grid-template-columns:1fr 1fr}
  .zz-item,.zz-item:nth-child(even){width:100%;justify-self:stretch}
  .gallery-rich{columns:2}
}
@media(max-width:560px){
  .media-duo,.media-trip{grid-template-columns:1fr}
  .gallery-rich{columns:1}
}

/* =====================================================================
   LUXURY THEME  —  espresso + ivory + antique brass, Fraunces display
   (appended last; overrides earlier rules)
   ===================================================================== */

/* tighter vertical rhythm — remove excess blank space */
section{padding:clamp(2.2rem,4.6vw,3.8rem) 0}
.section-head{margin-bottom:1.7rem;max-width:64ch}
.hero-inner{padding-block:clamp(2.2rem,5vw,3.8rem);gap:2rem}
.hero .lead{margin-bottom:1.4rem}

/* elegant serif display */
h1,h2,h3,h4{font-weight:600;letter-spacing:-.015em}
h1{font-size:clamp(2.35rem,5vw,3.8rem);line-height:1.05}
h2{font-size:clamp(1.75rem,3.5vw,2.55rem);line-height:1.1}
.eyebrow{color:var(--brass);letter-spacing:.2em;font-weight:600;font-size:.8rem}
a{color:var(--brass)}
a:hover{color:var(--brass-2)}

/* buttons — calm, premium (no bounce) */
.btn{border-radius:3px;font-weight:600;transition:background .2s ease,color .2s ease}
.btn:hover{transform:none}
.btn-primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-primary:hover{background:var(--petrol-2);color:#fff}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* header / nav */
.site-head{background:rgba(247,243,236,.9);border-bottom:1px solid var(--stone-3)}
.brand{font-family:var(--ff-display);font-weight:600}
.brand span{color:var(--brass)}
.nav-cta{background:var(--ink);border-radius:3px}
.nav-cta:hover{background:var(--petrol-2)}
.nav-links a:hover{color:var(--brass)}

/* hero — warm ivory, faint brass glow (no teal) */
.hero{background:
  radial-gradient(120% 85% at 88% -10%,rgba(169,132,76,.12),transparent 55%),
  linear-gradient(180deg,var(--paper),var(--stone))}
.hero::after{opacity:.3}
.hero-card{background:var(--ink);border-radius:6px}
.hero-card h3{font-family:var(--ff-display)}
.hero-card .tick{color:var(--brass)}
.hero-card .btn{background:var(--brass)!important;color:#1c1812!important;border-radius:3px}
.hero-card .btn:hover{background:#c4a06a!important}

/* clean radii everywhere */
.card,.cta-band,.form,.mega,.shot,.ph img,.svc-card{border-radius:6px}
.chips a{border-radius:99px}

/* ---------- service cards = image cards ---------- */
.svc-card{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--stone-3);
  border-radius:8px;overflow:hidden;box-shadow:var(--shadow);text-decoration:none;color:inherit;
  transition:transform .28s ease,box-shadow .28s ease}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 22px 46px -26px rgba(24,21,15,.55)}
.svc-card .thumb{aspect-ratio:4/3;overflow:hidden;background:var(--ink)}
.svc-card .thumb img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0;
  box-shadow:none;transition:transform .55s ease}
.svc-card:hover .thumb img{transform:scale(1.05)}
.svc-card .thumb.noimg{display:flex;align-items:center;justify-content:center;text-align:center;
  padding:1.2rem;background:linear-gradient(135deg,#211c14,#3a2e1c)}
.svc-card .thumb.noimg span{font-family:var(--ff-display);color:var(--brass);font-size:1.25rem;font-weight:600}
.svc-card .body{padding:1.1rem 1.25rem 1.35rem}
.svc-card h3{margin:0 0 .3em;font-size:1.2rem}
.svc-card p{margin:0 0 .7rem;color:var(--ink-2);font-size:1rem;line-height:1.5}
.svc-card .more{color:var(--brass);font-weight:600;font-size:.95rem}

.svc-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.svc-group-h{color:var(--brass);font-family:var(--ff-body);font-weight:700;font-size:.8rem;
  letter-spacing:.16em;margin:1.6rem 0 .3rem}
.svc-group-h:first-child{margin-top:0}

/* ---------- media: compact horizontal grids, uniform tiles ---------- */
.media-stack{gap:1.4rem}
.media-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem}
.media-grid .ph img,.media-trip .ph img,.media-duo .ph img{aspect-ratio:4/3;object-fit:cover}
.media-band .ph img{aspect-ratio:16/9;object-fit:cover;border-radius:8px}
.ph img{border-radius:6px}
.ph figcaption{font-size:.88rem;margin-top:.5rem;color:var(--ink-2)}
@media(max-width:560px){ .media-grid{grid-template-columns:1fr 1fr} }

/* referenssit: even gallery grid (not ragged columns) */
.gallery-rich{columns:auto;column-gap:0;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.gallery-rich figure.ph{break-inside:auto;margin:0}
.gallery-rich .ph img{aspect-ratio:4/3;object-fit:cover}
.gallery-rich .ph figcaption{display:none}
@media(max-width:560px){ .gallery-rich{grid-template-columns:1fr 1fr} }

/* stats / counters */
.stats .n{color:var(--ink);font-variant-numeric:tabular-nums}
.dark .stats .n{color:var(--brass)}
.dark .eyebrow{color:var(--brass)}

/* accents */
.faq summary::after{color:var(--brass)}
.faq summary{font-family:var(--ff-display);font-weight:600}
.step::before{color:var(--brass)}
.prose .callout{border-left-color:var(--brass);background:var(--stone-2)}
.cta-band{background:var(--ink)}
.cta-band h2{font-family:var(--ff-display)}
.cta-band .btn-primary{background:var(--brass);color:#1c1812}
.cta-band .btn-primary:hover{background:#fff;color:var(--ink)}

/* ---------- mega menu: luxe, click-to-open, no hover gap ---------- */
.mega{top:100%;border-radius:0 0 8px 8px;border:1px solid var(--stone-3);border-top:2px solid var(--brass);
  padding:1.6rem 1.8rem}
.mega-h{color:var(--brass)}
.mega-col a:hover{color:var(--brass)}
.mega-all{color:var(--brass)!important}
@media(max-width:860px){ .mega{border:0;border-top:0} }

/* ---------- homepage full-bleed hero with luxury interior background ---------- */
.hero-home{position:relative;background:none;border-bottom:0;overflow:hidden}
.hero-home::after{display:none}
.hero-home::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(105deg,rgba(20,17,11,.84) 0%,rgba(20,17,11,.58) 46%,rgba(20,17,11,.28) 100%),
    linear-gradient(0deg,rgba(20,17,11,.55),transparent 48%)}
.hero-home-inner{position:relative;z-index:2;grid-template-columns:1fr;
  min-height:min(78vh,680px);align-items:center}
.hero-home .hero-content{max-width:680px}
.hero-home .eyebrow{color:var(--brass)}
.hero-home h1{color:#fff;text-shadow:0 1px 30px rgba(0,0,0,.25)}
.hero-home .lead{color:rgba(255,255,255,.88);max-width:58ch}
.hero-home .hero-trust{color:rgba(255,255,255,.85)}
.hero-home .hero-trust b{color:#fff}
.hero-home .btn-primary{background:var(--brass);color:#1c1812;border-color:var(--brass)}
.hero-home .btn-primary:hover{background:#c4a06a;color:#1c1812}
.hero-home .btn-ghost{border-color:rgba(255,255,255,.65);color:#fff}
.hero-home .btn-ghost:hover{background:#fff;color:var(--ink)}

/* ============ PAGE HERO (image bg) – service & other pages ============ */
.page-hero{position:relative;background:none;border-bottom:0;overflow:hidden}
.page-hero::after{display:none}
.page-hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(105deg,rgba(20,17,11,.82) 0%,rgba(20,17,11,.55) 50%,rgba(20,17,11,.28) 100%),
    linear-gradient(0deg,rgba(20,17,11,.5),transparent 52%)}
.page-hero .hero-home-inner{position:relative;z-index:2;grid-template-columns:1fr;
  min-height:min(52vh,430px);align-items:center}
.page-hero .hero-content{max-width:680px}
.page-hero .eyebrow{color:var(--brass)}
.page-hero h1{color:#fff;text-shadow:0 1px 30px rgba(0,0,0,.25)}
.page-hero .lead{color:rgba(255,255,255,.9);max-width:60ch}
.page-hero .btn-primary{background:var(--brass);color:#1c1812;border-color:var(--brass)}
.page-hero .btn-primary:hover{background:#c4a06a;color:#1c1812}
.page-hero .btn-ghost{border-color:rgba(255,255,255,.65);color:#fff}
.page-hero .btn-ghost:hover{background:#fff;color:var(--ink)}

/* breadcrumb bar under hero */
.crumb-bar{background:var(--stone-2);border-bottom:1px solid var(--stone-3)}
.crumb-bar .crumbs{margin:0;padding:.7rem 0}

/* ============ FEATURE ROWS (alternating image / text) ============ */
.frows{}
.frow{padding:clamp(2.6rem,5.5vw,5rem) 0}
.frow.alt{background:var(--stone-2)}
.frow-in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:stretch}
.frow.rev .frow-media{order:2}
.frow-media{display:flex}
.frow-media img{width:100%;height:100%;min-height:340px;max-height:600px;object-fit:cover;border-radius:var(--radius-lg);
  box-shadow:0 24px 60px -28px rgba(24,21,15,.55);display:block}
.frow-text{align-self:center}
.frow-text h2{margin:0 0 1rem;font-size:clamp(1.5rem,2.6vw,2.1rem)}
.frow-text .prose,.frow-text p{font-size:1.04rem;line-height:1.75;color:var(--ink-2)}
.frow-text p{margin:0 0 1rem}
.frow-text ul.prose{padding-left:1.1em;margin:0 0 1rem}
.frow-text ul.prose li{margin:.4rem 0}
@media(max-width:780px){
  .frow{padding:2.2rem 0}
  .frow-in{grid-template-columns:1fr;gap:1.4rem;align-items:stretch}
  .frow.rev .frow-media{order:0}
  .frow-media img{height:auto;min-height:0;max-height:none;aspect-ratio:16/10}
}

/* ============ BENEFITS BAND (espresso) + price card ============ */
.benefits-band{background:var(--ink);color:var(--paper)}
.benefits-in{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.benefits-band .eyebrow{color:var(--brass)}
.benefits-band h2{color:#fff;margin:.2rem 0 1.4rem}
.benefits-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.6rem}
.benefits-list li{display:flex;gap:.6rem;align-items:flex-start;color:rgba(247,243,236,.9);line-height:1.4}
.benefits-list .tick{color:var(--brass);font-weight:700;flex:none}
.price-card{background:rgba(255,255,255,.06);border:1px solid rgba(169,132,76,.4);
  border-radius:var(--radius-lg);padding:1.8rem}
.price-card h3{color:#fff;margin:0 0 .6rem}
.price-card p{color:rgba(247,243,236,.82);font-size:.97rem;margin:0 0 1.3rem}
.price-card .btn{width:100%;justify-content:center}
.price-card .price-call{display:block;text-align:center;margin-top:.8rem;color:var(--brass);font-size:.95rem}
@media(max-width:780px){
  .benefits-in{grid-template-columns:1fr;gap:1.8rem}
  .benefits-list{grid-template-columns:1fr}
}

/* ============ LOGO (nav + footer) ============ */
.brand{display:inline-flex;align-items:center;gap:0;padding:0;line-height:0}
.brand img{height:38px;width:auto;display:block}
.site-foot .foot-brand{line-height:0}
.site-foot .foot-brand img{height:50px;width:auto;display:block}
@media(max-width:560px){ .brand img{height:32px} }

/* ============ HERO IMAGE LAYER + MOBILE STACK ============ */
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero-home h1,.page-hero h1,.hero h1{overflow-wrap:break-word;hyphens:auto}
.hero-home .hero-content,.page-hero .hero-content{max-width:680px}
/* on phones: image on top, text below on espresso panel (legible, no overflow) */
@media(max-width:680px){
  .hero-home,.page-hero{display:flex;flex-direction:column}
  .hero-home .hero-bg,.page-hero .hero-bg{position:static;width:100%;height:auto;
    aspect-ratio:16/10;z-index:0;display:block}
  .hero-home::before,.page-hero::before{display:none}
  .hero-home-inner,.page-hero .hero-home-inner{background:var(--ink);min-height:auto;
    padding:1.9rem var(--gap) 2.3rem}
  .hero-home h1,.page-hero h1{font-size:clamp(1.9rem,8vw,2.5rem)}
  .hero-home .lead,.page-hero .lead{font-size:1rem}
  .hero-home .hero-cta,.page-hero .hero-cta{margin-bottom:.4rem}
  .hero-home .hero-cta .btn,.page-hero .hero-cta .btn{flex:1 1 auto;justify-content:center}
}

/* ============ REFERENSSIT — vertical auto-scroll carousel ============ */
.wrap-wide{max-width:1400px;margin:0 auto;padding:0 var(--gap)}
.gallery-carousel{display:grid;grid-template-columns:repeat(3,1fr);gap:1.7rem;
  height:min(86vh,860px);overflow:hidden;
  -webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 7%,#000 93%,transparent 100%);
          mask-image:linear-gradient(to bottom,transparent 0,#000 7%,#000 93%,transparent 100%)}
.gc-col{overflow:hidden}
.gc-track{display:flex;flex-direction:column;gap:1.7rem;will-change:transform}
.gc-up .gc-track{animation:gcUp var(--gc-speed,42s) linear infinite}
.gc-down .gc-track{animation:gcDown var(--gc-speed,42s) linear infinite}
@keyframes gcUp{from{transform:translateY(0)}to{transform:translateY(-50%)}}
@keyframes gcDown{from{transform:translateY(-50%)}to{transform:translateY(0)}}
.gallery-carousel:hover .gc-track{animation-play-state:paused}
.gc-track img{width:100%;height:auto;border-radius:var(--radius-lg);display:block;cursor:zoom-in;
  box-shadow:0 14px 36px -22px rgba(24,21,15,.5);transition:transform .35s ease,box-shadow .35s ease}
.gc-track img:hover{transform:scale(1.02);box-shadow:0 22px 48px -22px rgba(24,21,15,.6)}
@media(max-width:680px){
  .gallery-carousel{grid-template-columns:repeat(2,1fr);align-items:stretch;gap:.7rem;height:min(78vh,620px)}
  .gc-col{min-height:0}
  .gc-col:nth-child(3){display:none}   /* 2 cols = single row → stretches to full height, no empty box */
  .gc-track{gap:.7rem}
}
@media(prefers-reduced-motion:reduce){
  .gc-up .gc-track,.gc-down .gc-track{animation:none}
  .gallery-carousel{height:auto;overflow:visible;-webkit-mask-image:none;mask-image:none}
  .gc-clone{display:none}   /* static fallback: show each photo once, not the loop duplicate */
}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  gap:.5rem;padding:clamp(.8rem,4vw,3rem);background:rgba(15,13,9,.92);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.lightbox.open{display:flex}
.lb-stage{margin:0;max-width:92vw;max-height:88vh;display:flex;align-items:center;justify-content:center}
.lb-img{max-width:92vw;max-height:88vh;width:auto;height:auto;border-radius:8px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.7);animation:lbIn .25s ease}
@keyframes lbIn{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
.lb-btn{flex:none;background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.25);
  width:48px;height:48px;border-radius:999px;font-size:1.7rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .2s}
.lb-btn:hover{background:var(--brass);border-color:var(--brass);color:#1c1812}
.lb-close{position:absolute;top:clamp(.8rem,3vw,1.6rem);right:clamp(.8rem,3vw,1.6rem);
  width:44px;height:44px;font-size:1.5rem}
@media(max-width:680px){
  .lb-prev,.lb-next{position:absolute;bottom:1.2rem;z-index:2}
  .lb-prev{left:1.2rem}.lb-next{right:1.2rem}
}

/* SEO content band on service pages */
.seo-band{background:var(--stone-2);border-top:1px solid var(--stone-3)}
.seo-band .prose{max-width:880px}
.seo-band .prose h2{font-size:clamp(1.4rem,2.4vw,1.9rem);margin:1.8rem 0 .7rem}
.seo-band .prose h2:first-child{margin-top:0}
.seo-band .prose h3{font-size:1.15rem;margin:1.3rem 0 .5rem}
.seo-band .prose p,.seo-band .prose li{font-size:1.02rem;line-height:1.75;color:var(--ink-2)}
/* rich SEO band: savings callout + area chips */
.seo-band .prose .kv-callout{display:flex;gap:1rem;align-items:flex-start;text-align:left;background:#fff;border:1px solid var(--stone-3);border-left:4px solid var(--brass);border-radius:12px;padding:1.15rem 1.3rem;margin:1.9rem auto;max-width:660px;box-shadow:0 12px 32px -26px rgba(24,21,15,.55)}
.kv-callout .kv-ic{flex:none;width:42px;height:42px;border-radius:10px;background:var(--brass);color:#fff;display:flex;align-items:center;justify-content:center}
.kv-callout .kv-ic svg{width:23px;height:23px}
.seo-band .prose .kv-callout h3{margin:0 0 .35rem;text-align:left;font-size:1.12rem}
.seo-band .prose .kv-callout p{margin:0}
.area-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin:1.05rem auto .2rem;max-width:780px}
.area-chips span{display:inline-flex;align-items:center;gap:.34rem;font-size:.92rem;font-weight:500;background:#fff;border:1px solid var(--stone-3);border-radius:999px;padding:.36rem .8rem .36rem .62rem;color:var(--ink)}
.area-chips span svg{width:12px;height:12px;color:var(--brass);flex:none}

/* ============ HOMEPAGE SERVICE TILES (photo bg + gradient + label) ============ */
.svc-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:.5rem}
.svc-tile{position:relative;display:block;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 14px 36px -24px rgba(24,21,15,.5)}
.svc-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.svc-tile::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(18,15,10,.86) 0%,rgba(18,15,10,.30) 46%,transparent 72%)}
.svc-tile-label{position:absolute;left:0;right:0;bottom:0;z-index:1;display:flex;align-items:center;
  justify-content:space-between;gap:.5rem;padding:1rem 1.15rem;color:#fff;font-family:var(--ff-display);
  font-weight:600;font-size:1.14rem;letter-spacing:-.01em;line-height:1.2}
.svc-tile-arrow{color:var(--brass);font-size:1.2rem;transition:transform .3s ease;flex:none}
.svc-tile:hover img{transform:scale(1.06)}
.svc-tile:hover .svc-tile-arrow{transform:translateX(5px)}
@media(max-width:780px){ .svc-tiles{grid-template-columns:repeat(2,1fr);gap:.7rem} }
@media(max-width:430px){ .svc-tiles{grid-template-columns:1fr} }

/* ============ ARTICLES / BLOG ============ */
.article-body{font-size:1.04rem;line-height:1.68}
.article-body h2{font-family:var(--ff-display);font-size:clamp(1.3rem,2.6vw,1.7rem);margin:1.5rem 0 .5rem;letter-spacing:-.01em}
.article-body h3{font-size:1.1rem;margin:1.05rem 0 .35rem}
.article-body p{margin:0 0 .85rem}
.article-body ul,.article-body ol{margin:0 0 1rem;padding-left:1.25rem}
.article-body li{margin:.3rem 0}
.article-body table{width:100%;border-collapse:collapse;margin:1.3rem 0;font-size:.98rem}
.article-body th,.article-body td{border:1px solid var(--line,#e0d8ca);padding:.62rem .85rem;text-align:left;vertical-align:top}
.article-body thead th{background:var(--stone,#efeae1);font-family:var(--ff-display);font-weight:600}
.article-body tbody tr:nth-child(even){background:rgba(169,132,76,.06)}
.article-cta{margin-top:2.4rem;padding:1.6rem 1.8rem;background:var(--ink,#18150f);color:#fff;border-radius:var(--radius-lg,8px)}
.article-cta h3{margin:0 0 .4rem;color:#fff;font-family:var(--ff-display);font-size:1.3rem}
.article-cta p{margin:0 0 1.1rem;color:rgba(255,255,255,.82)}
.article-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:.4rem}
.article-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line,#e7e0d3);border-radius:var(--radius-lg,8px);overflow:hidden;text-decoration:none;color:inherit;transition:transform .25s ease,box-shadow .25s ease}
.article-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px -26px rgba(24,21,15,.55)}
.article-card img{width:100%;height:auto;aspect-ratio:16/10;object-fit:cover}
.article-card .ac-body{padding:1.1rem 1.15rem 1.3rem;display:flex;flex-direction:column;flex:1}
.article-card .ac-date{font-size:.8rem;color:var(--brass,#a9844c);font-weight:600;letter-spacing:.02em;margin-bottom:.3rem}
.article-card h3{font-family:var(--ff-display);font-size:1.12rem;line-height:1.25;margin:0 0 .45rem}
.article-card p{font-size:.94rem;color:var(--muted,#6b6354);margin:0 0 .9rem;flex:1}
.article-card .more{font-weight:600;color:var(--brass,#a9844c);font-size:.92rem}
@media(max-width:880px){ .article-cards{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .article-cards{grid-template-columns:1fr} }

/* ============ TIKTOK CAROUSEL + PLAYER ============ */
.tt-section{background:var(--ink,#18150f);color:#fff}
.tt-section .eyebrow{color:var(--brass,#a9844c)}
.tt-section h2{color:#fff}
.tt-section .lead{color:rgba(255,255,255,.8)}
.tt-viewport{overflow:hidden;margin-top:1.9rem;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 4%,#000 96%,transparent);
  mask-image:linear-gradient(to right,transparent,#000 4%,#000 96%,transparent)}
.tt-track{display:flex;flex-wrap:nowrap;gap:1.1rem;width:max-content;padding:.6rem 1.1rem;
  animation:tt-marquee 52s linear infinite;will-change:transform}
.tt-track:has(.tt-card:hover){animation-play-state:paused}   /* pause only the card you hover */
@keyframes tt-marquee{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.tt-card{position:relative;flex:0 0 auto;width:clamp(232px,72vw,272px);aspect-ratio:9/16;border:0;padding:0;
  border-radius:14px;overflow:hidden;cursor:pointer;background:#000;
  box-shadow:0 18px 40px -22px rgba(0,0,0,.7);transition:transform .3s ease}
.tt-card:hover{transform:translateY(-4px)}
.tt-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
video.tt-video{background:#000}
.tt-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.72) 0%,rgba(0,0,0,.05) 45%,rgba(0,0,0,.15) 100%)}
.tt-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:62px;height:62px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#18150f;background:rgba(255,255,255,.92);
  padding-left:3px;transition:transform .25s ease,background .25s ease}
.tt-card:hover .tt-play{transform:translate(-50%,-50%) scale(1.08);background:var(--brass,#a9844c);color:#fff}
.tt-cap{position:absolute;left:0;right:0;bottom:0;z-index:1;padding:1rem .9rem 1.15rem;color:#fff;text-align:center;
  font-size:1.12rem;line-height:1.25;font-weight:600;font-family:var(--ff-display,Georgia,serif);letter-spacing:-.005em}
/* modal player */
.tt-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;
  background:rgba(12,10,7,.86);backdrop-filter:blur(6px)}
.tt-modal.open{display:flex}
.tt-frame{width:min(92vw,325px);height:min(86vh,745px);border-radius:14px;overflow:hidden;background:#000;
  box-shadow:0 30px 80px -30px rgba(0,0,0,.8)}
.tt-frame iframe{width:100%;height:100%;border:0;display:block}
.tt-demo{display:flex;align-items:center;justify-content:center;height:100%;padding:2rem;text-align:center;
  color:#fff;font-size:1rem;background:#18150f}
.tt-close{position:fixed;top:max(14px,env(safe-area-inset-top));right:max(14px,env(safe-area-inset-right));
  z-index:1002;width:46px;height:46px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;border:0;background:rgba(20,16,13,.72);color:#fff;font-size:30px;line-height:1;
  -webkit-tap-highlight-color:transparent;cursor:pointer}
.tt-close:hover{background:rgba(255,255,255,.28)}
@media(prefers-reduced-motion:reduce){ .tt-track{animation:none} .tt-viewport{overflow-x:auto} }

/* ============ MOBILE HARDENING (final QA pass) ============ */
body{overflow-x:clip}                       /* belt-and-suspenders against any stray horizontal scroll */
@media(max-width:560px){
  .article-body{font-size:1rem;line-height:1.7}
  .article-body table{font-size:.85rem}
  .article-body th,.article-body td{padding:.5rem .55rem}
  .tt-frame{width:94vw;height:min(82vh,700px)}
}

/* ============ SPACING + MOBILE BUTTON FIXES + QUOTE MODAL (QA pass 2) ============ */
/* tighter vertical rhythm (less dead space, esp. TikTok + the gap under it) */
section{padding:clamp(1.9rem,3.8vw,3.1rem) 0}
.tt-section{padding-top:clamp(2rem,4vw,3rem);padding-bottom:clamp(1.3rem,3vw,2rem)}
.tt-viewport{margin-top:1.3rem}
.section-head{margin-bottom:1.5rem}

/* buttons never exceed their container; long labels wrap instead of overflowing */
.btn{max-width:100%;white-space:normal;text-align:center}
@media(max-width:560px){
  .btn-lg{padding:.9rem 1.15rem;font-size:1rem}
  .hero-cta{gap:.6rem}
  .hero-cta .btn{flex:1 1 100%;justify-content:center}
  .cta-band .btn{width:100%;justify-content:center}
}
@media(max-width:400px){ .callbar a{font-size:.9rem;padding:.8rem .3rem} }

/* Pyydä tarjous popup */
.q-modal{position:fixed;inset:0;z-index:1100;display:none;align-items:center;justify-content:center;
  padding:1rem;background:rgba(18,15,10,.6);backdrop-filter:blur(6px)}
.q-modal.open{display:flex;animation:qfade .22s ease}
@keyframes qfade{from{opacity:0}to{opacity:1}}
.q-card{position:relative;width:min(100%,430px);max-height:96vh;overflow:auto;background:var(--paper);
  border:1px solid var(--stone-3);border-radius:18px;padding:clamp(1.3rem,4vw,1.9rem);
  box-shadow:0 40px 100px -28px rgba(0,0,0,.6);animation:qpop .26s cubic-bezier(.2,.7,.2,1)}
@keyframes qpop{from{transform:translateY(14px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.q-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brass);margin:0 0 .35rem}
.q-card h3{font-family:var(--ff-display);font-weight:600;font-size:clamp(1.4rem,5vw,1.65rem);
  color:var(--ink);margin:0 0 .9rem;letter-spacing:-.01em;line-height:1.05}
.q-form{display:flex;flex-direction:column;gap:.6rem}
.q-row{display:flex;flex-direction:column;gap:.6rem}
.q-field{display:flex;flex-direction:column;gap:.25rem;margin:0}
.q-field>span{font-size:.78rem;font-weight:600;color:var(--ink);letter-spacing:.01em}
.q-input{position:relative;display:block}
.q-input svg{position:absolute;left:.8rem;top:50%;transform:translateY(-50%);
  width:16px;height:16px;color:var(--brass);pointer-events:none}
.q-field input,.q-field textarea{width:100%;font:inherit;font-size:16px;color:var(--ink);
  background:#fff;border:1px solid var(--stone-3);border-radius:10px;padding:.6rem .8rem;
  transition:border-color .18s ease,box-shadow .18s ease}
.q-input input{padding-left:2.4rem}
.q-field textarea{resize:vertical;min-height:58px}
.q-field input::placeholder,.q-field textarea::placeholder{color:#a89e8c}
.q-field input:focus,.q-field textarea:focus{outline:0;border-color:var(--brass);
  box-shadow:0 0 0 3px rgba(169,132,76,.18)}
.q-submit{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  margin-top:.35rem;min-height:50px;background:var(--ink);color:#fff!important;border:0;border-radius:11px;
  font-weight:700;font-size:1.02rem;cursor:pointer;transition:background .2s ease,gap .2s ease}
.q-submit:hover{background:var(--brass);color:#1c1812!important;gap:.8rem}
.q-trust{display:flex;justify-content:center;flex-wrap:wrap;gap:.3rem 1rem;margin-top:.7rem}
.q-trust span{position:relative;font-size:.75rem;font-weight:600;color:var(--ink-2);padding-left:1.02rem}
.q-trust span::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:13px;height:13px;border-radius:50%;background:var(--brass)
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6 9 17l-5-5'/></svg>") center/9px no-repeat}
.q-or{text-align:center;color:var(--ink-2);font-size:.88rem;margin:.7rem 0 0}
.q-or a{color:var(--ink);font-weight:700;text-decoration:none;border-bottom:1px solid var(--brass)}
.q-close{position:absolute;top:.7rem;right:.7rem;width:40px;height:40px;border:0;border-radius:50%;
  background:rgba(24,21,15,.05);font-size:1.5rem;line-height:1;cursor:pointer;color:var(--ink-2);
  display:flex;align-items:center;justify-content:center;transition:background .18s,color .18s}
.q-close:hover{background:rgba(24,21,15,.1);color:var(--ink)}
@media(max-width:480px){
  .q-card{border-radius:16px;padding:1.25rem 1.15rem}
  .q-form{gap:.5rem}
  .q-row{gap:.5rem}
}
@media(prefers-reduced-motion:reduce){.q-modal.open,.q-card{animation:none}}

/* ============ "MUUT PALVELUT" IMAGE CAROUSEL ============ */
.svc-carousel{position:relative;margin-top:1.1rem}
.svc-ctrack{display:flex;gap:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch;cursor:grab;
  padding:.4rem .2rem 1.2rem;scrollbar-width:none;-ms-overflow-style:none;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 2.5%,#000 97.5%,transparent 100%);
          mask-image:linear-gradient(to right,transparent 0,#000 2.5%,#000 97.5%,transparent 100%)}
.svc-ctrack::-webkit-scrollbar{display:none}
.svc-ctrack.dragging{cursor:grabbing}
.svc-ctrack.dragging .svc-ctile{pointer-events:none}
.svc-ctile{position:relative;flex:0 0 auto;width:clamp(200px,62vw,250px);aspect-ratio:4/5;
  border-radius:14px;overflow:hidden;text-decoration:none;background:#0c0a07;
  box-shadow:0 16px 38px -24px rgba(24,21,15,.6);transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s ease}
.svc-ctile:hover{transform:translateY(-4px);box-shadow:0 26px 54px -26px rgba(24,21,15,.72)}
.svc-ctile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.svc-ctile:hover img{transform:scale(1.07)}
.svc-ctile-shade{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(18,15,10,.88) 0%,rgba(18,15,10,.28) 52%,transparent 82%)}
.svc-ctile-label{position:absolute;left:0;right:0;bottom:0;z-index:1;display:flex;align-items:center;
  justify-content:space-between;gap:.5rem;padding:1rem 1rem 1.1rem;color:#fff;font-family:var(--ff-display);
  font-weight:600;font-size:1.08rem;line-height:1.22;letter-spacing:-.01em}
.svc-ctile-label .arrow{color:var(--brass,#a9844c);transition:transform .3s ease;flex:none;font-size:1.15rem}
.svc-ctile:hover .svc-ctile-label .arrow{transform:translateX(5px)}
.svc-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;
  border-radius:50%;border:1px solid var(--line,#e0d8ca);background:rgba(255,255,255,.97);color:var(--ink,#18150f);
  font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 22px -8px rgba(0,0,0,.45);transition:opacity .3s ease,background .2s ease,color .2s ease,transform .2s ease}
.svc-arrow:hover{background:var(--ink,#18150f);color:#fff;border-color:var(--ink,#18150f);transform:translateY(-50%) scale(1.06)}
.svc-arrow.prev{left:-6px}.svc-arrow.next{right:-6px}
.svc-arrow.is-off{opacity:0;pointer-events:none}
@media(max-width:640px){ .svc-arrow{display:none} }

/* ============ NEW BRAND LOGO (SVG mark + wordmark) ============ */
.brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;line-height:1;padding:0}
.brand-mark{width:42px;height:42px;flex:none;border-radius:11px;display:block;box-shadow:0 6px 16px -8px rgba(24,21,15,.5)}
.brand-text{display:flex;flex-direction:column;justify-content:center}
.brand .brand-name{font-family:var(--ff-display);font-weight:700;font-size:1.5rem;color:var(--ink,#18150f);letter-spacing:-.015em;line-height:1}
.brand .brand-tag{font-family:var(--ff-body);font-weight:700;font-size:.58rem;letter-spacing:.2em;color:var(--brass,#a9844c);margin-top:4px;text-transform:uppercase}
.brand--light .brand-name{color:#fff}
.brand:hover .brand-mark{transform:translateY(-1px)}
.brand-mark{transition:transform .2s ease}
@media(max-width:560px){
  .brand-mark{width:36px;height:36px;border-radius:9px}
  .brand .brand-name{font-size:1.26rem}
  .brand .brand-tag{font-size:.5rem;letter-spacing:.16em}
}

/* ============ DROPDOWN OPENS ON HOVER (desktop) ============ */
@media(min-width:861px){
  .has-mega:hover .mega{display:grid}
  .has-mega:hover .mega-toggle .caret{transform:rotate(180deg)}
  /* let the Palvelut item fill the full navbar height so the dropdown drops from
     the navbar's bottom border (not the middle of the bar); link stays centered */
  .nav-links{align-self:stretch}
  .nav-list{align-self:stretch}
  .nav-list>li.has-mega{align-self:stretch;display:flex;align-items:center}
  .has-mega::after{content:"";position:absolute;left:0;right:0;top:100%;height:.55rem} /* hover bridge, no gap */
}

/* ============ "SUOMALAISTA PALVELUA" FLAG BADGE (footer) ============ */
.fi-badge{display:inline-flex;align-items:center;gap:.55rem;margin-top:1.2rem}
.fi-flag{width:36px;height:auto;flex:none;display:block}
.fi-text{font-family:var(--ff-display);font-weight:600;font-size:.95rem;line-height:1.12;
  color:#e8e3d8;letter-spacing:.005em}

/* ============ BRAND OPTION C (wordmark + hand-drawn underline) — overrides ============ */
.brand{display:inline-flex;align-items:center;gap:0;text-decoration:none;line-height:1;padding:0}
.brand-text{display:flex;flex-direction:column}
.brand-namewrap{position:relative;display:inline-block}
.brand .brand-name{font-family:var(--ff-display);font-weight:600;font-size:1.6rem;color:var(--ink,#18150f);letter-spacing:-.02em;line-height:.92}
.brand-underline{position:absolute;left:-2px;bottom:-6px;width:calc(100% + 6px);height:8px}
.brand .brand-tag{font-family:var(--ff-body);font-weight:700;font-size:.6rem;letter-spacing:.2em;color:var(--brass,#a9844c);margin-top:9px;text-transform:uppercase}
.brand--light .brand-name{color:#fff}
@media(max-width:560px){ .brand .brand-name{font-size:1.35rem} .brand .brand-tag{font-size:.52rem;letter-spacing:.15em} }

/* ============ REVIEWS / TESTIMONIALS (referenssit) ============ */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:1.8rem}
.review{position:relative;background:#fff;border:1px solid var(--line,#e7e0d3);border-radius:12px;
  padding:1.7rem 1.6rem 1.5rem;box-shadow:0 14px 36px -28px rgba(24,21,15,.5)}
.review::before{content:"\201C";position:absolute;top:.2rem;left:1rem;font-family:var(--ff-display,Georgia,serif);
  font-size:3.4rem;line-height:1;color:var(--brass,#a9844c);opacity:.28}
.review .stars{position:relative;color:var(--brass,#a9844c);font-size:1.05rem;letter-spacing:.12em;margin-bottom:.7rem}
.review blockquote{margin:0;font-size:1.1rem;line-height:1.6;color:var(--ink,#18150f)}
.review figcaption{margin-top:1.1rem;display:flex;flex-direction:column;gap:.1rem}
.review .who{font-family:var(--ff-display,serif);font-weight:600;font-size:1.05rem}
.review .role{color:var(--muted,#6b6354);font-size:.95rem}
@media(max-width:880px){ .reviews{grid-template-columns:1fr 1fr} }
@media(max-width:560px){ .reviews{grid-template-columns:1fr} }

/* =========================================================
   NAVBAR REDESIGN (top utility bar + main row, mobile panel)
   ========================================================= */
body{font-size:17.5px}
.site-head{position:sticky;top:0;z-index:200;background:var(--paper);border-bottom:1px solid var(--stone-3);box-shadow:0 2px 10px -8px rgba(24,21,15,.35)}

/* top utility bar */
.topbar{background:var(--ink);color:#e9e6df}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:40px}
.topbar-left{display:flex;align-items:center;gap:1.6rem}
.tb-link{display:inline-flex;align-items:center;gap:.45rem;color:#e9e6df;text-decoration:none;font-weight:500;font-size:.9rem}
.tb-link svg{width:15px;height:15px;color:var(--brass)}
.tb-link:hover{color:#fff}
.tb-muted{color:rgba(233,230,223,.66);font-size:.84rem;letter-spacing:.01em}

/* main nav row */
.nav{background:transparent;padding:0}
.nav-inner{display:flex;align-items:center;gap:1.5rem;min-height:78px}
.nav-links{display:flex;align-items:center;gap:2.2rem;margin-left:auto}
.nav-list{display:flex;align-items:center;gap:.2rem;list-style:none;margin:0;padding:0}
.nav-list>li{position:relative}
.nav-list>li>a{display:inline-flex;align-items:center;gap:.3rem;padding:.55rem .85rem;border-radius:6px;color:var(--ink);text-decoration:none;font-weight:600;font-size:1.02rem;line-height:1}
.nav-list>li>a:hover{color:var(--brass);background:rgba(169,132,76,.08)}
.nav-actions{display:flex;align-items:center;gap:1.1rem}
.nav-phone{display:inline-flex;align-items:center;gap:.45rem;color:var(--ink);text-decoration:none;font-weight:700;font-size:1.02rem;white-space:nowrap}
.nav-phone svg{width:17px;height:17px;color:var(--brass)}
.nav-phone:hover{color:var(--brass)}
.nav-cta{background:var(--ink);color:#fff!important;padding:.72rem 1.3rem;border-radius:6px;font-weight:700;font-size:1.02rem;white-space:nowrap;text-decoration:none;transition:background .2s ease}
.nav-cta:hover{background:var(--brass)}
.caret{font-size:.78em;transition:transform .2s ease}

/* mega menu position under Palvelut */
.has-mega{position:relative}
.mega{position:absolute;top:100%;left:0;display:none;grid-auto-flow:column;grid-template-rows:repeat(6,auto);
  gap:.1rem 2.4rem;background:var(--paper);border:1px solid var(--stone-3);border-top:2px solid var(--brass);
  border-radius:0 0 10px 10px;padding:1.4rem 1.6rem;box-shadow:0 26px 50px -28px rgba(24,21,15,.5);min-width:520px;margin-top:0}
.has-mega::after{content:"";position:absolute;left:0;right:0;top:100%;height:.8rem}
@media(hover:hover) and (pointer:fine){ .has-mega:hover .mega{display:grid} .has-mega:hover .caret{transform:rotate(180deg)} }
.has-mega:focus-within .mega{display:grid}
.mega-col{display:flex;flex-direction:column;gap:.1rem;min-width:200px}
.mega-h{font-family:var(--ff-display);font-weight:700;font-size:.8rem;color:var(--brass);text-transform:uppercase;letter-spacing:.08em;margin:.2rem 0 .35rem}
.mega-col a{color:var(--ink);text-decoration:none;font-size:1rem;font-weight:500;padding:.32rem 0}
.mega-col a:hover{color:var(--brass)}
.mega-foot{grid-row:auto;border-top:1px solid var(--stone-3);padding-top:.7rem;margin-top:.4rem}
.mega-all{font-weight:700;color:var(--brass)!important}

/* burger */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;margin-left:auto;background:none;border:0;cursor:pointer;padding:0}
.burger span{width:26px;height:2px;background:var(--ink);display:block;transition:.25s;margin:0 auto}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---- mobile menu (big text, large tap targets) ---- */
@media(max-width:900px){
  .topbar{display:none}
  /* backdrop-filter on the header makes it a containing block for position:fixed,
     which would shrink the menu panel to the header height — disable it on mobile */
  .site-head{backdrop-filter:none;-webkit-backdrop-filter:none}
  .burger{display:flex}
  .nav-inner{min-height:92px}
  .nav-links{position:fixed;top:92px;left:0;right:0;bottom:0;margin:0;flex-direction:column;align-items:stretch;
    justify-content:flex-start;gap:0;background:var(--paper);
    padding:.4rem 1.4rem calc(2.4rem + env(safe-area-inset-bottom));
    overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
    transform:translateY(-10px);opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s ease;
    box-shadow:0 24px 40px -22px rgba(0,0,0,.35)}
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-list{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .nav-list>li{border-bottom:1px solid var(--stone-3)}
  .nav-list>li>a{display:flex;align-items:center;justify-content:space-between;
    min-height:60px;padding:1.15rem .25rem;font-size:1.4rem;font-weight:600;line-height:1.2;
    color:var(--ink);border-radius:0}
  .nav-list>li>a:hover,.nav-list>li>a:active{background:none;color:var(--brass)}
  .nav-list .caret{font-size:1.15rem;color:var(--brass);transition:transform .25s ease}
  /* Palvelut submenu: single column of large tappable rows */
  .mega{position:static;display:none;grid-template-columns:1fr;grid-template-rows:none;grid-auto-flow:row;
    min-width:0;width:100%;border:0;box-shadow:none;border-radius:0;background:transparent;padding:.1rem 0 .7rem;gap:0}
  .has-mega.open .mega{display:grid}
  .has-mega.open .caret{transform:rotate(180deg)}
  .mega-feature{display:none}                            /* hide photo tile inside mobile menu */
  .mega-col,.mega-group{display:flex;flex-direction:column}
  .mega-h{display:block;color:var(--brass);font-size:.82rem;font-weight:700;letter-spacing:.09em;
    text-transform:uppercase;padding:1.1rem .25rem .15rem}
  .mega-group a{display:flex;align-items:center;min-height:52px;
    padding:.7rem .25rem .7rem 1rem;font-size:1.16rem;color:var(--ink-2);
    border-top:1px solid rgba(0,0,0,.05)}
  .mega-h + a{border-top:0}
  .mega-group a:active{color:var(--brass)}
  .mega-foot{grid-column:1/-1;display:flex;flex-direction:column;gap:.8rem;margin-top:1.1rem}
  .mega-all,.mega-cta{display:flex;align-items:center;justify-content:center;text-align:center}
  .mega-all{min-height:54px;padding:1rem;border:1px solid var(--stone-3);border-radius:9px;font-size:1.12rem;font-weight:600}
  .mega-cta{min-height:54px;padding:1.05rem;border-radius:9px;font-size:1.12rem;font-weight:700}
  /* bottom action buttons */
  .nav-actions{flex-direction:column;align-items:stretch;gap:.8rem;margin-top:1.6rem}
  .nav-phone{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:56px;padding:1.1rem;
    border:1.5px solid var(--ink);border-radius:10px;font-size:1.2rem;font-weight:700;color:var(--ink)}
  .nav-cta{display:flex;align-items:center;justify-content:center;text-align:center;min-height:56px;
    padding:1.15rem;border-radius:10px;font-size:1.2rem;font-weight:700}
}
@media(max-width:520px){ .mega{grid-template-columns:1fr} }

/* ============ OFFICIAL TALOX LOGO IMAGE (overrides wordmark brand) ============ */
.brand{display:inline-flex;align-items:center;gap:0;line-height:0;text-decoration:none;padding:0}
.brand-logo{height:36px;width:auto;display:block}
@media(max-width:900px){ .brand-logo{height:42px} }

/* TikTok section: own colour (deep teal) so it separates from the brown sections */
.tt-section{background:#13322e}
.tt-section .lead{color:rgba(255,255,255,.82)}

/* =========================================================
   MEGA-MENU REDESIGN (featured tile + 3 grouped columns)
   ========================================================= */
.has-mega{position:relative}
.mega{position:absolute;top:100%;left:0;right:auto;display:none;
  grid-template-columns:188px repeat(3,minmax(152px,1fr));grid-auto-flow:row;gap:0;
  background:var(--paper);border:1px solid var(--stone-3);border-top:2px solid var(--brass);
  border-radius:0 0 12px 12px;box-shadow:0 30px 60px -28px rgba(24,21,15,.5);
  width:max-content;min-width:0;max-width:calc(100vw - 2rem);padding:0;overflow:hidden;z-index:60}
.has-mega::after{content:"";position:absolute;left:0;right:0;top:100%;height:.7rem}
@media(hover:hover) and (pointer:fine){ .has-mega:hover .mega{display:grid} .has-mega:hover .caret{transform:rotate(180deg)} }
.has-mega:focus-within .mega{display:grid}

/* featured tile (left) */
.mega-feature{position:relative;display:flex;align-items:flex-end;min-height:100%;text-decoration:none;
  overflow:hidden;background:#111;min-height:230px}
.mega-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.mega-feature:hover img{transform:scale(1.05)}
.mega-feat-cap{position:relative;z-index:1;width:100%;padding:1.1rem 1.1rem 1.15rem;color:#fff;
  background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.15) 70%,transparent 100%)}
.mf-tag{display:block;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);font-weight:700}
.mf-title{display:block;font-family:var(--ff-display);font-weight:700;font-size:1.18rem;margin:.18rem 0 .25rem;line-height:1.1}
.mf-link{font-size:.84rem;color:rgba(255,255,255,.86)}

/* grouped link columns */
.mega-col{display:flex;flex-direction:column;gap:1.2rem;padding:1.5rem 1.4rem}
.mega-col+.mega-col,.mega-feature+.mega-col{border-left:1px solid var(--stone-3)}
.mega-group{display:flex;flex-direction:column;gap:.05rem}
.mega-h{font-family:var(--ff-display);font-weight:700;font-size:.72rem;letter-spacing:.11em;text-transform:uppercase;
  color:var(--brass);margin-bottom:.45rem}
.mega-col a{color:var(--ink);text-decoration:none;font-size:1rem;font-weight:500;line-height:1.2;
  padding:.4rem .55rem;margin:0 -.55rem;border-radius:6px;transition:background .15s ease,color .15s ease}
.mega-col a:hover{color:var(--brass);background:rgba(169,132,76,.09)}

/* footer bar */
.mega-foot{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.95rem 1.4rem;background:var(--stone);border-top:1px solid var(--stone-3)}
.mega-all{font-weight:700;color:var(--brass)!important;text-decoration:none;font-size:.98rem}
.mega-all:hover{text-decoration:underline}
.mega-cta{background:var(--ink);color:#fff!important;text-decoration:none;font-weight:700;font-size:.92rem;
  padding:.6rem 1.1rem;border-radius:6px;white-space:nowrap}
.mega-cta:hover{background:var(--brass)}

/* mobile: inline expandable, no feature image, stacked */
@media(max-width:900px){
  .mega{position:static;display:none;grid-template-columns:1fr 1fr;width:auto;max-width:none;min-width:0;
    border:0;border-top:0;box-shadow:none;border-radius:0;background:transparent;padding:.3rem 0 .9rem;overflow:visible}
  .has-mega.open .mega{display:grid}
  .has-mega.open .caret{transform:rotate(180deg)}
  .mega-feature{display:none}
  .mega-col{padding:.4rem .2rem;gap:1rem;border-left:0!important}
  .mega-col a{font-size:1rem;padding:.5rem 0;margin:0}
  .mega-h{color:var(--ink-2,#4a4438)}
  .mega-foot{grid-column:1/-1;flex-direction:column;align-items:stretch;gap:.6rem;background:transparent;padding:.9rem 0 0}
  .mega-cta{text-align:center}
}
@media(max-width:520px){ .mega{grid-template-columns:1fr} }

/* ============ PALVELUT HUB: bigger centered section titles + bigger cards ============ */
.svc-group-h{grid-column:1/-1;text-align:center;font-family:var(--ff-display);font-weight:700;
  font-size:clamp(1.7rem,3.6vw,2.2rem);letter-spacing:-.015em;text-transform:none;color:var(--ink);
  line-height:1.12;margin:2.8rem 0 1.4rem}
.svc-group-h:first-child{margin-top:.4rem}
.svc-group-h::after{content:"";display:block;width:48px;height:3px;background:var(--brass);border-radius:2px;margin:.7rem auto 0}
.svc-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.8rem}
.svc-card .thumb{aspect-ratio:16/11}
.svc-card .body{padding:1.4rem 1.5rem 1.6rem}
.svc-card h3{font-size:1.42rem;margin-bottom:.4rem}
.svc-card p{font-size:1.06rem;line-height:1.55}
.svc-card .more{font-size:1rem}
@media(max-width:560px){ .svc-grid{grid-template-columns:1fr} }

/* Mega featured tile: stop long Finnish compound words from overflowing */
.mega{grid-template-columns:224px repeat(3,minmax(150px,1fr))}
.mega-feat-cap{padding:1rem .95rem 1.05rem}
.mf-title{font-size:1.05rem;line-height:1.16;overflow-wrap:break-word;word-break:break-word;hyphens:auto}
.mf-tag{margin-bottom:.1rem}
@media(max-width:900px){ .mega{grid-template-columns:1fr 1fr} }
@media(max-width:520px){ .mega{grid-template-columns:1fr} }

/* Mega feature: keep "Kylpyhuoneremontti" on one line + readable "Suosituin" */
.mega{grid-template-columns:244px repeat(3,minmax(150px,1fr))}
.mf-title{white-space:nowrap;word-break:normal;overflow-wrap:normal;hyphens:none;font-size:1rem;letter-spacing:-.01em}
.mf-tag{color:#ecc886}
.mega-feat-cap{padding:1rem .95rem 1.05rem;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.5) 55%,rgba(0,0,0,.12) 100%)}
@media(max-width:900px){ .mega{grid-template-columns:1fr 1fr} }
@media(max-width:520px){ .mega{grid-template-columns:1fr} }

/* ============ HOMEPAGE REFERENSSIT: overlay tiles ============ */
.ref-trip{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:1.9rem}
.ref-tile{position:relative;margin:0;border-radius:12px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;
  box-shadow:0 18px 40px -26px rgba(24,21,15,.55)}
.ref-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;border-radius:0;
  box-shadow:none;transition:transform .55s ease}
.ref-tile:hover img{transform:scale(1.06)}
.ref-tile::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to top,rgba(0,0,0,.74) 0%,rgba(0,0,0,.12) 46%,transparent 72%)}
.ref-tile figcaption{position:absolute;left:0;right:0;bottom:0;z-index:1;pointer-events:none;
  padding:1rem 1.15rem 1.1rem;color:#fff;font-family:var(--ff-display);font-weight:600;font-size:1.12rem;
  line-height:1.2;margin:0;text-shadow:0 1px 12px rgba(0,0,0,.45)}
@media(max-width:760px){ .ref-trip{grid-template-columns:1fr 1fr} }
@media(max-width:520px){ .ref-trip{grid-template-columns:1fr} }

/* =========================================================
   GLOBAL CENTERED LAYOUT (heroes, section titles, intros)
   ========================================================= */
.hero-content{text-align:center;margin-inline:auto;max-width:820px}
.hero-content .lead{margin-inline:auto;max-width:680px}
.hero-cta{justify-content:center}
.hero-trust{justify-content:center}

.section-head{text-align:center;margin-inline:auto;max-width:760px}
.section-head .lead,.section-head .muted,.section-head p{margin-inline:auto;max-width:700px}

/* section-level titles + their intro paragraphs */
section > .wrap > h2,
section > .wrap > h3,
section > .wrap > .eyebrow,
section > .wrap > p.lead,
section > .wrap > p.muted,
section > .wrap > p.intro{text-align:center}
section > .wrap > p.lead,
section > .wrap > p.muted,
section > .wrap > p.intro{margin-inline:auto;max-width:720px}

/* alternating image/text rows: center heading + text, keep lists readable */
.frow-text{text-align:center}
.frow-text ul,.frow-text ol{text-align:left;display:inline-block;margin-inline:auto}

/* CTA band text centered */
.cta-band{text-align:center}
.cta-band > div:last-child{justify-content:center}

/* prose section sub-headings centered (body copy stays left for readability) */
.prose > h2,.prose > h3{text-align:center}

/* safety net: center any section-level row that holds a single action button */
section > .wrap > div:has(> .btn:only-child),
section > .wrap > p:has(> .btn:only-child),
.tt-section > .wrap:has(> .btn:only-child){text-align:center}

/* =========================================================
   CONTENT BLOCKS: center the columns (text stays left to read)
   ========================================================= */
.prose{margin-inline:auto}

/* FAQ -> centered card-accordion */
.faq{margin-left:auto;margin-right:auto}
.faq details{border-top:0;border:1px solid var(--stone-3);border-radius:12px;background:var(--paper);
  padding:1.05rem 1.3rem;margin:0 0 .8rem;box-shadow:0 8px 22px -18px rgba(24,21,15,.5);
  transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;text-align:left}
.faq details:hover{border-color:#d9cdb4}
.faq details[open]{border-color:var(--brass);box-shadow:0 16px 34px -22px rgba(24,21,15,.5)}
.faq summary{display:flex;justify-content:space-between;align-items:center;gap:1rem;cursor:pointer;
  list-style:none;font-family:var(--ff-display);font-weight:600;font-size:1.14rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brass);font-size:1.5rem;line-height:1;flex:none;transition:transform .2s ease}
.faq details[open] summary::after{content:"–"}
.faq p{margin:.75em 0 0;color:var(--ink-2);line-height:1.62}

/* ============ "HOW IT'S DONE" NUMBERED PROCESS BAND ============ */
.how-band{background:var(--stone)}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;margin-top:2.1rem}
.how-step{text-align:center}
.how-num{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;
  background:var(--brass);color:#fff;font-family:var(--ff-display);font-weight:700;font-size:1.5rem;
  margin:0 auto 1rem;box-shadow:0 10px 22px -12px rgba(169,132,76,.7)}
.how-step h3{margin:0 0 .45rem;font-size:1.18rem}
.how-step p{margin:0;color:var(--ink-2);font-size:1rem;line-height:1.55}
@media(max-width:860px){ .how-grid{grid-template-columns:1fr 1fr;gap:1.8rem} }
@media(max-width:520px){ .how-grid{grid-template-columns:1fr} }

/* ============ "REMONTIN VAIHTOEHDOT" OPTIONS BAND (animated icons) ============ */
.opt-band{background:var(--ink);color:#fff}
.opt-band .section-head h2{color:#fff}
.opt-band .section-head .eyebrow{color:var(--brass)}
.opt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.2rem;margin-top:2.3rem}
.opt-card{text-align:center}
.opt-ic{width:64px;height:64px;margin:0 auto 1.1rem;color:var(--brass)}
.oic{width:100%;height:100%;display:block;animation:opt-float 4.5s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
.opt-card:nth-child(2) .oic{animation-delay:.7s}
.opt-card:nth-child(3) .oic{animation-delay:1.4s}
@keyframes opt-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.odrip{transform-box:fill-box;transform-origin:center;animation:opt-drip 2.4s ease-in infinite}
@keyframes opt-drip{0%{transform:translateY(0);opacity:0}15%{opacity:1}70%{opacity:1}100%{transform:translateY(11px);opacity:0}}
.obub{transform-box:fill-box;transform-origin:center;animation:opt-bub 3s ease-in-out infinite;opacity:.55}
.ob2{animation-delay:.5s}.ob3{animation-delay:1s}
@keyframes opt-bub{0%,100%{transform:translateY(0) scale(1);opacity:.45}50%{transform:translateY(-5px) scale(1.12);opacity:1}}
.ochk{stroke-dasharray:34;stroke-dashoffset:34;animation:opt-chk 3s ease-in-out infinite}
@keyframes opt-chk{0%,15%{stroke-dashoffset:34}45%,80%{stroke-dashoffset:0}100%{stroke-dashoffset:34}}
.opt-card h3{font-size:1.3rem;margin:0 0 1.1rem;color:#fff}
.opt-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}
.opt-card li{color:rgba(255,255,255,.82);font-size:1.02rem;line-height:1.45}
.opt-card li:last-child{color:var(--brass);font-weight:600;margin-top:.3rem}
@media(prefers-reduced-motion:reduce){ .oic,.odrip,.obub,.ochk{animation:none} .ochk{stroke-dashoffset:0} }
@media(max-width:820px){ .opt-grid{grid-template-columns:1fr;max-width:440px;margin-inline:auto;gap:2.4rem} }

/* options band: single shared CTA (no repeated per-card CTA) */
.opt-card li:last-child{color:rgba(255,255,255,.82);font-weight:400;margin-top:0}
.opt-cta{text-align:center;margin-top:2.4rem;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.opt-cta-note{color:rgba(255,255,255,.6);font-size:.92rem}

/* =========================================================
   PRE-FOOTER "JÄTÄ SOITTOPYYNTÖ" CALLBACK BAND
   ========================================================= */
.cb-band{background:#211c14;border-top:1px solid rgba(169,132,76,.22)}
.cb-in{display:grid;grid-template-columns:1fr 1.35fr;gap:2.6rem;align-items:center}
.cb-left h2,.cb-right h2{font-family:var(--ff-display);color:#fff;font-weight:700;line-height:1.12;
  font-size:clamp(1.45rem,2.6vw,1.95rem);margin:0 0 .55rem}
.cb-left p{color:rgba(255,255,255,.68);margin:0 0 1.1rem}
.cb-phone{color:#fff;font-weight:700;font-size:1.3rem;text-decoration:none;border-bottom:2px solid var(--brass);padding-bottom:2px}
.cb-phone:hover{color:var(--brass)}
.cb-form{margin:0}
.cb-fields{display:flex;background:#fff;border-radius:12px;padding:.4rem;gap:0;align-items:stretch;
  box-shadow:0 16px 36px -22px rgba(0,0,0,.5)}
.cb-fields select,.cb-fields input{border:0;background:transparent;padding:.8rem .9rem;font-family:var(--ff-body);
  font-size:1rem;color:var(--ink);min-width:0;flex:1 1 0}
.cb-fields select{flex:0 0 auto;cursor:pointer}
.cb-fields input::placeholder{color:#9a948a}
.cb-fields > select + input,.cb-fields > input + input{border-left:1px solid #ece7dd}
.cb-fields .btn{flex:0 0 auto;white-space:nowrap;border-radius:9px;margin-left:.35rem}
.cb-note{color:rgba(255,255,255,.55);font-size:.9rem;margin:.75rem 0 0}
@media(max-width:880px){
  .cb-in{grid-template-columns:1fr;gap:1.7rem}
  .cb-fields{flex-direction:column;background:transparent;padding:0;gap:.6rem;box-shadow:none}
  .cb-fields select,.cb-fields input{background:#fff;border-radius:9px}
  .cb-fields > select + input,.cb-fields > input + input{border-left:0}
  .cb-fields .btn{width:100%;margin-left:0;padding-block:.95rem}
}

/* =========================================================
   HOMEPAGE "NÄIN SE TOIMII" — big 2x2 numbered card grid
   ========================================================= */
.how4{display:grid;grid-template-columns:1fr 1fr;margin-top:2.4rem;
  border:1px solid var(--stone-3);border-radius:16px;overflow:hidden;background:var(--paper);
  position:relative;left:50%;transform:translateX(-50%);width:min(94vw,1500px)}
.how4-card{position:relative;padding:3.4rem 3.4rem;text-align:left;min-height:260px;
  display:flex;flex-direction:column;justify-content:flex-start;
  border-right:1px solid var(--stone-3);border-bottom:1px solid var(--stone-3);
  transition:background-color .28s ease}
.how4-card:nth-child(2n){border-right:0}
.how4-card:nth-last-child(-n+2){border-bottom:0}
.how4-n{display:block;font-family:var(--ff-display);font-weight:700;line-height:.9;
  font-size:clamp(3rem,5vw,4rem);color:var(--ink);margin-bottom:1.4rem;transition:color .28s ease}
.how4-card h3{display:flex;align-items:center;gap:.55rem;margin:0 0 .7rem;
  font-family:var(--ff-body);font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  font-size:1rem;color:var(--ink)}
.how4-card h3 .arr{color:var(--brass);transition:transform .28s ease;will-change:transform}
.how4-card p{margin:0;color:var(--ink-2);font-size:1.02rem;line-height:1.6;max-width:42ch}
.how4-card:hover{background:var(--stone)}
.how4-card:hover .how4-n{color:var(--brass)}
.how4-card:hover h3 .arr{transform:translateX(7px)}
@media(prefers-reduced-motion:reduce){.how4-card,.how4-n,.how4-card h3 .arr{transition:none}}
@media(max-width:720px){
  .how4{grid-template-columns:1fr}
  .how4-card{border-right:0;padding:2.2rem 1.7rem}
  .how4-card:nth-last-child(-n+2){border-bottom:1px solid var(--stone-3)}
  .how4-card:last-child{border-bottom:0}
}

/* Toiminta-alue chips: hover -> same teal as "Kaikki alueet" */
.area-chip{transition:background-color .2s ease,border-color .2s ease,color .2s ease}
.area-chip:hover{background:#8fd0c8!important;border-color:#8fd0c8!important;color:var(--ink)!important}

/* =========================================================
   MOBILE MENU CLEANUP (must come after the mega-menu block
   so these win on source order; also higher specificity)
   ========================================================= */
@media(max-width:900px){
  .mega .mega-feature{display:none!important}   /* hide the "Kylpyhuoneremontti" photo tile in the menu */
  .mega .mega-cta{display:none}                 /* drop the duplicate quote button inside Palvelut */
  .mega-foot{margin-top:.6rem}
  body.menu-open .callbar{opacity:0;pointer-events:none;transition:opacity .15s ease} /* no phone/tarjous duplication while menu open */
}

/* =========================================================
   MOBILE HEADER:  Logo  ----  [Pyydä tarjous] [burger]
   (the always-visible quote button lives in the header;
    the slide-down menu is navigation only)
   ========================================================= */
@media(min-width:901px){ .nav-cta--top{display:none!important} }
@media(max-width:900px){
  .nav-cta--top{display:inline-flex!important;align-items:center;justify-content:center;
    margin-left:auto;width:auto!important;min-height:0!important;
    padding:.64rem 1.05rem!important;font-size:1.05rem;font-weight:700;border-radius:10px;
    white-space:nowrap;line-height:1;text-align:center}
  .burger{margin-left:.55rem;width:48px;height:48px}
  .burger span{width:28px;height:2.5px}
  /* CTAs live in the header + bottom bar — keep the menu itself pure navigation */
  /* nav-actions are shown + restyled in the redesign block below */
  /* Pyydä tarjous is now in the header, so the bottom bar is a single big "Soita" button */
  .callbar a[data-quote]{display:none}
  .callbar a{flex:1;font-size:1.06rem;padding:.95rem}
  /* submenu readability: bigger service rows + clearer group labels */
  .mega-h{font-size:.92rem;padding:1.25rem .25rem .2rem}
  .mega-group a{font-size:1.22rem;min-height:56px;padding:.85rem .25rem .85rem 1rem}
}
@media(max-width:380px){
  .nav-cta--top{padding:.55rem .8rem!important;font-size:.96rem}
  .brand-logo{height:26px}
}

/* =========================================================
   MOBILE MENU — PROFESSIONAL REDESIGN  (final, authoritative)
   - header: Logo —— [Pyydä tarjous • gold energy] [big burger]
   - open:   Logo + X only, options & sub-options CENTERED,
             Soita + Pyydä tarjous energy buttons below
   ========================================================= */

/* ---- rotating golden "energy" halo (used on key CTAs) ---- */
@property --tlx-ang{syntax:"<angle>";initial-value:0deg;inherits:false}
@keyframes tlx-spin{to{--tlx-ang:360deg}}
/* gold border-beam — runs the edge/corners, never fills the button (no bg forced here) */
.energy{position:relative;z-index:0}
.energy::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:2px;z-index:1;pointer-events:none;
  background:conic-gradient(from var(--tlx-ang),
    transparent 0deg, transparent 250deg,
    rgba(246,223,166,0) 268deg, #c79a4e 312deg, #fff7e6 340deg, #f6dfa6 352deg, transparent 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  animation:tlx-spin 3.2s linear infinite}
.energy::after{content:"";position:absolute;inset:0;border-radius:inherit;z-index:1;pointer-events:none;
  box-shadow:0 0 0 1px rgba(233,200,125,.22)}
@media(prefers-reduced-motion:reduce){
  .energy::before{animation:none;background:none}
  .energy::after{box-shadow:0 0 0 1.5px rgba(233,200,125,.55)}
}
/* desktop: energy stays ONLY on the dark "Pyydä tarjous" button, never the phone text link */
@media(min-width:901px){ .nav-phone.energy::before,.nav-phone.energy::after{content:none} }
/* mobile energy buttons need a solid ink fill so the beam reads as a border */
@media(max-width:900px){ .nav-cta--top.energy,.nav-actions .energy{background:var(--ink)} }

@media(min-width:901px){ .nav-cta--top{display:none!important} }

@media(max-width:900px){
  /* --- header row --- */
  .nav-inner{gap:.5rem}
  .brand{margin-right:auto}                       /* logo hugs left, rest pushed right */
  .nav-cta--top{display:inline-flex!important;align-items:center;justify-content:center;
    margin-left:0;width:auto!important;min-height:0!important;
    padding:.6rem .95rem!important;font-size:.98rem;font-weight:700;border-radius:11px;
    white-space:nowrap;line-height:1;color:#fff!important}
  .burger{margin-left:.7rem;width:52px;height:52px;border-radius:12px}
  .burger span{width:30px;height:3px;border-radius:2px}
  body.menu-open .nav-cta--top{display:none!important}   /* open => header is just Logo + X */

  /* --- open panel: everything centered --- */
  .nav-links{padding:1.4rem 1.3rem calc(2.6rem + env(safe-area-inset-bottom));text-align:center}
  .nav-list{align-items:center}
  .nav-list>li{width:100%;border-bottom:1px solid var(--stone-3)}
  .nav-list>li>a{justify-content:center;gap:.5rem;font-size:1.5rem;font-weight:600;
    min-height:64px;padding:1.1rem .25rem}
  .nav-list .caret{font-size:1.05rem}

  /* Palvelut sub-options centered */
  .mega{justify-items:center}
  .mega-group{align-items:center;width:100%}
  .mega-h{text-align:center;font-size:.92rem;color:var(--brass);letter-spacing:.1em;
    padding:1.3rem 0 .35rem}
  .mega-group a{justify-content:center;text-align:center;width:100%;
    font-size:1.18rem;min-height:54px;padding:.8rem .25rem;
    border-top:1px solid rgba(0,0,0,.06);color:var(--ink-2)}
  .mega-h + a{border-top:0}
  .mega-foot{margin-top:1rem}
  .mega-all{justify-content:center;font-size:1.08rem;font-weight:600}

  /* --- Soita + Pyydä tarjous energy buttons under the options --- */
  .nav-actions{display:flex!important;flex-direction:column;align-items:center;gap:.95rem;
    margin-top:1.8rem;width:100%}
  .nav-actions .energy{display:flex;align-items:center;justify-content:center;gap:.55rem;
    width:100%;max-width:340px;min-height:58px;padding:1.05rem 1.2rem;border:0;border-radius:13px;
    font-size:1.18rem;font-weight:700;color:#fff!important;text-decoration:none}
  .nav-actions .nav-phone svg{width:20px;height:20px}

  /* bottom call-bar stays a single big "Soita" while menu is closed */
  .callbar a[data-quote]{display:none}
  .callbar a{flex:1;font-size:1.06rem;padding:.95rem}
}
@media(max-width:380px){
  .nav-cta--top{padding:.5rem .72rem!important;font-size:.9rem}
  .brand-logo{height:26px}
  .burger{width:48px;height:48px}
}

/* the scroll-anchor between header and hero must not generate a line box (caused a strip above the hero) */
#callbar-anchor{display:block;height:0;line-height:0;font-size:0}

/* mobile header spacing: big gap after logo, hamburger tight to the CTA */
@media(max-width:900px){
  .nav-inner{gap:.45rem}
  .brand{margin-right:auto;padding-right:.6rem}   /* logo left + clear gap before the CTA */
  .nav-cta--top{margin-left:0!important}
  .burger{margin-left:.1rem!important}             /* sits right next to Pyydä tarjous */
}
@media(max-width:400px){
  .brand-logo{height:36px}
  .nav-cta--top{padding:.5rem .72rem!important;font-size:.9rem}
  .burger{width:48px;height:48px}
}

/* =========================================================
   FIX: on mobile, the Palvelut submenu must be controlled ONLY by .open.
   The global ":focus-within .mega{display:grid}" rules kept it stuck open
   after tapping (the link retains focus), so re-tapping never closed it.
   ========================================================= */
@media(max-width:900px){
  .has-mega:focus-within .mega{display:none}   /* focus alone no longer opens it on touch */
  .has-mega.open .mega{display:grid}            /* .open is the single source of truth (declared last = wins) */
  .mega-foot{display:none}                       /* drop "Katso kaikki palvelut" / CTA from the mobile dropdown */
}

/* =========================================================
   FINAL mobile header layout (authoritative — declared last)
   Logo hard-left ····· big gap ····· [Pyydä tarjous]  [burger]
   ========================================================= */
@media(max-width:900px){
  .nav-inner{display:flex!important;align-items:center;flex-wrap:nowrap;gap:0!important}
  .brand{margin:0!important;flex:0 0 auto}                         /* logo pinned left */
  .nav-cta--top{margin:0 .7rem 0 auto!important;flex:0 0 auto}     /* auto-left pushes CTA+burger to the right; .7rem gap before burger */
  .burger{margin:0!important;flex:0 0 auto;width:52px;height:52px} /* hard right, beside the CTA */
  body.menu-open .nav-cta--top{display:none!important}            /* open => Logo + X only */
  body.menu-open .brand{margin-right:auto!important}              /* keep X pinned right when open */
}
@media(max-width:380px){
  .nav-cta--top{padding:.5rem .7rem!important;font-size:.88rem}
  .burger{width:48px;height:48px}
}

/* =========================================================
   HEADER LAYOUT via STRUCTURE (logo | right-group) — final word
   The right group (.nav-right) holds the CTA + burger as ONE unit,
   so space-between can't get confused by leftover auto-margins.
   ========================================================= */
.nav-right{display:none}                      /* desktop: hidden (desktop uses .nav-links + .nav-actions) */
@media(max-width:900px){
  .nav-inner{display:flex!important;align-items:center;justify-content:space-between!important;
    gap:.6rem!important;flex-wrap:nowrap}
  .brand{margin:0!important;flex:0 0 auto}            /* logo hard-left */
  .nav-right{display:flex!important;align-items:center;gap:.75rem;flex:0 0 auto} /* CTA + burger, 0.75rem apart, hard-right */
  .nav-cta--top{margin:0!important}
  .burger{margin:0!important}
}

/* =========================================================
   ROOT-CAUSE FIX: .nav is display:flex, so .nav-inner (its only
   child, with .wrap's margin:0 auto) was shrinking to content width
   and being CENTERED inside .nav. That collapsed the header layout.
   On mobile, make .nav a block so .nav-inner fills full width and its
   own space-between (logo | right-group) actually has room to work.
   ========================================================= */
@media(max-width:900px){
  .nav{display:block!important}
  .nav-inner{width:100%!important;max-width:none!important;margin:0!important}
}

/* =========================================================
   FIX GAP ABOVE HERO: the global section{padding} was adding a
   ~30px strip above the mobile hero image (hero image is in normal
   flow on mobile). The hero is full-bleed and manages its own
   internal spacing, so it should not take section padding.
   ========================================================= */
.hero,.hero-home,.page-hero{padding:0}

/* =========================================================
   BIGGER mobile logo + Pyydä tarjous button (final overrides)
   ========================================================= */
@media(max-width:900px){
  .brand-logo{height:52px!important}
  .nav-cta--top{padding:.78rem 1.2rem!important;font-size:1.12rem!important;border-radius:12px!important}
  .burger{width:50px!important;height:50px!important}
  .burger span{width:30px;height:3px}
}
@media(max-width:400px){
  .brand-logo{height:42px!important}
  .nav-cta--top{padding:.6rem .85rem!important;font-size:1rem!important}
  .burger{width:46px!important;height:46px!important}
  .nav-right{gap:.55rem!important}
}

/* =========================================================
   Taller Pyydä tarjous pill + bigger, redesigned hamburger
   (final overrides — keep big sizes down to small phones)
   ========================================================= */
@media(max-width:900px){
  .brand-logo{height:52px!important}
  .nav-cta--top{padding:.92rem 1.25rem!important;font-size:1.12rem!important;
    min-height:50px!important;border-radius:13px!important}
  /* redesigned hamburger: soft rounded button, rounded ink bars, short middle bar */
  .burger{display:flex!important;flex-direction:column;align-items:center;justify-content:center;gap:6px;
    width:56px!important;height:56px!important;padding:0;margin:0!important;cursor:pointer;
    background:rgba(24,21,15,.05);border:1px solid var(--stone-3);border-radius:14px}
  .burger span{display:block;width:26px;height:2.5px;border-radius:3px;background:var(--ink);
    transition:transform .3s cubic-bezier(.7,0,.2,1),opacity .2s,width .3s}
  .burger span:nth-child(2){width:18px}                       /* shorter middle bar */
  .burger[aria-expanded="true"] span:nth-child(1){transform:translateY(8.5px) rotate(45deg)}
  .burger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .burger[aria-expanded="true"] span:nth-child(3){width:26px;transform:translateY(-8.5px) rotate(-45deg)}
}
@media(max-width:360px){
  .brand-logo{height:44px!important}
  .nav-cta--top{padding:.74rem .9rem!important;font-size:1rem!important;min-height:46px!important}
  .burger{width:50px!important;height:50px!important}
  .nav-right{gap:.5rem!important}
}

/* bigger DESKTOP logo (mobile already enlarged separately) */
@media(min-width:901px){ .brand .brand-logo{height:44px!important;width:auto} .nav-inner{min-height:80px} }

/* ============ CINEMATIC HERO VIDEO (desktop, motion-safe) ============ */
.hero-video{z-index:0}
@media(max-width:680px){.hero-home .hero-video,.page-hero .hero-video{position:absolute;top:0;left:0;width:100%;height:auto;aspect-ratio:16/10;z-index:1;display:block}}
@media(prefers-reduced-motion:reduce){.hero-video{display:none!important}}

/* TikTok cards: lowkey muted autoplay preview on scroll (local clip per data-tt-id) */
.tt-card .tt-preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s ease;pointer-events:none}
.tt-card.tt-playing .tt-preview{opacity:1}
.tt-card.tt-playing .tt-play{opacity:0;transition:opacity .3s ease}

/* process: clean 4-up numbered cards (replaces the broken 2-col .step grid) */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.proc-card{padding:1.6rem 1.4rem 1.7rem;border:1px solid rgba(255,255,255,.1);border-top:2px solid var(--brass);border-radius:14px;background:rgba(255,255,255,.03)}
.proc-num{display:block;font-family:var(--ff-display);font-weight:700;font-size:1.7rem;line-height:1;color:var(--brass);margin-bottom:.9rem;opacity:.92}
.proc-card h3{margin:0 0 .45rem;color:var(--paper);font-family:var(--ff-display);font-size:1.16rem;line-height:1.2}
.proc-card p{margin:0;color:#cfccc4;font-size:.94rem;line-height:1.55}
@media(max-width:900px){ .proc-grid{grid-template-columns:repeat(2,1fr);gap:1rem} }
@media(max-width:560px){ .proc-grid{grid-template-columns:1fr} }

/* TikTok tiles: honest branded cover when no real screenshot is provided */
.tt-card--brand{background:radial-gradient(120% 85% at 50% 0%,#332e27 0%,#1c1813 58%,#141009 100%)}
.tt-card .tt-poster:not(.tt-haspic){opacity:0}
.tt-card.tt-has .tt-shade,.tt-card.tt-has .tt-play,.tt-card.tt-has .tt-cap{display:none}


/* Popup fallback link — guarantees playback even if the embed is blank */
.tt-frame{position:relative}
.tt-open{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;gap:.45rem;
  min-height:48px;padding:.7rem .8rem;font:600 .9rem/1.2 var(--ff-display,inherit);letter-spacing:.02em;
  color:#fff;text-decoration:none;background:rgba(20,16,13,.88);backdrop-filter:blur(3px);
  border-top:1px solid rgba(255,255,255,.14);-webkit-tap-highlight-color:transparent}
.tt-open:hover{background:var(--brass,#a9844c);color:#1c1812}

/* ===== Desktop navbar: push phone + Pyydä tarjous further right, more breathing room ===== */
@media(min-width:861px){
  .nav-list{gap:.5rem}                              /* menu items less cramped */
  .nav-links{gap:clamp(2rem,3.6vw,3.6rem)}          /* clear gap between menu and the phone/CTA cluster */
  .nav-actions{gap:1.4rem;margin-left:.5rem}        /* phone + CTA nudged right, more space between them */
}

/* Brand text fallback — shows if the nav logo image ever fails to load (never blank) */
.brand-fallback{font-family:var(--ff-display,Georgia,serif);font-weight:800;font-size:1.55rem;
  letter-spacing:.06em;color:var(--ink,#18150f);line-height:1;text-transform:uppercase}

/* ===== Professional nav lockup (icon + TaloX) — authoritative sizing ===== */
.nav .brand{padding:.15rem 0;align-items:center}
.nav .brand .brand-logo{width:auto!important;display:block!important;height:54px!important}
@media(min-width:901px){ .nav .brand .brand-logo{height:60px!important} .nav-inner{min-height:92px} }
@media(max-width:900px){ .nav .brand .brand-logo{height:48px!important} }
@media(max-width:400px){ .nav .brand .brand-logo{height:40px!important} }

/* Brand/logo must never shrink in the flex nav (was collapsing to width:0) */
.nav-inner .brand{flex:0 0 auto;min-width:max-content}

/* ===== Bigger mobile logo + hamburger (header stays 92px, menu offset unchanged) ===== */
@media(max-width:900px){
  .nav .brand .brand-logo{height:60px!important}
  .burger{width:58px!important;height:58px!important;gap:7px!important}
  .burger span{width:34px!important;height:3px!important;border-radius:3px}
  .burger span:nth-child(2){width:24px!important}
  .burger[aria-expanded="true"] span:nth-child(1){transform:translateY(10px) rotate(45deg)!important}
  .burger[aria-expanded="true"] span:nth-child(2){opacity:0!important}
  .burger[aria-expanded="true"] span:nth-child(3){width:34px!important;transform:translateY(-10px) rotate(-45deg)!important}
}
@media(max-width:400px){
  .nav .brand .brand-logo{height:52px!important}
  .burger{width:52px!important;height:52px!important}
  .burger span{width:31px!important}
}

/* Hero video crossfade — eliminates the still-image flash before the video plays */
.hero-video{opacity:0;transition:opacity .5s ease}
.hero-video.is-playing{opacity:1}

/* ===== Muut palvelut: smooth responsive grid (replaces the spiky scroll carousel) ===== */
.svc-mgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-top:1.2rem}
.svc-mgrid .svc-ctile{width:auto!important;flex:none!important;aspect-ratio:4/5}
.svc-mgrid .svc-ctile img{will-change:transform}
@media(max-width:620px){ .svc-mgrid{grid-template-columns:repeat(2,1fr);gap:.65rem} }

/* ===== Article hero: compact + landscape ===== */
.page-hero--article .hero-home-inner{min-height:min(40vh,330px)}
@media(max-width:680px){.page-hero--article .hero-bg{aspect-ratio:16/9}}

/* ============ FORM SUCCESS STATES (AJAX submit) ============ */
.form-success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.45rem;padding:1.6rem .5rem 2.2rem;animation:fs-fade .3s ease}
.form-success h3{margin:.5rem 0 0;font-family:var(--ff-display);font-size:1.6rem;color:var(--ink)}
.form-success p{margin:0;color:var(--ink-2,#5b554a);max-width:34ch}
@keyframes fs-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.check{width:72px;height:72px;display:block}
.check-circle{fill:none;stroke:#2bb673;stroke-width:3;stroke-dasharray:151;stroke-dashoffset:151;animation:draw-circle .55s cubic-bezier(.65,0,.45,1) forwards}
.check-mark{fill:none;stroke:#2bb673;stroke-width:4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:40;stroke-dashoffset:40;animation:draw-mark .3s .5s cubic-bezier(.65,0,.45,1) forwards}
@keyframes draw-circle{to{stroke-dashoffset:0}}
@keyframes draw-mark{to{stroke-dashoffset:0}}
.cb-sent{display:flex;align-items:center;justify-content:center;gap:.55rem;padding:.95rem 1rem;font-weight:600;color:#1f8f59;background:rgba(43,182,115,.09);border:1px solid rgba(43,182,115,.32);border-radius:10px;animation:fs-fade .3s ease}
.cb-sent .check{width:26px;height:26px}
@media(prefers-reduced-motion:reduce){.check-circle,.check-mark{animation:none;stroke-dashoffset:0}}
