/* ─────────────────────────────────────────────────────────────────────────────
   UTC NEULENGBACH – Stylesheet
   Font: Barlow Condensed (headings) + Barlow (body)
   Colors: #c8133e (red) · #4e2f4b (purple/dark) · #f5f3f0 (cream)
───────────────────────────────────────────────────────────────────────────── */

:root {
  --red:        #c8133e;
  --red-dark:   #a60f32;
  --dark:       #4e2f4b;
  --dark2:      #2e1a2c;
  --cream:      #f5f3f0;
  --cream2:     #ede9e4;
  --white:      #ffffff;
  --text:       #1a1a1a;
  --text-mid:   #4a4540;
  --muted:      #7a746e;
  --border:     #ddd8d2;
  --nav-h:      64px;
  --radius:     6px;
  --shadow-sm:  0 2px 8px rgba(0,0,0,.07);
  --shadow:     0 4px 20px rgba(0,0,0,.10);
  --shadow-md:  0 8px 32px rgba(0,0,0,.14);
  --container:  1180px;
  --ease:       cubic-bezier(.22,1,.36,1);
}

/* ── RESET ──────────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h)}
body{
  font-family:'Barlow',system-ui,sans-serif;
  font-size:clamp(15px,1.05vw,17px);
  line-height:1.7;
  color:var(--text);
  background:var(--white);
  overflow-x:hidden
}
img,video,svg{display:block;max-width:100%}
ul,ol{list-style:none}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font:inherit;border:none;background:none}
input,select,textarea{font:inherit}

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:clamp(1rem,4vw,2.5rem)
}

/* ── SECTIONS ────────────────────────────────────────────────────────────────── */
.section{padding-block:clamp(3.5rem,7vw,6rem)}
.section--cream{background:var(--cream)}
.section--photo{
  position:relative;
  background-image:var(--photo);
  background-size:cover;
  background-position:center;
  padding-block:clamp(4rem,8vw,7rem);
}
.photo-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(78,47,75,.88),rgba(26,10,22,.82));
}

/* ── SECTION HEADING (with red left bar) ─────────────────────────────────── */
.sec-heading{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(1.9rem,3.5vw,2.8rem);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--text);
  position:relative;
  padding-left:1rem;
  margin-bottom:1.75rem;
}
.sec-heading::before{
  content:'';
  position:absolute;
  left:0;top:.1em;bottom:.1em;
  width:4px;
  background:var(--red);
  border-radius:2px;
}
.sec-heading--light{color:var(--white)}
.sec-heading--light::before{background:rgba(255,255,255,.5)}

/* ── NAVIGATION ─────────────────────────────────────────────────────────────── */
.site-header{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  height:var(--nav-h);
  background:rgba(255,255,255,.0);
  transition:background .3s,box-shadow .3s;
}
.site-header.is-scrolled{
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(0,0,0,.06),var(--shadow-sm);
}

.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:clamp(1rem,4vw,2.5rem);
}

.site-logo{
  display:flex;align-items:center;gap:.7rem;
  flex-shrink:0;
}
.site-logo img{
  width:42px;height:42px;
  border-radius:4px;
  object-fit:cover;
  flex-shrink:0;
}
.site-logo__text{
  display:flex;flex-direction:column;line-height:1.15;
  transition:opacity .3s;
}
/* Hide text when transparent (hero area) */
.site-header:not(.is-scrolled) .site-logo__text{opacity:0;pointer-events:none}
.site-logo__club{font-family:'Barlow Condensed',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--dark)}
.site-logo__sub{font-size:.65rem;color:var(--muted);letter-spacing:.04em}

.nav-burger{
  display:none;
  flex-direction:column;gap:5px;padding:.4rem;
}
.nav-burger span{
  display:block;width:22px;height:2px;
  background:var(--white);
  border-radius:1px;
  transition:all .28s var(--ease);
}
.site-header.is-scrolled .nav-burger span{background:var(--text)}
.nav-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}


.nav-list{
  display:flex;align-items:center;gap:.1rem;
}
.nav-a{
  display:flex;align-items:center;gap:.3rem;
  padding:.45em .75em;
  border-radius:4px;
  font-size:.875rem;
  font-weight:500;
  letter-spacing:.01em;
  color:rgba(255,255,255,.85);
  transition:color .2s,background .2s;
  white-space:nowrap;
  background:none;
}
.nav-a svg{width:10px;height:8px;transition:transform .2s;flex-shrink:0}
.nav-a:hover,.nav-a.is-active{color:var(--white);background:rgba(255,255,255,.1)}
.site-header.is-scrolled .nav-a{color:var(--text-mid)}
.site-header.is-scrolled .nav-a:hover{color:var(--red);background:rgba(200,19,62,.06)}

