/* ============================================================
   CALISTHENICS PARK BEXBACH — Redesign 2026
   Console / Terminal aesthetic · Mono condensed type
   Brand: yellow #ffd549 + charcoal/dark-grey
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Martian+Mono:wght@300..800&family=JetBrains+Mono:ital,wght@0,400;0,500;0,700;0,800;1,400&display=swap');

:root{
  --bg:#f3f2ec;
  --bg-2:#e9e7df;
  --ink:#1b1c20;
  --ink-soft:#52535b;
  --ink-faint:#8b8c92;
  --yellow:#ffd23f;
  --yellow-deep:#f5b800;
  --char:#131418;
  --char-2:#1b1d23;
  --char-3:#262932;
  --term:#c8ff5e;            /* terminal green accent (sparing) */
  --line:rgba(27,28,32,.16);
  --line-soft:rgba(27,28,32,.09);
  --line-light:rgba(255,255,255,.12);
  --radius:4px;
  --maxw:1240px;
  --pad:clamp(18px,5vw,64px);
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --display:"Martian Mono",var(--mono);
  --shadow:0 18px 50px -28px rgba(0,0,0,.55);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--mono);font-size:16px;line-height:1.6;
  font-feature-settings:"calt" 1;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--yellow);color:var(--char)}

/* subtle grid/scanline texture over the page */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),
                   linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:44px 44px;mask-image:radial-gradient(circle at 50% 30%,#000,transparent 90%);
  opacity:.5;
}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);position:relative;z-index:2}
.section{padding-block:clamp(56px,9vw,120px);position:relative;z-index:2}

/* ---- Type scale ---- */
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.02;
  letter-spacing:-.01em;margin:0;text-transform:uppercase;font-stretch:75%}
.display{font-size:clamp(2.6rem,8.5vw,6.2rem);font-weight:800;font-stretch:62%;letter-spacing:-.02em}
h2{font-size:clamp(1.9rem,4.5vw,3.2rem)}
h3{font-size:clamp(1.2rem,2.4vw,1.6rem)}
p{margin:0 0 1em}
strong{font-weight:700;color:var(--ink)}

/* eyebrow / terminal label */
.eyebrow{font-family:var(--mono);font-size:.72rem;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-soft);display:inline-flex;gap:.6em;align-items:center}
.eyebrow::before{content:"›";color:var(--yellow-deep);font-weight:800}
.tag{font-family:var(--mono);font-size:.66rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;padding:.32em .7em;border:1px solid var(--line);border-radius:99px;
  background:rgba(255,255,255,.4);color:var(--ink-soft)}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--mono);font-weight:700;
  font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;padding:.95em 1.5em;
  border:1.5px solid var(--ink);background:var(--ink);color:var(--bg);border-radius:var(--radius);
  cursor:pointer;transition:.18s ease;line-height:1}
