*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
html,body{margin:0;padding:0;background:#fff;font-family:var(--font-body);color:var(--tg-gray);line-height:var(--lh-body);}
section[id]{scroll-margin-top:80px;} /* Offset, damit Sektion nicht hinter dem Sticky-Header verschwindet */
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

/* ---------- HEADER ---------- */
.tg-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--tg-gray-line);}
.tg-header__inner{max-width:var(--max-w-content);margin:0 auto;padding:14px 24px;display:flex;flex-wrap:nowrap;align-items:center;gap:14px;}
.tg-logo img{height:36px;width:auto;display:block;}
.tg-nav{display:flex;flex-wrap:nowrap;gap:16px;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--tg-gray);}
.tg-nav a{padding:6px 2px;white-space:nowrap;border-bottom:2px solid transparent;transition:border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out);}
.tg-nav a:hover,.tg-nav a.is-active{border-bottom-color:var(--tg-red);color:var(--tg-red);}
.tg-header__cta{margin-left:auto;display:flex;flex-wrap:nowrap;gap:10px;align-items:center;}
.tg-header__cta .btn--ghost{white-space:nowrap;}
.tg-logo{flex-shrink:0;}
.tg-nav .lang-toggle--drawer{display:none;}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:14px;padding:11px 18px;border-radius:var(--r-pill);border:1.5px solid transparent;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out);text-decoration:none;line-height:1;}
.btn--primary{background:var(--tg-red);color:#fff;}
.btn--primary:hover{background:var(--tg-red-ink);}
.btn--outline{background:transparent;color:var(--tg-red);border-color:var(--tg-red);}
.btn--outline:hover{background:var(--tg-red-tint);}
.btn--ghost{background:transparent;color:var(--tg-gray);border-color:transparent;padding-left:6px;padding-right:6px;}
.btn--ghost:hover{color:var(--tg-red);}

/* ---------- HERO (Full-bleed Foto/Video-Banner — frei stehend, ohne Text) ---------- */
.hero{position:relative;width:100%;height:clamp(440px,72vh,720px);overflow:hidden;background:#1d0a0a;}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;z-index:0;}
.hero__bg img,.hero__bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
/* Stilisierter Fallback, falls noch kein Foto/Video gesetzt ist */
.hero__bg--placeholder{background:linear-gradient(135deg,#5a2a1f 0%,#1d0a0a 100%);}
.hero__bg--placeholder::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 45%,rgba(255,210,140,.32),transparent 55%),radial-gradient(circle at 78% 78%,rgba(206,33,40,.28),transparent 60%);}
@media (max-width:720px){
  .hero{height:clamp(320px,55vh,460px);}
}

/* ---------- INTRO (Headline + Lede + CTAs unter dem Banner) ---------- */
.intro{padding:64px 0 8px;}
.intro__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:end;}
.intro__eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-gray-soft);margin-bottom:14px;}
.intro h1{font-family:var(--font-display);font-weight:700;color:var(--tg-gray);margin:0 0 18px;font-size:clamp(2.25rem,4.2vw,3.5rem);line-height:1.04;letter-spacing:-.005em;}
.intro h1 em{font-style:italic;color:var(--tg-red);}
.intro p.lede{font-size:18px;line-height:1.55;color:var(--tg-gray);max-width:48ch;margin:0 0 26px;}
.intro__cta{display:flex;gap:12px;flex-wrap:wrap;}
.intro__stamp{justify-self:end;width:140px;height:140px;border-radius:50%;background:var(--tg-red);color:#fff;display:grid;place-items:center;text-align:center;font-family:var(--font-display);font-weight:700;line-height:1.05;transform:rotate(-9deg);box-shadow:0 6px 18px rgba(206,33,40,.28);}
.intro__stamp span{display:block;font-style:italic;font-weight:400;font-size:13px;text-transform:lowercase;}
.intro__stamp b{display:block;font-size:22px;letter-spacing:-.005em;}
.intro__stamp em{display:block;font-style:italic;font-weight:400;font-size:11px;margin-top:2px;}
@media (max-width:720px){
  .intro{padding:40px 0 4px;}
  .intro__inner{grid-template-columns:1fr;gap:28px;}
  .intro__stamp{justify-self:start;width:112px;height:112px;}
  .intro__stamp b{font-size:18px;}
}

/* ---------- PAGE HEADER (für Unterseiten wie Anfrage) ---------- */
.page-head{padding:72px 0 32px;}
.page-head__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.page-head__eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-gray-soft);margin-bottom:14px;}
.page-head h1{font-family:var(--font-display);font-weight:700;color:var(--tg-gray);margin:0 0 16px;font-size:clamp(2rem,3.8vw,3rem);line-height:1.04;letter-spacing:-.005em;}
.page-head h1 em{font-style:italic;color:var(--tg-red);}
.page-head p.lede{font-size:17px;line-height:1.6;color:var(--tg-gray);max-width:60ch;margin:0;}
.page-head .back-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--tg-gray-soft);margin-bottom:18px;transition:color var(--dur-fast) var(--ease-out);}
.page-head .back-link:hover{color:var(--tg-red);}
.page-head .back-link::before{content:"◂ ";}

/* ---------- KONZEPT-SECTION ---------- */
.konzept{background:var(--tg-light);padding:72px 0;}
.konzept__inner{max-width:1000px;margin:0 auto;padding:0 24px;}
.konzept__head{text-align:center;margin-bottom:36px;}
.konzept__head .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.konzept__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0;line-height:1.08;}
.konzept__head h2 em{color:var(--tg-red);font-style:italic;}
.konzept__intro{font-size:17px;line-height:1.65;color:var(--tg-gray);text-align:center;margin:0 auto 36px;max-width:62ch;}

