/* ============================================================
   THONGKHUN – DESIGN 1: ELEGANT & ROYAL
   Navy Blau + Gold  |  Klassisch, seriös, hochwertig
   ============================================================
   FARBEN ANPASSEN → :root weiter unten
   PREISE ANPASSEN → Suche nach "€" im HTML
   SOCIAL LINKS   → Suche nach "tiktok.com" und "instagram.com"
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#C9A35A;
  --gold-light:#E8C97A;
  --deep-blue:#0D1B3E;
  --mid-blue:#1A2F5E;
  --cream:#F7F3EC;
  --text-dark:#1a1a1a;
  --text-mid:#555;
}
body{font-family:'Jost',sans-serif;background:#fff;color:var(--text-dark);font-size:15px;line-height:1.7}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:#f0ece4}
::-webkit-scrollbar-thumb{background:var(--gold)}
nav{position:sticky;top:0;z-index:100;background:rgba(13,27,62,0.97);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;height:64px;border-bottom:1px solid rgba(201,163,90,0.25)}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:#fff;letter-spacing:1.5px;text-transform:uppercase}
.nav-logo-img{height:38px;width:auto;display:block}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{color:rgba(255,255,255,0.75);text-decoration:none;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:400;transition:color .2s}
.nav-links a:hover{color:var(--gold)}
.nav-divider{width:1px;height:20px;background:rgba(201,163,90,0.3)}
.nav-social{display:flex;align-items:center;gap:14px}
.lang-switch{display:flex;align-items:center;gap:5px;background:none;border:1px solid rgba(201,163,90,0.4);border-radius:20px;padding:5px 12px;cursor:pointer;font-family:'Jost',sans-serif;font-size:12px;letter-spacing:.5px;color:inherit}
.lang-switch .lang-opt{opacity:.45;transition:opacity .2s,color .2s}
.lang-switch .lang-opt.active{opacity:1;color:#C9A35A;font-weight:500}
.lang-switch .lang-sep{opacity:.3;font-size:11px}
.lang-switch:hover{border-color:rgba(201,163,90,0.8)}
.social-icon{display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.7);transition:color .2s,transform .2s}
.social-icon svg{width:21px;height:21px;display:block}
.social-icon:hover{color:var(--gold);transform:translateY(-2px)}
.book-btn-nav{background:var(--gold)!important;color:var(--deep-blue)!important;padding:8px 20px!important;border-radius:2px;font-weight:500!important;letter-spacing:1.5px!important;transition:background .2s!important}
.book-btn-nav:hover{background:var(--gold-light)!important}
.hero{height:92vh;min-height:580px;background:var(--deep-blue);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.hero-bg-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(201,163,90,0.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(201,163,90,0.06) 0%,transparent 40%)}
.hero-lines{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 79px,rgba(201,163,90,0.04) 80px),repeating-linear-gradient(90deg,transparent,transparent 79px,rgba(201,163,90,0.04) 80px)}
.hero-photo-bg{position:absolute;inset:0;background-image:url('images/hero.jpg');background-size:cover;background-position:center 40%;background-repeat:no-repeat;opacity:0.42;-webkit-mask-image:radial-gradient(ellipse 75% 80% at center 45%, rgba(0,0,0,1) 0%, rgba(0,0,0,0.85) 40%, rgba(0,0,0,0.4) 70%, rgba(0,0,0,0) 100%);mask-image:radial-gradient(ellipse 75% 80% at center 45%, rgba(0,0,0,1) 0%, rgba(0,0,0,0.85) 40%, rgba(0,0,0,0.4) 70%, rgba(0,0,0,0) 100%)}
.hero-photo-tint{position:absolute;inset:0;background:radial-gradient(ellipse 60% 65% at center 45%, rgba(13,27,62,0.35) 0%, rgba(13,27,62,0.55) 100%);z-index:1}
.hero-logo{display:block;width:150px;height:auto;margin:0 auto 1.4rem;filter:drop-shadow(0 4px 24px rgba(201,163,90,0.4))}
.hero-content{text-align:center;position:relative;z-index:2;padding:0 2rem;max-width:800px}
.hero-badge{display:inline-block;border:1px solid rgba(201,163,90,0.4);color:var(--gold);font-size:10px;letter-spacing:3px;text-transform:uppercase;padding:6px 18px;margin-bottom:2rem}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(48px,8vw,88px);font-weight:300;color:#fff;line-height:1.05;letter-spacing:2px;margin-bottom:.4rem}
.hero h1 em{font-style:italic;color:var(--gold);display:block;font-size:.55em;letter-spacing:4px;margin-bottom:8px}
.hero-sub{color:rgba(255,255,255,0.5);font-size:12px;letter-spacing:3px;text-transform:uppercase;margin-bottom:2.5rem}
.hero-addr{color:rgba(255,255,255,0.35);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:2.5rem}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-primary{background:var(--gold);color:var(--deep-blue);padding:14px 36px;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:500;border:none;cursor:pointer;border-radius:2px;font-family:'Jost',sans-serif;transition:background .2s,transform .15s,box-shadow .2s}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 6px 20px rgba(201,163,90,0.35)}
.btn-outline{background:transparent;color:#fff;padding:14px 36px;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:400;border:1px solid rgba(255,255,255,0.25);cursor:pointer;border-radius:2px;font-family:'Jost',sans-serif;transition:border-color .2s,color .2s,box-shadow .2s,transform .15s}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px);box-shadow:0 6px 20px rgba(201,163,90,0.2)}
.btn-preise{background:transparent;color:var(--deep-blue);padding:12px 32px;font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:500;border:1.5px solid var(--deep-blue);cursor:pointer;border-radius:2px;font-family:'Jost',sans-serif;transition:all .2s}
.btn-preise:hover{color:var(--gold);border-color:var(--gold);transform:translateY(-2px);box-shadow:0 6px 20px rgba(201,163,90,0.25)}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,0.3);font-size:10px;letter-spacing:2px;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(201,163,90,0.6),transparent)}
section{padding:6rem 2.5rem}
.section-label{font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,4vw,48px);font-weight:300;line-height:1.15;margin-bottom:1.5rem}
.section-divider{width:48px;height:1px;background:var(--gold);margin-bottom:2.5rem}
.leistungen{background:var(--cream)}
.capsule-row{display:flex;gap:1.25rem;max-width:1100px;margin:0 auto;justify-content:center;flex-wrap:wrap}
.capsule{position:relative;width:190px;height:380px;border-radius:120px;overflow:hidden;background-size:cover;background-position:center;cursor:pointer;box-shadow:0 8px 30px rgba(13,27,62,0.18);transition:transform .35s ease,box-shadow .35s ease}
.capsule:hover{transform:translateY(-22px);box-shadow:0 22px 50px rgba(13,27,62,0.30);outline:2px solid rgba(201,163,90,0.4)}
.capsule-title-static{position:absolute;left:0;right:0;bottom:0;padding:1.5rem 1rem;text-align:center;color:#fff;font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;letter-spacing:.5px;background:linear-gradient(to top,rgba(13,27,62,0.85) 0%,rgba(13,27,62,0.4) 60%,transparent 100%);transition:opacity .3s}
.capsule:hover .capsule-title-static{opacity:0}
.capsule-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.75rem 1.4rem;background:linear-gradient(to top,rgba(13,27,62,0.94) 0%,rgba(13,27,62,0.7) 55%,rgba(13,27,62,0.15) 100%);opacity:0;transition:opacity .35s ease}
.capsule-overlay-bottom{display:flex;flex-direction:column;width:100%}
.capsule-book-btn{display:inline-block;background:rgba(201,163,90,0.45);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-size:10px;letter-spacing:2px;text-transform:uppercase;font-weight:700;padding:8px 16px;border-radius:20px;text-align:center;font-family:'Jost',sans-serif;border:1px solid rgba(201,163,90,0.8);text-shadow:0 1px 3px rgba(0,0,0,0.3);width:fit-content}
.capsule:hover .capsule-overlay{opacity:1}
.capsule-overlay h3{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:600;color:#fff;margin-bottom:.6rem}
.capsule-desc{font-size:12px;line-height:1.6;color:rgba(255,255,255,0.85);margin-bottom:.9rem}
.capsule-dur{font-size:10px;letter-spacing:1.5px;color:var(--gold-light);text-transform:uppercase;text-align:center;display:block;width:100%}

/* GALERIE */
.galerie{background:#fff}
.gallery-wrap{position:relative;max-width:900px;margin:0 auto;border-radius:8px;overflow:hidden}
.gallery-track{display:flex;transition:transform .45s ease}
.gallery-slide{min-width:100%;aspect-ratio:16/10;background:#f0ece4}
.gallery-slide img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:none;background:rgba(13,27,62,0.55);color:#fff;font-size:24px;line-height:1;cursor:pointer;z-index:3;transition:background .2s;display:flex;align-items:center;justify-content:center}
.gallery-nav:hover{background:rgba(13,27,62,0.85)}
.gallery-prev{left:12px}
.gallery-next{right:12px}
.gallery-dots{display:flex;gap:8px;justify-content:center;margin-top:1.25rem}
.gallery-dot{width:9px;height:9px;border-radius:50%;border:none;background:#d8cfbf;cursor:pointer;padding:0;transition:background .2s,transform .2s}
.gallery-dot.active{background:var(--gold);transform:scale(1.25)}
.preise-inner{max-width:620px;margin:0 auto}
.price-section-title{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:600;color:var(--deep-blue);margin:2rem 0 .5rem;letter-spacing:1px}
.price-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:1px solid #f0ece4}
.price-row:last-child{border-bottom:none}
.price-name{font-size:14px;color:var(--text-dark)}
.price-amount{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--deep-blue)}
.price-old{text-decoration:line-through;opacity:.45;font-size:17px;margin-right:6px;font-weight:500}
.price-duo-pp{font-size:13px;font-family:'Inter',sans-serif;font-weight:400;opacity:.6;margin-left:3px}
.price-row-duo{background:linear-gradient(90deg,rgba(201,163,90,0.07),transparent);border-radius:8px;padding-left:12px;padding-right:12px}
.price-duo-note{display:block;font-size:11px;opacity:.55;font-weight:400;margin-top:2px}
.preis-philosophie{margin:0 auto 3.5rem;max-width:640px;text-align:center}
.preis-philosophie p{font-size:17px;line-height:1.9;color:var(--text-dark);margin-bottom:1.2rem}
.preis-philosophie .philo-lead{font-family:'Cormorant Garamond',serif;font-size:clamp(30px,4vw,42px);font-weight:400;color:var(--deep-blue);line-height:1.25;margin-bottom:1.75rem;letter-spacing:.5px}
.preis-philosophie strong{color:var(--deep-blue);font-weight:600}
.preis-philosophie .philo-promise{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:25px;color:var(--gold);font-weight:600;margin-top:1rem}

/* Glowing CTA button */
.preis-cta{position:relative;display:block;width:100%;max-width:640px;margin:2.5rem auto 0;border:none;cursor:pointer;border-radius:8px;padding:3px;background:transparent;overflow:hidden;font-family:'Jost',sans-serif}
.preis-cta-text{position:relative;z-index:2;display:block;background:var(--deep-blue);color:var(--gold-light);font-size:13px;letter-spacing:.5px;padding:1.1rem 1.5rem;border-radius:6px;transition:color .2s}
.preis-cta:hover .preis-cta-text{color:#fff;background:#13245a}
/* The rotating light beam */
.preis-cta-glow{position:absolute;z-index:1;top:50%;left:50%;width:180%;height:400%;transform:translate(-50%,-50%);background:conic-gradient(from 0deg,transparent 0deg,transparent 295deg,rgba(232,201,122,0.4) 320deg,var(--gold-light) 345deg,#fff8e8 358deg,var(--gold-light) 365deg,rgba(232,201,122,0.4) 385deg,transparent 410deg);animation:preis-spin 3.5s linear infinite}
@keyframes preis-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
@media (prefers-reduced-motion: reduce){.preis-cta-glow{animation:none;background:var(--gold)}}
.aktion{background:var(--deep-blue);color:#fff;text-align:center;padding:4rem 2rem}
.aktion .section-title{color:#fff}
.aktion-badge{display:inline-block;background:var(--gold);color:var(--deep-blue);font-size:32px;font-weight:700;padding:12px 28px;margin:1.5rem 0;font-family:'Cormorant Garamond',serif;letter-spacing:2px}
.aktion p{color:rgba(255,255,255,0.6);font-size:13px;letter-spacing:1px;margin-bottom:2rem}
.booking{background:var(--cream);position:relative;overflow:hidden}
.booking-team-bg{
  position:absolute;
  left:0;top:0;width:45%;height:100%;
  background-image:url('images/team.png');
  background-size:cover;
  background-position:center top;
  mask-image:linear-gradient(to right, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.5) 50%, transparent 100%);
  -webkit-mask-image:linear-gradient(to right, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.5) 50%, transparent 100%);
}
.booking-team-bg-right{
  position:absolute;
  right:0;top:0;width:45%;height:100%;
  background-image:url('images/team.png');
  background-size:cover;
  background-position:center top;
  transform:scaleX(-1);
  mask-image:linear-gradient(to right, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.5) 50%, transparent 100%);
  -webkit-mask-image:linear-gradient(to right, rgba(0,0,0,0.75) 0%, rgba(0,0,0,0.5) 50%, transparent 100%);
}
.booking-layout{display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;max-width:1000px;margin:0 auto;align-items:stretch}
.booking-form{
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  padding:2.5rem;
  border-top:3px solid var(--gold);
  border-radius:4px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
/* Barzahlung Box */
.cash-note{
  padding:1rem 1.25rem;
  background:rgba(255,255,255,0.6);
  border:1px solid rgba(201,163,90,0.25);
  border-radius:6px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:flex;
  align-items:center;
  gap:1rem;
}
.no-card-icon{width:101px;height:auto;flex-shrink:0;opacity:.85}
.cash-lines{display:flex;flex-direction:column;gap:.45rem;width:100%}
.cash-line{font-size:13px;color:var(--text-dark);display:flex;align-items:center;gap:.5rem}
.cash-line::before{content:"!";color:#f80000;font-weight:900;font-size:14px;flex-shrink:0;line-height:1}
.cash-lang{font-size:10px;font-weight:700;letter-spacing:.8px;color:var(--gold);flex-shrink:0;font-family:'Jost',sans-serif;text-transform:uppercase}
/* QR Code Box */
.qr-box{
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-radius:8px;
  padding:1.5rem;
  text-align:center;
  margin-top:1.5rem;
  border:1px solid rgba(201,163,90,0.25);
}
.qr-box img{width:140px;height:140px;margin:0 auto .75rem;display:block}
.qr-box .qr-label{font-size:12px;font-weight:500;color:var(--deep-blue);letter-spacing:.5px;margin-bottom:.3rem}
.qr-box .qr-addr{font-size:11px;color:var(--text-mid);letter-spacing:.3px}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-mid);margin-bottom:.4rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1px solid #e0dbd0;background:#fff;font-family:'Jost',sans-serif;font-size:14px;color:var(--text-dark);outline:none;transition:border-color .2s;border-radius:2px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group textarea{height:130px;resize:none}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.booking-info h3{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;margin-bottom:1.5rem;color:var(--deep-blue)}
.contact-item{display:flex;gap:12px;align-items:flex-start;margin-bottom:1.25rem;font-size:14px}
.contact-icon{width:32px;height:32px;border-radius:50%;background:var(--deep-blue);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;margin-top:2px}
.contact-label{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--gold);margin-bottom:2px}
.contact-value{color:var(--text-dark);font-size:14px}
.note-box{background:#fff;padding:1.25rem 1.5rem;border-left:2px solid var(--gold);margin-top:2rem;font-size:13px;color:var(--text-mid);line-height:1.7}
footer{background:var(--deep-blue);color:rgba(255,255,255,0.5);padding:3rem 2.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:#fff;letter-spacing:3px;text-transform:uppercase}
.footer-links{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}
.footer-links a{color:rgba(255,255,255,0.4);text-decoration:none;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;transition:color .2s}
.footer-links a:hover{color:var(--gold)}
.footer-copy{font-size:11px;letter-spacing:1px;color:rgba(255,255,255,0.25)}
.footer-line{width:48px;height:1px;background:rgba(201,163,90,0.3)}
.social-row{display:flex;gap:1rem}
.social-pill{border:1px solid rgba(201,163,90,0.3);padding:6px 16px;border-radius:20px;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.5);text-decoration:none;transition:all .2s}
.social-pill:hover{border-color:var(--gold);color:var(--gold)}
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ============================================================
   FLOATING SOCIAL BOX – fixed, folgt beim Scrollen
   ============================================================ */
.floating-social{
  position:fixed;
  top:72px;
  right:260px;
  z-index:99;
  --ft-text:rgba(255,255,255,0.9);
  --ft-label:#C9A35A;
  --ft-close:rgba(255,255,255,0.5);
  --ft-divider:rgba(255,255,255,0.15);
  --ft-gbg:rgba(255,255,255,0.12);
  --ft-gborder:rgba(255,255,255,0.2);
  --ft-gtext:#fff;
  --ft-border:rgba(255,255,255,0.15);
  background:rgba(13,27,62,0.55);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid var(--ft-border);
  border-radius:12px;
  padding:1rem 1.1rem 1rem;
  width:190px;
  box-shadow:0 4px 24px rgba(0,0,0,0.25);
  transition:border-color .4s;
}
.floating-close{
  position:absolute;
  top:7px;right:9px;
  background:none;border:none;cursor:pointer;
  color:var(--ft-close);font-size:13px;line-height:1;
  padding:2px 4px;transition:color .2s;
  text-shadow:0 1px 3px rgba(0,0,0,0.2);
}
.floating-close:hover{color:var(--ft-text)}
.floating-label{
  font-size:11px;letter-spacing:1px;text-transform:uppercase;
  color:var(--ft-label);margin-bottom:.75rem;padding-right:1rem;
}
.floating-links{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}
.floating-link{
  display:flex;align-items:center;gap:8px;
  font-size:12px;letter-spacing:.5px;
  color:var(--ft-text);text-decoration:none;
  transition:color .2s;
}
.floating-link:hover{color:var(--ft-label)}
.floating-link svg{width:15px;height:15px;flex-shrink:0}
.floating-divider{height:1px;background:var(--ft-divider);margin-bottom:.75rem}
.floating-google{
  display:flex;align-items:center;gap:7px;
  background:var(--ft-gbg);border:1px solid var(--ft-gborder);
  border-radius:6px;padding:.5rem .75rem;
  font-size:11px;letter-spacing:.5px;color:var(--ft-gtext);
  text-decoration:none;transition:background .2s;
}
.floating-google:hover{background:var(--ft-gbg);filter:brightness(1.2)}

/* alte nav-social-box styles – nicht mehr benötigt */
.nav-social-box{display:none}
.nav-box-divider{display:none}
.nav-google-btn{display:none}

@media(max-width:900px){
  .floating-social{
    top:auto;bottom:1.5rem;right:1rem;
    width:170px;font-size:11px;
  }
}

/* ============================================================
   REVIEWS STRIPE – direkt unter dem Hero (dunkler BG)
   ============================================================ */
.reviews-stripe{
  background:var(--deep-blue);
  padding:2rem 2.5rem 3.5rem;
  border-top:1px solid rgba(201,163,90,0.15);
}
.reviews-stripe .section-label{color:var(--gold)}
.reviews-stripe .section-title{color:#fff}
.reviews-stripe .section-divider{background:rgba(201,163,90,0.5);margin:0 auto 2.5rem}
.reviews-stripe-header{text-align:center;margin-bottom:2.5rem}
.reviews-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem;max-width:1200px;margin:0 auto}
.review-card{
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(201,163,90,0.18);
  border-radius:8px;padding:1.5rem;
  border-top:2px solid var(--gold);
}
.review-stars{display:flex;gap:3px;margin-bottom:.65rem}
.review-stars span{color:var(--gold);font-size:14px}
.review-text{font-size:13px;line-height:1.7;color:rgba(255,255,255,0.65);margin-bottom:.9rem;font-style:italic}
.review-author{font-size:12px;font-weight:500;color:#fff;letter-spacing:.5px}
.review-date{font-size:11px;color:rgba(255,255,255,0.3);margin-top:2px}
.review-google-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-top:.65rem}
.review-google-badge svg{width:12px;height:12px}
.reviews-cta{text-align:center;margin-top:2rem}
.reviews-cta a{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(201,163,90,0.4);color:var(--gold);padding:11px 26px;border-radius:4px;font-size:11px;letter-spacing:2px;text-transform:uppercase;text-decoration:none;transition:background .2s,border-color .2s}
.reviews-cta a:hover{background:rgba(201,163,90,0.1);border-color:var(--gold)}
.reviews-placeholder-note{text-align:center;font-size:11px;color:rgba(255,255,255,0.2);margin-top:.9rem;letter-spacing:.5px}

/* hide old bubble styles if any remain */
.hero-bubble{display:none!important}

@media(max-width:900px){
  .nav-social-box{display:none}
  .reviews-stripe{padding:3rem 1.5rem}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .reviews-stripe{padding:2.5rem 1.25rem}
  .reviews-grid{grid-template-columns:1fr}
}


/* ============================================================
   RESPONSIVE – Handy & Tablet
   ------------------------------------------------------------
   Diese Regeln passen die Seite automatisch an kleinere
   Bildschirme an. Nichts hier muss normalerweise geändert
   werden. Tablet = bis 900px, Handy = bis 600px.
   ============================================================ */

/* ---- TABLET (bis 900px Breite) ---- */
@media (max-width: 900px) {
  nav { padding: 0 1.25rem; height: auto; min-height: 60px; flex-wrap: wrap; gap: .5rem; }
  .nav-links { gap: 1rem; flex-wrap: wrap; justify-content: center; padding: .5rem 0; }
  .nav-links a { font-size: 11px; letter-spacing: 1px; }
  .nav-social { gap: 16px; }
  .nav-divider { display: none; }

  section { padding: 4rem 1.5rem; }

  .booking-layout { grid-template-columns: 1fr; gap: 2rem; }
  .booking-map { min-height: 300px; }
  .capsule-row { gap: 1rem; }
  .capsule { width: 160px; height: 320px; }
}

/* ---- HANDY (bis 600px Breite) ---- */
@media (max-width: 600px) {
  body { font-size: 16px; }

  nav { padding: .5rem 1rem; }
  .nav-logo { font-size: 17px; }
  .nav-links { gap: .75rem 1rem; }
  .nav-links a { font-size: 12px; }

  .hero { height: auto; min-height: 0; padding: 4rem 0; }
  .hero-content { padding: 0 1.25rem; }
  .hero-logo { width: 105px; }
  .hero-photo-bg { background-size: cover; opacity: 0.42; }
  .hero h1 { font-size: 44px; }
  .hero-ctas { flex-direction: column; }
  .hero-ctas .btn-primary,
  .hero-ctas .btn-outline { width: 100%; }
  .hero-scroll { display: none; }

  section { padding: 3.5rem 1.25rem; }

  .capsule-row { flex-wrap: nowrap; overflow-x: auto; justify-content: flex-start; padding: 1rem .25rem 1.5rem; -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory; }
  .capsule { flex: 0 0 auto; width: 165px; height: 330px; scroll-snap-align: center; }
  .capsule:hover { transform: none; }
  .capsule .capsule-overlay { opacity: 1; background: linear-gradient(to top,rgba(13,27,62,0.92) 0%,rgba(13,27,62,0.45) 60%,transparent 100%); }
  .capsule .capsule-title-static { opacity: 0; }
  .capsule-desc { font-size: 11px; }

  .gallery-nav { width: 38px; height: 38px; font-size: 20px; }

  .booking-form { padding: 1.5rem; }
  .form-row { grid-template-columns: 1fr; gap: 0; }

  .footer-links { gap: 1rem; }

  .aktion-badge { font-size: 26px; padding: 10px 22px; }
}

/* ===== Buchungs-Hinweis Sprechblase ===== */
.booking-notice{
  position:relative;
  max-width:560px;
  margin:0 auto 2rem;
  background:linear-gradient(135deg,#13234d,#0D1B3E);
  border:1px solid rgba(201,163,90,0.45);
  border-radius:14px;
  padding:18px 44px 18px 22px;
  box-shadow:0 10px 30px rgba(0,0,0,0.25);
  animation:noticePop .5s cubic-bezier(.34,1.56,.64,1) both;
  transition:opacity .4s ease, transform .4s ease;
}
.booking-notice::after{
  content:"";
  position:absolute;
  bottom:-11px;
  left:50%;
  transform:translateX(-50%) rotate(45deg);
  width:20px;height:20px;
  background:#0D1B3E;
  border-right:1px solid rgba(201,163,90,0.45);
  border-bottom:1px solid rgba(201,163,90,0.45);
}
.booking-notice.hide{opacity:0;transform:translateY(-8px);pointer-events:none}
.booking-notice-text{
  margin:0;
  font-size:13.5px;
  line-height:1.7;
  color:#f3ede2;
  text-align:center;
}
.booking-notice-text strong{color:var(--gold-light);font-weight:600}
.booking-notice-text a{color:var(--gold-light);text-decoration:none;font-weight:600;white-space:nowrap}
.booking-notice-text a:hover{text-decoration:underline}
.booking-notice-close{
  position:absolute;
  top:8px;right:12px;
  background:none;border:none;
  color:rgba(255,255,255,0.55);
  font-size:22px;line-height:1;
  cursor:pointer;
  padding:2px 6px;
  transition:color .2s;
}
.booking-notice-close:hover{color:var(--gold-light)}
@keyframes noticePop{
  0%{opacity:0;transform:scale(.85) translateY(10px)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}

/* ===== Nach-oben-Button ===== */
#scrollTopBtn{
  position:fixed;
  right:24px;bottom:24px;
  width:48px;height:48px;
  border:none;border-radius:50%;
  background:var(--gold);
  color:var(--deep-blue);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(13,27,62,0.3);
  transition:background .2s, transform .2s, opacity .3s, visibility .3s;
  opacity:0;visibility:hidden;
  z-index:9999;
}
#scrollTopBtn svg{width:22px;height:22px}
#scrollTopBtn:hover{background:var(--gold-light);transform:translateY(-3px)}
#scrollTopBtn.show{opacity:1;visibility:visible}

/* ===== Musik-Player in der Social-Box ===== */
.floating-music{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:10px;
  padding:8px 12px;
  background:rgba(13,27,62,0.45);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:8px;
}
.music-toggle{
  flex-shrink:0;
  width:32px;height:32px;
  border:1px solid rgba(255,255,255,0.35);
  border-radius:50%;
  background:rgba(255,255,255,0.15);
  color:#fff;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s, transform .15s, border-color .2s;
}
.music-toggle:hover{background:rgba(255,255,255,0.28);border-color:rgba(255,255,255,0.6);transform:scale(1.08)}
.music-toggle svg{width:16px;height:16px}

/* Play/Stop Icon-Wechsel */
.music-toggle .icon-pause{display:none}
.music-toggle.playing .icon-play{display:none}
.music-toggle.playing .icon-pause{display:block}

/* Lautstärke-Regler (kürzer, guter Kontrast) */
.music-volume{
  -webkit-appearance:none;appearance:none;
  width:90px;
  height:4px;
  border-radius:2px;
  background:rgba(255,255,255,0.3);
  outline:none;
  cursor:pointer;
}
.music-volume::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:13px;height:13px;border-radius:50%;
  background:#fff;cursor:pointer;
  box-shadow:0 1px 3px rgba(0,0,0,0.3);
}
.music-volume::-moz-range-thumb{
  width:13px;height:13px;border-radius:50%;border:none;
  background:#fff;cursor:pointer;
  box-shadow:0 1px 3px rgba(0,0,0,0.3);
}

@media(max-width:600px){
  #scrollTopBtn{right:16px;bottom:16px;width:44px;height:44px}
}
