/* ---------- self-hosted fonts (SIL OFL, served from this site) ---------- */
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:300;font-display:swap;src:url('assets/fonts/cormorant-garamond-300.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/cormorant-garamond-400.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/cormorant-garamond-500.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/cormorant-garamond-600.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:300;font-display:swap;src:url('assets/fonts/cormorant-garamond-300-italic.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:400;font-display:swap;src:url('assets/fonts/cormorant-garamond-400-italic.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('assets/fonts/cormorant-garamond-500-italic.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:300;font-display:swap;src:url('assets/fonts/jost-300.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/jost-400.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/jost-500.woff2') format('woff2');}

/* =========================================================
   Upgrade Yourself — "Die Mitte" palette + Logo 4 (Drop & Rise)
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* deep, fresh glacier-teal — depth without gloom */
  --deep:#143b49; --deep2:#0e2b37; --surface:#1b4757;
  --ink:#eef5f7; --muted:#9bb8c4; --line:rgba(255,255,255,.12);
  --ice:#54b6d8; --ice-d:#3a9ec2;
  --amber:#eaa463; --amber-d:#d2854a;
  /* light sections */
  --lite:#eef3f5; --lite2:#e3edf0; --card:#ffffff;
  --lite-ink:#11313d; --lite-muted:#5d7681; --lite-line:#dbe6ea;
  --maxw:1180px;
}
html{scroll-behavior:smooth}
body{background:var(--deep);color:var(--ink);font-family:"Jost",sans-serif;font-weight:300;line-height:1.75;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit}
em{font-style:italic}