.konzept__banner{position:relative;margin:0 auto 40px;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:21/9;max-width:1000px;background:linear-gradient(135deg,#5a2a1f 0%,#1d0a0a 100%);}
.konzept__banner img{width:100%;height:100%;object-fit:cover;display:block;}
.konzept__banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 60%,rgba(0,0,0,.35) 100%);pointer-events:none;}
@media (max-width:720px){
  .konzept__banner{aspect-ratio:16/9;margin-bottom:28px;}
}

.konzept__spiele{background:#fff;border-left:3px solid var(--tg-red);padding:20px 28px;margin:0 auto 48px;max-width:560px;text-align:center;border-radius:var(--r-sm);}
.konzept__spiele-label{font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-gray-soft);margin-bottom:8px;}
.konzept__spiele-list{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--tg-gray);line-height:1.4;margin-bottom:6px;}
.konzept__spiele-sub{font-size:13.5px;color:var(--tg-red);font-style:italic;}

.konzept__blocks{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin:0 0 44px;}
.konzept__block h3{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--tg-red);margin:0 0 10px;line-height:1.2;}
.konzept__block p{font-size:14.5px;line-height:1.6;color:var(--tg-gray);margin:0;}
.konzept__block ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;}
.konzept__block ul li{font-size:14.5px;line-height:1.5;color:var(--tg-gray);padding-left:18px;position:relative;}
.konzept__block ul li::before{content:"▪";position:absolute;left:0;color:var(--tg-red);font-weight:700;}

.konzept__outro{text-align:center;font-size:16px;line-height:1.65;color:var(--tg-gray);max-width:60ch;margin:0 auto 18px;}
.konzept__quote{text-align:center;font-family:var(--font-display);font-style:italic;font-weight:700;font-size:clamp(1.5rem,2.4vw,2rem);color:var(--tg-red);margin:0 auto;line-height:1.2;}

@media (max-width:720px){
  .konzept{padding:48px 0;}
  .konzept__blocks{grid-template-columns:1fr;gap:24px;margin-bottom:32px;}
}

/* ---------- STATS — Asymmetric Hero ---------- */
.stats{background:var(--tg-light);padding:40px 0;}
.stats__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.stats__eyebrow{display:block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--tg-red);margin-bottom:20px;}
.stats__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:stretch;}
.stats__hero{padding-right:48px;border-right:1px solid rgba(87,87,86,.18);display:flex;align-items:center;gap:28px;}
.stats__hero b{flex-shrink:0;display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(5rem,11vw,8.5rem);color:var(--tg-red);line-height:.88;letter-spacing:-.04em;min-width:2.5ch;font-variant-numeric:tabular-nums;text-align:left;}
.stats__hero__body{flex:1;min-width:0;}
.stats__hero .label{display:block;font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--tg-gray);line-height:1.3;margin-bottom:10px;}
.stats__hero p.hero-text{margin:0;font-size:14px;line-height:1.55;color:var(--tg-gray);}
.stats__list{display:flex;flex-direction:column;}
.stats__list .stat{display:flex;align-items:center;gap:20px;padding:12px 0;border-bottom:1px solid rgba(87,87,86,.18);text-align:left;}
.stats__list .stat:last-child{border-bottom:none;}
.stats__list .stat b{flex-shrink:0;width:200px;text-align:left;font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,3.2vw,2.6rem);color:var(--tg-red);line-height:1;letter-spacing:-.015em;font-variant-numeric:tabular-nums;}
.stats__list .stat span{font-size:14px;color:var(--tg-gray);line-height:1.45;}

@media (max-width:860px){
  .stats__grid{grid-template-columns:1fr;gap:32px;}
  .stats__hero{padding-right:0;border-right:none;padding-bottom:32px;border-bottom:1px solid rgba(87,87,86,.18);}
  .stats__list .stat b{width:160px;}
}
@media (max-width:560px){
  .stats{padding:48px 0;}
  .stats__hero{flex-direction:column;align-items:flex-start;gap:18px;}
  .stats__hero b{font-size:5rem;}
  .stats__list .stat{gap:14px;padding:14px 0;}
  .stats__list .stat b{width:120px;font-size:1.6rem;}
}

/* ---------- SECTION ---------- */
section{padding:64px 0;}
.container{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:32px;}
.section__head .eyebrow{font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-gray-soft);display:block;margin-bottom:10px;}
.section__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.75rem,2.6vw,2.25rem);color:var(--tg-gray);margin:0;line-height:1.1;}
.section__head h2 em{color:var(--tg-red);font-style:italic;}

/* ---------- TISCH-GRID (5 Tische, gemeinsamer Casino-Preis) ---------- */
.tables{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
/* 3D-Flip-Card */
.tables{align-items:stretch;}
.table-card{position:relative;background:transparent;border-radius:var(--r-md);perspective:1200px;cursor:pointer;outline:none;height:100%;}
.table-card__inner{position:relative;width:100%;height:100%;transition:transform .65s var(--ease-out);transform-style:preserve-3d;}
.table-card:hover .table-card__inner,
.table-card:focus-within .table-card__inner{transform:rotateY(180deg);}
.table-card__front,
.table-card__back{backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--r-md);overflow:hidden;}
.table-card__front{background:var(--tg-light);transition:box-shadow var(--dur-base) var(--ease-out),opacity 0s linear .32s;height:100%;display:flex;flex-direction:column;}
.table-card__front .table-card__body{flex:1;}
.table-card:hover .table-card__front{box-shadow:var(--shadow-card);}
/* Flip-Fix: Vorderseite beim Umdrehen sicher ausblenden (siehe Booster-Karten). */
.table-card:hover .table-card__front,
.table-card:focus-within .table-card__front{opacity:0;}
.table-card__back{position:absolute;inset:0;background:var(--tg-red);color:#fff;transform:rotateY(180deg);display:flex;flex-direction:column;justify-content:center;padding:24px 22px;}
.table-card__back-title{font-family:var(--font-display);font-weight:700;font-size:18px;margin:0 0 10px;line-height:1.15;}
.table-card__back-desc{font-size:13.5px;line-height:1.55;margin:0;color:rgba(255,255,255,.96);}

.table-card__media{position:relative;aspect-ratio:4/3;overflow:hidden;}
.table-card__media .photo{position:absolute;inset:0;}
.table-card__media .photo::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 40%,rgba(255,200,90,.22),transparent 55%);}
.table-card__num{display:none;}
.table-card__body{padding:14px 16px 16px;}
.table-card__title{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--tg-gray);margin:0 0 6px;line-height:1.2;}
.table-card__desc{margin:0;font-size:13px;color:var(--tg-gray);line-height:1.5;}