.nav-res-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.45em 1em;
  margin-left:.75rem;
  border-radius:4px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.875rem;
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
  background:var(--red);
  color:var(--white);
  transition:background .2s,transform .2s;
  white-space:nowrap;
}
.nav-res-btn:hover{background:var(--red-dark);transform:translateY(-1px);color:var(--white);}

/* Dropdown */
.nav-dropdown{position:relative}
.nav-dropdown:hover .nav-sub,
.nav-dropdown:focus-within .nav-sub{
  opacity:1;visibility:visible;transform:translateY(0);
}
.nav-dropdown .nav-a[aria-expanded="true"] svg{transform:rotate(180deg)}
.nav-sub{
  position:absolute;top:calc(100% + 4px);left:50%;
  transform:translateX(-50%) translateY(6px);
  min-width:190px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
  padding:.4rem 0;
  opacity:0;visibility:hidden;
  transition:all .22s var(--ease);
}
.nav-sub__a{
  display:block;
  padding:.55em 1.1em;
  font-size:.875rem;
  color:var(--text-mid);
  transition:background .15s,color .15s;
}
.nav-sub__a:hover{background:var(--cream);color:var(--red)}

/* ── HERO ────────────────────────────────────────────────────────────────────── */
.hero{
  position:relative;
  min-height:100dvh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  color:var(--white);
}
.hero__img{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center 30%;
  transform:scale(1.04);
  transition:transform 8s ease;
}
.hero:hover .hero__img{transform:scale(1)}

.hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    to bottom,
    rgba(20,5,18,.35) 0%,
    rgba(30,10,25,.55) 50%,
    rgba(20,5,18,.75) 100%
  );
}
.hero__body{
  position:relative;z-index:1;
  text-align:center;
  padding:calc(var(--nav-h) + 2rem) 1.5rem 5rem;
  max-width:780px;
}
.hero__logo{
  width:clamp(70px,10vw,110px);
  height:clamp(70px,10vw,110px);
  border-radius:50%;
  object-fit:cover;
  margin-inline:auto;
  margin-bottom:1.5rem;
  border:3px solid rgba(255,255,255,.35);
  box-shadow:0 0 0 6px rgba(200,19,62,.2);
}
.hero__eyebrow{
  font-size:clamp(.8rem,1.2vw,.95rem);
  font-weight:400;
  color:rgba(255,255,255,.65);
  letter-spacing:.06em;
  margin-bottom:.75rem;
}
.hero__title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(3.5rem,9vw,7rem);
  font-weight:800;
  letter-spacing:.03em;
  text-transform:uppercase;
  line-height:1;
  margin-bottom:.75rem;
  text-shadow:0 2px 20px rgba(0,0,0,.4);
}
.hero__tagline{
  font-size:clamp(.95rem,1.5vw,1.15rem);
  color:rgba(255,255,255,.7);
  margin-bottom:2.5rem;
  font-weight:300;
}
.hero__links{
  display:flex;align-items:center;justify-content:center;
  gap:1rem;flex-wrap:wrap;
}
.hero__btn{
  display:inline-block;
  padding:.7em 1.8em;
  border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:1rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:var(--red);
  color:var(--white);
  transition:background .2s,transform .2s;
}
.hero__btn:hover{background:var(--red-dark);transform:translateY(-2px)}
.hero__btn--outline{
  background:transparent;
  border:2px solid rgba(255,255,255,.5);
  color:var(--white);
}
.hero__btn--outline:hover{background:rgba(255,255,255,.1);border-color:var(--white)}

.hero__scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  z-index:1;
  color:rgba(255,255,255,.4);
  animation:scrollBounce 2.2s ease-in-out infinite;
  transition:color .2s;
}
.hero__scroll:hover{color:rgba(255,255,255,.8)}
.hero__scroll svg{width:28px;height:28px}
@keyframes scrollBounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  55%{transform:translateX(-50%) translateY(7px)}
}

