:root {
  --sage: #e7e9dd;
  --sage-2: #f0f1e9;
  --forest: #2c3522;
  --forest-2: #3a4a2e;
  --olive: #4a5d3a;
  --ink: #283021;
  --muted: #6e7563;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --body: 'Inter', system-ui, sans-serif;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}
* { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; scroll-padding-top:90px; }
body { font-family:var(--body); background:var(--sage); color:var(--ink); line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
img { display:block; max-width:100%; }
h1, h2, h3 { font-family:var(--serif); font-weight:600; line-height:1.08; }
h1 em, h2 em { font-style:italic; font-weight:500; color:var(--olive); }
.skip-link { position:absolute; left:-999px; }
.skip-link:focus { left:8px; top:8px; background:var(--forest); color:#fff; padding:8px 14px; z-index:999; }
:focus-visible { outline:2px solid var(--olive); outline-offset:3px; }
.js .reveal { opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.js .reveal.is-visible { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} .js .reveal{opacity:1!important;transform:none!important} }

.kicker { display:inline-block; font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.18em; color:var(--olive); margin-bottom:1rem; }
.btn { display:inline-flex; align-items:center; justify-content:center; gap:.4rem; padding:.85rem 1.9rem; border-radius:2rem; font-weight:500; font-size:.92rem; border:1px solid transparent; cursor:pointer; transition:all .25s var(--ease); }
.btn-forest { background:var(--forest); color:#fff; border-color:var(--forest); }
@media (hover: hover) { .btn-forest:hover { background:var(--forest-2); transform:translateY(-2px); } }
.btn-pill { background:transparent; color:var(--ink); border-color:var(--olive); }
@media (hover: hover) { .btn-pill:hover { background:var(--olive); color:#fff; } }
.btn-pill.light { background:#fff; color:var(--forest); border-color:#fff; }
@media (hover: hover) { .btn-pill.light:hover { background:var(--sage); } }
.btn-outline { background:transparent; color:var(--ink); border-color:var(--ink); }
@media (hover: hover) { .btn-outline:hover { background:var(--ink); color:var(--sage); } }
.btn-outline-d { background:transparent; color:var(--forest); border-color:#cdd2c0; }
@media (hover: hover) { .btn-outline-d:hover { background:var(--forest); color:#fff; border-color:var(--forest); } }
.full { width:100%; }

/* Header */
#siteHeader { position:sticky; top:0; z-index:100; background:rgba(231,233,221,.9); backdrop-filter:blur(8px); transition:box-shadow .3s; }
#siteHeader.scrolled { box-shadow:0 6px 20px rgba(40,48,33,.08); }
.head-inner { max-width:1240px; margin:0 auto; padding:1.1rem 2rem; display:flex; align-items:center; gap:1.5rem; }
.brand { font-family:var(--serif); font-weight:600; font-size:1.7rem; }
.nav-links { display:flex; gap:1.8rem; margin:0 auto; }
.nav-links a { font-size:.92rem; font-weight:500; color:var(--muted); }
@media (hover: hover) { .nav-links a:hover { color:var(--ink); } }
.mobile-menu-btn { display:none; background:none; border:none; cursor:pointer; width:40px; height:40px; align-items:center; justify-content:center; }
.burger, .burger::before, .burger::after { content:""; display:block; width:24px; height:2px; background:var(--ink); transition:transform .3s var(--ease), opacity .2s; }
.burger { position:relative; } .burger::before { position:absolute; top:-7px; } .burger::after { position:absolute; top:7px; }
#siteHeader.nav-open .burger { background:transparent; }
#siteHeader.nav-open .burger::before { transform:translateY(7px) rotate(45deg); }
#siteHeader.nav-open .burger::after { transform:translateY(-7px) rotate(-45deg); }

/* Hero */
.hero { max-width:1240px; margin:0 auto; padding:3rem 2rem 4rem; display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.hero-text h1 { font-size:clamp(2.8rem,6vw,4.8rem); line-height:1.05; margin-bottom:1.3rem; }
.hero-text p { color:var(--muted); font-size:1.1rem; max-width:400px; margin-bottom:2rem; }
.hero-cta { display:flex; gap:.8rem; flex-wrap:wrap; }
.hero-img { border-radius:1.6rem; overflow:hidden; aspect-ratio:4/5; background:#d4d8c6; }
.hero-img img { width:100%; height:100%; object-fit:cover; }

/* Band */
.band { background:var(--forest); color:#fff; padding:3rem 2rem; }
.band { display:grid; grid-template-columns:1.2fr 1fr; gap:3rem; max-width:1240px; margin:0 auto; align-items:center; border-radius:1.4rem; }
.band-stats { display:flex; gap:2.5rem; flex-wrap:wrap; }
.band-stats strong { font-family:var(--serif); font-size:2.6rem; font-weight:600; display:block; }
.band-stats strong span { color:#b7c79a; }
.band-stats > div > span { font-size:.85rem; color:rgba(255,255,255,.7); }
.band-text p { color:rgba(255,255,255,.85); margin-bottom:.8rem; font-size:.95rem; }
.band-link { color:#cde0ad; font-weight:600; font-size:.92rem; }
@media (hover: hover) { .band-link:hover { color:#fff; } }

/* Services */
.services { max-width:1240px; margin:0 auto; padding:5rem 2rem; }
.serv-head { display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.serv-head h2 { font-size:clamp(2rem,4vw,3rem); margin:.6rem 0; }
.serv-head p { color:var(--muted); max-width:420px; }
.serv-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.serv { background:var(--sage-2); border-radius:1.4rem; padding:2.2rem; transition:transform .3s var(--ease); }
@media (hover: hover) { .serv:hover { transform:translateY(-5px); } }
.serv-ic { font-size:2rem; display:block; margin-bottom:1rem; }
.serv h3 { font-size:1.6rem; margin-bottom:.6rem; }
.serv p { color:var(--muted); font-size:.95rem; margin-bottom:1.2rem; }
.more { font-weight:600; color:var(--olive); font-size:.9rem; }
@media (hover: hover) { .more:hover { color:var(--forest); } }

/* Team */
.team { max-width:1240px; margin:0 auto; padding:4rem 2rem 5rem; }
.team h2 { font-size:clamp(2rem,4vw,3rem); margin-bottom:2.5rem; }
.team-grid { display:grid; grid-template-columns:1.3fr 1fr 1fr 1fr; gap:1.3rem; }
.coach-feature { background:var(--forest); color:#fff; border-radius:1.4rem; padding:2rem; display:flex; flex-direction:column; }
.coach-feature h3 { color:#fff; font-size:1.7rem; margin-bottom:.8rem; }
.coach-feature p { color:rgba(255,255,255,.8); font-size:.92rem; margin-bottom:auto; }
.coach-feature .btn { margin-top:1.5rem; align-self:flex-start; }
.coach { position:relative; border-radius:1.4rem; overflow:hidden; aspect-ratio:3/4; }
.coach img { width:100%; height:100%; object-fit:cover; }
.coach figcaption { position:absolute; bottom:.9rem; left:.9rem; right:.9rem; background:rgba(231,233,221,.95); border-radius:.9rem; padding:.7rem 1rem; }
.coach strong { display:block; font-size:.95rem; }
.coach span { font-size:.8rem; color:var(--muted); }

/* Preise */
.preise { max-width:1240px; margin:0 auto; padding:4rem 2rem; text-align:center; }
.preise h2 { font-size:clamp(2rem,4vw,3rem); margin-bottom:2.5rem; }
.plan-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; text-align:left; }
.plan { background:var(--sage-2); border-radius:1.4rem; padding:2.2rem; position:relative; }
.plan.feat { background:#fff; border:1px solid var(--olive); }
.badge { position:absolute; top:1.5rem; right:1.5rem; background:var(--olive); color:#fff; font-size:.7rem; font-weight:600; padding:.25rem .8rem; border-radius:2rem; }
.plan h3 { font-size:1.6rem; margin-bottom:.5rem; }
.amount { font-family:var(--serif); font-size:2.4rem; font-weight:600; margin-bottom:1.3rem; }
.amount span { font-family:var(--body); font-size:.9rem; color:var(--muted); }
.plan ul { display:flex; flex-direction:column; gap:.6rem; margin-bottom:1.8rem; }
.plan li { font-size:.92rem; padding-left:1.4rem; position:relative; color:var(--ink); }
.plan li::before { content:""; position:absolute; left:0; width:16px; height:16px; background-image:url('data:image/svg+xml;utf8,<svg viewBox="0 0 24 24" fill="none" stroke="%234a5d3a" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" xmlns="http://www.w3.org/2000/svg"><polyline points="20 6 9 17 4 12"/></svg>'); background-size:contain; background-repeat:no-repeat; top:4px; }

/* CTA */
.cta { padding:2rem 2rem 5rem; }
.cta-inner { max-width:1240px; margin:0 auto; background:var(--forest); color:#fff; border-radius:1.6rem; padding:4.5rem 3rem; text-align:center; }
.cta-inner h2 { color:#fff; font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:.8rem; }
.cta-inner em { color:#cde0ad; }
.cta-inner p { color:rgba(255,255,255,.8); margin-bottom:2rem; }
.cta-form { display:flex; gap:.7rem; max-width:460px; margin:0 auto; flex-wrap:wrap; }
.cta-form input { flex:1; min-width:200px; padding:.9rem 1.2rem; border-radius:2rem; border:1px solid rgba(255,255,255,.4); background:rgba(255,255,255,.1); color:#fff; font-family:var(--body); }
.cta-form input::placeholder { color:rgba(255,255,255,.65); }
.cta-form input:focus { outline:none; border-color:#fff; }
.form-note { margin-top:1rem; color:#cde0ad; }

/* Footer */
.site-footer { padding:3rem 2rem; }
.foot-inner { max-width:1240px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.foot-inner .brand { font-size:1.5rem; }
.foot-inner > div:first-child p { color:var(--muted); font-size:.85rem; margin-top:.3rem; }
.foot-contact { display:flex; flex-direction:column; gap:.3rem; font-weight:600; }
@media (hover: hover) { .foot-contact a:hover { color:var(--olive); } }
.foot-legal { display:flex; gap:1.2rem; align-items:center; font-size:.85rem; color:var(--muted); flex-wrap:wrap; }
@media (hover: hover) { .foot-legal a:hover { color:var(--ink); } }

@media (max-width:900px){
  .hero, .band, .serv-grid, .team-grid, .plan-grid { grid-template-columns:1fr; }
  .band { gap:1.5rem; }
  .serv-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr 1fr; }
  .plan-grid { grid-template-columns:1fr; max-width:420px; margin:0 auto; }
}
@media (max-width:600px){
  .head-inner { gap:1rem; }
  .nav-links { display:none; position:absolute; top:100%; left:0; width:100%; flex-direction:column; gap:0; background:var(--sage-2); padding:.5rem 2rem 1rem; margin:0; }
  #siteHeader.nav-open .nav-links { display:flex; }
  .nav-links a { padding:.8rem 0; border-bottom:1px solid #d8dccb; }
  .mobile-menu-btn { display:flex; }
  .band-stats { gap:1.5rem; }
  .services, .team, .preise { padding: 2.5rem 1.5rem; }
  .team-grid { grid-template-columns:1fr; }
  .cta-inner { padding:2.5rem 1.5rem; }
  .cta-form { flex-direction: column; }
  .cta-form input { min-width: 0; flex: 1 1 auto; }
  .cta-form .btn { width: 100%; }
  .foot-inner { flex-direction:column; align-items:flex-start; }
}
