:root{
  /* etwas helleres, warmes Grau (mehr elegant, weniger "Tech") */
  --bg:#5b5853;
  --bg2:#6a6762;
  --text:#f6f2ee;          /* warmes Off-White */
  --muted:#e0d9d0;
  --muted2:#c9c1b8;

  --accent:#4f8a6a;        /* frisches Grün – aber nicht neon */
  --accentSoft:rgba(79,138,106,.16);
  --accentWarm:#a87b5a;    /* warme Sekundärfarbe */
  --red:#c94a4a;

  --card:rgba(255,255,255,.06);
  --card2:rgba(0,0,0,.08);
  --border:rgba(255,255,255,.12);

  --max:1120px;
  --radius:14px;
  --shadow:0 18px 54px rgba(0,0,0,.35);
}


*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  overflow-x:hidden;
  color:var(--text);
  background:
    radial-gradient(1200px 820px at 10% -22%, rgba(168,123,90,.10), transparent 60%),
    radial-gradient(1100px 740px at 55% -10%, rgba(255,255,255,.12), transparent 70%),
    radial-gradient(1000px 720px at 88% 6%, rgba(255,255,255,.14), transparent 66%),
    radial-gradient(900px 640px at 40% 16%, rgba(255,255,255,.08), transparent 70%),
    linear-gradient(180deg, var(--bg2), var(--bg));
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  letter-spacing:.2px;
}

.leftStrip{ display:none; }

a{color:inherit}
a:hover{opacity:.92}

.wrap{
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  padding:26px 18px 70px;
  position:relative;
}

/*
  Page-specific width: allow selected pages (e.g. Konfigurator)
  to use more horizontal space without changing the rest of the site.
*/
body.pageWide{--max:1520px}

header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:18px 0 12px;
  border:0;
  background:transparent;
  border-radius:0;
  position:relative;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}

.brand img{
  height:30px;
  width:auto;
  display:block;
}