/* ── NEWS ────────────────────────────────────────────────────────────────────── */
.news-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.news-item{
  border-top:3px solid var(--red);
  padding-top:1.25rem;
}
.news-item__head{margin-bottom:.6rem}
.news-item__date{
  font-size:.8rem;
  font-weight:600;
  color:var(--muted);
  letter-spacing:.03em;
}
.news-item__title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.3rem;
  font-weight:700;
  letter-spacing:.01em;
  line-height:1.25;
  margin-bottom:.7rem;
  color:var(--text);
}
.news-item__body{
  font-size:.9rem;
  color:var(--text-mid);
  line-height:1.65;
}

/* ── VEREIN ──────────────────────────────────────────────────────────────────── */
.verein-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,5rem);
  align-items:start;
}
.verein-photos{
  display:grid;
  grid-template-rows:auto auto;
  gap:.75rem;
}
.verein-photos__main{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius);
}
.verein-photos__sub{
  width:60%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius);
  margin-left:auto;
  margin-top:-3rem;
  box-shadow:var(--shadow-md);
  border:4px solid var(--white);
}
.verein-text p{
  font-size:.95rem;
  color:var(--text-mid);
  margin-bottom:1rem;
}
.verein-facts{
  margin-top:1.5rem;
  display:flex;flex-direction:column;gap:.6rem;
}
.verein-facts li{
  display:flex;align-items:center;gap:.6rem;
  font-size:.9rem;
  color:var(--text-mid);
}
.verein-facts__icon{font-size:1rem;flex-shrink:0}

/* ── TRAINING ────────────────────────────────────────────────────────────────── */
.training-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,5rem);
  align-items:start;
}
.training-intro p{
  font-size:.95rem;
  color:var(--text-mid);
  margin-bottom:.9rem;
}
.training-sub{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.2rem;
  font-weight:600;
  color:var(--dark);
  margin-bottom:1rem;
  line-height:1.3;
}
.training-note{
  font-size:.85rem;
  color:var(--muted);
  background:var(--cream);
  border-left:3px solid var(--red);
  padding:.7rem 1rem;
  border-radius:0 var(--radius) var(--radius) 0;
  margin-bottom:.9rem !important;
}

/* ── CAMPS ───────────────────────────────────────────────────────────────────── */
.camps-layout{
  display:grid;
  grid-template-columns:1fr auto;
  gap:2rem;
  align-items:center;
}
.camps-info p{
  color:rgba(255,255,255,.8);
  margin-bottom:.85rem;
  font-size:.95rem;
}
.btn-camp{
  display:inline-block;
  padding:.8em 2em;
  border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.1rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:var(--red);
  color:var(--white);
  white-space:nowrap;
  transition:background .2s,transform .2s;
  border:none;cursor:pointer;
}
.btn-camp:hover{background:var(--red-dark);transform:translateY(-2px)}

/* ── MITGLIED ────────────────────────────────────────────────────────────────── */
.member-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,5rem);
  align-items:start;
}
.member-intro p{
  font-size:.95rem;
  color:var(--text-mid);
  margin-bottom:.9rem;
}
.iban-box{
  background:var(--cream);
  border:1px solid var(--border);
  border-left:4px solid var(--red);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:1.25rem 1.5rem;
  margin:1.5rem 0;
}
.iban-box__label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--red);
  margin-bottom:.6rem;
}
.iban-box p{font-size:.9rem;color:var(--text-mid);margin-bottom:.4rem}
.iban-box__bank{font-weight:600;color:var(--text)}
.iban-box__iban{font-family:monospace;font-size:.95rem;color:var(--dark);letter-spacing:.04em}
.member-closing{color:var(--muted);font-style:italic;font-size:.9rem;margin-bottom:1.25rem !important}
.member-photo{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  border-radius:var(--radius);
  margin-top:.5rem;
}

/* ── SPIELERBÖRSE ────────────────────────────────────────────────────────────── */
.sb-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,5rem);
  align-items:start;
}
.sb-layout>div:first-child p{
  font-size:.95rem;
  color:var(--text-mid);
  margin-bottom:.9rem;
}