.btn:hover{transform:translateY(-2px);box-shadow:5px 5px 0 var(--yellow)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{box-shadow:5px 5px 0 var(--ink);background:var(--yellow)}
.btn--y{background:var(--yellow);border-color:var(--ink);color:var(--char)}
.btn--y:hover{box-shadow:5px 5px 0 var(--ink)}
.btn svg{width:1em;height:1em}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.topbar{position:sticky;top:0;z-index:50;background:var(--char);color:#e9eaee;
  border-bottom:1px solid var(--line-light)}
.topbar .strip{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;gap:1em;
  padding:.45em var(--pad);color:#8d909a;border-bottom:1px solid rgba(255,255,255,.06)}
.topbar .strip b{color:var(--term);font-weight:500}
.topbar .strip .dot{width:7px;height:7px;border-radius:50%;background:var(--term);
  display:inline-block;margin-right:.5em;box-shadow:0 0 8px var(--term);animation:pulse 2s infinite}
@keyframes pulse{50%{opacity:.35}}
.strip .right{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5em;
  padding:.7em var(--pad)}
.brand{display:flex;align-items:center;gap:.7em;color:#fff;line-height:1}
.brand-logo{height:clamp(36px,4vw,46px);width:auto;display:block;border-radius:5px}
.foot-logo .brand-logo{height:54px}
.nav-links{display:flex;gap:.3em;align-items:center}
.nav-links a{font-family:var(--mono);font-size:.78rem;font-weight:600;letter-spacing:.05em;
  text-transform:uppercase;color:#c3c5cd;padding:.6em .9em;border-radius:var(--radius);transition:.15s}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav-links a.cta{background:var(--yellow);color:var(--char);font-weight:700}
.nav-links a.cta:hover{background:#fff}
.burger{display:none;background:none;border:1px solid rgba(255,255,255,.25);border-radius:4px;
  width:44px;height:40px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:20px;height:2px;background:#fff;transition:.25s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:860px){
  .topbar .strip .right{display:none}
  .burger{display:flex}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:var(--char-2);
    flex-direction:column;align-items:stretch;gap:.2em;padding:90px 22px 30px;
    transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
    border-left:1px solid var(--line-light);z-index:40;overflow-y:auto}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1rem;padding:1em .8em;border-bottom:1px solid rgba(255,255,255,.06)}
  .nav-links a.cta{margin-top:.6em;justify-content:center;display:flex}
  .nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);opacity:0;visibility:hidden;
    transition:.3s;z-index:30}
  .nav-backdrop.open{opacity:1;visibility:visible}
}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;background:var(--char);color:#fff;overflow:hidden;z-index:2;
  min-height:min(92vh,820px);display:flex;align-items:center;
  padding-block:clamp(90px,14vw,150px)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 32%}
.hero-shade{position:absolute;inset:0;z-index:1;
  background:linear-gradient(95deg,rgba(13,14,18,.78) 0%,rgba(13,14,18,.45) 38%,rgba(13,14,18,.05) 100%)}
.hero-scan{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.22;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0 3px,rgba(0,0,0,.18) 3px 4px)}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-inner{max-width:640px}
.hero::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(circle at 70% 40%,#000,transparent 80%)}

.hero .console-tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;color:var(--term);
  text-transform:uppercase;margin-bottom:1.4em;display:flex;align-items:center;gap:.6em}