/* Reduced-Motion-Nutzer: keine Flip-Animation, Back-Seite kommt per Fade */
@media (prefers-reduced-motion: reduce){
  .table-card__inner{transition:none;}
  .table-card:hover .table-card__inner,
  .table-card:focus-within .table-card__inner{transform:none;}
  .table-card:hover .table-card__back,
  .table-card:focus-within .table-card__back{transform:none;opacity:1;}
  .table-card__back{opacity:0;transition:opacity .25s ease;}
}

/* Tisch-Grid: auf schmalen Bildschirmen weniger Spalten, am Handy untereinander */
@media (max-width:900px){
  .tables{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:720px){
  .tables{grid-template-columns:repeat(2,1fr);}
  .section__head{flex-direction:column;align-items:flex-start;gap:8px;}
}
@media (max-width:560px){
  .tables{grid-template-columns:1fr;}
}

/* ---------- PAKET-PREIS BANNER ---------- */
.package{margin-top:32px;background:var(--tg-light);border-radius:var(--r-lg);padding:36px;display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:center;}
.package h3{font-family:var(--font-display);font-weight:700;font-size:24px;color:var(--tg-gray);margin:0 0 8px;line-height:1.15;}
.package h3 em{color:var(--tg-red);font-style:italic;}
.package p{margin:0 0 16px;font-size:14.5px;color:var(--tg-gray);line-height:1.55;max-width:52ch;}
.package ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px;font-family:var(--font-display);font-size:13px;color:var(--tg-gray);}
.package ul li::before{content:"▪ ";color:var(--tg-red);font-weight:700;}
.package__cta{background:var(--tg-red);color:#fff;border-radius:var(--r-md);padding:28px 24px;text-align:center;font-family:var(--font-display);}
.package__cta small{display:block;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;opacity:.92;}
.package__cta b{display:block;font-size:34px;font-weight:700;line-height:1.05;margin:10px 0 4px;}
.package__cta em{display:block;font-style:normal;font-size:12px;font-weight:400;opacity:.88;margin-bottom:18px;line-height:1.4;}
.package__cta .btn{width:100%;justify-content:center;}

/* Paket-Banner: am Handy untereinander — erst der Text, dann die rote Box */
@media (max-width:720px){
  .package{grid-template-columns:1fr;gap:24px;}
}
@media (max-width:560px){
  .package{padding:24px;}
}

/* ---------- FEATURES (Magazin: Foto + Liste) ---------- */
.features{background:#fff;padding:72px 0;}
.features__layout{display:grid;grid-template-columns:.95fr 1.1fr;gap:56px;align-items:stretch;max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.features__media{position:relative;height:100%;min-height:280px;border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(135deg,#5a2a1f 0%,#1d0a0a 100%);}
.features__media::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 40%,rgba(255,210,140,.24),transparent 55%),radial-gradient(circle at 75% 75%,rgba(206,33,40,.22),transparent 60%);}
.features__media img,.features__media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}

.features__content .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.features__content h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0 0 24px;line-height:1.08;}
.features__content h2 em{color:var(--tg-red);font-style:italic;}

.features__list{list-style:none;margin:0;padding:0;}
.features__list .feature{display:flex;gap:22px;padding:16px 0;border-bottom:1px solid var(--tg-gray-line);}
.features__list .feature:last-child{border-bottom:none;}
.features__list .feature__num{flex-shrink:0;font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--tg-red);line-height:1;letter-spacing:-.01em;width:42px;text-align:left;}
.features__list .feature__body{flex:1;}
.features__list .feature__body h4{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--tg-gray);margin:0 0 4px;line-height:1.2;}
.features__list .feature__body p{margin:0;font-size:14px;line-height:1.55;color:var(--tg-gray);}

@media (max-width:860px){
  .features{padding:48px 0;}
  .features__layout{grid-template-columns:1fr;gap:28px;align-items:start;}
  .features__media{height:auto;aspect-ratio:16/9;min-height:0;}
}

/* ---------- MEHRWERT-SECTION ---------- */
.mehrwert{background:#fff;padding:72px 0;}
.mehrwert__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.mehrwert__head{text-align:center;margin-bottom:40px;}
.mehrwert__head .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.mehrwert__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0;line-height:1.08;}
.mehrwert__head h2 em{color:var(--tg-red);font-style:italic;}

.mehrwert__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.mehrwert__card{background:var(--tg-light);border-left:6px solid var(--tg-red);border-radius:var(--r-sm);padding:24px 22px;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);}
.mehrwert__card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);}
.mehrwert__card .num{display:block;font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.14em;color:var(--tg-red);margin-bottom:10px;}
.mehrwert__card h3{font-family:var(--font-display);font-weight:700;font-size:16.5px;color:var(--tg-gray);margin:0 0 8px;line-height:1.2;}
.mehrwert__card p{font-size:14px;line-height:1.55;color:var(--tg-gray);margin:0;}

@media (max-width:900px){
  .mehrwert__grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:560px){
  .mehrwert{padding:48px 0;}
  .mehrwert__grid{grid-template-columns:1fr;}
}

/* ---------- CASINOBOOSTER ---------- */
.booster{background:var(--tg-light);padding:72px 0;}
.booster__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.booster__head{text-align:center;margin-bottom:44px;}
.booster__head .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.booster__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0 0 12px;line-height:1.08;}
.booster__head h2 em{color:var(--tg-red);font-style:italic;}
.booster__head .lede{font-size:15.5px;line-height:1.6;color:var(--tg-gray);max-width:60ch;margin:0 auto;}

