/* ============ TOKENS ============ */
:root{
  --navy:#333745; --navy-2:#3e4356; --navy-soft:#4a5066;
  --gold:#33b5f7; --gold-2:#73d0ff; --gold-deep:#2191cc;
  --red:#ffb606; --red-deep:#e0a000;
  --cream:#f5f7fa; --cream-2:#e8edf3;
  --ink:#2b2f3a; --muted:#707688; --line:#e3e7ee;
  --white:#ffffff;
  --shadow:0 18px 50px rgba(51,55,69,.16);
  --shadow-sm:0 8px 24px rgba(51,55,69,.10);
  --radius:18px; --radius-lg:26px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;color:var(--ink);
  background:var(--cream);line-height:1.6;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:min(var(--maxw),92%);margin-inline:auto}
h1,h2,h3,h4,h5{font-family:'Playfair Display',serif;line-height:1.12;color:var(--navy)}
.kicker{display:inline-block;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  font-size:.74rem;color:var(--gold-deep);margin-bottom:.7rem}
.kicker.center{display:block;text-align:center}
.section{padding:clamp(64px,9vw,120px) 0}
.section-head{text-align:center;max-width:720px;margin:0 auto clamp(40px,6vw,68px)}
.section-head h2{font-size:clamp(1.9rem,4.2vw,3rem)}
.head-p{color:var(--muted);margin-top:.8rem}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.98rem;
  padding:.95rem 1.7rem;border-radius:60px;border:0;cursor:pointer;transition:.35s var(--ease);
  letter-spacing:.01em;position:relative;overflow:hidden}
.btn-gold{background:linear-gradient(120deg,var(--gold),var(--gold-deep));color:#fff;
  box-shadow:0 12px 30px rgba(51,181,247,.45)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(51,181,247,.6);
  background:linear-gradient(120deg,var(--gold-2),var(--gold))}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.55);
  backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.22);transform:translateY(-3px)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--navy-2);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.btn-block{width:100%;justify-content:center;margin-top:.6rem}

/* ============ PROMO TOP (Gratis-Zusatzleistung) ============ */
.promo-top{display:block;position:relative;overflow:hidden;text-decoration:none;
  background:linear-gradient(120deg,var(--gold-deep),var(--gold-2) 45%,var(--gold-deep));
  background-size:200% 100%;animation:promoShimmer 6s linear infinite;color:#08263a}
@keyframes promoShimmer{to{background-position:200% 0}}
.promo-inner{display:flex;align-items:center;gap:1rem;padding:.55rem 0;flex-wrap:wrap;justify-content:center}
.promo-tag{font-weight:800;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;
  background:rgba(10,38,58,.92);color:var(--gold-2);padding:.32rem .85rem;border-radius:40px;white-space:nowrap}
.promo-text{font-size:.92rem;font-weight:500;text-align:center}
.promo-text b{font-weight:800}
.promo-cta{font-weight:800;font-size:.88rem;white-space:nowrap;background:#08263a;color:#fff;
  padding:.4rem 1.05rem;border-radius:40px;transition:.3s var(--ease)}
.promo-top:hover .promo-cta{background:var(--navy);transform:translateX(3px)}
@media(max-width:680px){
  .promo-text{font-size:.82rem;flex-basis:100%;order:3}
  .promo-inner{gap:.6rem;padding:.5rem 0}
}

/* ============ TOPBAR ============ */
.topbar{background:var(--navy);color:#dbe6f3;font-size:.82rem}
.topbar-inner{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;flex-wrap:wrap}
.topbar a{color:var(--gold-2);font-weight:600}

/* ============ NAV ============ */
.nav{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
  box-shadow:0 6px 24px rgba(51,55,69,.08);transition:.4s var(--ease)}
.nav.scrolled{background:rgba(255,255,255,.98);backdrop-filter:blur(12px);
  box-shadow:0 8px 28px rgba(51,55,69,.10)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-img{height:48px;width:auto;display:block}
.brand-mark{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#fff;
  font-family:'Playfair Display';font-weight:800;font-size:1.05rem;box-shadow:var(--shadow-sm)}
.brand-text{font-family:'Playfair Display';font-weight:800;font-size:1.18rem;color:var(--navy);line-height:1}
.brand-accent{color:var(--gold-deep)}
.brand-text small{display:block;font-family:'Inter';font-weight:500;font-size:.62rem;
  letter-spacing:.04em;color:var(--muted);margin-top:3px}
.nav.scrolled .brand-text,.nav.scrolled .brand-text small{color:var(--navy)}
/* weißer Header – Logo + dunkle Navigation (wie Live-Site) */
.nav .menu a{color:var(--ink)}
.menu{display:flex;align-items:center;gap:1.6rem}
/* Hervorgehobener Zusatzleistung-Menüpunkt */
.nav-zusatz{color:var(--gold-deep) !important;font-weight:800 !important;white-space:nowrap}
.nav-zusatz::after{background:var(--gold) !important;height:2px}
/* Dropdown */
.nav-drop{position:relative}
.nav-drop-menu{position:absolute;top:calc(100% + 14px);left:50%;translate:-50% 0;min-width:248px;
  background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:.5rem;opacity:0;visibility:hidden;
  transform:translateY(8px);transition:.28s var(--ease);z-index:99;border:1px solid var(--line)}
.nav-drop-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.nav-drop:hover .nav-drop-menu{opacity:1;visibility:visible;transform:none}
.nav-drop-menu a{display:flex;flex-direction:column;gap:1px;padding:.6rem .8rem;border-radius:10px;
  color:var(--navy) !important;transition:.2s}
.nav-drop-menu a:hover{background:var(--cream-2)}
.nav-drop-menu a b{font-size:.95rem}
.nav-drop-menu a small{color:var(--muted);font-size:.78rem}
.nav-drop-menu a::after{display:none}
.menu a{font-weight:600;font-size:.95rem;position:relative;transition:.25s}
.menu a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;
  background:var(--gold);transition:.3s var(--ease)}
.menu a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:var(--gold);color:#fff !important;padding:.6rem 1.2rem;border-radius:50px;font-weight:700}
.nav-cta:hover{background:var(--gold-deep);transform:translateY(-2px)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:26px;height:2.5px;background:var(--navy);border-radius:2px;transition:.3s}
.nav.scrolled .burger span{background:var(--navy)}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;color:#fff;
  overflow:hidden;margin-top:-72px;padding-top:72px}
.hero-bg{position:absolute;inset:-8% 0;
  background:
    radial-gradient(90% 70% at 80% 16%, rgba(51,181,247,.32), transparent 60%),
    radial-gradient(80% 80% at 8% 92%, rgba(255,182,6,.14), transparent 62%),
    linear-gradient(160deg,#333745 0%, #2b2f3b 55%, #23262f 100%);
  transform:scale(1.08);will-change:transform;animation:heroZoom 18s ease-in-out infinite alternate}
@keyframes heroZoom{to{transform:scale(1.16)}}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(30,33,42,.45),rgba(30,33,42,.25) 45%,rgba(30,33,42,.80));}
.hero-content{position:relative;z-index:3;padding:5vh 0 8vh}
.hero-eyebrow{font-family:'Great Vibes',cursive;font-size:clamp(2rem,5vw,3.4rem);
  color:var(--gold-2);text-shadow:0 4px 18px rgba(0,0,0,.4);margin-bottom:-.4rem}
