/* main.css – v1.6 Custom Hero Image */
header{ position: fixed !important; top:0; left:0; right:0; z-index: 9999; background: rgba(22,22,23,.9); backdrop-filter: saturate(180%) blur(20px); border-bottom: 1px solid rgba(255,255,255,.06); }
body{ padding-top: var(--header-h) !important; } body.admin-bar{ padding-top: calc(var(--header-h) + 32px) !important; }
@media (max-width: 782px){ body.admin-bar{ padding-top: calc(var(--header-h) + 46px) !important; } }
.container{max-width:var(--maxw);margin:auto;padding:0 20px}
.global-nav{height:var(--header-h);display:flex;align-items:center;position:relative}
.global-nav .inner{width:100%;max-width:980px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:28px}
.global-nav a{font-size:12px;letter-spacing:.02em;color:#d6d6d6;text-decoration:none;opacity:.88;padding:0 6px;line-height:var(--header-h);transition:opacity .2s ease,color .2s ease}
.global-nav a:hover{opacity:1}
.global-nav a[aria-current="page"], .global-nav a.active{opacity:1;color:#fff;font-weight:600}
.brand-logo{display:flex;align-items:center;height:var(--header-h)}
.brand-logo img{height:18px;width:auto;display:block;opacity:.9;transition:opacity .2s ease, filter .2s ease, transform .2s ease;filter: drop-shadow(0 0 2px rgba(0,0,0,.25))}
.brand-logo:hover img{opacity:1;filter: drop-shadow(0 0 6px rgba(139,92,246,.55));transform: translateY(-0.2px)}
.bag{
  position:absolute;
  right:20px;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  align-items:center;
  justify-content:center;
  height:100%;
  color:currentColor;
}
body.theme-dark .bag{
  color:#f5f5f7;
}
.bag svg{
  display:block;
  height:18px;
  width:18px;
  margin-top:-1px; /* optional fine-tune just like Apple */
  opacity:.88;
  transition:opacity .2s ease, transform .2s ease;
}

.bag:hover svg{
  opacity:1;
  transform:translateY(-0.5px);
}

.theme-toggle{position:absolute;right:54px;top:0;height:var(--header-h);display:flex;align-items:center;justify-content:center;padding:0 8px;background:none;border:0;cursor:pointer;color:#d6d6d6;font-size:14px;line-height:1;opacity:.88;transition:opacity .2s}
.theme-toggle:hover{opacity:1}
.hamburger{display:none;position:absolute;right:20px;transform:translateX(36px);cursor:pointer;background:none;border:0}
.hamburger span{display:block;width:18px;height:2px;background:#d6d6d6;margin:4px 0;border-radius:2px}
@media (max-width: 900px){ .global-nav .inner{gap:18px} }
@media (max-width: 780px){ .global-nav .inner{display:none} .hamburger{display:block} }
.mobile-sheet{position:fixed;inset:0;background:rgba(22,22,23,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:9998;display:none}
.mobile-sheet.open{display:block}
.sheet-inner{max-width:980px;margin:0 auto;padding:84px 20px}
.sheet-nav{display:grid;gap:16px}
.sheet-nav a{font-size:20px;color:#f5f5f7;text-decoration:none;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.sheet-cta{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap}
.sr-only{position:absolute;left:-9999px}
/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 18px;border-radius:999px;border:1px solid #d2d2d7;background:#fff;color:#000;font-weight:600;transition:all .2s}
.btn:hover{background:#f2f2f2;transform:translateY(-1px)}
.btn.primary{background:linear-gradient(180deg,#a78bfa,#8b5cf6);border-color:#8b5cf6;color:#fff;box-shadow:0 2px 6px rgba(139,92,246,.25)}
.btn.primary:hover{background:linear-gradient(180deg,#b794f6,#9d72f9);box-shadow:0 4px 8px rgba(139,92,246,.35)}
.link-btn{font-weight:700;color:var(--link);text-decoration:none}
.link-btn::after{content:"›";margin-left:6px}
.plain-link{font-weight:600;color:var(--link);text-decoration:none;opacity:.9;transition:opacity .2s}
.plain-link:hover{opacity:1;text-decoration:none}
/* Hero with custom background image */
.hero{position:relative;text-align:center;padding:120px 0 90px;overflow:hidden;background:none}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transform:translateY(0);transition:transform .2s ease-out;z-index:-1;opacity:.9}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(900px 420px at 80% -10%,rgba(139,92,246,.18),transparent)}
.hero-overlay{position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(0,0,0,.35),transparent 40%,rgba(0,0,0,.45))}
body.theme-dark .hero-overlay{background:linear-gradient(180deg,rgba(0,0,0,.55),transparent 40%,rgba(0,0,0,.55))}
.eyebrow{display:inline-block;padding:6px 12px;border:1px solid var(--shade);border-radius:999px;color:#fff;font-weight:600;backdrop-filter:blur(6px);background:rgba(0,0,0,.25)}
h1{font-size:68px;line-height:1.04;margin:16px 0 14px;color:#fff}
p.lead{font-size:21px;color:#e5e5ea;max-width:760px;margin:auto}
.cta-row{display:flex;gap:14px;margin-top:22px;flex-wrap:wrap;align-items:center;justify-content:center}
.status{margin-top:24px;display:inline-flex;align-items:center;gap:10px;padding:12px 18px;border-radius:12px;border:1px solid rgba(255,255,255,.24);background:rgba(0,0,0,.35);box-shadow:0 1px 3px rgba(0,0,0,.25);color:#fff}
.dot-on{width:10px;height:10px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.25)}
/* Sections */
section{padding:72px 0;border-top:1px solid #0000000f}
h2{font-size:34px;letter-spacing:-.02em;margin:0 0 18px}
.muted{color:var(--ink-2)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:#fff;border:1px solid #00000012;border-radius:22px;padding:22px}
.card h3{margin:0 0 8px}
/* Banner */
.banner{position:relative;background:#000;border-radius:26px;overflow:hidden}
.banner img{display:block;width:100%;height:auto}
.tagbar{position:absolute;bottom:16px;left:16px;display:flex;gap:8px;flex-wrap:wrap}
.chip{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:rgba(0,0,0,.42);border:1px solid rgba(255,255,255,.18);color:#fff;padding:6px 12px;border-radius:999px;font-weight:600;font-size:14px}
/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.step{background:#fff;border:1px solid #00000012;border-radius:18px;padding:18px}
.step strong{display:block;margin-bottom:6px}
/* Footer */
footer{padding:54px 0;border-top:1px solid #0000000f;color:var(--ink-2)}
.foot{text-align:center}
/* Regelwerk (sticky TOC) */
.rules-layout{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start}
.rules-toc{position:sticky;top:calc(var(--header-h) + 16px);background:var(--paper-elev);border:1px solid #00000012;border-radius:18px;padding:18px}
.rules-toc a{display:block;color:var(--link);text-decoration:none;font-weight:600;opacity:.95;padding:6px 4px;border-radius:10px}
.rules-toc a.active{background:rgba(139,92,246,.10)}
.rules-section .rule-card{background:var(--paper-elev);border:1px solid #00000012;border-radius:22px;padding:22px}
.rules-section .rule-card + .rule-card{margin-top:18px}
/* ===== Regelwerk – flacher Apple-Doku-Look ===== */

.rules-shell{
  padding:48px 0 80px;
  border-top:1px solid rgba(0,0,0,.06);
}
body.theme-dark .rules-shell{
  border-top:1px solid rgba(255,255,255,.08);
}

.rules-page{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 20px;
}

.rules-page .rules-layout{
  display:grid;
  grid-template-columns:220px minmax(0,1fr);
  gap:32px;
  align-items:flex-start;
}

/* TOC links – flach, keine Box */
.rules-page .rules-toc{
  background:transparent;
  border:0;
  border-radius:0;
  padding:0;
  box-shadow:none;
}

.rules-page .rules-toc a{
  display:block;
  padding:4px 0;
  color:var(--ink-2);
  font-weight:500;
  text-decoration:none;
  border-radius:0;
  opacity:.95;
}

.rules-page .rules-toc a:hover{
  opacity:1;
  color:var(--ink);
}

.rules-page .rules-toc a.active{
  background:none;
  color:var(--ink);
}

body.theme-dark .rules-page .rules-toc a{
  color:#a1a1a6;
}
body.theme-dark .rules-page .rules-toc a:hover{
  color:#f5f5f7;
}
body.theme-dark .rules-page .rules-toc a.active{
  color:#f5f5f7;
}

/* Rechte Spalte: flache Sections statt Karten */
.rules-page .rules-section{
  max-width:720px;
}

.rules-page .rule-card{
  background:transparent;
  border:0;
  border-radius:0;
  padding:0 0 32px;
  margin:0 0 32px;
  border-bottom:1px solid rgba(0,0,0,.06);
}

body.theme-dark .rules-page .rule-card{
  border-bottom:1px solid rgba(255,255,255,.08);
}

.rules-page .rule-card:last-of-type{
  border-bottom:0;
  margin-bottom:0;
  padding-bottom:0;
}

/* Typografie für Überschriften */
.rules-page .rule-card h2{
  font-size:22px;
  letter-spacing:-.01em;
  margin:0 0 8px;
}

.rules-page .rule-card h3{
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin:18px 0 4px;
  color:var(--ink-2);
}

/* Listen etwas luftiger */
.rules-page .rule-card ul{
  padding-left:18px;
  margin:6px 0 10px;
}
.rules-page .rule-card li{
  margin-bottom:3px;
}

/* Responsive Anpassung */
@media (max-width:900px){
  .rules-page .rules-layout{
    grid-template-columns:1fr;
    gap:20px;
  }
  .rules-page .rules-toc{
    position:static;
    display:flex;
    flex-wrap:wrap;
    gap:8px 16px;
  }
  .rules-page .rules-toc a{
    font-size:13px;
  }
}

/* Reveal Animations */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.show{opacity:1;transform:none}
@media (max-width: 980px){
  .grid,.steps{grid-template-columns:1fr 1fr}
  h1{font-size:44px}
  .rules-layout{grid-template-columns:1fr}
  .rules-toc{position:relative;top:auto}
}
@media (max-width: 720px){
  .grid,.steps{grid-template-columns:1fr}
  h1{font-size:36px}
  .global-nav .inner{display:none}
  .hamburger{display:block}
}
.dot-off{
  width:10px;
  height:10px;
  border-radius:50%;
  background:#ef4444;
  box-shadow:0 0 0 4px #ef444422;
}

/* ===== Handy-Slider – 1 Bild, Auto-Slide ===== */

.phone-slider-section{
  padding:64px 0 80px;
  border-top:1px solid rgba(0,0,0,.04);
}

body.theme-dark .phone-slider-section{
  border-top:1px solid rgba(255,255,255,.06);
}

.phone-slider-section .pg-title{
  font-size:28px;
  letter-spacing:-.02em;
  margin:0 0 6px;
}

.phone-slider-section .pg-subtitle{
  margin:0 0 24px;
}

.phone-slider{
  position:relative;
  max-width:960px;
  margin:0 auto;
  overflow:hidden;
}

.phone-slider-track{
  display:flex;
  transition:transform .6s ease;
  will-change:transform;
}

.phone-slider-item{
  min-width:100%;
  padding:0 4px;
  box-sizing:border-box;
}

.phone-slider-frame{
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  background: #000;
  border: 1px solid rgba(0,0,0,.07);
  box-shadow: 0 14px 35px rgba(0,0,0,.25);

  /* ===== FIXIERTE HÖHE ===== */
  height: 420px; /* kannst du ändern: 320, 360, 400, 500 usw. */
  width: 100%;
}

.phone-slider-frame img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover; /* schneidet sauber zu */
  object-position:center; /* fokussiert die Mitte */
  transition:transform .8s ease, opacity .3s ease;
}


body.theme-dark .phone-slider-frame{
  border-color:rgba(255,255,255,.08);
  background:radial-gradient(circle at top, rgba(120,120,120,.18), rgba(0,0,0,.9));
  box-shadow:0 18px 40px rgba(0,0,0,.8);
}

.phone-slider-frame:hover img{
  transform:scale(1.03);
}

.phone-slider-meta{
  margin-top:8px;
  font-size:12px;
  color:var(--ink-2);
  text-align:right;
}

body.theme-dark .phone-slider-meta{
  color:#a1a1a6;
}

@media (max-width:720px){
  .phone-slider-section{
    padding:48px 0 64px;
  }
}

/* ===== Lightbox für Handy-Slider ===== */

.phone-slider-item{
  position:relative;
}

.phone-slider-img{
  cursor:zoom-in;
}

/* Overlay */
.phone-lightbox{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
}

.phone-lightbox.is-open{
  display:flex;
}

.phone-lightbox-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.78);
}

.phone-lightbox-inner{
  position:relative;
  max-width:90vw;
  max-height:90vh;
  z-index:1;
  border-radius:20px;
  overflow:hidden;
  background:#000;
  box-shadow:0 20px 50px rgba(0,0,0,.8);
}

.phone-lightbox-img{
  display:block;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
}

.phone-lightbox-close{
  position:absolute;
  top:10px;
  right:14px;
  border:0;
  background:rgba(0,0,0,.6);
  color:#fff;
  width:30px;
  height:30px;
  border-radius:999px;
  font-size:18px;
  line-height:1;
  cursor:pointer;
}
body.theme-dark .phone-lightbox-close{
  background:rgba(255,255,255,.16);
}

.phone-lightbox-prev,
.phone-lightbox-next{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:36px;
  height:36px;
  border-radius:999px;
  border:0;
  background:rgba(0,0,0,.6);
  color:#fff;
  font-size:20px;
  line-height:1;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}

.phone-lightbox-prev{ left:10px; }
.phone-lightbox-next{ right:10px; }

.phone-lightbox-prev:hover,
.phone-lightbox-next:hover{
  background:rgba(0,0,0,.8);
}

body.theme-dark .phone-lightbox-prev,
body.theme-dark .phone-lightbox-next{
  background:rgba(255,255,255,.16);
}

body.theme-dark .phone-lightbox-prev:hover,
body.theme-dark .phone-lightbox-next:hover{
  background:rgba(255,255,255,.26);
}

/* Join-Steps – Darkmode-Fix */
body.theme-dark .step{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.14);
}

body.theme-dark .step strong{
  color:#f5f5f7;
}

body.theme-dark .step .muted{
  color:#a1a1a6;
}

/* Hero-Textfarben – Light & Dark sauber trennen */

/* Standard: Lightmode */
.hero{
  color: var(--ink);
}

.hero h1{
  color: var(--ink);
}

.hero .lead{
  color: var(--ink-2);
}

/* Darkmode-Overrides */
body.theme-dark .hero{
  color:#f5f5f7;
}

body.theme-dark .hero h1{
  color:#f5f5f7;
}

body.theme-dark .hero .lead{
  color:#d2d2d7;
}

/* ===== Footer – clean, dezent, Apple-ish ===== */

.site-footer{
  border-top:1px solid rgba(0,0,0,.06);
  background:#f5f5f7;
  padding:32px 0 26px;
  color:var(--ink-2);
  font-size:14px;
}

body.theme-dark .site-footer{
  background:#000;
  border-top:1px solid rgba(255,255,255,.08);
  color:#a1a1a6;
}

.footer-grid{
  display:grid;
  grid-template-columns:2fr 1.2fr 1.4fr;
  gap:32px;
  align-items:flex-start;
}

.footer-col h4{
  margin:0 0 10px;
  font-size:14px;
  font-weight:600;
  color:var(--ink);
}

body.theme-dark .footer-col h4{
  color:#f5f5f7;
}

.footer-brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  margin-bottom:8px;
}

.footer-brand img{
  width:28px;
  height:28px;
  border-radius:8px;
}

.footer-brand span{
  font-weight:600;
  color:var(--ink);
}

body.theme-dark .footer-brand span{
  color:#f5f5f7;
}

.footer-copy{
  margin:4px 0 0;
}

.footer-links{
  list-style:none;
  padding:0;
  margin:0;
}

.footer-links li{
  margin-bottom:4px;
}

.footer-links a{
  text-decoration:none;
  color:var(--ink-2);
}

.footer-links a:hover{
  text-decoration:underline;
}

body.theme-dark .footer-links a{
  color:#a1a1a6;
}

.footer-social{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:8px;
}

.social-btn{
  width:34px;
  height:34px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  color:#111;
  font-size:17px;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}

.social-btn img{
  display:block;
  width:18px;
  height:18px;
  object-fit:contain;
}


.social-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 10px rgba(0,0,0,.15);
}

body.theme-dark .social-btn{
  background:#111;
  border-color:rgba(255,255,255,.18);
  color:#f5f5f7;
}

body.theme-dark .social-btn:hover{
  background:#18181b;
  box-shadow:0 6px 16px rgba(0,0,0,.7);
}

.footer-sub{
  margin:0;
}

/* Responsive Footer */
@media (max-width:900px){
  .footer-grid{
    grid-template-columns:1fr 1fr;
    row-gap:24px;
  }
}

@media (max-width:640px){
  .footer-grid{
    grid-template-columns:1fr;
  }
}

/* ===== FINAL MOBILE SHEET FIX ===== */
@media (max-width: 900px){
  #mobileSheet,
  #mobileSheet.mobile-sheet,
  .mobile-sheet.open{
    position: fixed !important;
    inset: 0 !important;
    z-index: 9999 !important;
    background: #f5f5f7 !important;      /* Lightmode: deckend hell */
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  body.theme-dark #mobileSheet,
  body.theme-dark #mobileSheet.mobile-sheet,
  body.theme-dark .mobile-sheet.open{
    background: #000000 !important;      /* Darkmode: deckend schwarz */
  }

  /* Falls das Innenleben transparent ist, geben wir dem auch nen Hintergrund */
  #mobileSheet .sheet-inner{
    background: transparent !important;
  }
}