/* 3-Spalten-Layout: 1 Spalte pro Kategorie, Cards untereinander */
.booster__columns{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.booster__group{margin-bottom:0;}
.booster__group-head{margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--tg-red);text-align:left;}
.booster__group-head h3{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--tg-gray);margin:0 0 2px;line-height:1.2;}
.booster__group-head p{margin:0;font-family:var(--font-display);font-size:12.5px;color:var(--tg-red);font-style:italic;}

.booster__grid{display:flex;flex-direction:column;gap:10px;}

/* Flip-Card (kompakt) */
.booster-card{position:relative;background:transparent;perspective:1200px;cursor:pointer;outline:none;}
.booster-card__inner{position:relative;width:100%;min-height:158px;transition:transform .55s var(--ease-out);transform-style:preserve-3d;}
.booster-card:hover .booster-card__inner,
.booster-card:focus-within .booster-card__inner{transform:rotateY(180deg);}
.booster-card__front,
.booster-card__back{backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--r-md);overflow:hidden;}
.booster-card__front{background-color:#fff;background-size:cover;background-position:center;border:1px solid var(--tg-gray-line);box-shadow:0 1px 3px rgba(40,40,40,.05);min-height:158px;padding:16px 14px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;transition:border-color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),opacity 0s linear .28s;}
.booster-card:hover .booster-card__front{border-color:var(--tg-red);box-shadow:0 4px 14px rgba(206,33,40,.10);}
/* Flip-Fix: Vorderseite beim Umdrehen ausblenden — sonst scheint sie auf manchen
   Handy-Browsern spiegelverkehrt durch (backface-visibility dort unzuverlässig). */
.booster-card:hover .booster-card__front,
.booster-card:focus-within .booster-card__front{opacity:0;}

/* Foto-Variante: Hintergrund-Bild + dunkler Verlauf + Titel als Overlay */
.booster-card.has-photo .booster-card__front{background-color:#1d0a0a;padding:0;justify-content:flex-end;align-items:stretch;text-align:left;gap:0;position:relative;border:none;}
.booster-card.has-photo .booster-card__front::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,.82) 100%);pointer-events:none;}
.booster-card.has-photo .booster-card__icon{display:none;}
.booster-card.has-photo .booster-card__front h4{position:relative;z-index:1;color:#fff;padding:0 14px 14px;margin:0;text-shadow:0 1px 3px rgba(0,0,0,.5);font-size:16px;}
.booster-card.has-photo:hover .booster-card__front{border-color:transparent;box-shadow:0 6px 18px rgba(0,0,0,.20);}
.booster-card__icon{width:54px;height:54px;color:var(--tg-red);background:var(--tg-light);border-radius:50%;display:grid;place-items:center;margin:0;transition:background var(--dur-base) var(--ease-out);}
.booster-card:hover .booster-card__icon{background:#fde9ea;}
.booster-card__icon svg{width:55%;height:55%;display:block;}
.booster-card__front h4{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--tg-gray);margin:0;line-height:1.2;}
.booster-card__back{position:absolute;inset:0;background:var(--tg-red);color:#fff;transform:rotateY(180deg);padding:14px 14px;display:flex;flex-direction:column;justify-content:space-between;text-align:left;gap:8px;box-shadow:0 1px 3px rgba(40,40,40,.05);}
.booster-card__back p{font-size:12.5px;line-height:1.45;margin:0;color:rgba(255,255,255,.96);}
.booster-card__price{display:inline-flex;align-items:baseline;gap:5px;background:#fff;color:var(--tg-red);padding:4px 9px;border-radius:var(--r-sm);align-self:flex-start;}
.booster-card__price b{font-family:var(--font-display);font-weight:700;font-size:12.5px;line-height:1;}
.booster-card__price span{font-family:var(--font-display);font-size:10px;opacity:.75;}

@media (max-width:900px){
  .booster__columns{grid-template-columns:repeat(2,1fr);gap:24px;}
}
@media (max-width:600px){
  .booster{padding:48px 0;}
  .booster__columns{grid-template-columns:1fr;gap:32px;}
}

/* Reduced-Motion */
@media (prefers-reduced-motion: reduce){
  .booster-card__inner{transition:none;}
  .booster-card:hover .booster-card__inner,
  .booster-card:focus-within .booster-card__inner{transform:none;}
  .booster-card:hover .booster-card__back,
  .booster-card:focus-within .booster-card__back{transform:none;opacity:1;}
  .booster-card__back{opacity:0;transition:opacity .25s ease;}
}

/* ---------- GALERIE ---------- */
.galerie{background:#fff;padding:72px 0;}
.galerie__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.galerie__head{text-align:center;margin-bottom:36px;}
.galerie__head .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.galerie__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0;line-height:1.08;}
.galerie__head h2 em{color:var(--tg-red);font-style:italic;}
.galerie__grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:14px;grid-auto-flow:dense;}
.galerie__item{position:relative;border-radius:var(--r-md);overflow:hidden;background:linear-gradient(135deg,#5a2a1f 0%,#1d0a0a 100%);}
.galerie__item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out);}
.galerie__item:hover img{transform:scale(1.07);}
.galerie__item.galerie__item--wide{grid-column:span 2;}
.galerie__item__caption{position:absolute;left:14px;bottom:12px;color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.6);z-index:1;}
.galerie__item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.55) 100%);pointer-events:none;}
@media(max-width:900px){.galerie__grid{grid-template-columns:repeat(2,1fr);}.galerie__item--wide{grid-column:span 2;}}
@media(max-width:560px){.galerie{padding:48px 0;}.galerie__grid{grid-template-columns:1fr;grid-auto-rows:180px;}.galerie__item--wide{grid-column:span 1;}}

