/* ==========================================================================
   The Players Club — Components (Forest & Sand)
   hero, ticker, stats, intro, formats, schedule, levels, pricing,
   franchise, cta-band, contact, newsletter, footer
   ========================================================================== */

/* ── HERO ── */
.hero{min-height:100svh;display:flex;flex-direction:column;padding:0 5%;
  background:linear-gradient(to bottom,rgba(12,35,24,.7) 0%,rgba(12,35,24,.4) 55%,rgba(12,35,24,.9) 100%),
    var(--hero-img,#0c2318) center/cover no-repeat}
.hero-top{flex:1;display:flex;flex-direction:column;justify-content:flex-end;padding:110px 0 4rem}
.hero-kicker{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:rgba(240,235,225,.6);margin-bottom:1.8rem}
.hero-kicker::before{content:'';width:24px;height:1px;background:rgba(240,235,225,.4)}
.hero h1{font-size:clamp(3.5rem,10vw,9rem);font-weight:900;line-height:.92;letter-spacing:-.05em;color:var(--sand)}
.hero h1 .outline{color:transparent;-webkit-text-stroke:1.5px rgba(240,235,225,.4)}
.hero-bottom{border-top:1px solid rgba(240,235,225,.12);display:grid;grid-template-columns:1fr auto;
  align-items:center;gap:2rem;padding:2rem 0}
.hero-desc{font-size:1rem;color:rgba(240,235,225,.7);max-width:460px;line-height:1.7}
.hero-btns{display:flex;gap:.8rem;flex-shrink:0;flex-wrap:wrap}
@media(max-width:640px){.hero-bottom{grid-template-columns:1fr}}

/* ── TICKER ── */
.ticker-wrap{border-top:1px solid rgba(240,235,225,.1);padding:1rem 0;overflow:hidden}
.ticker{display:flex;gap:2.5rem;width:max-content;animation:tick 32s linear infinite}
.ti{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(240,235,225,.4);white-space:nowrap}
.ti::after{content:' ·';color:rgba(240,235,225,.2);margin-left:2.5rem}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker{animation:none}}

/* ── STAT STRIP ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);background:var(--forest)}
.stat{padding:2.2rem 5%;border-right:1px solid rgba(240,235,225,.08)}
.stats .wrap{display:contents}
.stat:last-child{border:none}
.stat .n{font-size:2.6rem;font-weight:900;letter-spacing:-.05em;color:var(--sand);line-height:1}
.stat .l{font-size:.8rem;color:rgba(240,235,225,.5);margin-top:.3rem}
@media(max-width:900px){.stats{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:none}}
@media(max-width:560px){.stats{grid-template-columns:1fr}.stat{border-right:none;border-bottom:1px solid rgba(240,235,225,.08)}}

/* ── INTRO GRID ── */
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;margin-top:3rem}
.intro-img{aspect-ratio:4/3;border-radius:var(--r-lg);overflow:hidden;position:relative}
.intro-img img{width:100%;height:100%;object-fit:cover}
.intro-img-badge{position:absolute;bottom:1.5rem;left:1.5rem;background:rgba(12,35,24,.85);
  backdrop-filter:blur(8px);color:var(--sand);border-radius:12px;padding:1rem 1.4rem;font-size:.82rem;
  font-weight:600;border:1px solid rgba(240,235,225,.12)}
.intro-img-badge strong{display:block;font-size:1.5rem;font-weight:900;letter-spacing:-.03em;color:#fff;line-height:1.1}
.intro-text p{font-size:1.05rem;color:var(--muted);line-height:1.8;margin:1.4rem 0 2.5rem}
.intro-checklist{list-style:none;display:flex;flex-direction:column;gap:.9rem}
.intro-checklist li{display:flex;align-items:flex-start;gap:.9rem;font-size:.95rem;color:var(--ink);line-height:1.5}
.check-icon{width:22px;height:22px;border-radius:50%;background:var(--forest);color:var(--sand);
  display:flex;align-items:center;justify-content:center;font-size:.65rem;flex-shrink:0;margin-top:.1rem}
@media(max-width:900px){.intro-grid{grid-template-columns:1fr;gap:2.5rem}}

/* ── FORMATS (forest section) ── */
.forest{background:var(--forest)}
.forest .tag{color:rgba(240,235,225,.5)}
.forest h2{color:var(--sand)}
.forest .sec-lead{color:rgba(240,235,225,.6);max-width:520px;margin-top:1rem;line-height:1.7}
.formats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:3rem;
  border:1px solid rgba(240,235,225,.08);border-radius:var(--r);overflow:hidden}