.hero-title{font-size:clamp(4rem,16vw,11rem);font-weight:800;letter-spacing:.02em;color:#fff;
  text-shadow:0 10px 40px rgba(0,0,0,.45);line-height:.9}
.hero-title .line{display:block}
.hero-sub-script{display:block;font-family:'Great Vibes',cursive;font-weight:400;
  font-size:clamp(1.6rem,5vw,3rem);color:#fff;letter-spacing:.02em;margin-top:.1rem;
  text-shadow:0 4px 18px rgba(0,0,0,.5)}
.hero-lead{max-width:560px;font-size:clamp(1rem,1.6vw,1.18rem);color:#eaf1fb;margin:1.6rem 0 2rem;
  text-shadow:0 2px 10px rgba(0,0,0,.35)}
.hero-lead strong{color:var(--gold-2)}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}

/* countdown */
.countdown{margin-top:2.6rem}
.cd-label{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);font-weight:700}
.cd-grid{display:flex;gap:.7rem;margin-top:.7rem}
.cd-box{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(8px);border-radius:14px;padding:.7rem 1rem;text-align:center;min-width:66px}
.cd-box b{display:block;font-family:'Playfair Display';font-size:1.8rem;font-weight:800;color:#fff}
.cd-box i{font-style:normal;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:#cdd8e8}

/* gutschein badge */
.gutschein-badge{position:absolute;z-index:4;top:18%;right:max(5%,calc((100vw - var(--maxw))/2));
  width:178px;height:178px;border-radius:50%;display:grid;place-content:center;text-align:center;
  background:radial-gradient(circle at 30% 25%,var(--red),var(--red-deep));color:#fff;
  box-shadow:0 18px 50px rgba(178,31,31,.5),inset 0 0 0 4px rgba(255,255,255,.25);
  animation:badgeFloat 4.5s ease-in-out infinite;rotate:8deg}
@keyframes badgeFloat{50%{transform:translateY(-14px)}}
.gb-top{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;opacity:.9}
.gb-val{font-family:'Playfair Display';font-weight:800;font-size:2.5rem;line-height:1;margin:.15rem 0}
.gb-val small{font-size:1.1rem}
.gb-bot{font-size:.74rem;font-weight:600;opacity:.95;padding:0 1rem}

.scroll-down{position:absolute;bottom:26px;left:50%;translate:-50% 0;z-index:4;width:26px;height:42px;
  border:2px solid rgba(255,255,255,.6);border-radius:20px}
.scroll-down span{position:absolute;top:8px;left:50%;translate:-50% 0;width:5px;height:8px;border-radius:3px;
  background:#fff;animation:scroll 1.6s infinite}
@keyframes scroll{0%{opacity:0;top:8px}40%{opacity:1}80%{opacity:0;top:22px}}

/* ============ STATS ============ */
.stats{background:var(--navy);color:#fff;padding:2.4rem 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;text-align:center}
.stat b{display:block;font-family:'Playfair Display';font-weight:800;font-size:clamp(1.8rem,4vw,2.7rem);
  color:var(--gold-2)}
.stat span{font-size:.86rem;color:#bcc9db}

/* ============ INTRO ============ */
.intro-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.intro-text h2{font-size:clamp(1.7rem,3.6vw,2.6rem);margin:.3rem 0 1rem}
.intro-text p{color:var(--muted);font-size:1.05rem}
.ticks{list-style:none;margin:1.4rem 0 1.8rem;display:grid;gap:.65rem}
.ticks li{position:relative;padding-left:2rem;font-weight:500}
.ticks li::before{content:"✓";position:absolute;left:0;top:0;width:1.4rem;height:1.4rem;border-radius:50%;
  background:var(--gold);color:#08263a;display:grid;place-items:center;font-size:.8rem;font-weight:800}
.intro-media{position:relative}
.intro-img{aspect-ratio:4/5;border-radius:var(--radius-lg);background:url("../img/oldtown.png") center/cover;
  box-shadow:var(--shadow)}
.intro-float{position:absolute;bottom:-26px;left:-26px;background:#fff;padding:1rem 1.3rem;border-radius:16px;
  box-shadow:var(--shadow);max-width:240px}
.intro-float b{color:var(--gold-deep);font-size:1rem;letter-spacing:.1em}
.intro-float span{display:block;font-size:.88rem;color:var(--muted);font-style:italic;margin-top:.2rem}

/* ============ PROGRAMM TIMELINE ============ */
.programm{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.timeline{display:grid;gap:clamp(2rem,4vw,3.4rem)}
.tl-item{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.4rem,4vw,3.2rem);align-items:center}
.tl-item.alt{direction:rtl}.tl-item.alt .tl-body{direction:ltr}.tl-item.alt .tl-media{direction:ltr}
.tl-media{aspect-ratio:16/11;border-radius:var(--radius-lg);background-size:cover;background-position:center;
  box-shadow:var(--shadow);transition:.6s var(--ease)}
.tl-item:hover .tl-media{transform:translateY(-6px) scale(1.01)}
.tl-day{display:inline-block;background:var(--navy);color:var(--gold-2);font-weight:700;font-size:.78rem;
  letter-spacing:.12em;text-transform:uppercase;padding:.4rem 1rem;border-radius:40px}
.tl-body h3{font-size:clamp(1.4rem,3vw,2rem);margin:.9rem 0 .7rem}
.tl-body p{color:var(--muted);font-size:1.02rem}

/* ============ GALERIE ============ */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:230px;gap:1rem}
.g-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;
  background-size:cover;background-position:center;box-shadow:var(--shadow-sm)}
.g-item.g-big{grid-row:span 2;grid-column:span 2}
.g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(7,22,42,.78));
  opacity:.7;transition:.4s}
.g-item figcaption{position:absolute;left:16px;bottom:14px;z-index:2;color:#fff;font-weight:700;
  font-family:'Playfair Display';font-size:1.05rem;transform:translateY(6px);transition:.4s}
.g-item:hover{transform:scale(1.012)}
.g-item:hover::after{opacity:.95}
.g-item:hover figcaption{transform:translateY(0)}
.g-item::before{content:"⤢";position:absolute;top:14px;right:16px;z-index:2;color:#fff;font-size:1.1rem;
  opacity:0;transition:.4s}
.g-item:hover::before{opacity:.9}

/* ============ LEISTUNGEN ============ */
.leist-inner{margin-top:clamp(48px,7vw,80px)}
.leist-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.leist{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem 1.4rem;transition:.4s var(--ease);box-shadow:var(--shadow-sm)}
.leist:hover{transform:translateY(-6px);border-color:var(--gold);box-shadow:var(--shadow)}
.li-ico{font-size:1.8rem;display:block;margin-bottom:.7rem}
.leist h4{color:var(--navy);font-size:1.12rem;margin-bottom:.35rem}
.leist p{color:var(--muted);font-size:.9rem}
.leist-note{text-align:center;margin-top:1.6rem;color:var(--gold-deep);font-weight:600}

/* RentenMillion corner ribbon */
.rm-card{position:relative}
.rm-ribbon{position:absolute;top:18px;right:-46px;z-index:5;rotate:45deg;
  background:linear-gradient(120deg,var(--gold-2),var(--gold-deep));color:#08263a;
  font-weight:800;font-size:.78rem;letter-spacing:.04em;padding:.5rem 3.4rem;
  box-shadow:0 8px 20px rgba(200,146,58,.45)}

/* ============ VORTEILE / RENTENMILLION ============ */
.vorteile{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.vorteile.flip{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.rm-card{display:grid;grid-template-columns:1fr 1.15fr;background:#fff;border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow);margin-bottom:1.6rem}
.rm-media{position:relative;background-size:cover;background-position:center;min-height:360px}
.rm-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(51,55,69,.15),transparent 60%)}
.rm-badge{position:absolute;top:16px;left:16px;z-index:2;background:var(--red);color:#fff;
  font-size:.72rem;font-weight:700;letter-spacing:.06em;padding:.4rem .9rem;border-radius:40px;
  box-shadow:0 8px 20px rgba(178,31,31,.4)}
.rm-body{padding:clamp(1.6rem,3.5vw,2.8rem)}
.rm-logo{font-family:'Playfair Display';font-weight:700;font-size:1.6rem;color:var(--navy);letter-spacing:-.01em}
.rm-logo b{color:var(--gold-deep)}
.rm-claim{display:block;font-family:'Great Vibes',cursive;font-size:1.5rem;color:var(--gold-deep);margin:.1rem 0 .6rem}
.rm-body h3{font-size:clamp(1.3rem,2.6vw,1.9rem);line-height:1.2;margin-bottom:.7rem}
.rm-amt{color:var(--red-deep)}
.rm-body p{color:var(--muted);font-size:1rem}
.rm-balls{display:flex;gap:.6rem;margin:1.3rem 0;flex-wrap:wrap}
.rm-balls span{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-weight:800;
  font-family:'Playfair Display';color:#08263a;
  background:radial-gradient(circle at 32% 28%,var(--gold-2),var(--gold-deep));
  box-shadow:0 8px 18px rgba(200,146,58,.4),inset 0 2px 4px rgba(255,255,255,.5);
  opacity:0;transform:scale(.4) translateY(10px);animation:ballPop .5s var(--ease) forwards}
.rm-card.in .rm-balls span{animation:ballPop .5s var(--ease) forwards}
.rm-balls span:nth-child(1){animation-delay:.15s}.rm-balls span:nth-child(2){animation-delay:.27s}
.rm-balls span:nth-child(3){animation-delay:.39s}.rm-balls span:nth-child(4){animation-delay:.51s}
.rm-balls span:nth-child(5){animation-delay:.63s}.rm-balls span:nth-child(6){animation-delay:.75s}
.rm-balls span:nth-child(7){animation-delay:.87s;background:radial-gradient(circle at 32% 28%,#ff7b6b,var(--red-deep));color:#fff}
@keyframes ballPop{60%{transform:scale(1.12) translateY(0)}100%{opacity:1;transform:scale(1) translateY(0)}}
.shop-chips{display:flex;flex-wrap:wrap;gap:.55rem;margin:1.1rem 0 .2rem}
.shop-chips span{background:var(--cream-2);border:1px solid var(--line);color:var(--navy);font-weight:700;
  font-size:.86rem;padding:.4rem .9rem;border-radius:40px}
.rm-facts{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin:0 0 1.6rem;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.1rem 0}
.rm-facts b{display:block;font-family:'Playfair Display';font-weight:800;font-size:1.25rem;color:var(--navy)}
.rm-facts i{font-style:normal;font-size:.74rem;color:var(--muted)}

/* alt layout: Bild rechts */
.rm-card.alt{grid-template-columns:1.15fr 1fr;margin-top:1.6rem}
.rm-card.alt .rm-media{order:2}
.rm-card.alt .rm-body{order:1}

.zusatz-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem;margin-top:1.6rem}
.zus-card{background:#fff;border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm);
  border:1px solid var(--line);transition:.4s var(--ease);display:block}
.zus-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold)}
.zus-ico{font-size:2rem;display:block;margin-bottom:.6rem}
.zus-card h4{font-size:1.3rem;margin-bottom:.4rem}
.zus-card p{color:var(--muted);font-size:.94rem;margin-bottom:.8rem}
.zus-link{font-weight:700;color:var(--gold-deep)}
.zus-soon{background:linear-gradient(160deg,#fff,var(--cream-2));border-style:dashed}
.zus-soon .zus-link{color:var(--muted)}

/* ============ TERMINE ============ */
.termine{background:var(--cream)}
.plz-finder{max-width:560px;margin:0 auto 2.4rem;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.6rem;display:grid;grid-template-columns:1fr auto;gap:.7rem;align-items:end}
.plz-finder label{grid-column:1/-1;font-weight:700;color:var(--navy);font-size:.9rem}
.plz-finder input{padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:12px;font-size:1.05rem;
  font-weight:600;letter-spacing:.1em}
.plz-finder input:focus{outline:none;border-color:var(--gold)}
.plz-result{grid-column:1/-1;font-weight:600;color:var(--navy);min-height:1.2rem}
.plz-result.hit{color:var(--red-deep)}
.table-scroll{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff}
.termine-table{width:100%;border-collapse:collapse;min-width:760px}
.termine-table th{background:var(--navy);color:#fff;font-family:'Inter';font-weight:600;font-size:.82rem;
  padding:.9rem .8rem;text-align:left}
.termine-table th small{display:block;font-weight:400;color:#aebfd6;font-size:.68rem}
.termine-table td{padding:.8rem;border-bottom:1px solid var(--line);font-size:.9rem}
.termine-table tbody tr{transition:.2s}
.termine-table tbody tr:hover{background:var(--cream-2)}
.termine-table tr.row-hit{background:#fff5dd !important;box-shadow:inset 4px 0 0 var(--gold)}
.termine-table td:first-child{font-weight:700;color:var(--navy)}
.termine-note{margin-top:1.4rem;font-size:.84rem;color:var(--muted);max-width:840px}

/* ============ ANMELDUNG ============ */
.anmeldung{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff}
.anmeldung h2{color:#fff}
.anmeldung .kicker{color:var(--gold-2)}
.anm-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.anm-info p{color:#cdd8e8}
.anm-info h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin:.3rem 0 .9rem}
.code-chip{display:inline-flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.08);
  border:1px dashed var(--gold);border-radius:50px;padding:.5rem 1.1rem;margin:1.2rem 0;font-size:.92rem}
.code-chip b{font-family:'Playfair Display';font-size:1.15rem;color:var(--gold-2);letter-spacing:.1em}
.anm-points{list-style:none;display:grid;gap:.5rem;margin:.6rem 0 1.6rem;color:#dce6f3}
.anm-contact{border-top:1px solid rgba(255,255,255,.15);padding-top:1.2rem;font-size:.92rem;color:#cdd8e8}
.anm-contact a{color:var(--gold-2);font-weight:700;word-break:break-word}
.anm-veranstalter{opacity:.75;margin-top:.4rem}
.reise-service{margin-top:1.4rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-left:4px solid var(--gold);border-radius:14px;padding:1.2rem 1.4rem}
.reise-service h4{color:#fff;font-size:1.05rem;margin-bottom:.5rem}
.reise-service p{color:#cdd8e8;font-size:.92rem;margin-bottom:.6rem}
.reise-service .rs-tel b{color:#fff}
.reise-service .rs-note{font-size:.86rem}
.reise-service a{color:var(--gold-2);font-weight:700;word-break:break-word}

/* ============ BUCHUNGS-HOTLINE (Reise) ============ */
.hero-hotline{margin-top:1.4rem;font-size:1.06rem;font-weight:600;color:#fff;
  text-shadow:0 2px 10px rgba(0,0,0,.45)}
.hero-hotline a{color:var(--gold-2);font-weight:800}
.hotline-banner{display:flex;align-items:center;gap:1.2rem;max-width:760px;margin:0 auto 2.2rem;
  background:linear-gradient(120deg,var(--gold-2),var(--gold-deep));color:#08263a;
  border-radius:18px;padding:1.1rem 1.6rem;text-decoration:none;
  box-shadow:0 14px 36px rgba(51,181,247,.45);transition:.35s var(--ease);
  animation:hbPulse 2.6s ease-in-out infinite}
@keyframes hbPulse{0%,100%{box-shadow:0 14px 36px rgba(51,181,247,.45)}
  50%{box-shadow:0 14px 44px rgba(51,181,247,.75)}}
.hotline-banner:hover{transform:translateY(-4px)}
.hb-ico{font-size:2.1rem;flex-shrink:0}
.hb-text{display:flex;flex-direction:column;line-height:1.3}
.hb-label{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;opacity:.85}
.hb-num{font-family:'Playfair Display';font-size:clamp(1.2rem,2.8vw,1.75rem);font-weight:800}
.hb-hours{font-size:.82rem;font-weight:600;opacity:.82}
.hb-cta{margin-left:auto;flex-shrink:0;background:#08263a;color:#fff;font-weight:800;
  padding:.65rem 1.15rem;border-radius:40px;white-space:nowrap}
@media(max-width:600px){.hotline-banner{flex-wrap:wrap;text-align:center;justify-content:center}
  .hb-text{align-items:center}.hb-cta{margin:.4rem auto 0}}
.footer-grid a[href^="mailto"]{word-break:break-word}
.anm-form{background:#fff;border-radius:var(--radius-lg);padding:clamp(1.4rem,3vw,2.2rem);
  box-shadow:var(--shadow);color:var(--ink)}
.anm-form-title{font-size:1.5rem;color:var(--navy);margin-bottom:.35rem}
.anm-form-sub{color:var(--muted);font-size:.95rem;margin-bottom:1.3rem}
.form-block{margin-bottom:1.4rem}
.form-block h4{color:var(--navy);font-size:1.1rem;margin-bottom:.8rem;display:flex;gap:.5rem;align-items:baseline}
.form-block h4 small{font-family:'Inter';font-weight:400;color:var(--muted);font-size:.78rem}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.anm-form input[type=text],.anm-form input:not([type]),.anm-form input[type=email],.form-row input{
  width:100%;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:11px;font-size:.95rem;
  font-family:inherit;transition:.25s}
.anm-form input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(51,181,247,.18)}
.form-row{margin-bottom:1rem}
.check{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--muted);margin:.5rem 0;cursor:pointer}
.check input{margin-top:.25rem;accent-color:var(--gold-deep)}
.check a{color:var(--gold-deep);font-weight:600}
.form-ok{margin-top:1rem;background:#eaf7ec;color:#1d7a3a;padding:.9rem 1rem;border-radius:12px;
  font-weight:600;text-align:center}

/* ============ FOOTER ============ */
.footer{background:#081a31;color:#bcc9db;padding-top:clamp(48px,7vw,80px)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1.2fr 1fr;gap:2rem;padding-bottom:2.6rem}
.footer h5{color:#fff;font-family:'Inter';font-weight:700;font-size:.78rem;letter-spacing:.14em;
  text-transform:uppercase;margin-bottom:1rem}
.footer-grid a{display:block;color:#a9b8cd;padding:.2rem 0;transition:.2s}
.footer-grid a:hover{color:var(--gold-2)}
.footer p{font-size:.9rem;line-height:1.7}
.brand-foot{margin-bottom:1rem}
.brand-foot .brand-text{color:#fff;font-size:1.3rem}
.footer-bar{border-top:1px solid rgba(255,255,255,.08);padding:1.2rem 0;font-size:.82rem;color:#7d8ca3}
.footer-bar-in{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-bar a{color:#a9b8cd}

/* ============ FLOAT CTA ============ */
.float-cta{position:fixed;right:18px;bottom:18px;z-index:80;background:linear-gradient(120deg,var(--gold-2),var(--gold-deep));
  color:#08263a;font-weight:800;padding:.9rem 1.3rem;border-radius:50px;box-shadow:0 12px 30px rgba(51,181,247,.5);
  transform:translateY(120px);transition:.5s var(--ease)}
.float-cta.show{transform:translateY(0)}
.float-cta:hover{transform:translateY(-4px)}

/* ============ LIGHTBOX ============ */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(7,16,30,.92);display:none;
  align-items:center;justify-content:center;padding:4vw}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
#lbClose{position:absolute;top:20px;right:28px;background:none;border:0;color:#fff;font-size:2.4rem;cursor:pointer}

/* ============ CASHBACK MODAL ============ */
.modal{position:fixed;inset:0;z-index:110;background:rgba(7,16,30,.72);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:5vw}
.modal.open{display:flex;animation:modalFade .3s ease}
@keyframes modalFade{from{opacity:0}to{opacity:1}}
.modal-box{position:relative;width:min(440px,100%);background:#fff;border-radius:var(--radius-lg);
  padding:clamp(1.6rem,4vw,2.4rem);box-shadow:0 30px 80px rgba(0,0,0,.4);
  animation:modalPop .35s var(--ease)}
@keyframes modalPop{from{transform:translateY(24px) scale(.96);opacity:0}to{transform:none;opacity:1}}
.modal-box .kicker{margin-bottom:.4rem}
.modal-box h3{font-size:1.6rem;color:var(--navy);margin-bottom:.5rem}
.modal-p{color:var(--muted);font-size:.95rem;margin-bottom:1.3rem}
.modal-box form{display:grid;gap:.7rem}
.modal-box input{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:12px;
  font-size:.98rem;font-family:inherit;transition:.25s}
.modal-box input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(51,181,247,.18)}
.modal-hint{text-align:center;font-size:.8rem;color:var(--muted);margin-top:.2rem}
.modal-close{position:absolute;top:12px;right:16px;background:none;border:0;font-size:2rem;line-height:1;
  color:var(--muted);cursor:pointer;transition:.2s}
.modal-close:hover{color:var(--navy);transform:rotate(90deg)}

/* ============ REVEAL ANIM ============ */
.reveal,.reveal-l,.reveal-r{opacity:0;transition:.9s var(--ease)}
.reveal{transform:translateY(40px)}
.reveal-l{transform:translateX(-50px)}
.reveal-r{transform:translateX(50px)}
.reveal.in,.reveal-l.in,.reveal-r.in{opacity:1;transform:none}

/* ============ RESPONSIVE ============ */
@media(max-width:900px){
  .menu{position:fixed;inset:0 0 0 auto;width:min(78%,320px);flex-direction:column;justify-content:center;
    gap:1.6rem;background:var(--navy);padding:2rem;transform:translateX(100%);transition:.45s var(--ease);z-index:95}
  .menu.open{transform:none}
  .nav:not(.scrolled) .menu a,.menu a{color:#fff !important}
  .burger{display:flex;z-index:96}
  .nav.scrolled .burger span,.menu.open ~ .burger span{background:#fff}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:1.4rem}
  .intro-grid,.anm-grid{grid-template-columns:1fr}
  .tl-item,.tl-item.alt{grid-template-columns:1fr;direction:ltr}
  .leist-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .g-item.g-big{grid-column:span 2;grid-row:span 1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gutschein-badge{width:130px;height:130px;top:auto;bottom:30px;right:5%;rotate:6deg}
  .gb-val{font-size:1.8rem}
  .intro-img{aspect-ratio:4/3}
  .rm-card,.rm-card.alt{grid-template-columns:1fr}
  .rm-card.alt .rm-media{order:0}
  .rm-card.alt .rm-body{order:1}
  .rm-media{min-height:240px}
  .zusatz-grid{grid-template-columns:1fr}
  .leist-bonus{flex-direction:column;text-align:center}
  .lb-arrow{margin:0}
  /* Dropdown im mobilen Menü statisch anzeigen */
  .nav-drop-menu{position:static;opacity:1;visibility:visible;transform:none;translate:0;box-shadow:none;
    background:transparent;border:0;padding:.4rem 0 0;min-width:0}
  .nav-drop-menu a{color:#fff !important}
  .nav-drop-menu a small{color:#cdd8e8}
  .nav-drop-menu a:hover{background:rgba(255,255,255,.08)}
}
@media(max-width:540px){
  .fgrid{grid-template-columns:1fr}
  .leist-grid,.gallery{grid-template-columns:1fr}
  .g-item.g-big{grid-column:span 1}
  .stats-grid{grid-template-columns:1fr 1fr}
  .plz-finder{grid-template-columns:1fr}
  .topbar-inner .topbar-item:nth-child(3){display:none}
  .cd-box{min-width:58px;padding:.6rem .7rem}
}
@media(prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}
  .reveal,.reveal-l,.reveal-r{opacity:1;transform:none}}

/* =========================================================
   FRAMER-STYLE MOTION & 3D
   ========================================================= */

/* Scroll-Fortschrittsbalken */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;pointer-events:none;
  background:linear-gradient(90deg,var(--gold-2),var(--gold-deep),var(--red));
  box-shadow:0 0 14px rgba(51,181,247,.7)}

/* Reicheres 3D-Reveal (überschreibt die einfachen Werte) */
.reveal{opacity:0;transform:translateY(52px) scale(.96);filter:blur(3px)}
.reveal.in{opacity:1;transform:none;filter:none}
.reveal-l{opacity:0;transform:perspective(1100px) translateX(-64px) rotateY(10deg)}
.reveal-r{opacity:0;transform:perspective(1100px) translateX(64px) rotateY(-10deg)}
.reveal-l.in,.reveal-r.in{opacity:1;transform:none}

/* Tilt-Elemente: weiche Rückkehr */
.rm-card,.leist,.zus-card,.stat,.intro-img,.tl-media{will-change:transform}

/* Gold-Button Glanz-Sweep */
.btn-gold::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;pointer-events:none;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.6),transparent);transform:skewX(-20deg)}
.btn-gold:hover::after{animation:btnShine .85s ease}
@keyframes btnShine{from{left:-130%}to{left:150%}}

/* Schwebende Licht-Blobs (Tiefe) */
.vorteile,.programm{position:relative;overflow:hidden}
.vorteile>.wrap,.programm>.wrap{position:relative;z-index:1}
.vorteile::before,.programm::after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;
  filter:blur(75px);opacity:.45;z-index:0;pointer-events:none;
  background:radial-gradient(circle,rgba(51,181,247,.55),transparent 70%);
  animation:blobFloat 16s ease-in-out infinite}
.vorteile::before{top:-90px;left:-70px}
.programm::after{bottom:-110px;right:-80px;animation-duration:21s;
  background:radial-gradient(circle,rgba(214,43,43,.28),transparent 70%)}
@keyframes blobFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(46px,-34px) scale(1.18)}}

/* Idle-Float für die Hero-CTA-Hotline */
.hero-hotline{animation:floatY 3.4s ease-in-out infinite}
@keyframes floatY{50%{transform:translateY(-5px)}}

@media(prefers-reduced-motion:reduce){
  .scroll-progress,.vorteile::before,.programm::after{display:none}
  .reveal,.reveal-l,.reveal-r{opacity:1 !important;transform:none !important;filter:none !important}
  .hero-hotline{animation:none}
}

/* =========================================================
   EXTRA WOW: Preloader · Cursor · Marquee · Aurora · Glare
   ========================================================= */

/* ---- Preloader ---- */
.preloader{position:fixed;inset:0;z-index:300;display:grid;place-items:center;
  background:linear-gradient(160deg,var(--navy),#081a31);transition:transform .8s var(--ease),opacity .6s ease}
.preloader.done{transform:translateY(-100%);opacity:0;pointer-events:none}
.pl-inner{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}
.pl-mark{display:grid;place-items:center;width:74px;height:74px;border-radius:18px;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#08263a;
  font-family:'Playfair Display';font-weight:800;font-size:1.7rem;box-shadow:0 18px 50px rgba(51,181,247,.5);
  animation:plPop .7s var(--ease) both}
.pl-name{font-family:'Playfair Display';font-weight:800;font-size:1.5rem;color:#fff;letter-spacing:.01em;
  animation:plUp .6s var(--ease) .15s both}
.pl-name b{color:var(--gold-2)}
.pl-sub{font-family:'Great Vibes',cursive;font-size:1.4rem;color:var(--gold-2);animation:plUp .6s var(--ease) .25s both}
.pl-bar{margin-top:.6rem;width:160px;height:3px;border-radius:3px;background:rgba(255,255,255,.15);overflow:hidden}
.pl-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-2),var(--gold-deep));
  animation:plLoad 1.1s ease .2s forwards}
@keyframes plPop{0%{transform:scale(.5) rotate(-8deg);opacity:0}100%{transform:none;opacity:1}}
@keyframes plUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes plLoad{to{width:100%}}

/* ---- Custom Cursor ---- */
.cursor-ring{position:fixed;top:0;left:0;width:38px;height:38px;border:2px solid var(--gold);
  border-radius:50%;pointer-events:none;z-index:250;transform:translate(-50%,-50%);
  transition:width .25s ease,height .25s ease,background .25s ease,border-color .25s ease;
  mix-blend-mode:difference;will-change:transform}
.cursor-ring.grow{width:64px;height:64px;background:rgba(244,205,114,.18);border-color:var(--gold-2)}
.cursor-ring.hide{opacity:0}
@media(hover:none){.cursor-ring{display:none}}

/* ---- Marquee ---- */
.marquee{background:var(--navy);overflow:hidden;border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08)}
.marquee-track{display:flex;width:max-content;animation:marquee 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:'Playfair Display';font-weight:800;font-size:1.15rem;letter-spacing:.04em;
  color:var(--gold-2);padding:.7rem 0;white-space:nowrap}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---- Hero Aurora ---- */
.hero-aurora{position:absolute;inset:0;z-index:2;pointer-events:none;mix-blend-mode:screen;opacity:.65;
  background:
    radial-gradient(42% 50% at 18% 28%,rgba(51,181,247,.55),transparent 62%),
    radial-gradient(38% 46% at 82% 62%,rgba(214,43,43,.45),transparent 62%),
    radial-gradient(42% 42% at 62% 18%,rgba(120,160,255,.32),transparent 62%);
  animation:aurora 18s ease-in-out infinite alternate}
@keyframes aurora{
  0%{background-position:0% 0%,0% 0%,0% 0%;filter:hue-rotate(0deg)}
  100%{background-position:12% 18%,-14% -10%,8% -12%;filter:hue-rotate(18deg)}}

/* ---- Cursor-Glare auf Karten ---- */
.fx-glare{position:relative}
.fx-glare::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:3;
  opacity:0;transition:opacity .35s ease;
  background:radial-gradient(240px circle at var(--gx,50%) var(--gy,50%),rgba(255,255,255,.38),transparent 60%)}
.fx-glare:hover::after{opacity:1}

@media(prefers-reduced-motion:reduce){
  .preloader{display:none}
  .cursor-ring{display:none}
  .marquee-track{animation:none}
  .hero-aurora{animation:none;opacity:.4}
  .fx-glare::after{display:none}
}

/* =========================================================
   GUTSCHEIN-BADGE 3D-MEDAILLON (explosiv)
   ========================================================= */
.gutschein-badge{position:absolute;z-index:5;top:15%;right:max(4%,calc((100vw - var(--maxw))/2));
  width:200px;height:200px;perspective:900px;rotate:8deg;will-change:transform;
  animation:gbDrop 1.1s var(--ease) both}
.gb-rays{position:absolute;inset:-28%;border-radius:50%;z-index:0;pointer-events:none;
  background:repeating-conic-gradient(from 0deg,rgba(255,206,92,0) 0 9deg,rgba(255,206,92,.5) 9deg 12deg);
  -webkit-mask:radial-gradient(circle,transparent 37%,#000 41%,#000 70%,transparent 75%);
          mask:radial-gradient(circle,transparent 37%,#000 41%,#000 70%,transparent 75%);
  filter:blur(.6px);opacity:.75;animation:gbRays 16s linear infinite}
.gb-3d{position:absolute;inset:0;border-radius:50%;display:grid;place-content:center;text-align:center;z-index:1;
  transform-style:preserve-3d;
  background:radial-gradient(circle at 32% 26%,#ff6457,var(--red) 46%,var(--red-deep));
  box-shadow:0 24px 60px rgba(178,31,31,.55),inset 0 0 0 4px rgba(255,255,255,.30),
    inset 0 -12px 30px rgba(120,0,0,.45),inset 0 12px 26px rgba(255,255,255,.25);
  animation:gbFloat 4.6s ease-in-out infinite,gbSpin 7s ease-in-out infinite,gbGlow 3.2s ease-in-out infinite}
.gb-3d>.gb-top,.gb-3d>.gb-val,.gb-3d>.gb-bot{position:relative;z-index:4;transform:translateZ(26px)}
.gb-3d::after{content:"";position:absolute;inset:0;border-radius:50%;pointer-events:none;z-index:2;
  background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.55) 50%,transparent 58%);
  background-size:300% 300%;animation:gbShine 3.6s ease-in-out infinite}
@keyframes gbDrop{0%{opacity:0;transform:translateY(-55px) scale(.3) rotate(-45deg)}
  55%{opacity:1;transform:translateY(10px) scale(1.12) rotate(5deg)}100%{opacity:1;transform:none}}
@keyframes gbFloat{50%{translate:0 -16px}}
@keyframes gbSpin{0%,100%{transform:rotateY(-18deg) rotateX(7deg)}50%{transform:rotateY(18deg) rotateX(-7deg)}}
@keyframes gbGlow{50%{box-shadow:0 28px 76px rgba(214,43,43,.9),inset 0 0 0 4px rgba(255,255,255,.42),
  inset 0 -12px 30px rgba(120,0,0,.45),inset 0 12px 26px rgba(255,255,255,.32)}}
@keyframes gbRays{to{transform:rotate(360deg)}}
@keyframes gbShine{0%{background-position:140% 0}100%{background-position:-80% 0}}
@media(max-width:900px){.gutschein-badge{width:140px;height:140px;top:auto;bottom:26px;right:5%;rotate:6deg}}
@media(prefers-reduced-motion:reduce){
  .gutschein-badge,.gb-3d{animation:none}
  .gb-rays,.gb-3d::after{display:none}
  .gb-3d{transform:none}
}

/* ============ LEISTUNGS-GARANTIE ============ */
.garantie-sec{background:var(--cream-2)}
.garantie-box{
  max-width:920px;margin:0 auto;text-align:center;
  background:linear-gradient(160deg,var(--navy),var(--navy-2));
  color:var(--cream);border:1px solid rgba(115,208,255,.32);
  border-radius:var(--radius-lg);padding:48px 42px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;
}
.garantie-box::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 120% at 50% -10%,rgba(51,181,247,.20),transparent 60%);
}
.garantie-box>*{position:relative;z-index:1}
.garantie-box .g-ico{font-size:48px;display:block;margin-bottom:14px}
.garantie-box h3{color:#fff;font-family:"Playfair Display",serif;font-size:1.7rem;margin:0 0 14px}
.garantie-box p{color:rgba(245,241,232,.92);font-size:1.06rem;line-height:1.75;margin:0 auto;max-width:680px}
.garantie-box .g-seal{
  display:inline-block;margin-top:24px;padding:11px 24px;
  border:1.5px solid var(--gold);border-radius:999px;
  color:var(--gold-2);font-weight:700;letter-spacing:.3px;
}
@media(max-width:640px){.garantie-box{padding:36px 22px}.garantie-box h3{font-size:1.4rem}}