/* ── GÄSTE ───────────────────────────────────────────────────────────────────── */
.gaeste-layout{
  display:grid;
  grid-template-columns:1fr auto;
  gap:2rem;
  align-items:start;
}
.gaeste-layout>div:first-child p{
  font-size:.95rem;
  color:var(--text-mid);
  margin-bottom:.9rem;
}
.gaeste-contact{
  background:var(--cream);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.5rem;
  font-size:.9rem;
  white-space:nowrap;
}
.gaeste-contact p{margin-bottom:.5rem}
.gaeste-contact a{color:var(--red)}
.gaeste-contact a:hover{text-decoration:underline}

/* ── ANFAHRT ─────────────────────────────────────────────────────────────────── */
.anfahrt-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:start;
}
.anfahrt-photo{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius);
}

.anfahrt-addr{
  font-size:1rem;
  line-height:1.8;
  color:var(--text-mid);
  margin-bottom:1.5rem;
}
.anfahrt-addr strong{color:var(--text);font-family:'Barlow Condensed',sans-serif;font-size:1.15rem;font-weight:700;letter-spacing:.03em}
.anfahrt-map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.anfahrt-gmaps{
  display:block;
  padding:.65rem 1rem;
  background:var(--cream);
  font-size:.85rem;
  font-weight:500;
  color:var(--red);
  border-top:1px solid var(--border);
  transition:background .2s;
}
.anfahrt-gmaps:hover{background:var(--cream2)}

/* ── SPONSORS ────────────────────────────────────────────────────────────────── */
.sponsors{
  padding-block:2.5rem;
  border-top:1px solid var(--border);
  background:var(--white);
}
.sponsors__label{
  text-align:center;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:1.5rem;
}
.sponsors__logos{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:3rem;
  flex-wrap:wrap;
}
.sponsor-logo{
  display:block;
  opacity:.55;
  transition:opacity .2s;
  max-height:50px;
}
.sponsor-logo:hover{opacity:1}
.sponsor-logo img{
  max-height:50px;
  width:auto;
  object-fit:contain;
}

/* ── FORMS ───────────────────────────────────────────────────────────────────── */
.form-block{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:2rem 2rem 2.25rem;
  box-shadow:var(--shadow-sm);
}
.form-block__title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.2rem;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--dark);
  margin-bottom:1.5rem;
  padding-bottom:1rem;
  border-bottom:2px solid var(--red);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row--3{grid-template-columns:1fr 1fr 1fr}
.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.65rem}
.form-label{
  font-size:.78rem;
  font-weight:600;
  color:var(--text-mid);
  letter-spacing:.02em;
}
.req{color:var(--red)}
.form-input,.form-select,.form-textarea{
  width:100%;
  padding:.6em .85em;
  border:1.5px solid var(--border);
  border-radius:4px;
  background:var(--white);
  color:var(--text);
  font-size:.9rem;
  transition:border-color .18s,box-shadow .18s;
  outline:none;
  appearance:none;
  -webkit-appearance:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--red);
  box-shadow:0 0 0 3px rgba(200,19,62,.1);
}
.form-input::placeholder,.form-textarea::placeholder{color:#bbb}
.form-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath d='M1 1l6 6 6-6' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right .8em center;
  padding-right:2.4em;
  cursor:pointer;
}
.form-textarea{resize:vertical;min-height:90px}

.form-fieldset{border:none;margin-bottom:.75rem}
.form-fieldset legend{
  font-size:.78rem;font-weight:600;color:var(--text-mid);letter-spacing:.02em;margin-bottom:.6rem
}
.form-checkrow{display:flex;flex-wrap:wrap;gap:.5rem}
.form-check{
  display:inline-flex;position:relative;cursor:pointer;
}
.form-check input[type="checkbox"],
.form-check input[type="radio"] {
  position:absolute;
  opacity:0;
  width:0;
  height:0;
  margin:0;
}
.form-check span{
  font-size:.85rem;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--text-mid);
  padding:.2em .6em;
  border:1px solid var(--border);
  border-radius:3px;
  transition:all .15s;
}
.form-check input:checked+span{
  background:var(--red);color:var(--white);border-color:var(--red);
}

.form-section-label{
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:.75rem;
  margin-top:1rem;
  padding-top:.75rem;
  border-top:1px solid var(--border);
}

.form-checkbox{
  display:flex;align-items:flex-start;gap:.6rem;cursor:pointer;
  font-size:.85rem;color:var(--text-mid);
}
.form-checkbox input{margin-top:.15rem;accent-color:var(--red)}
.form-link{color:var(--red)}