.format-card{background:rgba(255,255,255,.04);padding:2.5rem 2rem;border-right:1px solid rgba(240,235,225,.08);transition:background .25s}
.format-card:last-child{border:none}
.format-card:hover{background:rgba(255,255,255,.07)}
.format-num{font-size:.72rem;font-weight:700;letter-spacing:.12em;color:rgba(240,235,225,.3);margin-bottom:1.4rem}
.format-card h3{font-size:1.25rem;font-weight:800;color:var(--sand);margin-bottom:.6rem;letter-spacing:-.02em}
.format-card p{font-size:.88rem;color:rgba(240,235,225,.55);line-height:1.7}
.format-pill{display:inline-block;margin-top:1.4rem;background:rgba(240,235,225,.08);color:rgba(240,235,225,.65);
  font-size:.72rem;font-weight:600;letter-spacing:.04em;padding:.3rem .8rem;border-radius:50px;border:1px solid rgba(240,235,225,.1)}
@media(max-width:900px){.formats-grid{grid-template-columns:1fr}.format-card{border-right:none;border-bottom:1px solid rgba(240,235,225,.08)}}

/* ── SCHEDULE ── */
.schedule-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:3rem}
.sched-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:2rem;
  display:flex;gap:1.5rem;align-items:flex-start;transition:box-shadow .25s,transform .2s}
.sched-card:hover{box-shadow:0 8px 28px rgba(17,22,16,.1);transform:translateY(-3px)}
.sched-day{background:var(--forest);color:var(--sand);border-radius:10px;padding:.7rem .9rem;text-align:center;flex-shrink:0;min-width:52px}
.sched-day .d{font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.sched-day .t{font-size:1.1rem;font-weight:900;margin-top:.15rem;letter-spacing:-.03em}
.sched-info h4{font-size:.98rem;font-weight:700;margin-bottom:.3rem}
.sched-info p{font-size:.83rem;color:var(--muted);line-height:1.5}
.sched-tag{display:inline-block;margin-top:.7rem;background:#f0f7f3;color:var(--mid);font-size:.7rem;
  font-weight:600;padding:.2rem .65rem;border-radius:50px;border:1px solid #cce8d8}
@media(max-width:900px){.schedule-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.schedule-grid{grid-template-columns:1fr}}

/* ── LEVELS ── */
.levels-section{background:var(--sand2)}
.levels-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:3rem}
.level-card{border-radius:var(--r);padding:1.8rem;border:1.5px solid transparent;transition:transform .2s,box-shadow .2s}
.level-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(17,22,16,.1)}
.lc-1{background:var(--card);border-color:var(--border)}
.lc-2{background:#e8f3ed;border-color:#c8e0d3}
.lc-3{background:#d4ecdf;border-color:#aad3bc}
.lc-4{background:var(--forest);border-color:var(--forest)}
.level-icon{font-size:1.6rem;margin-bottom:1rem}
.level-card h3{font-size:1rem;font-weight:800;margin-bottom:.4rem;letter-spacing:-.02em}
.level-card p{font-size:.82rem;line-height:1.6;color:var(--muted)}
.lc-4 h3{color:var(--sand)}
.lc-4 p{color:rgba(240,235,225,.65)}
@media(max-width:900px){.levels-row{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.levels-row{grid-template-columns:1fr}}

/* ── PRICING ── */
.price-head{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.seg{display:inline-flex;background:var(--card);border:1px solid var(--border);border-radius:50px;padding:4px}
.seg button{border:0;background:transparent;color:var(--muted);font-weight:700;font-size:.8rem;padding:.5rem .9rem;border-radius:50px;cursor:pointer}
.seg button[aria-pressed="true"]{background:var(--forest);color:var(--sand)}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:3rem;align-items:start}
.plan{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:2.2rem;position:relative;transition:transform .2s,box-shadow .2s}
.plan:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(17,22,16,.1)}
.plan.feat{background:var(--forest);border-color:var(--forest)}
.plan.feat h3,.plan.feat .amt{color:var(--sand)}
.plan.feat .sub{color:rgba(240,235,225,.6)}
.plan.feat li{color:rgba(240,235,225,.85)}
.plan.feat .plan-tag{background:var(--sand);color:var(--forest)}
.plan-tag{position:absolute;top:-12px;right:1.4rem;background:var(--forest);color:var(--sand);
  font-size:.68rem;font-weight:800;letter-spacing:.06em;padding:.3rem .8rem;border-radius:50px;text-transform:uppercase}
.plan h3{font-size:1.1rem;font-weight:800}
.plan .amt{font-size:2.6rem;font-weight:900;letter-spacing:-.04em;margin:.6rem 0 .2rem}
.plan .amt small{font-size:.9rem;font-weight:600;color:var(--muted)}
.plan.feat .amt small{color:rgba(240,235,225,.5)}
.plan .sub{font-size:.85rem;color:var(--muted);min-height:2.6em}
.plan ul{list-style:none;margin:1.4rem 0 1.8rem;display:grid;gap:.7rem}
.plan li{font-size:.88rem;display:flex;gap:.6rem;align-items:flex-start;color:var(--ink)}
.plan li::before{content:'✓';color:var(--mid);font-weight:800}
.plan.feat li::before{color:var(--sand)}
.plan .btn{width:100%;justify-content:center}
@media(max-width:900px){.plans{grid-template-columns:1fr}}

/* ── FRANCHISE / TRAINER ── */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:5rem;align-items:center;margin-top:3rem}
.split-img{aspect-ratio:4/3;border-radius:var(--r-lg);overflow:hidden}
.split-img img{width:100%;height:100%;object-fit:cover}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:2.5rem}}