/* Award-Badge im Stats-Hero */
.award-badge{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:6px 14px;background:#fff;border:1.5px solid var(--tg-red);border-radius:var(--r-pill);font-family:var(--font-display);font-weight:700;font-size:12px;color:var(--tg-red);letter-spacing:.02em;text-transform:uppercase;}
.award-badge::before{content:"★";font-size:14px;line-height:1;}

/* Social Media im Footer */
.footer-social{display:flex;gap:10px;margin-top:18px;}
.footer-social a{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;text-decoration:none;transition:background var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);}
.footer-social a:hover{background:var(--tg-red);transform:translateY(-2px);}
.footer-social a svg{width:18px;height:18px;display:block;}

/* ---------- REFERENZEN ---------- */
.referenzen{background:#fff;padding:72px 0;}
.referenzen__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.referenzen__head{text-align:center;margin-bottom:36px;}
.referenzen__head .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.referenzen__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0;line-height:1.08;}
.referenzen__head h2 em{color:var(--tg-red);font-style:italic;}
.referenzen__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.referenz-card{background:var(--tg-light);border-radius:var(--r-md);padding:26px 24px;display:flex;flex-direction:column;position:relative;}
.referenz-card::before{content:"\201E";position:absolute;top:4px;left:18px;font-family:Georgia,serif;font-size:80px;color:var(--tg-red);opacity:.18;line-height:1;}
.referenz-card__stars{color:var(--tg-red);font-size:15px;letter-spacing:2px;margin-bottom:14px;position:relative;}
.referenz-card__quote{font-size:14.5px;line-height:1.6;color:var(--tg-gray);margin:0 0 18px;flex:1;}
.referenz-card__author{border-top:1px solid var(--tg-gray-line);padding-top:14px;}
.referenz-card__name{display:block;font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--tg-gray);}
.referenz-card__role{display:block;font-size:13px;color:var(--tg-gray-soft);margin-top:2px;}
.referenzen__note{margin-top:24px;padding:14px 18px;background:var(--tg-light);border-left:3px solid var(--tg-red);border-radius:var(--r-sm);font-size:13px;color:var(--tg-gray);}
@media(max-width:900px){.referenzen__grid{grid-template-columns:1fr;}}
@media(max-width:560px){.referenzen{padding:48px 0;}}

/* ---------- ANLÄSSE ---------- */
.anlaesse{background:var(--tg-light);padding:72px 0;}
.anlaesse__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.anlaesse__head{text-align:center;margin-bottom:40px;}
.anlaesse__head .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.anlaesse__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0;line-height:1.08;}
.anlaesse__head h2 em{color:var(--tg-red);font-style:italic;}
.anlaesse__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.anlass-card{background:#fff;border-radius:var(--r-md);padding:24px 22px;text-align:center;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);border:1px solid transparent;}
.anlass-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);border-color:var(--tg-red);}
.anlass-card__icon{width:56px;height:56px;background:var(--tg-light);border-radius:50%;display:grid;place-items:center;margin:0 auto 14px;color:var(--tg-red);transition:background var(--dur-base);}
.anlass-card:hover .anlass-card__icon{background:#fde9ea;}
.anlass-card__icon svg{width:60%;height:60%;}
.anlass-card h3{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--tg-gray);margin:0 0 8px;line-height:1.2;}
.anlass-card p{margin:0;font-size:13.5px;line-height:1.5;color:var(--tg-gray);}
@media(max-width:900px){.anlaesse__grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.anlaesse{padding:48px 0;}.anlaesse__grid{grid-template-columns:1fr;}}

/* ---------- ABLAUF (4-Schritte) ---------- */
.ablauf{background:#fff;padding:72px 0;}
.ablauf__inner{max-width:var(--max-w-content);margin:0 auto;padding:0 24px;}
.ablauf__head{text-align:center;margin-bottom:44px;}
.ablauf__head .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.ablauf__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0;line-height:1.08;}
.ablauf__head h2 em{color:var(--tg-red);font-style:italic;}
.ablauf__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;}
.ablauf-step{background:var(--tg-light);border-radius:var(--r-md);padding:28px 22px 22px;position:relative;text-align:center;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);}
.ablauf-step:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);}
.ablauf-step__num{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:50%;background:var(--tg-red);color:#fff;font-family:var(--font-display);font-weight:700;font-size:20px;margin-bottom:14px;}
.ablauf-step h3{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--tg-gray);margin:0 0 8px;line-height:1.2;}
.ablauf-step p{margin:0;font-size:14px;line-height:1.55;color:var(--tg-gray);}
@media(max-width:900px){.ablauf__grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.ablauf{padding:48px 0;}.ablauf__grid{grid-template-columns:1fr;}}

/* ---------- FAQ (Accordion) ---------- */
.faq{background:var(--tg-light);padding:72px 0;}
.faq__inner{max-width:880px;margin:0 auto;padding:0 24px;}
.faq__head{text-align:center;margin-bottom:36px;}
.faq__head .eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-red);margin-bottom:12px;}
.faq__head h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.85rem,3vw,2.5rem);color:var(--tg-gray);margin:0;line-height:1.08;}
.faq__head h2 em{color:var(--tg-red);font-style:italic;}
.faq__list{display:flex;flex-direction:column;gap:12px;}
.faq-item{background:#fff;border-radius:var(--r-md);border:1px solid var(--tg-gray-line);transition:border-color var(--dur-base) var(--ease-out);overflow:hidden;}
.faq-item[open]{border-color:var(--tg-red);}
.faq-item summary{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--tg-gray);padding:18px 52px 18px 22px;cursor:pointer;list-style:none;position:relative;line-height:1.35;transition:color var(--dur-fast) var(--ease-out);}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary:hover{color:var(--tg-red);}
.faq-item summary::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--tg-red);transition:transform var(--dur-base) var(--ease-out);line-height:1;}
.faq-item[open] summary::after{content:"−";}
.faq-item__body{padding:0 22px 20px;font-size:14.5px;line-height:1.6;color:var(--tg-gray);}
.faq-item__body p{margin:0;}
@media(max-width:560px){.faq{padding:48px 0;}.faq-item summary{font-size:15px;padding:16px 46px 16px 18px;}.faq-item summary::after{right:18px;}}