h1,h2,h3{font-family:"Cormorant Garamond",serif;font-weight:300;line-height:1.06;letter-spacing:.005em}
.eyebrow{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;font-weight:500;color:var(--amber)}
.rule{width:54px;height:2px;background:var(--amber);margin:22px 0 30px;border-radius:2px}
.inner{max-width:var(--maxw);margin:0 auto;padding:0 40px}
section{padding:120px 0}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-family:"Jost",sans-serif;font-weight:400;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;padding:1rem 2rem;border-radius:5px;border:1px solid transparent;cursor:pointer;text-decoration:none;transition:transform .25s ease,background .25s ease,color .25s ease,border-color .25s ease}
.btn-ice{background:var(--ice);color:#08222c}
.btn-ice:hover{background:#6cc4e2;transform:translateY(-2px)}
.btn-warm{background:var(--amber);color:#3a1f08}
.btn-warm:hover{background:#f0b478;transform:translateY(-2px)}
.btn-outline{background:transparent;border-color:rgba(255,255,255,.32);color:var(--ink)}
.btn-outline:hover{border-color:var(--ice);color:var(--ice)}
.btn-ghost-d{background:transparent;border:1px solid var(--ice-d);color:var(--ice-d)}
.btn-ghost-d:hover{background:var(--ice-d);color:#fff}

/* ---------- nav ---------- */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px 40px;transition:background .35s ease,padding .35s ease,box-shadow .35s ease}
#nav.scrolled{background:rgba(14,43,55,.92);backdrop-filter:blur(12px);padding:14px 40px;box-shadow:0 1px 0 var(--line)}
.nav-logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.nav-logo svg{flex-shrink:0}
.nav-logo .nl-text{display:flex;flex-direction:column;line-height:1}
.nav-logo .nl-up{font-family:"Jost";font-weight:500;letter-spacing:.28em;text-transform:uppercase;font-size:.95rem;color:var(--ink)}
.nav-logo .nl-self{font-family:"Jost";font-weight:300;letter-spacing:.42em;text-transform:uppercase;font-size:.56rem;color:var(--ice);margin-top:5px}
.nav-links{list-style:none;display:flex;align-items:center;gap:34px}
.nav-links a{text-decoration:none;font-size:.82rem;font-weight:400;letter-spacing:.08em;color:var(--ink);opacity:1;transition:opacity .2s,color .2s,text-shadow .35s ease}
.nav-links a:hover{opacity:1;color:var(--ice)}
.nav-links a:not(.nav-cta){position:relative;text-shadow:0 1px 12px rgba(8,25,34,.55)}
#nav.scrolled .nav-links a:not(.nav-cta){text-shadow:none}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:0;bottom:-5px;height:1px;background:var(--ice);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.nav-links a:not(.nav-cta):hover::after{transform:scaleX(1)}
.nav-links .nav-cta{padding:.6rem 1.3rem;border:1px solid var(--amber);border-radius:4px;color:var(--amber);opacity:1;letter-spacing:.14em;text-transform:uppercase;font-size:.72rem}
.nav-links .nav-cta:hover{background:var(--amber);color:#3a1f08}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-burger span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('assets/eisbaden-eupen-aachen-hero.jpg') center/cover no-repeat;transform:scale(1.05)}
.hero-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,43,55,.62) 0%,rgba(14,43,55,.52) 45%,rgba(14,43,55,.78) 100%)}
.hero-content{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 40px;width:100%}
.hero-eyebrow{display:block;color:var(--amber);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;margin-bottom:26px;font-weight:500}
.hero-title{font-size:clamp(3rem,7vw,6rem);color:#fff;margin-bottom:30px;text-shadow:0 2px 30px rgba(8,25,34,.4)}
.hero-title em{color:var(--ice)}
.hero-sub{font-size:clamp(1rem,1.6vw,1.25rem);max-width:520px;color:#dbe8ee;margin-bottom:42px;line-height:1.85}
.hero-cta-row{display:flex;gap:14px;flex-wrap:wrap}
@media (prefers-reduced-motion: no-preference){
  .hero-eyebrow,.hero-title,.hero-sub,.hero-cta-row{opacity:0;transform:translateY(22px);animation:heroIn .85s cubic-bezier(.2,.7,.2,1) forwards}
  .hero-eyebrow{animation-delay:.15s}
  .hero-title{animation-delay:.3s}
  .hero-sub{animation-delay:.5s}
  .hero-cta-row{animation-delay:.65s}
}
@keyframes heroIn{to{opacity:1;transform:none}}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--muted);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase}
.scroll-cue .dot{width:1px;height:42px;background:linear-gradient(var(--ice),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- stats band ---------- */
.statband{background:var(--deep2);display:grid;grid-template-columns:repeat(4,1fr)}
.statband .s{text-align:center;padding:44px 20px;border-right:1px solid var(--line)}
.statband .s:last-child{border-right:none}
.statband .n{font-family:"Cormorant Garamond",serif;font-size:3.2rem;line-height:1;color:var(--ice);display:block}
.statband .s:nth-child(3) .n{color:var(--amber)}
.statband .l{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:12px;display:block}

/* ---------- LIGHT section base ---------- */
.light{background:var(--lite);color:var(--lite-ink)}
.light .eyebrow{color:var(--ice-d)}
.light h2{color:var(--lite-ink)}
.light h2 em{color:var(--ice-d)}
.section-head h2{font-size:clamp(2.4rem,4.4vw,3.6rem)}
.section-head p.intro{max-width:620px;color:var(--lite-muted);font-size:1.05rem;margin-top:4px}

/* ---------- workshops ---------- */
.ws-tabs{display:flex;flex-wrap:wrap;gap:12px;margin:40px 0 0}
.ws-tab{flex:1;min-width:160px;text-align:left;font-family:"Jost";background:var(--lite);border:1.5px solid var(--lite-line);border-radius:12px;padding:1rem 1.1rem;cursor:pointer;transition:.22s}
.ws-tab:hover{border-color:var(--ice)}
.ws-tab.active{background:var(--deep);border-color:var(--deep)}
.ws-tab .wt-ttl{display:block;font-weight:500;font-size:.95rem;color:var(--lite-ink);transition:.22s}
.ws-tab .wt-sub{display:block;font-size:.75rem;font-weight:500;color:#42606c;margin-top:4px;transition:.22s}
.ws-tab.active .wt-ttl{color:#fff}
.ws-tab.active .wt-sub{color:var(--ice)}
.ws-panel{display:none;grid-template-columns:1fr 1fr;gap:54px;align-items:start;padding-top:48px}
.ws-panel.active{display:grid;animation:fade .5s ease}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.ws-tag{display:inline-block;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ice-d);border:1px solid var(--lite-line);padding:.38rem .9rem;border-radius:100px;margin-bottom:20px}
.ws-panel h3{font-size:2.1rem;color:var(--lite-ink);margin-bottom:18px;text-wrap:pretty}
.ws-panel p{color:var(--lite-muted);margin-bottom:16px;max-width:46ch}
.ws-steps{list-style:none;margin:28px 0 0;display:flex;flex-direction:column;gap:16px}
.ws-steps li{display:flex;gap:16px}
.step-n{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--ice-d);color:#fff;font-family:"Jost";font-size:.82rem;display:flex;align-items:center;justify-content:center;font-weight:400}
.step-b{font-size:.92rem;color:var(--lite-muted);line-height:1.55}
.step-b strong{display:block;color:var(--lite-ink);font-weight:500;margin-bottom:2px}
.price-tags{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.price-tag{background:var(--card);border:1px solid var(--lite-line);border-radius:10px;padding:.8rem 1.1rem;text-align:center;min-width:90px}
.price-tag strong{display:block;font-family:"Cormorant Garamond",serif;font-weight:500;font-size:1.4rem;color:var(--ice-d);line-height:1}
.price-tag span{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--lite-muted)}
.ws-img-wrap{position:sticky;top:100px}
.ws-img{width:100%;height:560px;object-fit:cover;box-shadow:0 18px 38px -26px rgba(11,34,45,.32)}

/* ---------- ice divider quote ---------- */
.ice-divider{position:relative;height:340px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--deep2)}
.ice-divider img{position:absolute;left:0;width:100%;height:142%;top:-21%;object-fit:cover;opacity:.5;will-change:transform}
.ice-divider::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,43,55,.5),rgba(20,59,73,.6))}
.ice-divider span{position:relative;z-index:2;font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:300;font-size:clamp(1.6rem,3.4vw,2.7rem);color:#fff;text-align:center;max-width:840px;padding:0 30px;text-wrap:balance}

/* ---------- erlebnis ---------- */
.erlebnis{background:var(--deep);padding:0}
.exp-head{max-width:var(--maxw);margin:0 auto;padding:118px 40px 56px;text-align:center}
.exp-head .eyebrow{color:var(--amber)}
.exp-head h2{font-size:clamp(2.4rem,4.4vw,3.6rem);color:#fff}
.exp-head h2 em{color:var(--ice)}
.exp-head .rule{margin:22px auto 26px}
.exp-head p{color:var(--muted);max-width:60ch;margin:0 auto;font-size:1.05rem}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr)}
.exp-card{position:relative;height:580px;overflow:hidden}
.exp-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.exp-card:hover img{transform:scale(1.06)}
.exp-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,43,55,.1) 0%,rgba(14,43,55,.35) 50%,rgba(10,30,40,.92) 100%)}
.exp-content{position:absolute;left:0;right:0;bottom:0;padding:42px 38px;z-index:2}
.exp-num{font-family:"Cormorant Garamond",serif;font-size:1.1rem;color:var(--ice);letter-spacing:.1em;margin-bottom:8px}
.exp-title{font-family:"Cormorant Garamond",serif;font-size:2rem;color:#fff;margin-bottom:12px}
.exp-text{font-size:.94rem;color:#cfe0e7;line-height:1.7;max-width:30ch}

/* ---------- science ---------- */
.science{position:relative;background:var(--deep2);overflow:hidden}
.science-bg{position:absolute;inset:0;background:url('assets/eisbaden-kaltes-wasser-banner.jpg') center/cover;opacity:.14}
.science .inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.science h2{font-size:clamp(2.4rem,4.4vw,3.6rem);color:#fff}
.science h2 em{color:var(--ice)}
.science p{color:var(--muted);margin-bottom:18px;max-width:50ch}
.sci-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.sci-stat{background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:14px;padding:30px 26px}
.sci-stat .n{font-family:"Cormorant Garamond",serif;font-size:3rem;line-height:1;color:var(--ice);display:block}
.sci-stat:nth-child(even) .n{color:var(--amber)}
.sci-stat .l{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:10px;display:block}

/* ---------- über mich ---------- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start}
.about-img{position:sticky;top:100px}
.about-img img{width:100%;height:auto;box-shadow:0 18px 44px -30px rgba(11,34,45,.34);filter:grayscale(.1)}
.about-text p{color:var(--lite-muted);margin-bottom:18px}
.about-text h2{font-size:clamp(2.2rem,4vw,3.2rem)}
.quote-block{border-left:3px solid var(--amber);padding:6px 0 6px 26px;margin:30px 0}
.quote-block p{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:1.5rem;line-height:1.5;color:var(--lite-ink)}
.signature{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:1.4rem;color:var(--ice-d);margin-top:14px}

/* ---------- mosaic ---------- */
.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:230px;gap:0}
.mosaic div{overflow:hidden}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.mosaic div:hover img{transform:scale(1.07)}
.mosaic .m1{grid-column:span 2;grid-row:span 2}

/* ---------- faq ---------- */
.faq-cols{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:50px}
.faq-group{display:block;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ice-d);margin:8px 0 18px;font-weight:400}
.faq-group:not(:first-child){margin-top:40px}
.faq-item{border-bottom:1px solid var(--lite-line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;background:none;border:none;text-align:left;cursor:pointer;padding:18px 0;font-family:"Jost";font-weight:400;font-size:1rem;color:var(--lite-ink)}
.faq-icon{flex-shrink:0;font-size:1.3rem;color:var(--ice-d);transition:transform .3s;font-weight:300}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 0 20px;color:var(--lite-muted);font-size:.94rem;line-height:1.7;max-width:54ch}
.faq-a strong{color:var(--lite-ink)}

/* ---------- kontakt ---------- */
.kontakt{background:var(--deep)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.kontakt h2{font-size:clamp(2.4rem,4.6vw,3.8rem);color:#fff}
.kontakt h2 em{color:var(--ice)}
.kontakt .eyebrow{color:var(--ice)}
.kontakt > .inner > .contact-grid p.lead{color:var(--muted);max-width:42ch}
.contact-item{display:flex;gap:18px;align-items:flex-start;margin-top:24px}
.contact-icon{flex-shrink:0;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ice);font-size:1.1rem}
.contact-label{display:block;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.contact-val{display:block;font-size:1.05rem;color:var(--ink);margin-top:3px}
.contact-val a{text-decoration:none}
.contact-val a:hover{color:var(--ice)}
.contact-img{width:100%;height:520px;object-fit:cover;box-shadow:0 24px 50px -34px rgba(0,0,0,.32)}

/* ---------- footer ---------- */
footer{background:var(--deep2);text-align:center;padding:54px 40px;border-top:1px solid var(--line)}
footer .foot-logo{display:flex;align-items:center;justify-content:center;gap:11px;margin-bottom:22px}
.foot-social{display:flex;justify-content:center;gap:14px;margin:0 0 22px}
.foot-social a{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:50%;color:var(--ice);transition:background .2s,color .2s,border-color .2s,transform .2s}
.foot-social a:hover{background:var(--ice);color:#08222c;border-color:var(--ice);transform:translateY(-2px)}
footer .foot-logo .nl-up{font-family:"Jost";font-weight:500;letter-spacing:.28em;text-transform:uppercase;font-size:.9rem;color:var(--ink)}
footer p{color:var(--muted);font-size:.84rem;margin:4px 0}
footer a{color:var(--ice);text-decoration:none}


/* ---------- Kommende Termine ---------- */
#termine{background:var(--deep)}
.termine-list{max-width:880px;margin:50px auto 0;border-top:1px solid var(--line)}
.termine-row{display:grid;grid-template-columns:92px 1fr auto;align-items:center;gap:30px;padding:28px 8px;border-bottom:1px solid var(--line);transition:background .25s}
.termine-row:hover{background:rgba(255,255,255,.025)}
.termine-date{text-align:center}
.termine-date .d{font-family:"Cormorant Garamond",serif;font-size:2.8rem;color:var(--ink);line-height:.9}
.termine-date .m{font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--amber);margin-top:6px}
.termine-date .wd{font-size:.68rem;color:var(--muted);margin-top:4px}
.termine-main h3{font-family:"Cormorant Garamond",serif;font-weight:300;font-size:1.55rem;color:var(--ink);line-height:1.12}
.termine-meta{display:flex;flex-wrap:wrap;gap:5px 16px;align-items:center;margin-top:8px;color:var(--muted);font-size:.84rem}
.termine-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.5}
.termine-cta .btn{padding:.7rem 1.5rem;font-size:.68rem}
.termine-note{max-width:880px;margin:26px auto 0;color:var(--muted);font-size:.86rem;text-align:center}
.termine-empty{max-width:880px;margin:50px auto 0;text-align:center;padding:54px 24px;border:1px solid var(--line);border-radius:8px}
@media(max-width:600px){
  .termine-row{grid-template-columns:58px 1fr;gap:14px}
  .termine-date .d{font-size:2.1rem}
  .termine-cta{grid-column:1/-1;display:flex;justify-content:flex-end;margin-top:4px}
}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}

/* ---------- responsive ---------- */
@media(max-width:900px){
  section{padding:84px 0}
  .inner{padding:0 24px}
  .nav-links{position:fixed;top:0;right:0;height:100vh;width:78%;max-width:340px;background:var(--deep2);flex-direction:column;justify-content:center;gap:30px;transform:translateX(100%);transition:transform .4s ease,box-shadow .4s ease;box-shadow:none}
  .nav-links.open{transform:none;box-shadow:-20px 0 60px rgba(0,0,0,.4)}
  .nav-burger{display:flex;z-index:101}
  .nav-links .lang-li{margin-top:6px}
  .nav-links .lang-switch{display:flex;flex-direction:row}
  .nav-links .lang-switch a{display:block;padding:.7rem 1.4rem;font-size:.82rem;letter-spacing:.14em}
  .statband{grid-template-columns:1fr 1fr;padding:32px 0}
  .statband .s{padding:24px 16px;border-bottom:1px solid var(--line)}
  .statband .s:nth-child(2){border-right:none}
  .statband .n{font-size:2rem}
  .statband .l{font-size:.62rem}
  .ws-panel{grid-template-columns:1fr;gap:32px}
  .ws-img-wrap{position:static;order:-1}
  .ws-img{height:300px}
  .exp-grid{grid-template-columns:1fr}
  .exp-card{height:420px}
  .science .inner{grid-template-columns:1fr;gap:36px}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .about-img{position:static}
  .mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .mosaic .m1{grid-column:span 2;grid-row:span 1}
  .faq-cols{grid-template-columns:1fr;gap:0}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .contact-img{height:340px}
  .hero-bg{background-attachment:scroll}
}
@media(max-width:480px){
  .inner,#nav{padding-left:18px;padding-right:18px}
  .statband{grid-template-columns:1fr;padding:24px 0}
  .statband .s{padding:20px 16px;border-right:none;border-bottom:1px solid var(--line)}
  .statband .s:last-child{border-bottom:none}
  .statband .n{font-size:1.8rem}
  .statband .l{font-size:.6rem}
  .ws-tabs{gap:10px}
  .ws-tab{min-width:140px;padding:.85rem 1rem}
  .ws-tab .wt-ttl{font-size:.88rem}
}


/* ---------- footer legal links ---------- */
.foot-links{display:flex;justify-content:center;flex-wrap:wrap;gap:8px 22px;margin:20px 0 2px}
.foot-links a{color:var(--muted);font-size:.8rem;letter-spacing:.04em;text-decoration:none}
.foot-links a:hover{color:var(--ice)}

/* ---------- legal pages ---------- */
.legal-top{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 40px;background:rgba(14,43,55,.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.legal-top .back{color:var(--ice);text-decoration:none;font-size:.82rem;letter-spacing:.06em}
.legal-top .back:hover{color:var(--ink)}
.legal-wrap{max-width:740px;margin:0 auto;padding:64px 40px 100px}
.legal-wrap h1{font-size:clamp(2.1rem,5vw,3rem);margin-bottom:12px}
.legal-wrap h2{font-size:1.4rem;margin:44px 0 12px}
.legal-wrap h3{font-family:"Jost",sans-serif;font-weight:500;font-size:1rem;letter-spacing:.02em;margin:24px 0 6px;color:var(--ink)}
.legal-wrap p,.legal-wrap li{color:var(--muted);font-size:1rem}
.legal-wrap p{margin-bottom:13px}
.legal-wrap strong{color:var(--ink);font-weight:500}
.legal-wrap a{color:var(--ice);text-decoration:none}
.legal-wrap a:hover{text-decoration:underline}
.legal-wrap ul{padding-left:22px;margin:6px 0 16px}
.legal-wrap li{margin-bottom:7px}
.legal-wrap address{font-style:normal;color:var(--ink);line-height:1.75;margin-bottom:14px}
.legal-wrap .lead{color:var(--ink);font-size:1.08rem;margin-bottom:8px}
.legal-wrap .updated{margin-top:50px;padding-top:18px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted)}
@media(max-width:900px){.legal-top{padding:14px 24px}.legal-wrap{padding:48px 24px 80px}}


/* ---------- WhatsApp ---------- */
.btn-whatsapp{display:inline-flex;align-items:center;gap:.6rem;background:#25D366;color:#08300f}
.btn-whatsapp:hover{background:#3ee07a;transform:translateY(-2px)}
.btn-whatsapp svg{width:18px;height:18px}
.contact-cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:2.5rem}
.contact-cta-row .btn{margin-top:0}
.wa-fab{position:fixed;right:22px;bottom:22px;z-index:300;display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;box-shadow:0 10px 30px -8px rgba(0,0,0,.5);transition:transform .25s ease,box-shadow .25s ease}
.wa-fab svg{width:32px;height:32px}
.wa-fab:hover{transform:scale(1.07);box-shadow:0 14px 34px -8px rgba(0,0,0,.6)}
.wa-fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid #25D366;animation:waPulse 2.6s ease-out infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.5);opacity:0}100%{opacity:0}}
@media(prefers-reduced-motion:reduce){.wa-fab::after{animation:none;display:none}}
@media(max-width:600px){.wa-fab{right:16px;bottom:16px;width:54px;height:54px}.wa-fab svg{width:28px;height:28px}}

/* ---------- 404 ---------- */
.nf-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 28px 80px;position:relative;overflow:hidden}
.nf-bg{position:absolute;inset:0;background:url('assets/eisbaden-kaltes-wasser-banner.jpg') center/cover;opacity:.16;z-index:0}
.nf-wrap::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,43,55,.4),rgba(10,30,40,.85));z-index:1}
.nf-inner{position:relative;z-index:2;max-width:580px}
.nf-code{font-family:"Cormorant Garamond",serif;font-size:clamp(6rem,18vw,11rem);line-height:.9;color:#fff;letter-spacing:.02em}
.nf-code em{color:var(--ice);font-style:normal}
.nf-eyebrow{display:block;color:var(--amber);font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;margin:18px 0 22px;font-weight:500}
.nf-wrap h1{font-size:clamp(1.8rem,4vw,2.6rem);color:#fff;margin-bottom:18px}
.nf-wrap p{color:var(--muted);font-size:1.05rem;max-width:46ch;margin:0 auto 38px;line-height:1.8}
.nf-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.nf-links{margin-top:42px;display:flex;flex-wrap:wrap;gap:6px 26px;justify-content:center}
.nf-links a{color:var(--muted);text-decoration:none;font-size:.82rem;letter-spacing:.04em}
.nf-links a:hover{color:var(--ice)}

/* mobile hero: lighter image on small screens */
@media(max-width:600px){.hero-bg{background-image:url('assets/eisbaden-eupen-aachen-hero-mobile.jpg')}}

/* ---------- language switch ---------- */
.lang-switch{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:5px;overflow:hidden;background:rgba(255,255,255,.06)}
.lang-switch a{padding:.4rem .68rem;font-family:"Jost",sans-serif;font-weight:500;font-size:.7rem;letter-spacing:.1em;color:var(--ink);text-decoration:none;line-height:1;transition:background .2s,color .2s,opacity .2s}
.lang-switch a.active{background:var(--ice);color:#08222c}
.lang-switch a:not(.active){opacity:.7}
.lang-switch a:not(.active):hover{opacity:1;color:var(--ice)}
.nav-links .lang-switch a{text-shadow:none}
.nav-links .lang-switch a::after{display:none!important}
.legal-top-right{display:flex;align-items:center;gap:16px;margin-left:auto}
