:root{
  --c-petrol:#01283D;
  --c-green:#1E6B4E;
  --c-sand:#E7DDC9;

  --c-ink:#0E1620;
  --c-white:#FFFFFF;

  --bg:#FBFAF8;
  --bg-alt:#F4F1EA;

  --radius:8px;
  --radius-sm:7px;

  --shadow:0 16px 44px rgba(1,40,61,.14);
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--c-ink);
  background:var(--bg);
  line-height:1.5;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(var(--max),calc(100% - 40px));margin:0 auto}
.is-hidden{display:none !important}

/* A11y */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skiplink{
  position:absolute;left:-999px;top:10px;
  background:var(--c-white);color:var(--c-ink);
  padding:10px 12px;border-radius:var(--radius-sm);box-shadow:var(--shadow)
}
.skiplink:focus{left:14px;z-index:9999}

/* Header */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(251,250,248,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(14,22,32,.08)
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:14px}

/* Logo */
.brand-logo{height:64px;width:auto}

/* Logo Hover: 3× + nach unten */
.brand-zoom{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:var(--radius-sm);
}
.brand-zoom .brand-logo{
  transform-origin:left top;
  transition:transform .18s ease, filter .18s ease;
  will-change:transform;
}
.brand-zoom:hover{ z-index:2001; }
.brand-zoom:hover .brand-logo{
  transform: translateY(22px) scale(3);
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.22));
}
@media (hover:none){
  .brand-zoom:hover .brand-logo{ transform:none; filter:none; }
}

/* Nav */
.nav{display:flex;align-items:center;gap:14px}
.nav-menu{display:flex;align-items:center;gap:12px}
.nav-link{font-weight:750;opacity:.88;padding:10px 10px;border-radius:var(--radius-sm)}
.nav-link:hover{background:rgba(1,40,61,.06);text-decoration:none}
.nav-cta{
  font-weight:900;
  padding:12px 16px;border-radius:var(--radius-sm);
  background:var(--c-petrol);color:var(--c-white);
  border:0;cursor:pointer
}
.nav-cta:hover{filter:brightness(1.05)}
.nav-toggle{
  display:none;width:44px;height:44px;
  border:1px solid rgba(14,22,32,.12);
  border-radius:var(--radius-sm);
  background:var(--c-white);cursor:pointer
}
.nav-toggle-bar{display:block;width:18px;height:2px;background:var(--c-ink);margin:0 auto;position:relative}
.nav-toggle-bar::before,.nav-toggle-bar::after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--c-ink)}
.nav-toggle-bar::before{top:-6px}
.nav-toggle-bar::after{top:6px}

/* Type */
.h1{margin:0;font-size:clamp(2.2rem,4.6vw,3.7rem);line-height:1.06;font-weight:950;letter-spacing:-.02em}
.h2{margin:0 0 10px;font-size:clamp(1.55rem,2.3vw,2.2rem);line-height:1.12;font-weight:950;letter-spacing:-.02em}
.h3{margin:0 0 6px;font-size:1.05rem;font-weight:850}
.kicker{margin:0 0 10px;font-weight:800;letter-spacing:.02em;opacity:.92}
.lead{margin:14px 0 22px;font-size:clamp(1.02rem,1.4vw,1.2rem);max-width:72ch;opacity:.96}
.body{margin:0 0 14px;max-width:76ch;opacity:.92}
.small{font-size:.92rem}
.muted{opacity:.82}
.strong{font-weight:900}

/* Headline Curve */
.headline{
  position:relative;
  display:inline-block;
}

.headline-curve{
  width:min(520px,80%);
  height:auto;
  margin-top:8px;
  opacity:.98;
  pointer-events:none;
}

/* LANG – fast doppelt so groß + mehr Abstand nach oben */
.headline-curve_tisch{
  width:250%;
  height:auto;
  margin-top:22px;
  margin-bottom:22px;
  opacity:.98;
  pointer-events:none;
  transform: scale(1.8);
  transform-origin: left center;
  }

.headline-curve_lang{
  width:100%;
  height:auto;
  margin-top:22px;
  margin-bottom:22px;
  opacity:.98;
  pointer-events:none;
  transform: scale(1.8);
  transform-origin: left center;
}