.form-response{min-height:0;margin-bottom:.5rem}
.form-success,.form-error{
  padding:.8rem 1rem;border-radius:4px;
  font-size:.875rem;font-weight:500;
  margin-bottom:.6rem;
  animation:fIn .25s ease;
}
.form-success{background:rgba(22,163,74,.08);color:#15623a;border:1px solid rgba(22,163,74,.18)}
.form-error  {background:rgba(200,19,62,.06);color:#8a0020;border:1px solid rgba(200,19,62,.18)}
@keyframes fIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* Submit button */
.btn-submit{
  width:100%;
  padding:.75em 1.5em;
  border-radius:3px;
  background:var(--red);
  color:var(--white);
  font-family:'Barlow Condensed',sans-serif;
  font-size:1rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  border:none;cursor:pointer;
  transition:background .2s,transform .2s;
}
.btn-submit:hover{background:var(--red-dark);transform:translateY(-1px)}
.btn-submit:active{transform:none}
.btn-submit .btn-loader{display:none}
.btn-submit.is-loading .btn-text{display:none}
.btn-submit.is-loading .btn-loader{display:inline}
.btn-submit.is-loading{pointer-events:none;opacity:.7}

/* ── MODAL ───────────────────────────────────────────────────────────────────── */
.modal{
  position:fixed;inset:0;
  z-index:2000;
  display:flex;align-items:flex-start;justify-content:center;
  padding:1rem;
  overflow-y:auto;
}
.modal[hidden]{display:none}
.modal__backdrop{
  position:fixed;inset:0;
  background:rgba(10,0,14,.7);
  backdrop-filter:blur(5px);
  -webkit-backdrop-filter:blur(5px);
  cursor:pointer;
}
.modal__panel{
  position:relative;
  background:var(--white);
  border-radius:var(--radius);
  width:100%;max-width:680px;
  padding:1.5rem 2rem 2rem;
  box-shadow:var(--shadow-md);
  margin-block:auto;
  animation:mIn .3s var(--ease);
}
@keyframes mIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.modal__close{
  position:absolute;top:1.1rem;right:1.1rem;
  width:32px;height:32px;
  display:grid;place-items:center;
  border-radius:50%;
  color:var(--muted);
  transition:background .15s,color .15s;
}
.modal__close:hover{background:var(--cream);color:var(--text)}
.modal__close svg{width:17px;height:17px}
.modal__title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.5rem;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;
  color:var(--dark);
  margin-bottom:1rem;
  padding-bottom:.5rem;
  border-bottom:2px solid var(--red);
}
.form-modal .form-group{margin-bottom:.6rem}

/* ── FOOTER ──────────────────────────────────────────────────────────────────── */
.site-footer{
  background:var(--dark2);
  color:rgba(255,255,255,.55);
  padding-block:2.5rem;
  border-top:3px solid var(--red);
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
  flex-wrap:wrap;
}
.footer-brand{
  display:flex;align-items:center;gap:.85rem;
}
.footer-brand img{
  width:44px;height:44px;
  border-radius:4px;object-fit:cover;
  opacity:.85;
}
.footer-brand__name{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1rem;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;
  color:rgba(255,255,255,.85);
  margin-bottom:.1rem;
}
.footer-brand__addr{font-size:.8rem;color:rgba(255,255,255,.4)}
.footer-nav{
  display:flex;flex-wrap:wrap;gap:.25rem .75rem;
  justify-content:center;
}
.footer-nav a{
  font-size:.82rem;
  color:rgba(255,255,255,.45);
  transition:color .15s;
}
.footer-nav a:hover{color:rgba(255,255,255,.85)}
.footer-legal{
  display:flex;flex-direction:column;align-items:flex-end;gap:.3rem;
  font-size:.78rem;
}
.footer-legal a{color:rgba(255,255,255,.35);transition:color .15s}
.footer-legal a:hover{color:rgba(255,255,255,.7)}
.footer-legal p{color:rgba(255,255,255,.25)}

/* ── BACK TO TOP ─────────────────────────────────────────────────────────────── */
.back-top{
  position:fixed;bottom:1.75rem;right:1.75rem;
  z-index:900;
  width:42px;height:42px;
  background:var(--red);
  color:var(--white);
  border-radius:3px;
  display:grid;place-items:center;
  box-shadow:0 3px 14px rgba(200,19,62,.4);
  opacity:0;visibility:hidden;
  transform:translateY(10px);
  transition:all .28s var(--ease);
}
.back-top.is-visible{opacity:1;visibility:visible;transform:none}
.back-top:hover{background:var(--red-dark);transform:translateY(-2px)}
.back-top svg{width:18px;height:18px}

/* ── SCROLL ANIMATIONS ───────────────────────────────────────────────────────── */
.reveal-up{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .6s var(--ease),transform .6s var(--ease);
}
.reveal-up.is-visible{opacity:1;transform:none}

/* ── SECTION HEADING ROW ─────────────────────────────────────────────────────── */
.section-heading-row{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  margin-bottom:1.75rem;
}
.section-heading-row .sec-heading{margin-bottom:0}
.all-posts-link{
  font-family:'Barlow Condensed',sans-serif;
  font-size:.9rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--red);white-space:nowrap;
  transition:color .15s;
}
.all-posts-link:hover{color:var(--red-dark)}