/* ── CTA BAND ── */
.cta-band{background:var(--forest);margin:0 5% 7rem;border-radius:var(--r-lg);padding:4rem;position:relative;
  overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band::after{content:'PC';position:absolute;right:3rem;top:50%;transform:translateY(-50%);
  font-size:18rem;font-weight:900;letter-spacing:-.1em;color:rgba(255,255,255,.04);line-height:1;pointer-events:none}
.cta-band h2{color:var(--sand);font-size:clamp(1.8rem,3.5vw,2.8rem);position:relative}
.cta-band p{color:rgba(240,235,225,.6);margin-top:.5rem;position:relative}
.cta-btns{display:flex;gap:1rem;flex-shrink:0;flex-wrap:wrap;position:relative}
@media(max-width:640px){.cta-band{padding:2.5rem 1.8rem}}

/* ── CONTACT + NEWSLETTER ── */
.contact-wrap{display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:start;margin-top:3rem}
.contact-lead{font-size:1rem;color:var(--muted);line-height:1.7;margin:1rem 0 2.5rem}
.contact-items{display:flex;flex-direction:column;gap:.7rem}
.c-item{display:flex;align-items:center;gap:1rem;background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:1rem 1.4rem;color:var(--ink);transition:box-shadow .2s,transform .2s}
.c-item:hover{box-shadow:0 6px 20px rgba(17,22,16,.09);transform:translateX(4px)}
.c-icon{width:36px;height:36px;border-radius:9px;background:var(--forest);display:flex;align-items:center;
  justify-content:center;font-size:.9rem;flex-shrink:0;color:var(--sand)}
.c-lbl{font-size:.7rem;color:var(--muted);font-weight:500}
.c-val{font-size:.9rem;font-weight:600}
.cform{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:2.5rem;display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cform input,.cform textarea,.cform select{width:100%;padding:.85rem 1.1rem;background:var(--sand);
  border:1.5px solid var(--border);border-radius:10px;font-size:.88rem;color:var(--ink);font-family:inherit;
  transition:border-color .2s,box-shadow .2s}
.cform input::placeholder,.cform textarea::placeholder{color:var(--muted)}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(26,92,53,.1)}
.cform textarea{resize:vertical;min-height:100px}
@media(max-width:900px){.contact-wrap{grid-template-columns:1fr;gap:2.5rem}}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}

/* ── FOOTER ── */
footer.site-footer{background:var(--ink);color:rgba(240,235,225,.4);padding:2.5rem 5%;display:flex;
  align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.8rem}