/* ---------- ANFRAGE CTA BLOCK ---------- */
.cta-block{position:relative;background-color:var(--tg-red);background-image:linear-gradient(rgba(40,10,12,.55),rgba(206,33,40,.88)),url('/assets/blackjack-foto.jpg');background-size:cover;background-position:center;color:#fff;border-radius:var(--r-lg);padding:48px;display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center;overflow:hidden;}
.cta-block h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.75rem,2.6vw,2.25rem);color:#fff;margin:0 0 12px;line-height:1.1;}
.cta-block h2 em{font-style:italic;}
.cta-block p{margin:0 0 24px;font-size:16px;color:rgba(255,255,255,.92);max-width:42ch;}
.cta-block .btn--white{background:#fff;color:var(--tg-red);}
.cta-block .btn--white:hover{background:var(--tg-light);}
.cta-form{background:#fff;border-radius:var(--r-md);padding:24px;color:var(--tg-gray);}
.cta-form .field{margin-bottom:12px;}
.cta-form label{display:block;font-family:var(--font-display);font-weight:600;font-size:12px;color:var(--tg-gray);margin-bottom:6px;}
.cta-form input,.cta-form select,.cta-form textarea{width:100%;font-family:var(--font-body);font-size:14px;color:var(--tg-gray);padding:10px 12px;border:1px solid var(--tg-gray-line);border-radius:var(--r-sm);background:#fff;outline:none;transition:border-color var(--dur-fast) var(--ease-out);}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{border-color:var(--tg-red);}
.cta-form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.cta-form .form-honeypot{position:absolute;left:-9999px;width:0;height:0;opacity:0;pointer-events:none;}
.cta-form .form-consent{display:flex;gap:10px;align-items:flex-start;margin:14px 0;font-size:12px;line-height:1.5;color:var(--tg-gray);cursor:pointer;}
.cta-form .form-consent input[type="checkbox"]{margin-top:3px;flex-shrink:0;cursor:pointer;accent-color:var(--tg-red);width:16px;height:16px;}
.cta-form .form-consent a{color:var(--tg-red);text-decoration:underline;}
.cta-form input:invalid:not(:placeholder-shown){border-color:#d11;}

/* Anfrage-Block: auf schmalen Bildschirmen untereinander — erst Text, dann Formular */
@media (max-width:760px){
  .cta-block{grid-template-columns:1fr;gap:28px;padding:32px 24px;}
}
@media (max-width:560px){
  .cta-block{padding:22px 16px;}
  .cta-form{padding:18px;}
  .cta-form .row{grid-template-columns:1fr;}
}

/* ---------- FOOTER ---------- */
footer{background:var(--tg-gray);color:#fff;padding:56px 0 24px;margin-top:48px;}
footer .container{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;}
@media (max-width:720px){footer .container{grid-template-columns:1fr;gap:32px;}}
footer h5{font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin:0 0 14px;}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;}
footer a{color:rgba(255,255,255,.78);font-size:13.5px;}
footer a:hover{color:#fff;}
footer .legal{max-width:var(--max-w-content);margin:36px auto 0;padding:18px 24px 0;border-top:1px solid rgba(255,255,255,.18);display:flex;justify-content:space-between;color:rgba(255,255,255,.6);font-size:12px;}
.footer-logo img{height:32px;width:auto;filter:brightness(0) invert(1);margin-bottom:12px;}
footer p.lede{color:rgba(255,255,255,.78);font-size:13.5px;line-height:1.55;margin:0 0 16px;max-width:36ch;}
.footer-address{font-size:13px;line-height:1.55;color:rgba(255,255,255,.78);}
.footer-address strong{display:block;color:#fff;font-family:var(--font-display);font-weight:700;font-size:13.5px;margin-bottom:4px;}
footer .hours{color:rgba(255,255,255,.55);font-size:12.5px;}

.doc-note{max-width:var(--max-w-content);margin:24px auto 0;padding:14px 24px;font-size:12.5px;color:var(--tg-gray-soft);}
.doc-note code{font-family:'SFMono-Regular',Menlo,monospace;background:var(--tg-light);padding:1px 6px;border-radius:3px;color:var(--tg-gray);}

/* ---------- LEGAL-PAGES (Impressum, Datenschutz, AGB) ---------- */
.legal-header{background:#fff;border-bottom:1px solid var(--tg-gray-line);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px;max-width:var(--max-w-content);margin:0 auto;}
.legal-header .tg-logo img{height:32px;width:auto;}
.legal-back-btn{font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--tg-gray);text-decoration:none;transition:color .15s ease;display:inline-flex;align-items:center;gap:4px;}
.legal-back-btn:hover{color:var(--tg-red);}

.legal-page{max-width:880px;margin:0 auto;padding:48px 24px 80px;}
.legal-page h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,4vw,2.8rem);color:var(--tg-gray);margin:0 0 8px;line-height:1.08;}
.legal-page__lead{font-family:var(--font-body);font-size:15.5px;color:var(--tg-gray-soft);margin:0 0 32px;}
.legal-page h2{font-family:var(--font-display);font-weight:700;font-size:1.35rem;color:var(--tg-red);margin:36px 0 10px;line-height:1.2;}
.legal-page h3{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--tg-gray);margin:24px 0 8px;line-height:1.25;}
.legal-page p,.legal-page li{font-size:15px;line-height:1.7;color:var(--tg-gray);}
.legal-page p{margin:0 0 12px;}
.legal-page ul,.legal-page ol{margin:0 0 18px;padding-left:22px;}
.legal-page li{margin-bottom:6px;}
.legal-page a{color:var(--tg-red);text-decoration:underline;}
.legal-page strong{color:var(--tg-gray);font-weight:700;}
.legal-page__note{background:var(--tg-light);border-left:3px solid var(--tg-red);padding:14px 18px;margin:20px 0;border-radius:var(--r-sm);font-size:14px;color:var(--tg-gray);}
.legal-page__date{font-style:italic;color:var(--tg-gray-soft);margin-top:40px;font-size:13.5px;padding-top:18px;border-top:1px solid var(--tg-gray-line);}

/* ---------- STICKY CTA (rechts unten beim Scrollen) ---------- */
.sticky-cta{position:fixed;bottom:24px;right:24px;z-index:90;opacity:0;transform:translateY(60px);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out);pointer-events:none;text-decoration:none;}
.sticky-cta.is-visible{opacity:1;transform:translateY(0);pointer-events:auto;}
.sticky-cta .btn{box-shadow:0 6px 18px rgba(206,33,40,.35);padding:14px 22px;font-size:14px;}
@media(max-width:560px){.sticky-cta{bottom:90px;right:16px;}.sticky-cta .btn{padding:12px 18px;font-size:13px;}}

/* ---------- LIGHTBOX (Galerie) ---------- */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;padding:32px;animation:lightbox-fade .25s var(--ease-out);}
.lightbox.is-open{display:flex;}
.lightbox img{max-width:100%;max-height:calc(100vh - 64px);border-radius:var(--r-md);box-shadow:0 20px 60px rgba(0,0,0,.5);object-fit:contain;}
.lightbox__close{position:absolute;top:18px;right:18px;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;border:0;font-size:28px;cursor:pointer;display:grid;place-items:center;transition:background .2s,transform .2s;line-height:1;}
.lightbox__close:hover{background:rgba(255,255,255,.28);transform:rotate(90deg);}
@keyframes lightbox-fade{from{opacity:0;}to{opacity:1;}}
.galerie__item img{cursor:zoom-in;}

/* ---------- MOBILE HAMBURGER ---------- */
.hamburger{display:none;background:transparent;border:0;cursor:pointer;width:40px;height:40px;padding:0;flex-direction:column;justify-content:center;align-items:center;gap:5px;margin-left:auto;}
.hamburger span{display:block;width:24px;height:2px;background:var(--tg-gray);transition:transform .3s var(--ease-out),opacity .3s var(--ease-out),background .15s;border-radius:1px;}
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--tg-red);}
.hamburger.is-open span:nth-child(2){opacity:0;}
.hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--tg-red);}
.menu-backdrop{position:fixed;inset:0;z-index:55;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .3s;}
.menu-backdrop.is-open{opacity:1;pointer-events:auto;}