.news-item__more{
  display:inline-block;margin-top:.75rem;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--red);transition:color .15s;
}
.news-item__more:hover{color:var(--red-dark)}

/* ── VEREINSVORSTAND ─────────────────────────────────────────────────────────── */
.vorstand-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  margin-bottom:1px;
}
.vorstand-item{
  background:var(--white);
  padding:1.2rem 1.4rem;
  transition:background .18s;
}
.vorstand-item:hover{background:var(--cream)}
.vorstand-item--pres{
  background:var(--dark);
}
.vorstand-item--pres:hover{background:var(--dark2)}
.vorstand-item__role{
  font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--red);margin-bottom:.35rem;
}
.vorstand-item--pres .vorstand-item__role{color:rgba(255,255,255,.5)}
.vorstand-item__name{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.1rem;font-weight:700;letter-spacing:.02em;
  color:var(--text);line-height:1.2;margin-bottom:.3rem;
}
.vorstand-item--pres .vorstand-item__name{color:var(--white)}
.vorstand-item__phone{
  font-size:.78rem;color:var(--muted);transition:color .15s;
}
.vorstand-item__phone:hover{color:var(--red)}
.vorstand-beirat{
  display:flex;flex-wrap:wrap;gap:.75rem 3rem;
  padding:1rem 1.4rem;
  border:1px solid var(--border);
  border-top:none;
  border-radius:0 0 var(--radius) var(--radius);
  background:var(--cream);
}
.vorstand-beirat__group{display:flex;flex-direction:column;gap:.15rem}
.vorstand-beirat__label{
  font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--red);
}
.vorstand-beirat__names{font-size:.88rem;color:var(--text-mid)}

/* ── TRAINING PRICE BOX ──────────────────────────────────────────────────────── */
.training-price-box{
  display:inline-flex;align-items:center;gap:1.1rem;
  background:var(--dark);
  border-radius:var(--radius);
  padding:1rem 1.5rem;
  margin:1.2rem 0 1rem;
}
.training-price-box__amount{
  font-family:'Barlow Condensed',sans-serif;
  font-size:2.6rem;font-weight:800;
  color:var(--white);line-height:1;letter-spacing:-.01em;
}
.training-price-box__label{
  font-size:.85rem;color:rgba(255,255,255,.65);line-height:1.45;
}
.training-price-box__label small{
  display:block;font-size:.75rem;color:rgba(255,255,255,.4);
}

/* ── CAMP CARDS ──────────────────────────────────────────────────────────────── */
.camps-lead{
  color:rgba(255,255,255,.7);font-size:.95rem;
  margin-bottom:2rem;margin-top:-.5rem;
}
.camp-cards{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.25rem;margin-bottom:2rem;
}
.camp-card{
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);padding:1.5rem;
  position:relative;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:background .2s,transform .2s;
  display:flex;flex-direction:column;
}
.camp-card:hover{background:rgba(255,255,255,.17);transform:translateY(-3px)}
.camp-card--perf{
  border-color:rgba(200,19,62,.45);
  background:rgba(200,19,62,.1);
}
.camp-card__badge{
  display:inline-block;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  background:var(--red);color:var(--white);
  padding:.2em .65em;border-radius:2px;
  margin-bottom:.75rem;align-self:flex-start;
}
.camp-card__type{
  font-family:'Barlow Condensed',sans-serif;
  font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin-bottom:.25rem;
}
.camp-card__dates{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.35rem;font-weight:700;
  color:var(--white);margin-bottom:.75rem;line-height:1.2;
}
.camp-card__price{
  font-family:'Barlow Condensed',sans-serif;
  font-size:2.2rem;font-weight:800;
  color:var(--white);line-height:1;
  margin-bottom:.35rem;letter-spacing:-.01em;
  margin-top:auto;
}
.camp-card__note{font-size:.8rem;color:rgba(255,255,255,.5);margin-bottom:1.25rem}
.camp-card__btn{
  display:block;width:100%;
  padding:.6em 1em;border-radius:3px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.9rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  background:rgba(255,255,255,.9);color:var(--dark);
  cursor:pointer;border:none;
  transition:background .18s,color .18s;
  margin-top:auto;
}
.camp-card__btn:hover{background:var(--white)}
.camp-card--perf .camp-card__btn{background:var(--red);color:var(--white)}
.camp-card--perf .camp-card__btn:hover{background:var(--red-dark)}
.camps-footnote{
  font-size:.85rem;color:rgba(255,255,255,.45);
  text-align:center;max-width:600px;margin-inline:auto;
}