.hero .console-tag .blink{width:9px;height:16px;background:var(--term);display:inline-block;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.hero h1{color:#fff}
.hero h1 .y{color:var(--yellow)}
.hero .lede{font-size:clamp(1rem,1.6vw,1.18rem);color:#bcbec7;max-width:46ch;margin-top:1.5em;line-height:1.7}
.hero-actions{display:flex;gap:.9em;flex-wrap:wrap;margin-top:2.2em}
.hero-actions .btn{border-color:#fff}
.hero-actions .btn--ghost{color:#fff}
.hero-actions .btn--ghost:hover{color:var(--char)}




/* hero stats ribbon */
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line-light);
  margin-top:clamp(40px,6vw,68px)}
.hero-stats div{padding:1.4em 1em;border-right:1px solid var(--line-light)}
.hero-stats div:last-child{border-right:0}
.hero-stats b{font-family:var(--display);font-stretch:62%;font-weight:800;font-size:clamp(1.5rem,3vw,2.2rem);
  color:var(--yellow);display:block;line-height:1}
.hero-stats .inf{font-style:normal;font-size:1.7em;line-height:.6;display:inline-block;vertical-align:-.08em}
.news-card .date .d .inf{font-style:normal;font-size:1.6em;line-height:.55;display:inline-block;vertical-align:-.05em}
.hero-stats span{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:#9a9ca5}
@media(max-width:780px){
  
  
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .hero-stats div:nth-child(2){border-right:0}
  .hero-stats div:nth-child(1),.hero-stats div:nth-child(2){border-bottom:1px solid var(--line-light)}
}

/* =========================================================
   SECTION HEADER
   ========================================================= */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5em;
  margin-bottom:clamp(30px,5vw,56px);flex-wrap:wrap}
.sec-head .l{max-width:60ch}
.sec-head h2{margin-top:.35em}
.sec-head p{color:var(--ink-soft);margin-top:.8em;font-size:.95rem}

/* =========================================================
   NEWS / EVENTS (mini blog)
   ========================================================= */
.news{background:var(--bg-2)}
.news-list{display:grid;gap:18px}
.news-card{display:grid;grid-template-columns:150px 1fr auto;gap:clamp(16px,3vw,34px);
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(18px,3vw,28px);align-items:start;transition:.2s;position:relative}
.news-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.news-card .date{font-family:var(--mono);border-right:1px solid var(--line);padding-right:18px}
.news-card .date .d{font-family:var(--display);font-stretch:62%;font-weight:800;font-size:2.6rem;line-height:.9;color:var(--ink)}
.news-card .date .m{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-top:.4em}
.news-card .date .y{font-size:.72rem;color:var(--ink-faint);margin-top:.2em}
.news-card .body h3{margin-bottom:.5em}
.news-card .body p{color:var(--ink-soft);font-size:.9rem;margin-bottom:.8em}
.news-card .meta{display:flex;gap:.6em;flex-wrap:wrap;margin-bottom:1em}
.news-card .links{display:flex;flex-direction:column;gap:.5em;font-size:.78rem}
.news-card .links a{color:var(--ink);border-bottom:1px solid var(--yellow-deep);padding-bottom:1px;
  display:inline-flex;gap:.4em;font-weight:600;width:fit-content}
.news-card .links a:hover{color:var(--yellow-deep)}
.news-card .pin{position:absolute;top:-1px;right:18px;background:var(--ink);color:var(--yellow);
  font-family:var(--mono);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:.35em .7em}
.ev-disciplines{list-style:none;padding:0;margin:.4em 0 0;font-size:.84rem;color:var(--ink-soft)}
.ev-disciplines li{padding:.25em 0;border-bottom:1px dashed var(--line);display:flex;gap:.6em}
.ev-disciplines li::before{content:"▹";color:var(--yellow-deep)}
@media(max-width:760px){
  .news-card{grid-template-columns:1fr;gap:14px}
  .news-card .date{display:flex;align-items:baseline;gap:.6em;border-right:0;border-bottom:1px solid var(--line);padding:0 0 12px}
  .news-card .date .d{font-size:1.8rem}
  .news-card .date .m,.news-card .date .y{margin:0}
  .news-card .links{flex-direction:row;flex-wrap:wrap}
}

/* =========================================================
   WAS IST CALISTHENICS  (text feature)
   ========================================================= */
.about{background:var(--char);color:#dadbe0;position:relative;overflow:hidden}
.about::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(circle at 20% 0,#000,transparent 75%)}
.about .wrap{position:relative}
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(34px,5vw,72px);align-items:center}
.about h2{color:#fff}
.about .eyebrow{color:#8d909a}
.about .term{background:var(--char-2);border:1px solid var(--line-light);border-radius:var(--radius);
  font-family:var(--mono);font-size:.82rem;line-height:1.85;overflow:hidden;box-shadow:var(--shadow)}
.term-bar{background:#0c0d10;padding:.7em 1em;display:flex;align-items:center;gap:.5em;border-bottom:1px solid var(--line-light)}
.term-bar i{width:11px;height:11px;border-radius:50%;display:inline-block}
.term-bar i:nth-child(1){background:#ff5f57}.term-bar i:nth-child(2){background:#febc2e}.term-bar i:nth-child(3){background:#28c840}
.term-bar span{margin-left:.6em;color:#7e818b;font-size:.7rem;letter-spacing:.1em}
.term-body{padding:1.4em 1.5em;color:#c4c6cd}
.term-body .pr{color:var(--term)}
.term-body .cm{color:#6f727c}
.term-body .y{color:var(--yellow)}
.about .lede{color:#c8cad1;font-size:clamp(1rem,1.5vw,1.12rem);line-height:1.8}
.about .lede strong{color:#fff}
.def{display:inline-block;border-left:3px solid var(--yellow);padding:.2em 0 .2em 1em;margin:.4em 0 1.4em;
  color:#fff;font-family:var(--display);font-stretch:75%;text-transform:none;font-size:1.05rem}
@media(max-width:820px){.about-grid{grid-template-columns:1fr}}

/* =========================================================
   FEATURES (3 reasons)
   ========================================================= */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feat{border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,32px);
  background:var(--bg);position:relative;transition:.2s;overflow:hidden}
.feat:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--ink)}
.feat .no{font-family:var(--mono);font-size:.7rem;font-weight:700;letter-spacing:.18em;color:var(--ink-faint)}
.feat h3{margin:.8em 0 .5em}
.feat p{color:var(--ink-soft);font-size:.9rem;margin:0}
.feat::after{content:"";position:absolute;left:0;bottom:0;height:4px;width:0;background:var(--yellow);transition:.3s}
.feat:hover::after{width:100%}
@media(max-width:760px){.feat-grid{grid-template-columns:1fr}}

/* =========================================================
   EXERCISES strip
   ========================================================= */
.ex-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.ex{border:1px solid var(--line);border-radius:var(--radius);background:var(--bg);padding:1.4em;
  display:flex;flex-direction:column;gap:.5em;transition:.2s}
.ex:hover{background:var(--ink);color:var(--bg)}
.ex:hover .ex-n,.ex:hover p{color:rgba(255,255,255,.6)}
.ex-n{font-family:var(--mono);font-weight:700;color:var(--yellow-deep);font-size:.8rem;letter-spacing:.1em}
.ex h3{font-size:1.15rem}
.ex p{font-size:.82rem;color:var(--ink-soft);margin:0}
@media(max-width:860px){.ex-grid{grid-template-columns:repeat(2,1fr)}}

/* =========================================================
   GALLERY / PARK
   ========================================================= */
.gallery{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:12px}
.gallery figure{margin:0;overflow:hidden;border-radius:var(--radius);position:relative;border:1px solid var(--line)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:.5s;filter:grayscale(.1)}
.gallery figure:hover img{transform:scale(1.06);filter:grayscale(0)}
.gallery figcaption{position:absolute;left:0;bottom:0;background:var(--char);color:#fff;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;padding:.4em .7em;
  opacity:0;transform:translateY(100%);transition:.3s}
.gallery figure:hover figcaption{opacity:1;transform:translateY(0)}
.g-a{grid-column:span 4;grid-row:span 2}
.g-b{grid-column:span 2}
.g-c{grid-column:span 2}
.g-d{grid-column:span 2}
.g-e{grid-column:span 2}
.g-f{grid-column:span 2}
@media(max-width:860px){
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .g-a,.g-b,.g-c,.g-d,.g-e,.g-f{grid-column:span 1;grid-row:span 1}
  .g-a{grid-column:span 2;grid-row:span 2}
}

/* =========================================================
   FAQ accordion
   ========================================================= */
.faq{max-width:880px}
.qa{border-top:1px solid var(--line)}
.qa:last-child{border-bottom:1px solid var(--line)}
.qa summary{cursor:pointer;list-style:none;padding:1.3em 3em 1.3em 0;position:relative;
  font-family:var(--display);font-stretch:75%;text-transform:uppercase;font-size:clamp(1rem,2vw,1.25rem);
  font-weight:700;display:block}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";position:absolute;right:.2em;top:50%;transform:translateY(-50%);
  font-family:var(--mono);font-weight:400;color:var(--yellow-deep);font-size:1.6rem;transition:.25s}
.qa[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.qa .a{padding:0 0 1.4em;color:var(--ink-soft);font-size:.95rem;max-width:70ch}
.qa .a a{border-bottom:1px solid var(--yellow-deep);font-weight:600}

/* =========================================================
   PARTNERS
   ========================================================= */
.partners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.partner{border:1px solid var(--line);border-radius:var(--radius);background:#fff;
  aspect-ratio:3/2;display:flex;align-items:center;justify-content:center;padding:1.6em;transition:.2s}
.partner:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.partner img{max-height:90px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.7;transition:.2s}
.partner:hover img{filter:grayscale(0);opacity:1}
@media(max-width:680px){.partners-grid{grid-template-columns:repeat(2,1fr)}}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{background:var(--char);color:#dadbe0}
.contact .wrap{position:relative}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,64px)}
.contact h2{color:#fff}
.contact .eyebrow{color:#8d909a}
.info-row{display:flex;gap:1em;padding:1.1em 0;border-bottom:1px solid var(--line-light);align-items:flex-start}
.info-row .k{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--yellow);min-width:120px;padding-top:.2em}
.info-row .v{color:#e6e7ec;font-size:.95rem;line-height:1.6}
.info-row .v a{border-bottom:1px solid rgba(255,255,255,.3)}
.info-row .v a:hover{color:var(--yellow);border-color:var(--yellow)}
.cform{background:var(--char-2);border:1px solid var(--line-light);border-radius:var(--radius);padding:clamp(22px,3vw,32px)}
.cform .field{margin-bottom:1.1em}
.cform label{display:block;font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;
  text-transform:uppercase;color:#9a9ca5;margin-bottom:.5em}
.cform input,.cform textarea{width:100%;background:#0e0f13;border:1px solid var(--line-light);
  border-radius:var(--radius);color:#fff;font-family:var(--mono);font-size:.9rem;padding:.85em 1em;transition:.15s}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--yellow);box-shadow:0 0 0 3px rgba(255,210,63,.15)}
.cform textarea{resize:vertical;min-height:120px}
.map-embed{margin-top:1.5em;border:1px solid var(--line-light);border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9}
.map-embed iframe{width:100%;height:100%;border:0;filter:grayscale(1) invert(.92) hue-rotate(180deg) contrast(.9)}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* =========================================================
   FOOTER
   ========================================================= */
.foot{background:#0c0d10;color:#8d909a;border-top:1px solid var(--line-light);
  font-family:var(--mono);font-size:.8rem}
.foot .wrap{padding-block:clamp(40px,6vw,64px)}
.foot-top{display:flex;justify-content:space-between;gap:2em;flex-wrap:wrap;
  padding-bottom:2em;border-bottom:1px solid rgba(255,255,255,.07)}
.foot-brand{max-width:34ch}
.foot-brand .brand{margin-bottom:1em}
.foot-cols{display:flex;gap:clamp(30px,6vw,72px);flex-wrap:wrap}
.foot-col h4{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--yellow);
  text-transform:uppercase;margin-bottom:1em}
.foot-col a{display:block;padding:.35em 0;color:#aaacb4}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;gap:1em;flex-wrap:wrap;padding-top:1.6em;font-size:.72rem;color:#62646c}
.foot-bottom a{color:#8d909a;border-bottom:1px solid transparent}
.foot-bottom a:hover{color:#fff;border-color:var(--yellow)}
.foot .sep{color:rgba(255,255,255,.2);margin:0 .6em}

/* =========================================================
   LEGAL / SUBPAGE HERO
   ========================================================= */
.page-hero{background:var(--char);color:#fff;padding-block:clamp(70px,10vw,120px);position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:48px 48px;mask-image:radial-gradient(circle at 80% 20%,#000,transparent 80%)}
.page-hero .wrap{position:relative}
.page-hero .crumb{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#8d909a;margin-bottom:1.2em}
.page-hero .crumb a:hover{color:var(--yellow)}
.page-hero .crumb b{color:var(--term);font-weight:500}
.page-hero h1{font-size:clamp(2.2rem,6vw,4rem);color:#fff}
.page-hero p{color:#bcbec7;max-width:60ch;margin-top:1em}
.page-hero p strong{color:#fff}

.legal{max-width:820px}
.legal h2{font-size:clamp(1.4rem,3vw,2rem);margin:2.2em 0 .6em;padding-top:1.4em;border-top:1px solid var(--line)}
.legal h2:first-child{border-top:0;padding-top:0;margin-top:0}
.legal h3{font-size:1.05rem;margin:1.6em 0 .5em;color:var(--ink)}
.legal p,.legal li{color:var(--ink-soft);font-size:.94rem;line-height:1.75}
.legal ul{padding-left:1.2em}
.legal a{border-bottom:1px solid var(--yellow-deep);font-weight:600;word-break:break-word}
.legal .card{background:var(--bg-2);border:1px solid var(--line);border-left:4px solid var(--yellow);
  border-radius:var(--radius);padding:clamp(18px,3vw,26px);margin:1.4em 0}
.legal .card p:last-child{margin-bottom:0}
.legal .k{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:.2em}
.toc{display:flex;flex-direction:column;gap:.3em;font-family:var(--mono);font-size:.85rem;
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.4em;margin-bottom:2.5em}
.toc a{padding:.3em 0;border-bottom:0}
.toc a:hover{color:var(--yellow-deep)}
.toc a::before{content:"› ";color:var(--yellow-deep)}

/* =========================================================
   TRAININGSPLÄNE
   ========================================================= */
.level-nav{position:sticky;top:0;z-index:20;background:var(--bg);border-bottom:1px solid var(--line);
  display:flex;gap:0;overflow-x:auto;scrollbar-width:none}
.level-nav::-webkit-scrollbar{display:none}
.level-nav a{font-family:var(--mono);font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:1.1em 1.4em;white-space:nowrap;color:var(--ink-soft);border-bottom:3px solid transparent;transition:.15s}
.level-nav a:hover{color:var(--ink)}
.level-nav a.active{color:var(--ink);border-color:var(--yellow)}
.level-nav .wrap{display:flex;padding-block:0}

.level{padding-block:clamp(48px,7vw,90px);border-top:1px solid var(--line)}
.level:first-of-type{border-top:0}
.level-head{display:flex;align-items:center;gap:1em;margin-bottom:.6em;flex-wrap:wrap}
.level-badge{font-family:var(--mono);font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:.4em .8em;border-radius:99px;color:var(--char)}
.lvl-1 .level-badge{background:var(--term)}
.lvl-2 .level-badge{background:var(--yellow)}
.lvl-3 .level-badge{background:var(--ink);color:var(--yellow)}
.level-head .meter{display:flex;gap:4px}
.level-head .meter i{width:22px;height:6px;border-radius:2px;background:var(--line)}
.lvl-1 .meter i:nth-child(-n+1),.lvl-2 .meter i:nth-child(-n+2),.lvl-3 .meter i:nth-child(-n+3){background:var(--ink)}
.level>.wrap>p.intro{color:var(--ink-soft);max-width:65ch;margin-bottom:2.2em}

.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:2.5em}
.move{border:1px solid var(--line);border-radius:var(--radius);background:var(--bg);padding:clamp(18px,2.5vw,26px);
  display:flex;flex-direction:column;transition:.2s;position:relative;overflow:hidden}
.move:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--ink)}
.move .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.7em}
.move .id{font-family:var(--mono);font-size:.72rem;font-weight:700;letter-spacing:.12em;color:var(--ink-faint)}
.move .reps{font-family:var(--mono);font-size:.7rem;font-weight:700;letter-spacing:.06em;color:var(--char);
  background:var(--yellow);padding:.3em .6em;border-radius:99px;white-space:nowrap}
.move h3{font-size:1.12rem;margin-bottom:.5em}
.move p{font-size:.86rem;color:var(--ink-soft);margin:0}
.move .muscles{display:flex;gap:.4em;flex-wrap:wrap;margin-top:auto;padding-top:1em}
.move .muscles span{font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);border:1px solid var(--line);border-radius:99px;padding:.25em .6em}

/* sample routine block (console) */
.routine{background:var(--char);color:#c4c6cd;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  font-family:var(--mono);margin-top:.6em}
.routine .term-bar span{color:#7e818b}
.routine .rows{padding:1.2em 1.5em;font-size:.86rem;line-height:1.9}
.routine .rows .pr{color:var(--term)}
.routine .rows .y{color:var(--yellow);font-weight:700}
.routine .rows .cm{color:#6f727c}
.routine .rows .row{display:flex;justify-content:space-between;gap:1em;border-bottom:1px dashed rgba(255,255,255,.08);padding:.25em 0}
.routine .rows .row:last-child{border-bottom:0}
@media(max-width:860px){.plan-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.plan-grid{grid-template-columns:1fr}}

.callout{background:var(--bg-2);border:1px solid var(--line);border-left:4px solid var(--yellow);
  border-radius:var(--radius);padding:clamp(18px,3vw,26px);margin:1.5em 0;font-size:.92rem;color:var(--ink-soft)}
.callout strong{color:var(--ink)}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(24px)}
.reveal.in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1)}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}*{animation:none!important;scroll-behavior:auto}}

/* ---- Anfahrtsskizze (lokales SVG, kein externer Dienst) ---- */
.route-map{margin:1.5em 0 0;border:1px solid var(--line-light);border-radius:var(--radius);overflow:hidden;background:#0c0d10}
.route-map>img{display:block;width:100%;height:auto}
.route-map figcaption{display:flex;flex-wrap:wrap;gap:.6em 1.2em;justify-content:space-between;align-items:center;
  padding:.8em 1em;border-top:1px solid var(--line-light);
  font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;color:#7e818b}
.route-map figcaption a{color:var(--term);text-underline-offset:3px;white-space:nowrap}
.route-map figcaption a:hover{color:#fff}

/* ---- Footer Social / Verein ---- */
.foot-social{display:flex;align-items:center;flex-wrap:wrap;gap:1em;
  margin-top:2em;padding-top:1.6em;border-top:1px solid var(--line-light)}
.foot-social__label{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;
  text-transform:uppercase;color:#6f727c}
.social{display:flex;gap:.7em;flex-wrap:wrap}
.social a{display:inline-flex;align-items:center;gap:.5em;
  padding:.55em .9em;border:1px solid var(--line-light);border-radius:var(--radius);
  color:#c7c9d2;font-family:var(--mono);font-size:.76rem;letter-spacing:.06em;
  text-decoration:none;transition:.18s}
.social a:hover{background:var(--yellow);border-color:var(--yellow);color:var(--char)}
.social svg{flex:0 0 auto}
.social__txt{line-height:1}
@media(max-width:560px){ .social__txt{display:none} .social a{padding:.6em} }

/* ---- kleiner Ticket-Button in News-Card ---- */
.btn--sm{padding:.6em 1.1em;font-size:.78rem}
.ticket-btn{display:inline-flex;margin-top:1.3em}

/* ===== Seite: Trainings unter Anleitung ===== */
.spart-head{margin-bottom:2em}
.spart-head .eyebrow{color:var(--yellow-deep)}
.spart-head h2{font-family:var(--display);font-weight:800;font-stretch:62%;text-transform:uppercase;
  letter-spacing:-.01em;font-size:clamp(1.7rem,4.5vw,2.6rem);line-height:1.02;margin:.2em 0 0;color:var(--ink)}
.spart--alt{background:#eceae1}
.spart-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(1.5em,4vw,3em);align-items:start}
.spart-media{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);position:sticky;top:120px}
.spart-media img{display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.spart-body p{color:var(--ink-soft);line-height:1.75;margin:0 0 1.4em}
.spart-body p strong{color:var(--ink)}
.spart-sub{font-family:var(--mono);font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);margin:1.8em 0 .8em;padding-bottom:.5em;border-bottom:2px solid var(--yellow)}
.spart-list{list-style:none;padding:0;margin:0 0 1em}
.spart-list li{position:relative;padding:.5em 0 .5em 1.6em;color:var(--ink-soft);line-height:1.5;
  border-bottom:1px dashed var(--line-soft)}
.spart-list li::before{content:"▸";position:absolute;left:0;color:var(--yellow-deep);font-weight:700}
/* Info-Karte (hell) */
.info-card{border:1px solid var(--line);border-radius:var(--radius);padding:.4em 1.2em;margin:.5em 0 1.6em;background:#fff}
.spart--alt .info-card{background:var(--bg)}
.info-card .info-row{display:flex;gap:1em;padding:.85em 0;border-bottom:1px solid var(--line-soft);align-items:flex-start}
.info-card .info-row:last-child{border-bottom:0}
.info-card .k{flex:0 0 92px;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-faint);padding-top:.15em}
.info-card .v{color:var(--ink);font-size:.95rem;line-height:1.5}
.todo{display:inline-block;background:#fff4cc;color:#7a5c00;border:1px dashed #d9b400;
  font-family:var(--mono);font-size:.78rem;padding:.25em .7em;border-radius:3px}
.spart--alt .todo{background:#fbf3d0}
@media(max-width:760px){
  .spart-grid{grid-template-columns:1fr}
  .spart-media{position:static;max-width:420px}
  .spart-grid--rev .spart-media{order:-1}
}
/* Term-Block (dunkel, „mitmachen") */
.term-block{background:var(--char);border:1px solid var(--line-light);border-radius:var(--radius);overflow:hidden;max-width:760px}
.term-block .prompt{color:var(--term);font-weight:700;margin-right:.4em}
.term-block .term-body p{margin:0 0 .6em;font-family:var(--mono);font-size:.95rem}
.term-block .muted{color:#9a9ca5;font-size:.85rem;line-height:1.7}