.headline-curve_mitte{
  width:80%;
  height:auto;
  margin-top:22px;
  margin-bottom:22px;
  opacity:.98;
  pointer-events:none;
  transform: scale(1.8);
  transform-origin: left center;
}

/* Hero */
.hero{
  position:relative;min-height:74vh;
  display:flex;align-items:flex-end;
  padding:92px 0 54px;overflow:hidden
}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(1,40,61,.56) 0%,rgba(1,40,61,.55) 45%,rgba(1,40,61,.80) 100%)
}
.hero-content{position:relative;z-index:1;color:var(--c-white)}
.hero-meta{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;margin:18px 0 26px
}
.meta-card{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius);
  padding:12px 14px
}
.meta-label{display:block;font-size:.82rem;opacity:.9}
.meta-value{display:block;font-weight:950;margin-top:4px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* Puzzle */
.puzzle{
  position:absolute;
  left:-10px;
  top:230px;

  width:105px;        /* ← EINZIGE maßgebliche Größe */
  height:auto;

  opacity:.14;
  pointer-events:none;
  z-index:1;
  filter:drop-shadow(0 20px 40px rgba(0,0,0,.18));
}

/* Varianten: NUR Position + Opacity, KEINE Größe */
.puzzle-hero{
  top:110px;
  opacity:.22;
}

.puzzle-section{
  top:38px;
  opacity:.14;
}

.puzzle-dark{
  opacity:.10;
}

/* Sections */
.section{position:relative;padding:74px 0}
.section-alt{background:var(--bg-alt)}
.section-dark{background:var(--c-petrol);color:var(--c-white)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:18px}
.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:start}

/* v7: Kontakt-Grid Breite anpassen (links breiter, rechts schmaler) */
.kontakt-grid{
  display:grid;
  grid-template-columns:1.35fr 0.65fr;
  gap:26px;
  align-items:start;
  margin-top:18px;
}

/* Cards */
.card{
  background:var(--c-white);
  border:1px solid rgba(14,22,32,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:18px
}
.badge{
  font-weight:950;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(30,107,78,.14);
  border:1px solid rgba(30,107,78,.28);
  color:var(--c-green)
}
.section-dark .badge{background:rgba(231,221,201,.10);border-color:rgba(231,221,201,.22);color:var(--c-sand)}

/* Lists */
.list{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.time{display:inline-block;min-width:92px;font-weight:950;color:var(--c-petrol)}

/* Timeline */
.timeline{display:grid;gap:12px;margin-top:14px}
.slot{
  display:grid;grid-template-columns:86px 1fr;gap:16px;
  padding:16px;border-radius:var(--radius);
  background:var(--c-white);
  border:1px solid rgba(14,22,32,.08);
  box-shadow:0 10px 28px rgba(14,22,32,.06)
}
.slot-time{font-weight:950;color:var(--c-petrol)}
.slot-body p{margin:0;opacity:.9;max-width:90ch}
.subcards{display:grid;gap:10px;margin-top:10px}
.subcard{
  background:rgba(1,40,61,.03);
  border:1px solid rgba(1,40,61,.08);
  border-radius:var(--radius-sm);
  padding:12px
}
.subhead{font-weight:950;color:var(--c-petrol);margin-bottom:6px}

/* Media */
.media-card{
  margin:0;border-radius:var(--radius);
  overflow:hidden;background:var(--c-white);
  box-shadow:var(--shadow);
  border:1px solid rgba(14,22,32,.08)
}
.media-card img{width:100%;height:420px;object-fit:cover}
.media-card figcaption{padding:12px 14px;font-weight:700;opacity:.86}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:10px;border-radius:var(--radius-sm);
  padding:12px 16px;font-weight:950;
  border:1px solid transparent;text-decoration:none;cursor:pointer
}
.btn-primary{background:var(--c-green);color:var(--c-white)}
.btn-primary:hover{filter:brightness(1.05);text-decoration:none}
.btn-ghost{
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.22);color:var(--c-white)
}
.btn-ghost:hover{background:rgba(255,255,255,.16);text-decoration:none}
.btn-solid{background:var(--c-petrol);color:var(--c-white)}
.btn-solid:hover{filter:brightness(1.05)}
.btn-outline{
  background:transparent;border-color:rgba(1,40,61,.18);color:var(--c-petrol)
}
.btn-outline:hover{background:rgba(1,40,61,.06);text-decoration:none}