.f-logo{font-weight:800;color:rgba(240,235,225,.75);letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem}
.f-mark{width:22px;height:22px;border-radius:5px;background:var(--green);display:flex;align-items:center;
  justify-content:center;font-size:.55rem;font-weight:900;color:var(--sand)}
.f-links{display:flex;gap:1.5rem;list-style:none;flex-wrap:wrap}
.f-links a{font-size:.8rem;color:rgba(240,235,225,.4)}
.f-links a:hover{color:rgba(240,235,225,.8)}

/* ── MAP ── */
.map-filter{display:flex;gap:.5rem;margin-top:2rem;flex-wrap:wrap}
.map-btn{border:1px solid rgba(240,235,225,.2);background:transparent;color:rgba(240,235,225,.6);
  font-size:.82rem;font-weight:700;padding:.5rem 1.1rem;border-radius:50px;cursor:pointer;transition:all .2s}
.map-btn:hover{color:var(--sand);border-color:rgba(240,235,225,.5)}
.map-btn.active{background:var(--sand);color:var(--forest);border-color:var(--sand)}
.map-container{height:460px;border-radius:var(--r-lg);overflow:hidden;margin-top:1.5rem;
  border:1px solid rgba(240,235,225,.1)}
.map-marker{background:none;border:none}
.mm-inner{width:28px;height:28px;background:var(--forest);border:3px solid var(--sand);
  border-radius:50%;box-shadow:0 2px 10px rgba(12,35,24,.5);transition:transform .15s}
.mm-inner:hover{transform:scale(1.2)}
.pc-popup .leaflet-popup-content-wrapper{background:var(--forest);color:var(--sand);
  border-radius:10px;border:1px solid rgba(240,235,225,.15);box-shadow:0 8px 24px rgba(12,35,24,.4)}
.pc-popup .leaflet-popup-tip{background:var(--forest)}
.pc-popup .leaflet-popup-content{margin:.9rem 1.1rem;font-family:var(--font);line-height:1.6}
.pc-popup strong{font-size:.95rem;font-weight:800;color:#fff}
.mp-sub{font-size:.78rem;color:rgba(240,235,225,.55)}
.mp-tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.06em;
  background:rgba(240,235,225,.1);border:1px solid rgba(240,235,225,.15);
  color:rgba(240,235,225,.7);padding:.15rem .55rem;border-radius:50px;margin:.25rem 0}
@media(max-width:640px){.map-container{height:340px}}

/* ── TESTIMONIALS ── */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:3rem}
.tcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:2rem;
  display:flex;flex-direction:column;gap:1.5rem;transition:box-shadow .25s,transform .2s}
.tcard:hover{box-shadow:0 8px 28px rgba(17,22,16,.1);transform:translateY(-3px)}
.tcard-quote{font-size:.95rem;line-height:1.7;color:var(--ink);flex:1}
.tcard-author{display:flex;align-items:center;gap:.9rem;font-size:.82rem;color:var(--muted)}
.tcard-author strong{color:var(--ink)}
.tcard-avatar{width:40px;height:40px;border-radius:50%;background:var(--forest);color:var(--sand);
  display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:900;flex-shrink:0}
@media(max-width:900px){.testimonials-grid{grid-template-columns:1fr}}

/* ── TRAINER SECTION ── */
.trainer-section{background:var(--sand2)}
.trainer-card{display:flex;align-items:flex-start;gap:2.5rem;background:var(--forest);border-radius:var(--r-lg);
  padding:3rem;margin-top:3rem}
.trainer-avatar{width:80px;height:80px;border-radius:50%;background:rgba(240,235,225,.12);border:2px solid rgba(240,235,225,.18);
  color:var(--sand);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:900;flex-shrink:0}
.trainer-info h3{font-size:1.5rem;font-weight:900;color:var(--sand);letter-spacing:-.03em;margin-bottom:.25rem}
.trainer-title{font-size:.82rem;color:rgba(240,235,225,.5);font-weight:600;margin-bottom:1rem}
.trainer-bio{font-size:.95rem;color:rgba(240,235,225,.7);line-height:1.75;max-width:520px;margin-bottom:1.4rem}
.trainer-badges{display:flex;flex-wrap:wrap;gap:.5rem}
.t-badge{background:rgba(240,235,225,.08);color:rgba(240,235,225,.65);border:1px solid rgba(240,235,225,.12);
  font-size:.72rem;font-weight:600;letter-spacing:.04em;padding:.3rem .8rem;border-radius:50px}