/* ── PRICE TABLE ─────────────────────────────────────────────────────────────── */
.price-table{
  width:100%;border-collapse:collapse;
  margin:1rem 0;font-size:.8rem;
}
.price-table caption{
  caption-side:top;
  font-size:.78rem;color:var(--muted);
  text-align:left;margin-bottom:.5rem;
  font-style:italic;padding-bottom:.4rem;
}
.price-table th{
  font-family:'Barlow Condensed',sans-serif;
  font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);padding:.5rem .75rem;
  border-bottom:2px solid var(--border);text-align:left;
}
.price-table td{
  padding:.35rem .75rem;
  border-bottom:1px solid var(--border);
  color:var(--text-mid);vertical-align:middle;
}
.price-table tbody tr:hover td{background:var(--cream)}
.price-col{text-align:right;font-weight:600;color:var(--text);white-space:nowrap}
.price-note{font-size:.76rem;color:var(--muted);display:block;margin-top:.1rem}
.price-free{color:var(--dark);font-weight:700}
.price-row--early td{background:rgba(200,19,62,.025)}
.price-row--sep td{border-top:2px solid var(--border)}
.price-table tfoot td{
  font-size:.78rem;color:var(--muted);
  padding:.65rem .75rem;border-bottom:none;
  border-top:2px solid var(--border);
}

/* ── GAESTE RATES ────────────────────────────────────────────────────────────── */
.gaeste-rates{
  display:flex;gap:1.25rem;margin:1.25rem 0;flex-wrap:wrap;
}
.gaeste-rate{
  flex:1;min-width:150px;
  background:var(--cream);
  border:1px solid var(--border);
  border-left:4px solid var(--red);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:1rem 1.4rem;
}
.gaeste-rate__price{
  font-family:'Barlow Condensed',sans-serif;
  font-size:2rem;font-weight:800;
  color:var(--dark);line-height:1;margin-bottom:.2rem;
}
.gaeste-rate__label{font-size:.82rem;color:var(--muted);line-height:1.4}

/* ── ANFAHRT CONTACT ROW ─────────────────────────────────────────────────────── */
.anfahrt-contact-row{
  display:flex;align-items:center;gap:.5rem;
  margin-bottom:1.25rem;font-size:.9rem;color:var(--text-mid);
}
.anfahrt-contact-row a{color:var(--red);transition:color .15s}
.anfahrt-contact-row a:hover{text-decoration:underline}

/* ── SUBPAGE LAYOUT (neuigkeiten, impressum, datenschutz) ─────────────────────── */
.subpage-hero{
  background:var(--dark);
  padding:calc(var(--nav-h) + 3rem) 0 3rem;
  color:var(--white);
  border-bottom:3px solid var(--red);
}
.subpage-hero__eyebrow{
  font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.45);margin-bottom:.6rem;
}
.subpage-hero h1{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(2.2rem,5vw,3.6rem);
  font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  color:var(--white);line-height:1;
}
.subpage-body{
  padding-block:clamp(3rem,6vw,5rem);
}
.prose{max-width:760px}
.prose h2{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.5rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
  color:var(--dark);margin:2rem 0 .75rem;
  padding-left:1rem;position:relative;
}
.prose h2::before{
  content:'';position:absolute;left:0;top:.1em;bottom:.1em;
  width:3px;background:var(--red);border-radius:2px;
}
.prose h3{
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.15rem;font-weight:700;letter-spacing:.02em;
  color:var(--dark);margin:1.5rem 0 .5rem;
}
.prose p{font-size:.95rem;color:var(--text-mid);line-height:1.75;margin-bottom:.9rem}
.prose ul{margin:.5rem 0 .9rem 1.2rem;list-style:disc}
.prose ul li{font-size:.93rem;color:var(--text-mid);line-height:1.65;margin-bottom:.3rem}
.prose a{color:var(--red);transition:color .15s}
.prose a:hover{text-decoration:underline}
.prose strong{color:var(--text);font-weight:600}