@media(max-width:1200px){
  .hamburger{display:inline-flex;}
  .tg-nav{position:fixed;top:0;right:0;bottom:0;width:280px;max-width:80vw;background:#fff;flex-direction:column;padding:80px 24px 24px;box-shadow:-4px 0 24px rgba(0,0,0,.18);transform:translateX(100%);transition:transform .35s var(--ease-out);z-index:60;gap:0;align-items:flex-start;overflow-y:auto;}
  .tg-nav.is-open{transform:translateX(0);}
  .tg-nav a{padding:14px 0;font-size:16px;border-bottom:1px solid var(--tg-gray-line);width:100%;border-radius:0;}
  .tg-nav a:last-child{border-bottom:none;}
  body.menu-open{overflow:hidden;}
  /* Header (und damit das Menü) über die Verdunkelung heben, sonst liegt das
     offene Menü dahinter und ist nicht anklickbar. */
  body.menu-open .tg-header{z-index:60;}
  .tg-header__inner{gap:8px;}
  .tg-header__cta{margin-left:0;gap:4px;}
  .tg-header__cta .btn--ghost{display:none;}
  .tg-header__cta .lang-toggle{display:none;}
  .tg-nav .lang-toggle--drawer{display:inline-flex;margin-top:14px;}
  .tg-nav .lang-toggle--drawer button{font-size:15px;padding:6px 10px;}
}

@media(max-width:560px){
  .tg-logo img{height:30px;}
  .tg-header__inner{padding:10px 14px;}
  .tg-header__cta .btn--primary{padding:9px 13px;font-size:13px;}
}

/* ---------- COOKIE-BANNER ---------- */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;background:#fff;border-top:3px solid var(--tg-red);box-shadow:0 -4px 20px rgba(0,0,0,.15);padding:18px 24px;animation:cookie-slide-up .45s var(--ease-out);}
@keyframes cookie-slide-up{from{transform:translateY(100%);}to{transform:translateY(0);}}
.cookie-banner__inner{max-width:var(--max-w-content);margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;}
.cookie-banner__text{margin:0;font-size:14px;color:var(--tg-gray);line-height:1.5;max-width:64ch;}
.cookie-banner__text a{color:var(--tg-red);text-decoration:underline;}
.cookie-banner__buttons{display:flex;gap:10px;flex-wrap:wrap;}
.cookie-banner__buttons .btn{padding:9px 16px;font-size:13px;}
@media(max-width:720px){
  .cookie-banner__inner{grid-template-columns:1fr;}
  .cookie-banner__buttons{justify-content:stretch;}
  .cookie-banner__buttons .btn{flex:1;}
}

.legal-footer{background:var(--tg-light);padding:24px;text-align:center;font-size:13px;color:var(--tg-gray-soft);}
.legal-footer p{margin:4px 0;}
.legal-footer a{color:var(--tg-gray);text-decoration:none;}
.legal-footer a:hover{color:var(--tg-red);}

@media (max-width:560px){
  .legal-header{flex-direction:column;align-items:flex-start;gap:10px;padding:14px 16px;}
  .legal-page{padding:32px 16px 60px;}
}

/* ---------- SCROLL-REVEAL & MIKRO-ANIMATIONEN ---------- */
@media (prefers-reduced-motion: no-preference) {
  /* Einzelnes Element: opacity + slide-up */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1);will-change:opacity,transform;}
  .reveal.in-view{opacity:1;transform:translateY(0);}

  /* Container mit Kindern: Kinder gestaffelt einfaden */
  .reveal-stagger > *{opacity:0;transition:opacity .55s ease-out;will-change:opacity;}
  .reveal-stagger.in-view > *{opacity:1;}
  .reveal-stagger.in-view > *:nth-child(1){transition-delay:0ms;}
  .reveal-stagger.in-view > *:nth-child(2){transition-delay:80ms;}
  .reveal-stagger.in-view > *:nth-child(3){transition-delay:160ms;}
  .reveal-stagger.in-view > *:nth-child(4){transition-delay:240ms;}
  .reveal-stagger.in-view > *:nth-child(5){transition-delay:320ms;}
  .reveal-stagger.in-view > *:nth-child(6){transition-delay:400ms;}
  .reveal-stagger.in-view > *:nth-child(n+7){transition-delay:480ms;}

  /* Wir-Gefühl-Stempel: dezenter Puls */
  .intro__stamp{animation:wg-pulse 4.5s ease-in-out infinite;}
  @keyframes wg-pulse{
    0%, 100% { transform: rotate(-9deg) scale(1); }
    50%      { transform: rotate(-9deg) scale(1.045); }
  }

  /* Logo: leichtes Hover-Scale */
  .tg-logo img{transition:transform .25s var(--ease-out);}
  .tg-logo:hover img{transform:scale(1.06);}

  /* Sprachumschalter */
  .lang-toggle{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-display);font-weight:600;}
  .lang-toggle button{background:transparent;border:0;color:var(--tg-gray-soft);cursor:pointer;padding:4px 6px;font-family:inherit;font-weight:600;font-size:13px;letter-spacing:.04em;transition:color .15s ease;}
  .lang-toggle button:hover{color:var(--tg-red);}
  .lang-toggle button.is-active{color:var(--tg-red);}
  .lang-toggle span{color:var(--tg-gray-line);user-select:none;font-size:13px;}

  /* Buttons: subtiler Lift beim Hover */
  .btn--primary{transition:background var(--dur-fast) var(--ease-out),transform .18s var(--ease-out),box-shadow .25s var(--ease-out);}
  .btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(206,33,40,.25);}

  /* Headline-Highlight em: leichter Akzent beim Hover über die Headline */
  .intro h1 em,.konzept__head h2 em,.mehrwert__head h2 em,.booster__head h2 em,.features__content h2 em,.cta-block h2 em,.section__head h2 em,.package h3 em{display:inline-block;transition:transform .35s var(--ease-out);}
  .intro h1:hover em,.konzept__head h2:hover em,.mehrwert__head h2:hover em,.booster__head h2:hover em,.features__content h2:hover em,.cta-block h2:hover em,.section__head h2:hover em,.package h3:hover em{transform:scale(1.06);}

  /* Foto-Cards beim Hover sanft zoomen */
  .table-card__media .photo{transition:transform .8s var(--ease-out);}
  .table-card:hover .table-card__media .photo{transform:scale(1.06);}

  /* Page-Load Fade */
  body{animation:page-fade-in .5s ease-out;}
  @keyframes page-fade-in{from{opacity:0;}to{opacity:1;}}
}