/* Member greeting */
.member-greeting{
  margin-top:18px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius);
  padding:14px
}

/* Form */
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px
}
label span{display:block;font-weight:900;margin-bottom:6px}
input{
  width:100%;
  padding:12px 12px;
  border-radius:var(--radius-sm);
  border:1px solid rgba(14,22,32,.14);
  background:var(--c-white);
  font:inherit
}
input:focus{outline:none;border-color:rgba(30,107,78,.55);box-shadow:0 0 0 4px rgba(30,107,78,.14)}
.full{grid-column:1 / -1}

.fieldset{
  margin:16px 0 0;
  border:1px solid rgba(14,22,32,.10);
  border-radius:var(--radius);
  padding:12px
}
legend{padding:0 8px;font-weight:950}
.check,.radio{display:flex;align-items:center;gap:10px;margin-top:10px;font-weight:850}
.radios{display:flex;gap:16px;flex-wrap:wrap}
.form-actions{margin-top:16px;display:grid;gap:8px}
.error{color:#ffb4b4;font-weight:950}

/* Checkbox/Radios */
.check input[type="checkbox"],
.radio input[type="radio"]{
  width:18px;height:18px;margin:0;
  accent-color:var(--c-green);
}

/* Downloads */
.download-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px
}
.download-card{
  background:var(--c-white);
  border:1px solid rgba(14,22,32,.08);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:0 10px 28px rgba(14,22,32,.06)
}
.download-card p{margin:0 0 12px;opacity:.9}

/* Kontakt */
.contact-card{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);
  padding:16px
}
.contact-lines{display:grid;gap:6px;margin-top:10px}
.contact-lines a{font-weight:950;color:var(--c-sand)}
.legal-links{display:flex;gap:14px;margin-top:12px}
.legal-links a{font-weight:950;color:rgba(255,255,255,.92)}

/* Footer Logo Card */
.footer-logo-card{
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.footer-logo{width:127px;height:auto;opacity:.98}

/* Footer */
.site-footer{
  padding:26px 0 36px;
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:46px
}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}

/* Modal */
.modal{position:fixed;inset:0;display:none;z-index:2000}
.modal[aria-hidden="false"]{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.modal-panel{
  position:relative;
  width:min(520px,calc(100% - 40px));
  margin:7vh auto 0;
  background:var(--c-white);
  border-radius:var(--radius);
  border:1px solid rgba(14,22,32,.10);
  box-shadow:0 30px 90px rgba(0,0,0,.28);
  padding:18px
}
.modal-close{
  position:absolute;right:14px;top:12px;
  width:44px;height:44px;border-radius:var(--radius-sm);
  border:1px solid rgba(14,22,32,.10);
  background:var(--c-white);cursor:pointer;
  font-size:26px;line-height:1
}

/* Responsive */
@media (max-width: 980px){
  .hero-meta{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .media-card img{height:340px}
  .download-grid{grid-template-columns:1fr}
  .puzzle{left:-40px}
  .kontakt-grid{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .nav-menu{
    position:absolute;right:20px;top:84px;
    width:min(420px,calc(100vw - 40px));
    background:var(--c-white);
    border:1px solid rgba(14,22,32,.10);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    padding:12px;
    display:none;flex-direction:column;align-items:stretch;gap:8px
  }
  .nav-menu.is-open{display:flex}
  .nav-cta{width:100%}
  .form-grid{grid-template-columns:1fr}
  .brand-logo{height:58px}
}
@media (max-width: 520px){
  .puzzle{width:210px;top:24px}
  .puzzle-hero{width:260px;top:100px}
  .headline-curve{width:60%}
  .headline-curve_tisch{width:85%;}
  .headline-curve_lang{width:65%;}
  .footer-logo{width:120px}
}