/* accessible text helper */
.srOnly{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* top-left start mark (open red ring with "Start") */

/* Admin dot: hidden by default, can be enabled via ?admin=1 */
.adminDot{
  position:relative;
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:999px;
  border:0;
  color:var(--red);
  text-decoration:none;
  font-weight:800;
  font-size:12px;
  letter-spacing:.02em;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.adminDot::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:999px;
  background:conic-gradient(from 115deg, var(--red) 0 312deg, transparent 312deg 360deg);
  -webkit-mask:radial-gradient(farthest-side, transparent calc(100% - 3px), #000 calc(100% - 3px));
          mask:radial-gradient(farthest-side, transparent calc(100% - 3px), #000 calc(100% - 3px));
  opacity:.95;
}
.adminDot:hover{ transform:translateY(-1px); }
.startBadge{
  position:relative;
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  border-radius:999px;
  flex:0 0 auto;
}
.startBadge::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:999px;
  /* open ring */
  background:conic-gradient(from 115deg, var(--red) 0 312deg, transparent 312deg 360deg);
  -webkit-mask:radial-gradient(farthest-side, transparent calc(100% - 3px), #000 calc(100% - 3px));
          mask:radial-gradient(farthest-side, transparent calc(100% - 3px), #000 calc(100% - 3px));
}
.startBadgeText{
  position:relative;
  z-index:1;
  font-size:9px;
  font-weight:650;
  letter-spacing:1.2px;
  text-transform:uppercase;
  color:var(--text);
}

.navToggle{
  display:none;
  border:0;
  background:rgba(255,255,255,.06);
  color:var(--text);
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
}


nav{
  display:flex;
  gap:18px;
  align-items:center;
}

nav a{
  text-decoration:none;
  color:var(--muted);
  font-size:14px;
  padding:10px 10px;
  border-radius:12px;
  border:0;
  background:transparent;
}

nav a.active{
  color:var(--text);
  background:var(--accentSoft);
  box-shadow: inset 0 -2px 0 rgba(79,138,106,.55);
}
nav a:hover{
  color:var(--text);
  background:rgba(255,255,255,.07);
}

.hero{
  padding:64px 0 18px;
}

/* Startseite – Textlogo (ohne rote Punkte, weicher gesetzt) */
.heroWordmark{
  text-align:center;
  margin:0 auto 42px;
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
}
.heroWordmark .wordmarkLine{
  display:inline-flex;
  align-items:baseline;
  gap:.08em;
  /* etwas kleiner als vorher */
  font-size:clamp(36px, 5.0vw, 56px);
  letter-spacing:.10em;
  text-transform:uppercase;
  line-height:1;
}
.heroWordmark .spring{
  font-weight:600;
}
.heroWordmark .werk{
  font-weight:300;
  opacity:.95;
}
.heroWordmark .wordmarkTag{
  margin-top:10px;
  font-size:12px;
  letter-spacing:2.6px;
  text-transform:uppercase;
  font-weight:300;
  color:var(--muted2);
}

.heroLogo{
  width:min(480px, 90%);
  height:auto;
  display:block;
  margin:0 auto 46px; /* more air below logo */
}

.heroText{
  text-align:center;
  max-width:860px;
  margin:0 auto;
}


.statusPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:9px 15px;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
  letter-spacing:1.6px;
  text-transform:uppercase;
  border:1px solid rgba(79,138,106,.28);
  background:rgba(79,138,106,.08);
  color:var(--text);
  margin:0 auto 18px;
}

.kicker{
  color:rgba(79,138,106,.85);
  font-size:13px;
  letter-spacing:1.6px;
  text-transform:uppercase;
  margin:0 0 10px;
}

.h1{
  font-size:38px;
  line-height:1.1;
  margin:0 0 14px;
  font-weight:650;
}

.sub{
  color:var(--muted);
  font-size:16px;
  line-height:1.55;
  margin:0 auto 26px;
}

.ctaRow{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
  margin:0 0 18px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 16px;
  border-radius:14px;
  text-decoration:none;
  font-weight:620;
  font-size:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.045);
}

.btn.primary{
  border-color:rgba(79,138,106,.55);
  background:rgba(79,138,106,.18);
}
.grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
  margin:30px 0 10px;
  width:100%;
}

.card{
  border:1px solid var(--border);
  background:var(--card);
  border-radius:var(--radius);
  padding:18px 18px;
  position:relative;
  overflow:hidden;
}

.card h3{
  margin:0 0 10px;
  font-size:16px;
  display:inline-block;
  position:relative;
  padding-bottom:7px;
}
.card h3::after{
  content:"";
  position:absolute;
  left:0;
  right:-18px;
  bottom:0;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(79,138,106,.55), rgba(255,255,255,0));
  opacity:.9;
}
.card p{
  margin:0;
  color:var(--muted);
  line-height:1.55;
  font-size:14px;
}

.card small{
  display:block;
  margin-top:12px;
  color:var(--muted2);
}

.hr{
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  margin:26px 0;
}

.sectionTitle{
  font-size:15px;
  letter-spacing:.6px;
  margin:0 0 12px;
}

.narrow{
  max-width:720px;
  margin:0 auto;
}

.form{
  max-width:720px;
  margin:0 auto;
  border:1px solid var(--border);
  background:rgba(255,255,255,.05);
  border-radius:var(--radius);
  padding:18px 18px;
}

