/* === MASTER STYLESHEET · Schwimmschule Mallorca Academy === */
:root{--bg-1:#061226;--bg-2:#0a1f44;--bg-3:#13315c;--card-1:#0f2752;--card-2:#173a73;--line:rgba(255,255,255,.08);--text:#e8f2ff;--muted:#a4bcd9;--soft:#cfe4ff;--gold-1:#d4a857;--gold-2:#f0c66e;--cta-1:#ff7a3c;--cta-2:#ff9456;--live:#3ee87b;--live-2:#5cff9c;--pill:999px}
*{box-sizing:border-box}
html,body{margin:0;padding:0;scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;font-weight:300;background:linear-gradient(180deg,var(--bg-1),var(--bg-2) 38%,var(--bg-3));color:var(--text);line-height:1.62;min-height:100vh}
img{max-width:100%;display:block}
a{color:var(--soft);text-decoration:none;transition:color .2s}
a:hover{color:#fff}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:300;line-height:1.18;margin:0 0 .5em}
h1{font-size:clamp(40px,5.6vw,68px);background:linear-gradient(120deg,#fff,#cfe4ff 55%,#5fa8ff);-webkit-background-clip:text;background-clip:text;color:transparent}
h2{font-size:clamp(26px,3.2vw,42px);color:#fff}
h3{font-size:22px;color:#fff;font-weight:400}
h4{font-size:18px;color:#fff;font-weight:400}
p{margin:0 0 1em}
em{font-style:italic;color:var(--soft)}
section{scroll-margin-top:90px}
.eyebrow{letter-spacing:.34em;text-transform:uppercase;font-size:11px;color:var(--gold-2)}
.muted{color:var(--muted)}
.serif{font-family:'Cormorant Garamond',serif;font-weight:400}

/* TOPBAR */
.topbar{position:sticky;top:0;z-index:80;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:rgba(6,18,38,.78);border-bottom:1px solid var(--line)}
.topbar-inner{max-width:1480px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:18px}
.brand{display:flex;align-items:center;gap:14px;flex:1}
.brand a{display:flex;align-items:center;gap:14px;color:inherit}
.brand-mark{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#173a73,#0a1f44);display:grid;place-items:center;font-size:22px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.1)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:19px;color:#fff}
.brand-sub{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-2);margin-top:2px}
.nav{display:flex;gap:18px}
.nav a{font-size:13px}
.nav a:hover{color:var(--gold-2)}
.lang-pill{display:inline-flex;gap:6px;padding:6px 12px;border:1px solid var(--line);border-radius:var(--pill);font-size:11px;letter-spacing:.18em}
.lang-pill a{color:var(--muted);font-size:11px}
.lang-pill a.active{color:var(--gold-2)}
@media(max-width:980px){.nav{display:none}}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:var(--pill);font-weight:500;font-size:13.5px;border:1px solid transparent;transition:transform .15s,filter .15s;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,var(--cta-1),var(--cta-2));color:#0a1226;box-shadow:0 8px 20px rgba(255,122,60,.28)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.06);color:#0a1226}
.btn-ghost{border-color:var(--line);color:var(--soft)}
.btn-ghost:hover{color:#fff;border-color:rgba(255,255,255,.2)}

/* SHELLS */
.shell{max-width:1320px;margin:0 auto;padding:54px 28px 90px}
.shell-sub{max-width:1320px;margin:0 auto;padding:34px 28px 100px;display:grid;grid-template-columns:280px 1fr;gap:36px}
@media(max-width:980px){.shell-sub{grid-template-columns:1fr;padding:24px 16px 110px}}
@media(max-width:680px){.shell{padding:32px 16px 110px}}

/* HERO (Index/Programme) */
.hero{text-align:center;padding:36px 16px 56px;border-bottom:1px solid var(--line);margin-bottom:72px}
.hero h1{margin:20px auto 22px;max-width:1080px}
.hero-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(20px,2.2vw,28px);color:var(--soft);max-width:840px;margin:0 auto 8px}
.hero-stats{display:flex;justify-content:center;gap:38px;flex-wrap:wrap;margin-top:28px;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.hero-stat{text-align:center}
.hero-stat b{display:block;font-family:'Cormorant Garamond',serif;font-size:34px;color:var(--gold-2);font-weight:400;line-height:1}
.hero-stat span{display:block;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.hero-cta{margin-top:32px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* SECTIONS */
.s{margin-bottom:88px}
.s-head{text-align:center;margin-bottom:28px}
.s-head .eyebrow{display:block;margin-bottom:10px}
.s-head .lead{color:var(--muted);max-width:740px;margin:8px auto 0;font-size:15.5px}

/* COACH CARD */
.coach{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:center;background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:24px;padding:40px;box-shadow:0 14px 40px rgba(0,0,0,.28)}
@media(max-width:880px){.coach{grid-template-columns:1fr}}
.coach-img{aspect-ratio:4/5;background:#0a1f44 center/cover no-repeat;border-radius:18px;border:1px solid var(--line);min-height:280px}
.coach-pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}
.tag{display:inline-block;padding:5px 11px;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;border-radius:var(--pill);border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--soft)}

/* METHODE / PHASES */
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:880px){.method-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.method-grid{grid-template-columns:1fr}}
.phase{background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:14px;padding:22px}
.phase-num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:36px;color:var(--gold-2);line-height:1;margin-bottom:6px}
.phase h4{margin:0 0 6px}
.phase p{margin:0;font-size:13.5px;color:var(--muted)}

/* PROGRAM MINI CARDS (Index) */
.prog-mini{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
@media(max-width:980px){.prog-mini{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.prog-mini{grid-template-columns:1fr}}
.pm{position:relative;background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:14px;padding:16px 14px;text-align:left;transition:transform .2s,border-color .2s;color:inherit;display:block}
.pm:hover{transform:translateY(-2px);border-color:rgba(212,168,87,.35);color:inherit}
.pm-num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;color:var(--gold-2);letter-spacing:.16em;text-transform:uppercase}
.pm h4{margin:6px 0 4px;font-family:'Cormorant Garamond',serif;font-size:17px;line-height:1.25}
.pm p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.45}
.pm-flag{position:absolute;top:10px;right:10px;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;padding:3px 7px;border-radius:var(--pill)}
.pm-flag.live{background:rgba(62,232,123,.14);color:var(--live-2);border:1px solid rgba(62,232,123,.32)}
.pm-flag.perf{background:rgba(255,122,60,.14);color:var(--cta-2);border:1px solid rgba(255,122,60,.32)}
.prog-cta{text-align:center;margin-top:28px}

/* PROGRAMME PAGE (large cards) */
.prog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:880px){.prog-grid{grid-template-columns:1fr}}
.pg{position:relative;background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:18px;padding:26px;transition:transform .2s,border-color .2s;color:inherit;display:block}
.pg:hover{transform:translateY(-2px);border-color:rgba(212,168,87,.35);color:inherit}
.pg-num{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:14px;color:var(--gold-2);letter-spacing:.18em;text-transform:uppercase}
.pg h3{margin:8px 0 10px;font-size:24px}
.pg p{margin:0 0 12px;color:var(--muted);font-size:14px}
.pg-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.pg-tags span{font-size:10px;letter-spacing:.1em;padding:3px 8px;border-radius:var(--pill);border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--muted);text-transform:uppercase}

/* FEATURES (Services / Equipment) */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:880px){.feat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.feat-grid{grid-template-columns:1fr}}
.feat{background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
.feat-img{aspect-ratio:4/3;background:#0a1f44 center/cover no-repeat}
.feat-body{padding:16px 18px;display:flex;flex-direction:column;flex:1}
.feat h4{margin:0 0 6px;font-family:'Cormorant Garamond',serif;font-size:18px}
.feat p{font-size:13px;color:var(--muted);margin:0 0 12px;flex:1}
.feat-body a{font-size:12px;letter-spacing:.06em;color:var(--gold-2)}
.feat-body a:hover{color:#fff}

/* TIPPS */
.tipps{display:grid;grid-template-columns:1fr 1.1fr;gap:32px;align-items:center}
@media(max-width:880px){.tipps{grid-template-columns:1fr}}
.tipps-img{aspect-ratio:4/5;background:#0a1f44 center/cover no-repeat;border-radius:18px;border:1px solid var(--line);min-height:280px}
.tipps ol{padding-left:20px;margin:0}
.tipps li{margin-bottom:10px;font-size:14.5px}
.tipps li b{color:#fff;font-weight:500}
.src{font-size:12px;color:var(--muted);margin-top:14px;font-style:italic}

/* ORTE */
.orte-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:880px){.orte-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.orte-grid{grid-template-columns:1fr}}
.ort{background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:14px;padding:16px 20px}
.ort small{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);display:block;margin-bottom:4px}
.ort h4{margin:0 0 4px;font-family:'Cormorant Garamond',serif;font-size:19px}
.ort p{font-size:13px;color:var(--muted);margin:0}

/* DATEN / JENNY */
.daten,.jenny{background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:24px;padding:40px;text-align:center}
.daten p,.jenny p{max-width:680px;margin:14px auto 0;color:var(--soft);font-size:16px;font-style:italic;font-family:'Cormorant Garamond',serif}
.jenny .btn{margin-top:22px;padding:16px 28px;font-size:14.5px}

/* FAQ */
.faq details{background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:12px;padding:16px 22px;margin-bottom:10px}
.faq details[open]{background:rgba(255,255,255,.05)}
.faq summary{cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:20px;color:#fff;list-style:none;font-weight:400}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--gold-2);font-size:24px}
.faq details[open] summary::after{content:"−"}
.faq details p{margin-top:12px;font-size:14.5px}

/* SIDEBAR (Sub-Pages) */
.sidebar{position:sticky;top:84px;align-self:start;background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:18px;padding:22px}
@media(max-width:980px){.sidebar{position:static}}
.sidebar h5{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-2);margin:0 0 14px;font-weight:500;font-family:'Inter',sans-serif}
.side-list{list-style:none;padding:0;margin:0 0 18px;counter-reset:s}
.side-list li{margin-bottom:4px}
.side-list a{display:block;padding:8px 12px;border-radius:8px;font-size:13.5px;color:var(--soft);transition:background .15s}
.side-list a:hover{background:rgba(255,255,255,.05);color:#fff}
.side-list a.active{background:linear-gradient(135deg,rgba(212,168,87,.18),rgba(212,168,87,.05));color:var(--gold-2);border:1px solid rgba(212,168,87,.3)}
.side-list a small{display:block;font-size:10px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-bottom:2px}
.side-cta{margin-top:14px;padding-top:18px;border-top:1px solid var(--line)}
.side-cta a{display:block;text-align:center;padding:11px 14px;border-radius:var(--pill);font-size:13px;margin-bottom:8px}
.side-wa{background:linear-gradient(135deg,var(--cta-1),var(--cta-2));color:#0a1226;font-weight:500}
.side-tel{border:1px solid var(--line);color:var(--soft)}
.side-back{margin-top:14px;font-size:12px;color:var(--muted);text-align:center}
.side-back a{color:var(--gold-2)}

/* SUB-HERO + SECTIONS (Sub-Pages) */
main{min-width:0}
.sub-hero{padding:18px 0 36px;border-bottom:1px solid var(--line);margin-bottom:40px}
.sub-hero .eyebrow{display:block;margin-bottom:10px}
.sub-hero h1{font-size:clamp(34px,4.6vw,54px);margin:8px 0 14px}
.sub-hero-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:21px;color:var(--soft);max-width:680px}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}
.sub-cta{margin-top:22px;display:flex;gap:12px;flex-wrap:wrap}
.sec{margin-bottom:48px}
.sec h2{margin-bottom:18px}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:580px){.cards{grid-template-columns:1fr}}
.card{background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:14px;padding:20px}
.card h4{margin:0 0 8px;font-family:'Cormorant Garamond',serif}
.card p{margin:0;font-size:14px;color:var(--muted)}
.steps{display:grid;gap:12px}
.step{display:grid;grid-template-columns:60px 1fr;gap:16px;align-items:start;padding:18px 22px;background:rgba(255,255,255,.02);border:1px solid var(--line);border-radius:12px}
.step-n{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:30px;color:var(--gold-2);line-height:1}
.step h4{margin:0 0 6px;font-family:'Cormorant Garamond',serif;font-size:18px}
.step p{margin:0;font-size:14px;color:var(--muted)}

/* PAGE NAV (Sub-Pages Bottom) */
.page-nav{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;padding:22px;background:linear-gradient(170deg,var(--card-1),var(--card-2));border:1px solid var(--line);border-radius:16px;margin-top:48px}
@media(max-width:580px){.page-nav{grid-template-columns:1fr}}
.page-nav a{padding:14px 16px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid var(--line);font-size:13px;text-align:center;transition:background .15s}
.page-nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.page-nav a.center{background:linear-gradient(135deg,var(--cta-1),var(--cta-2));color:#0a1226;border-color:transparent;font-weight:500}
.page-nav small{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);margin-bottom:4px}

/* FOOTER */
.footer{margin-top:72px;padding:36px 28px 24px;border-top:1px solid var(--line);max-width:1480px;margin-left:auto;margin-right:auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:26px}
@media(max-width:880px){.footer{grid-template-columns:1fr 1fr}}
.f-col h5{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-2);margin:0 0 12px;font-weight:500}
.f-col a{display:block;font-size:13px;color:var(--soft);margin-bottom:7px}
.f-col a:hover{color:#fff}
.f-brand p{font-size:13px;color:var(--muted);line-height:1.55}
.f-copy{max-width:1480px;margin:0 auto;padding:18px 28px 24px;text-align:center;font-size:11.5px;color:var(--muted);border-top:1px solid var(--line)}
.f-name{font-family:'Cormorant Garamond',serif;color:var(--soft);font-style:italic}

/* MOBILE STICKY CTA */
.mobile-sticky{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:90;padding:14px 18px;border-radius:var(--pill);background:linear-gradient(135deg,var(--cta-1),var(--cta-2));color:#0a1226;font-weight:500;text-align:center;font-size:14.5px;box-shadow:0 8px 24px rgba(0,0,0,.4)}
@media(max-width:680px){.mobile-sticky{display:block}}