/* news-full page */
.news-full-grid{
  display:flex;flex-direction:column;gap:3.5rem;
}
.news-article{
  border-top:3px solid var(--red);
  padding-top:1.75rem;
  max-width:760px;
}
.news-article__date{
  font-size:.78rem;font-weight:700;letter-spacing:.04em;color:var(--muted);
  margin-bottom:.5rem;
}
.news-article__title{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;
  letter-spacing:.03em;text-transform:uppercase;
  color:var(--text);line-height:1.1;margin-bottom:1.1rem;
}
.news-article__body{font-size:.95rem;color:var(--text-mid);line-height:1.78}
.news-article__body p{margin-bottom:.85rem}
.news-article__body strong{color:var(--text);font-weight:600}

/* ── RESPONSIVE ─────────────────────────────────────────────────────────────── */
@media(max-width:1024px){
  .verein-grid,
  .training-layout,
  .member-layout,
  .sb-layout,
  .anfahrt-grid{grid-template-columns:1fr}
  .verein-photos{display:block}
  .verein-photos__sub{display:none}
  .news-grid{grid-template-columns:1fr 1fr}
  .camps-layout{grid-template-columns:1fr;text-align:center}
  .camps-layout .btn-camp{margin-inline:auto}
  .gaeste-layout{grid-template-columns:1fr}
  .camp-cards{grid-template-columns:1fr 1fr}
  .vorstand-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
}

@media(max-width:768px){
  .nav-burger{display:flex}
  .site-nav{
    position:fixed;
    top:var(--nav-h);left:0;right:0;
    background:rgba(46,26,44,.97);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    padding:1.25rem 1.5rem 2rem;
    border-top:2px solid var(--red);
    opacity:0;pointer-events:none;
    transform:translateY(-10px);
    transition:all .28s var(--ease);
  }
  .site-nav.is-open{opacity:1;pointer-events:auto;transform:none}
  .nav-list{flex-direction:column;align-items:stretch;gap:.2rem}
  .nav-a{color:rgba(255,255,255,.8);padding:.65em .85em;font-size:.95rem}
  .nav-a:hover,.nav-a.is-active{color:var(--white);background:rgba(255,255,255,.1)}
  .site-header.is-scrolled .nav-a{color:rgba(255,255,255,.8)}
  .nav-res-btn{margin-left:0;margin-top:.5rem;width:100%;text-align:center;}
  .nav-sub{display:none;position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:rgba(255,255,255,.05);border:none;padding:.2rem 0 .2rem 1rem}
  .nav-dropdown.is-open .nav-sub{display:block}
  .nav-sub__a{color:rgba(255,255,255,.6)}
  .nav-sub__a:hover{background:transparent;color:var(--white)}
  .nav-dropdown .nav-a{width:100%;justify-content:space-between}

  .news-grid{grid-template-columns:1fr}
  .site-logo__text{opacity:1 !important;pointer-events:auto !important}
  .form-row{grid-template-columns:1fr}
  .form-row--3{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:1.5rem}
  .footer-legal{align-items:flex-start}
  .modal__panel{padding:1.5rem 1.25rem 2rem;margin:1rem 0}
  .camp-cards{grid-template-columns:1fr}
  .vorstand-grid{grid-template-columns:1fr 1fr}
  .price-table{display:block;overflow-x:auto}
  .training-price-box{width:100%;box-sizing:border-box}
  .gaeste-rates{flex-direction:column}
}

@media(max-width:520px){
  .hero__title{font-size:clamp(2.8rem,14vw,4rem)}
  .hero__links{flex-direction:column;align-items:stretch}
  .hero__btn{text-align:center}
  .back-top{bottom:1rem;right:1rem}
}