.formRow{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

label{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin:0 0 6px;
}
input, select, textarea{
  width:100%;
  background:rgba(0,0,0,.25);
  color:var(--text);
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;
  padding:12px 12px;
  outline:none;
}
textarea{min-height:120px; resize:vertical}

.help{
  color:var(--muted2);
  font-size:12px;
  line-height:1.45;
  margin-top:10px;
}

.inline{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin-top:12px;
}
.inline input[type="checkbox"]{
  width:18px;
  height:18px;
  margin-top:3px;
}

.notice{
  border:1px solid rgba(255,255,255,.10);
  border-left:3px solid rgba(79,138,106,.30);
  border-radius:14px;
  padding:14px 14px;
  color:var(--muted);
  background:rgba(255,255,255,.035);
}

.noticePlain{
  border:none;
  background:transparent;
  padding:2px 0;
}

.noticeCenter{
  text-align:center;
}
.noticeCenter .noticeLead{
  margin:0;
  color:var(--text);
}
.noticeCenter .noticeBody{
  margin:10px auto 0;
  max-width:72ch;
}
.noticeCenter .noticeBigLine{
  margin:14px 0 0;
  font-weight:800;
  letter-spacing:.2px;
  color:var(--text);
  font-size:clamp(18px, 2.2vw, 28px);
  line-height:1.15;
}

.bannerSlides{
  /* Full-bleed horizontal banner (Präsentation) */
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  padding:10px 18px 22px;
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.bannerSlide{
  flex:0 0 min(980px, 90vw);
  height:360px;
  display:block;
  border:none;
  border-radius:var(--radius);
  object-fit:cover;
  scroll-snap-align:center;
  box-shadow:0 10px 40px rgba(0,0,0,.25);
}
@media (max-width:720px){
  .bannerSlide{ height:260px; }
}

/* Booking picker (compact UI) */
.bookingPicker{
  max-width:720px;
  margin:0 auto;
  display:flex;
  align-items:stretch;
  gap:12px;
  flex-wrap:wrap;
  border:1px solid var(--border);
  background:rgba(255,255,255,.035);
  border-radius:var(--radius);
  padding:14px 14px;
}
.bookingPickCard{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
  cursor:pointer;
}
.bookingPickCard:hover{
  background:rgba(0,0,0,.22);
}
.bookingPickCard img{
  width:42px;
  height:42px;
  display:block;
  opacity:.92;
}
.bookingPickControls{
  flex:1 1 320px;
  min-width:260px;
}
.bookingPickRow{
  display:flex;
  align-items:center;
  gap:10px;
}
.bookingPickRow select{
  flex:1;
}
.availabilityDetails{
  max-width:720px;
  margin:14px auto 0;
}
.availabilityDetails summary{
  cursor:pointer;
  color:var(--muted);
  padding:10px 0;
}
.availabilityDetails[open] summary{
  color:var(--text);
}


/* Hut selector (booking) */
.hutGrid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
  margin-top:8px;
}
.hutCard{
  border:1px solid var(--border);
  background:rgba(0,0,0,.18);
  border-radius:14px;
  padding:12px 12px;
}
.hutTitle{
  font-weight:650;
  margin:0 0 4px;
}
.hutMeta{
  color:var(--muted2);
  font-size:12px;
  line-height:1.45;
  margin:0 0 10px;
}
.hutControls{
  display:flex;
  align-items:center;
  gap:10px;
}
.hutControls input[type="number"]{
  max-width:120px;
}
.hutControls select{
  flex:1;
  min-width:180px;
}
.hutUnit{
  color:var(--muted2);
  font-size:12px;
}


.table{
  width:100%;
  border-collapse:collapse;
  overflow:hidden;
  border-radius:16px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.035);
}
.table th, .table td{
  padding:12px 12px;
  border-bottom:1px solid var(--border);
  text-align:left;
  font-size:14px;
}
.table th{
  color:var(--muted);
  font-weight:650;
  background:rgba(255,255,255,.04);
}
.badge{
  display:inline-flex;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  border:1px solid rgba(255,255,255,.12);
}
.badge.free{color:#cfead8; background:rgba(79,138,106,.12); border-color:rgba(79,138,106,.28)}
.badge.busy{color:#ffb3b3; background:rgba(231, 76, 60, .08); border-color:rgba(231, 76, 60, .22)}
.badge.req{color:#d8d8d8; background:rgba(255,255,255,.05);}

footer{
  margin-top:46px;
  padding-top:18px;
  border-top:1px solid var(--border);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:var(--muted2);
  font-size:13px;
}
footer a{color:var(--muted2); text-decoration:none}
footer a:hover{color:var(--text)}

@media (max-width: 860px){
  nav{display:none}
  .navToggle{
  display:none;
  border:0;
  background:rgba(255,255,255,.06);
  color:var(--text);
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
}

  nav.open{
    display:flex;
    position:absolute;
    right:0;
    top:calc(100% + 10px);
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    padding:10px;
    border:1px solid var(--border);
    border-radius:16px;
    background:rgba(43,42,40,.98);
  }
  .grid{grid-template-columns:1fr}
  .card{grid-column:1}
  .h1{font-size:32px}
  .formRow{grid-template-columns:1fr}
  .hutGrid{grid-template-columns:1fr}

}


/* --- Konfigurator (2-Spalten Layout) --- */
.sw-konfig-wrap{width:100%;max-width:1520px;margin:0 auto;padding:0 18px 70px}
.page{padding:28px 0}
.pageHead{margin:10px 0 18px}
.pageHead .sub{margin:6px 0 0;color:var(--muted)}
.cfgLayout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);gap:18px;align-items:start}
.cfgMain{min-width:0}
.cfgSide{position:sticky;top:18px}
@media (max-width: 980px){
  .cfgLayout{grid-template-columns:1fr}
  .cfgSide{position:static}
}
.cardHead h3{margin:0 0 4px}
.cardHead .muted{margin:0;color:var(--muted2);font-size:14px}
.intentRow{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.radioPill{display:inline-flex;gap:8px;align-items:center;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:10px 12px;background:rgba(0,0,0,.10)}
.radioPill input{accent-color:var(--accent)}
.lbl{display:block;font-weight:700;margin:12px 0 6px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
@media (max-width: 820px){
  .grid2,.grid3{grid-template-columns:1fr}
}
.cfgGroup{margin-top:14px}
.cfgGroupTitle{font-weight:800;margin:10px 0 8px}
.cfgChecks{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:10px}
@media (max-width: 1100px){.cfgChecks{grid-template-columns:repeat(2,minmax(220px,1fr));}}
@media (max-width: 720px){.cfgChecks{grid-template-columns:1fr;}}
.cfgCheck{display:flex;gap:10px;align-items:flex-start;padding:10px 10px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:rgba(0,0,0,.08)}
.cfgCheck input{margin-top:3px;accent-color:var(--accent)}
.cfgCheckName{font-weight:700;display:block}
.cfgCheckDesc{display:block;color:var(--muted2);font-size:13px;margin-top:3px}
.actionsRow{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.errorCard{border-color:rgba(255,120,120,.5)}
.okCard{border-color:rgba(120,255,170,.35)}
.miniRow{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}

.cfgSummary .sumRow{display:flex;justify-content:space-between;gap:12px;margin:8px 0}
.cfgSummary .sumRow span{color:var(--muted2)}
.cfgSummary .sumList{margin:8px 0 0;padding-left:18px;color:var(--text)}
.cfgSummary .sumList .muted{color:var(--muted2)}
.sumListTitle,.sumPriceTitle{font-weight:800;margin-top:8px}
.sumPrice{margin-top:8px}

/* --- SPRINGWERK THEME OVERRIDE: BEIGE + BLACK (FOOTER STAYS BLACK) --- */
:root{
  /* Warmes Beige + schwarzer Text (global) */
  --bg:#f5f0e6;
  --bg2:#f2ebdd;

  /* Textfarben */
  --text:#111111;
  --muted:#222222;
  --muted2:#333333;

  /* UI-Flächen */
  --card:rgba(255,255,255,.88);
  --card2:rgba(0,0,0,.03);
  --border:rgba(0,0,0,.14);

  /* Schatten etwas softer für helles Theme */
  --shadow:0 18px 54px rgba(0,0,0,.12);
}

/* Seitenhintergrund + Standardschrift */
html, body{ background:var(--bg); color:var(--text); }

/* Input/Forms lesbar im hellen Theme */
input, select, textarea{
  background:rgba(255,255,255,.96) !important;
  color:#111 !important;
  border:1px solid rgba(0,0,0,.18) !important;
}
input::placeholder, textarea::placeholder{ color:rgba(0,0,0,.45) !important; }

/* Navigation (Desktop) */
nav a{ color:rgba(0,0,0,.75); }
nav a:hover{ color:#000; background:rgba(0,0,0,.04); }
nav a.active{
  color:#000;
  background:rgba(79,138,106,.14);
  box-shadow: inset 0 -2px 0 rgba(79,138,106,.45);
}

/* Burger-Button */
.navToggle{
  background:rgba(0,0,0,.06) !important;
  color:#000 !important;
  border:1px solid rgba(0,0,0,.12);
}

/* Karten bleiben hell */
.card{
  background:var(--card);
  border:1px solid var(--border);
}

/* Footer: MUSS schwarz mit weißer Schrift bleiben */
footer{
  background:#000 !important;
  color:#fff !important;
  border-top:none !important;
  padding:24px 0 18px !important;
}
footer a{ color:#fff !important; }
footer a:hover{ opacity:.85; }

/* Mobile Menu: Burger MUSS sichtbar sein + Dropdown lesbar */
@media (max-width: 860px){
  .navToggle{ display:inline-flex !important; }
  nav.open{
    background:rgba(245,240,230,.98) !important;
    border:1px solid rgba(0,0,0,.18) !important;
    z-index:999 !important;
  }
  nav.open a{ color:#111 !important; }
}

.btn.danger{ border-color:rgba(201,74,74,.55) !important; background:rgba(201,74,74,.14) !important; }

/* Kleine Utility-Klassen (ohne Inline-Styles) */
.mb12{ margin-bottom:12px !important; }
.mt14{ margin-top:14px !important; }
.hrSep{ margin:18px 0; border:0; border-top:1px solid var(--border); }



/* --- SPRINGWERK: Brand logo replaces Start badge --- */
.brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}
.brandWord{
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  font-size:12px;
  color: #000;
  opacity:0.95;
}
.brandLogo{
  height:28px;
  width:auto;
  display:block;
  filter: invert(1);
}

.startBadge{ display:none !important; }
.startBadgeText{ display:none !important; }

/* --- SPRINGWERK: Footer screenshot-style --- */
.siteFooter{
  background:#000;
  color:#fff;
  margin-top:48px;
}
.siteFooter a{ color:#fff; text-decoration:none; opacity:0.92; }
.siteFooter a:hover{ text-decoration:underline; opacity:1; }
.siteFooterInner{
  max-width:1200px;
  margin:0 auto;
  padding:48px 20px 18px;
}
.footerGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:48px;
}
.footerTitle{
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  opacity:0.85;
  margin-bottom:12px;
}
.footerLines{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:14px;
  line-height:1.45;
}
.footerLabel{
  margin-top:14px;
  font-size:12px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  opacity:0.85;
}
.footerBottom{
  margin-top:34px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,0.12);
  display:flex;
  gap:16px;
  justify-content:space-between;
  align-items:center;
  font-size:13px;
  opacity:0.85;
}
@media (max-width: 860px){
  .brandLogo{ height:26px; }
  .brandWord{ font-size:11px; }
  .footerGrid{ grid-template-columns:1fr; gap:28px; }
  .siteFooterInner{ padding:34px 16px 16px; }
  .footerBottom{ flex-direction:column; align-items:flex-start; gap:8px; }
}


/* --- Form pages (login/registration/reset wrappers) --- */
.formWrap{max-width:720px;margin:0 auto;}
.formWrap h1{margin-top:0;}


/* --- Auth/Portal UI helpers (no inline styles) --- */
.hero.tight{ padding-top:34px; }
.ctaRow.mt14{ margin-top:14px; }
.ctaRow.left{ justify-content:flex-start; }
.notice[data-login-error]{ display:none; margin-bottom:12px; }

/* Footer full-bleed background (content stays in layout) */
footer{ position:relative; z-index:0; }
footer::before{
  content:"";
  position:absolute;
  top:0; bottom:0;
  left:50%;
  width:100vw;
  transform:translateX(-50%);
  background:#000;
  z-index:-1;
}


/* --- SPRINGWERK: Sticky glass header (aligns legacy pages with new sw-nav) --- */
header{
  position: sticky;
  top: 0;
  z-index: 1000;
  padding: 12px 0;
}
header::before{
  content:"";
  position:absolute;
  top:0; bottom:0;
  left:50%;
  width:100vw;
  transform:translateX(-50%);
  background: rgba(245,240,230,.88);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border-bottom: 1px solid rgba(0,0,0,.08);
  z-index:-1;
}
@media (max-width: 860px){
  nav.open{ box-shadow: 0 12px 28px rgba(0,0,0,.14); }
}