/* ---------- MODAL / POP-UP ---------- */
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:32px 24px;background:rgba(40,40,40,.55);overflow-y:auto;animation:modal-fade var(--dur-base) var(--ease-out);}
.modal.is-open{display:flex;}
.modal__dialog{background:#fff;border-radius:var(--r-lg);max-width:720px;width:100%;margin:auto;position:relative;padding:40px 40px 36px;box-shadow:0 20px 60px rgba(0,0,0,.35);animation:modal-pop var(--dur-base) var(--ease-out);}
.modal__close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:transparent;color:var(--tg-gray);border:0;font-size:26px;font-family:var(--font-display);font-weight:600;cursor:pointer;line-height:1;display:grid;place-items:center;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out);}
.modal__close:hover{background:var(--tg-light);color:var(--tg-red);}
.modal__eyebrow{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--tg-gray-soft);margin-bottom:10px;}
.modal h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,2.4vw,2rem);color:var(--tg-gray);margin:0 0 10px;line-height:1.12;}
.modal h2 em{color:var(--tg-red);font-style:italic;}
.modal__lede{font-size:15px;line-height:1.55;color:var(--tg-gray);margin:0 0 22px;max-width:54ch;}
.modal__alt{margin:18px 0 0;font-size:13.5px;color:var(--tg-gray-soft);text-align:center;}
.modal__alt a{color:var(--tg-red);font-family:var(--font-display);font-weight:600;}
.modal__alt a:hover{text-decoration:underline;}
.modal .cta-form{padding:0;background:transparent;}
body.modal-open{overflow:hidden;}
@keyframes modal-fade{from{opacity:0;}to{opacity:1;}}
@keyframes modal-pop{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@media (max-width:560px){
  .modal{padding:20px 12px;}
  .modal__dialog{padding:32px 20px 24px;}
  .modal .cta-form .row{grid-template-columns:1fr;}
}

/* ============ BARRIEREFREIHEIT ============ */
/* Deutlich sichtbare Tastatur-Fokus-Markierung — auch auf den Flip-Karten,
   die sonst per outline:none keinerlei Fokus zeigen. */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,
textarea:focus-visible,summary:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--tg-red);
  outline-offset:2px;
}
/* Skip-Link — unsichtbar, bis er per Tastatur (Tab) fokussiert wird. */
.skip-link{
  position:absolute;left:8px;top:-64px;z-index:1000;
  background:var(--tg-red);color:#fff;padding:10px 18px;
  border-radius:0 0 6px 6px;font-family:var(--font-display);font-weight:700;font-size:14px;
  transition:top .15s var(--ease-out);
}
.skip-link:focus{top:0;}