@media(max-width:640px){.trainer-card{flex-direction:column;gap:1.5rem}}

/* ── FAQ ── */
.faq{max-width:760px;margin:3rem auto 0}
.faq details{border-bottom:1px solid var(--border);padding:1.2rem 0}
.faq details:first-child{border-top:1px solid var(--border)}
.faq summary{font-size:1rem;font-weight:700;cursor:pointer;list-style:none;display:flex;
  justify-content:space-between;align-items:center;gap:1rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.3rem;font-weight:400;color:var(--muted);flex-shrink:0}
.faq details[open] summary{color:var(--green)}
.faq details[open] summary::after{content:'−'}
.faq details p{font-size:.92rem;color:var(--muted);line-height:1.75;padding:.9rem 0 .4rem}
.faq details p a{color:var(--green);font-weight:600}

/* ── TRAINER-BAR (separater Trainer-Einstieg, abgesetzt vom Spieler-Login) ── */
.trainer-bar{background:var(--mid);color:var(--sand)}
.trainer-bar-inner{max-width:var(--maxw);margin:0 auto;padding:1.6rem 5%;display:flex;
  align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.trainer-bar-text strong{display:block;font-size:1.05rem;font-weight:800;letter-spacing:-.02em}
.trainer-bar-text span{font-size:.85rem;color:rgba(240,235,225,.82)}
.trainer-bar-actions{display:flex;gap:.7rem;flex-wrap:wrap;flex-shrink:0}
.btn-trainer{background:var(--sand);color:var(--forest);border-color:var(--sand);font-weight:800}
.btn-trainer:hover{background:#fff;transform:translateY(-2px)}
@media(max-width:560px){.trainer-bar-inner{flex-direction:column;align-items:flex-start}}

/* ── Scroll fade-up ── */
.fade-up{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.fade-up.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.fade-up{opacity:1;transform:none;transition:none}}

/* ── Cookie-/Consent-Banner ── */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:200;background:var(--forest);
  color:var(--sand);box-shadow:0 -8px 30px rgba(0,0,0,.25)}
.cookie-inner{max-width:var(--maxw);margin:0 auto;padding:1.1rem 5%;display:flex;align-items:center;
  justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.cookie-text{max-width:62ch}
.cookie-text strong{display:block;font-size:.95rem;font-weight:800;margin-bottom:.2rem}
.cookie-text span{font-size:.82rem;color:rgba(240,235,225,.78);line-height:1.55}
.cookie-text a{color:var(--sand);text-decoration:underline}
.cookie-actions{display:flex;gap:.6rem;flex-wrap:wrap;flex-shrink:0}
.cookie-actions .btn{font-size:.83rem;padding:.6rem 1.3rem}
.cookie-actions .btn-outline{color:var(--sand);border-color:rgba(240,235,225,.4)}
.cookie-actions .btn-outline:hover{border-color:var(--sand);background:rgba(240,235,225,.08)}

/* ── Karten-Consent-Platzhalter ── */
.map-container.map-placeholder{display:flex;align-items:center;justify-content:center;
  background:var(--sand2);border:1px dashed var(--border)}
.map-consent{max-width:420px;text-align:center;padding:2rem}
.map-consent .mc-title{font-weight:800;font-size:1.05rem;color:var(--ink)}
.map-consent .mc-desc{font-size:.88rem;color:var(--muted);line-height:1.6;margin:.6rem 0 1.2rem}
.map-consent .mc-note{font-size:.78rem;color:var(--muted);margin-top:.9rem}
.map-consent .mc-note a{color:var(--green);font-weight:600}

/* ── Formular-Consent ── */
.form-consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.8rem;color:var(--muted);line-height:1.5}
.form-consent input[type=checkbox]{width:auto;flex-shrink:0;margin-top:.15rem}
.form-consent a{color:var(--green);font-weight:600}
.form-note{font-size:.72rem;color:var(--muted);margin-top:.2rem}
.form-note a{color:var(--green)}
