/* Bereinigte style.css – ersetzt die doppelte Detailseiten-/Header-Logik */
:root {
  --bg: #f8fafb;
  --white: #ffffff;
  --primary: #0f2a44;
  --accent: #2e6f95;
  --accent-soft: #e9f1f5;
  --text: #18202a;
  --muted: #667085;
  --line: #e5e7eb;
  --shadow: 0 14px 35px rgba(15, 42, 68, 0.08);
  --shadow-hover: 0 18px 45px rgba(15, 42, 68, 0.12);
  --container: 1240px;
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{background:linear-gradient(180deg,#f7fafc 0%,#eef4f7 100%);color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.6}
a{color:var(--primary);text-decoration:none} a:hover{color:var(--accent)} img{max-width:100%;display:block}
.site-main{padding:38px 0 80px}
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(229,231,235,.9)}
.site-header__inner,.site-footer__inner,.container,.hero,.breadcrumbs,.detail-composer-hero,.detail-composer-layout{width:min(var(--container),calc(100% - 32px));margin:0 auto}
.site-header__inner{display:flex;justify-content:space-between;align-items:center;gap:24px;min-height:88px}
.logo{display:inline-flex;align-items:center;gap:14px;color:var(--primary);font-weight:800;letter-spacing:-.02em;text-decoration:none}
.logo__mark{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--primary));color:#fff;box-shadow:var(--shadow)}
.logo__text{font-size:17px}
.main-nav{display:flex;flex-wrap:wrap;gap:22px}
.main-nav a{color:#607086;font-weight:600;font-size:15px}
.main-nav a:hover{color:var(--primary)}
.breadcrumbs{margin-bottom:18px;color:var(--muted);font-size:14px}
.breadcrumbs a{color:var(--muted)}
.hero{background:radial-gradient(circle at top right,rgba(46,111,149,.15),transparent 28%),linear-gradient(135deg,#ffffff 0%,#eef5f8 100%);border:1px solid rgba(229,231,235,.9);border-radius:28px;box-shadow:var(--shadow);padding:56px;margin-bottom:28px}
.hero__kicker{display:inline-flex;min-height:34px;padding:0 14px;border-radius:999px;background:#eef5fb;color:var(--accent);font-size:13px;font-weight:700;margin-bottom:18px;align-items:center}
.hero h1,h1{margin:0 0 14px;color:var(--primary);font-size:clamp(38px,5vw,62px);line-height:1.02;letter-spacing:-.04em;font-weight:800}
.hero p{max-width:760px;font-size:19px;color:var(--muted);margin:0}
.container{display:grid;gap:28px}
.section,.box{background:rgba(255,255,255,.92);border:1px solid rgba(229,231,235,.95);border-radius:26px;box-shadow:var(--shadow);padding:28px}
.section__head{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:20px}
.section__head h2,.box h2{margin:0 0 8px;color:var(--primary);font-size:28px;line-height:1.15}
.section__head p,.box p,.notice{margin:0;color:var(--muted)}
.filter-bar{display:grid;grid-template-columns:2fr 1.5fr 1fr auto;gap:14px}
.filter-bar select,.filter-bar input{width:100%;min-height:52px;padding:0 16px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--text);font:inherit}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--white);border-radius:22px;overflow:hidden;border:1px solid rgba(229,231,235,.95);box-shadow:var(--shadow);transition:transform .22s ease,box-shadow .22s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.card__image-link{display:block;background:linear-gradient(135deg,#dbe8ef 0%,#eff5f8 100%)}
.card__image,.card__image--empty{width:100%;height:230px;object-fit:cover}
.card__image--empty{background:linear-gradient(135deg,#dbe8ef 0%,#eff5f8 100%)}
.card__body{padding:20px}
.card__eyebrow{margin:0 0 10px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:800;color:var(--accent)}
.card__title{margin:0 0 10px;font-size:20px;line-height:1.25}
.card__title a{color:var(--primary)}
.card__meta{margin-bottom:18px;color:var(--muted);font-size:14px}
.card__footer{display:flex;justify-content:space-between;align-items:end;gap:14px}
.card__price strong{font-size:28px;line-height:1;color:var(--primary)}
.card__actions{display:flex;gap:10px}
.button,.btn-primary{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 18px;border-radius:12px;border:1px solid var(--primary);background:var(--primary);color:#fff;font-weight:700;font-size:15px;cursor:pointer}
.button:hover,.btn-primary:hover{background:#163a5e;border-color:#163a5e;color:#fff}
.button--ghost{background:#fff;color:var(--primary);border-color:var(--line)}
.button--ghost:hover{background:#f8fbfd;color:var(--primary)}
.notice{padding:18px 20px;border-radius:14px;background:#f8fbfd;border:1px dashed #c9d7e2}
.site-footer{margin-top:40px;border-top:1px solid rgba(229,231,235,.95);background:rgba(255,255,255,.85)}
.site-footer__inner{padding:28px 0 34px;color:var(--muted);font-size:14px}
.site-footer__small{margin-top:4px}
.hero--home{margin-top:8px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.hero-claim{font-size:18px;color:#64748b;max-width:600px;margin-top:10px}
.trust-box{background:#f8fafc;padding:30px;border-radius:16px;margin:40px 0}
.section--soft{background:linear-gradient(135deg,rgba(255,255,255,.96) 0%,rgba(241,245,248,.96) 100%)}
.premium-places{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}
.premium-place{display:block;padding:18px;border-radius:18px;background:#fff;border:1px solid rgba(229,231,235,.95);box-shadow:var(--shadow);transition:.2s ease}
.premium-place:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.premium-place__name{display:block;color:var(--primary);font-weight:700;font-size:18px;line-height:1.2}
.premium-place__count{display:block;margin-top:8px;color:var(--muted);font-size:14px}
.grid--featured{grid-template-columns:repeat(3,minmax(0,1fr))}
.section--editorial{background:radial-gradient(circle at top left,rgba(46,111,149,.10),transparent 24%),linear-gradient(135deg,rgba(255,255,255,.96) 0%,rgba(241,245,248,.96) 100%)}
.editorial-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.editorial-box{display:block;padding:26px;border-radius:22px;background:#fff;border:1px solid rgba(229,231,235,.95);box-shadow:var(--shadow);transition:.2s ease}
.editorial-box:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.editorial-box__kicker{display:inline-flex;min-height:30px;align-items:center;padding:0 12px;border-radius:999px;background:#eef5fb;color:var(--accent);font-size:12px;font-weight:700;margin-bottom:14px;text-transform:uppercase;letter-spacing:.08em}
.editorial-box h3{margin:0 0 10px;color:var(--primary);font-size:28px;line-height:1.1;letter-spacing:-.03em}
.editorial-box p{margin:0;color:var(--muted)}
.top-orte{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.top-orte a{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 16px;border-radius:12px;background:#fff;border:1px solid var(--line);color:var(--primary);font-weight:600;transition:.18s ease}
.top-orte a:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.detail-composer-hero{position:relative;border-radius:32px;overflow:hidden;background:#dbe8ef;box-shadow:var(--shadow-hover);margin-bottom:30px}
.detail-composer-hero__image img,.detail-composer-hero__placeholder{width:100%;height:620px;object-fit:cover;display:block}
.detail-composer-hero__placeholder{background:linear-gradient(135deg,#dbe8ef 0%,#eef5f8 100%)}
.detail-composer-hero__overlay{position:absolute;inset:0;display:grid;grid-template-columns:minmax(0,1.4fr) 360px;gap:24px;align-items:end;padding:38px;background:linear-gradient(180deg,rgba(15,42,68,.10) 0%,rgba(15,42,68,.82) 100%)}
.detail-composer-hero__content{max-width:820px}
.detail-composer-hero__kicker{display:inline-flex;align-items:center;min-height:34px;padding:0 14px;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.26);color:#fff;font-size:13px;font-weight:700;margin-bottom:18px;backdrop-filter:blur(8px)}
.detail-composer-hero h1{margin:0 0 14px;color:#fff;font-size:clamp(38px,5vw,64px);line-height:.98;letter-spacing:-.045em;font-weight:800}
.detail-composer-hero__lead{margin:0;color:rgba(255,255,255,.90);font-size:18px;max-width:720px}
.detail-composer-hero__badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.detail-badge{display:inline-flex;align-items:center;min-height:38px;padding:0 14px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:14px;font-weight:600;backdrop-filter:blur(8px)}
.detail-composer-hero__booking{display:flex;justify-content:end;align-self:end}
.detail-booking-card{width:100%;max-width:340px;padding:24px;border-radius:24px;background:rgba(255,255,255,.95);box-shadow:0 20px 50px rgba(15,42,68,.16)}
.detail-booking-card__label{color:var(--muted);font-size:14px;margin-bottom:10px}
.detail-booking-card__price{color:var(--primary);font-size:42px;line-height:1;font-weight:800;letter-spacing:-.04em;margin-bottom:10px}
.detail-booking-card__unit{margin:0 0 18px;color:var(--muted)}
.detail-booking-card__button{width:100%}
.detail-composer-layout{display:grid;grid-template-columns:minmax(0,1.5fr) 340px;gap:28px;align-items:start}
.detail-composer-main,.detail-composer-sidebar{display:grid;gap:24px}
.detail-side-block h2,.detail-block h2{margin-top:0}
@media (max-width:1100px){
  .detail-composer-hero__overlay,.detail-composer-layout{grid-template-columns:1fr}
  .detail-composer-hero__booking{justify-content:start}
}
@media (max-width:980px){
  .grid--featured,.editorial-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:880px){
  .hero{padding:34px 24px}
  .filter-bar{grid-template-columns:1fr}
  .main-nav{gap:14px}
  .card__footer{flex-direction:column;align-items:start}
  .card__actions{width:100%}
  .card__actions .button{flex:1}
}
@media (max-width:780px){
  .detail-composer-hero__image img,.detail-composer-hero__placeholder{height:500px}
  .detail-composer-hero__overlay{padding:24px}
}
@media (max-width:700px){
  .grid--featured,.editorial-grid,.grid{grid-template-columns:1fr}
}
/* ===== HEADER PREMIUM ===== */

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(229,231,235,0.7);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  min-height: 82px;
}

/* LOGO */
.logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}

.logo__mark {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: linear-gradient(135deg, #2e6f95, #0f2a44);
  color: #fff;
  font-weight: 800;
  display: grid;
  place-items: center;
  font-size: 18px;
}

.logo__text {
  font-weight: 800;
  color: var(--primary);
  line-height: 1.05;
}

.logo__text small {
  display: block;
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.08em;
}

/* NAV */
.main-nav {
  display: flex;
  gap: 26px;
}

.main-nav a {
  position: relative;
  color: #5b6b7c;
  font-weight: 600;
  font-size: 15px;
  transition: 0.2s ease;
}

.main-nav a:hover {
  color: var(--primary);
}

/* feine underline animation */
.main-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 0;
  height: 2px;
  background: var(--primary);
  transition: 0.2s ease;
}

.main-nav a:hover::after {
  width: 100%;
}

/* CTA */
.header-cta {
  padding: 12px 20px;
  border-radius: 14px;
  font-size: 14px;
  box-shadow: 0 10px 25px rgba(15,42,68,0.15);
}

/* RESPONSIVE */
@media (max-width: 900px) {
  .main-nav {
    display: none;
  }
}
.filter-bar--search {
  grid-template-columns: 2fr 1.4fr 1.2fr 1fr 1fr auto;
}

@media (max-width: 1100px) {
  .filter-bar--search {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 700px) {
  .filter-bar--search {
    grid-template-columns: 1fr;
  }
}
/* Premium Suchleiste */
.search-premium {
  padding: 8px;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(241,245,248,0.98) 100%);
  border: 1px solid rgba(229,231,235,0.95);
  box-shadow: var(--shadow);
}

.search-premium__grid {
  display: grid;
  grid-template-columns: 2fr 1.2fr 1.1fr 0.9fr 0.9fr auto;
  gap: 12px;
  align-items: end;
}

.search-premium__field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 12px 10px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(229,231,235,0.95);
}

.search-premium__field label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--muted);
}

.search-premium__field input,
.search-premium__field select {
  width: 100%;
  min-height: 44px;
  border: 0;
  outline: none;
  background: transparent;
  color: var(--text);
  font: inherit;
  padding: 0;
}

.search-premium__field input::placeholder {
  color: #94a3b8;
}

.search-premium__field:focus-within {
  border-color: rgba(46,111,149,0.35);
  box-shadow: 0 0 0 4px rgba(46,111,149,0.08);
}

.search-premium__action {
  display: flex;
  align-items: stretch;
}

.search-premium__button {
  min-height: 72px;
  padding: 0 24px;
  border-radius: 18px;
  white-space: nowrap;
  box-shadow: 0 12px 28px rgba(15,42,68,0.18);
}

@media (max-width: 1200px) {
  .search-premium__grid {
    grid-template-columns: 1.6fr 1fr 1fr 0.8fr 0.8fr auto;
  }
}

@media (max-width: 980px) {
  .search-premium__grid {
    grid-template-columns: 1fr 1fr;
  }

  .search-premium__button {
    min-height: 56px;
    width: 100%;
  }
}

@media (max-width: 640px) {
  .search-premium__grid {
    grid-template-columns: 1fr;
  }
}
.cookie-banner {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  max-width: 600px;
  background: #fff;
  padding: 20px;
  border-radius: 16px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.15);
  display: none;
  z-index: 9999;
}

.cookie-inner {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.cookie-buttons {
  display: flex;
  gap: 10px;
}

.btn-ghost {
  background: #eee;
  padding: 10px 15px;
  border-radius: 10px;
}
.footer-links {
  display: flex;
  gap: 20px;
  margin-top: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

.footer-links a {
  color: #6b7280;
  font-size: 14px;
  text-decoration: none;
}

.footer-links a:hover {
  color: var(--primary);
}
/* ===== BOUTIQUE HEADER + HOME HERO (mit Bild) ===== */
.site-header--boutique{
  position:sticky;
  top:0;
  z-index:120;
  background:rgba(248,250,251,.86);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(214,223,230,.82);
  box-shadow:0 12px 32px rgba(15,42,68,.06);
}
.logo--boutique{gap:14px}
.logo__mark--boutique{
  position:relative;
  width:54px;
  height:54px;
  border-radius:18px;
  background:linear-gradient(160deg,#2f88a4 0%,#123452 100%);
  box-shadow:0 14px 30px rgba(18,52,82,.22);
  overflow:hidden;
}
.logo__mark--boutique strong{
  position:relative;
  z-index:2;
  font-size:20px;
  font-weight:800;
  letter-spacing:-.03em;
}
.logo__mark-ring{
  position:absolute;
  inset:8px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.16);
}
.logo__mark-waves,
.logo__mark-waves::before,
.logo__mark-waves::after{
  content:"";
  position:absolute;
  left:8px;
  right:8px;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
}
.logo__mark-waves{bottom:10px}
.logo__mark-waves::before{bottom:10px}
.logo__mark-waves::after{bottom:20px}
.logo__text--boutique{font-size:17px;line-height:1.02;color:var(--primary)}
.logo__text--boutique small{
  display:block;
  margin-top:3px;
  font-size:11px;
  letter-spacing:.14em;
  color:#6c7a8b;
}
.main-nav--boutique a{
  color:#526377;
  font-weight:650;
}
.main-nav--boutique a:hover{color:var(--primary)}
.header-cta--boutique{
  min-height:50px;
  padding:0 24px;
  border-radius:999px;
  background:linear-gradient(180deg,#12395b 0%,#102f4a 100%);
  border-color:#102f4a;
  box-shadow:0 12px 26px rgba(16,47,74,.16);
}
.header-cta--boutique:hover{
  background:linear-gradient(180deg,#16456d 0%,#12395b 100%);
  border-color:#12395b;
}

.home-hero-boutique{
  width:min(var(--container),calc(100% - 32px));
  min-height:620px;
  margin:22px auto 30px;
  border-radius:32px;
  overflow:hidden;
  position:relative;
  background-color:#d9e4ea;
  background-position:center center;
  background-size:cover;
  background-repeat:no-repeat;
  box-shadow:0 28px 60px rgba(12,35,56,.18);
}
.home-hero-boutique::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:180px;
  background:linear-gradient(180deg,rgba(7,23,31,0) 0%, rgba(7,23,31,.28) 100%);
  pointer-events:none;
}
.home-hero-boutique__content{
  position:relative;
  z-index:1;
  max-width:660px;
  padding:56px 52px 42px;
  color:#fff;
}
.home-hero-boutique__eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:0 16px;
  margin-bottom:18px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.32);
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:800;
  backdrop-filter:blur(8px);
}
.home-hero-boutique h1{
  margin:0;
  max-width:10.2ch;
  font-size:clamp(38px,5.2vw,72px);
  line-height:.94;
  letter-spacing:-.045em;
  color:#fff;
  text-shadow:0 2px 14px rgba(0,0,0,.16);
  text-wrap:balance;
}
.home-hero-boutique p{
  margin:20px 0 0;
  max-width:54ch;
  color:rgba(255,255,255,.92);
  font-size:clamp(17px,1.6vw,19px);
  line-height:1.68;
}
.home-hero-boutique__actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:28px;
}
.home-hero-boutique .button{
  min-height:52px;
  padding:0 22px;
  border-radius:999px;
  border-color:#0f6c82;
  background:#0f6c82;
  box-shadow:0 12px 26px rgba(15,108,130,.22);
}
.home-hero-boutique .button:hover{background:#0d596c;border-color:#0d596c}
.button--ghost-light{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 22px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  color:#fff;
  border:1px solid rgba(255,255,255,.36);
  backdrop-filter:blur(8px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12);
}
.button--ghost-light:hover{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.42)}
.home-hero-boutique__facts{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin-top:32px;
}
.home-hero-fact{
  padding:18px 18px 16px;
  border-radius:20px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.24);
  backdrop-filter:blur(10px);
  box-shadow:0 18px 40px rgba(8,24,29,.10);
}
.home-hero-fact strong{
  display:block;
  margin-bottom:8px;
  font-size:18px;
  line-height:1.15;
  color:#fff;
}
.home-hero-fact span{
  display:block;
  color:rgba(255,255,255,.88);
  font-size:15px;
  line-height:1.55;
}

@media (max-width: 1100px){
  .home-hero-boutique{min-height:590px}
  .home-hero-boutique__content{max-width:620px;padding:48px 36px 34px}
  .home-hero-boutique__facts{grid-template-columns:1fr 1fr}
}
@media (max-width: 900px){
  .site-header--boutique .main-nav{display:none}
  .home-hero-boutique{min-height:560px}
  .home-hero-boutique h1{font-size:clamp(36px,7vw,58px);max-width:100%}
}
@media (max-width: 700px){
  .home-hero-boutique{width:min(var(--container),calc(100% - 20px));min-height:520px;margin:16px auto 24px;border-radius:24px}
  .home-hero-boutique__content{padding:28px 22px 22px}
  .home-hero-boutique h1{font-size:clamp(34px,11vw,52px);line-height:.98}
  .home-hero-boutique p{font-size:17px}
  .home-hero-boutique__facts{grid-template-columns:1fr}
  .home-hero-fact{padding:16px}
}
.hero--home h1,
.hero h1,
.hero-premium__title {
  max-width: 820px;
  font-size: clamp(38px, 5.2vw, 72px);
  line-height: 0.96;
  letter-spacing: -0.04em;
  text-wrap: balance;
}

@media (max-width: 700px) {
  .hero--home h1,
  .hero h1,
  .hero-premium__title {
    max-width: 100%;
    font-size: clamp(34px, 11vw, 52px);
    line-height: 0.98;
  }
}
.hero--home {
  position: relative;
  background:
    linear-gradient(90deg, rgba(9,26,43,.62) 0%, rgba(9,26,43,.34) 42%, rgba(9,26,43,.12) 100%),
    url('/assets/images/ostsee-strand.jpg') center center / cover no-repeat;
  border-radius: 28px;
  overflow: hidden;
}

.hero--home h1 {
  max-width: 820px;
  font-size: clamp(38px, 5.2vw, 72px);
  line-height: .96;
  letter-spacing: -.04em;
  color: #fff;
}

.hero--home p {
  color: rgba(255,255,255,.94);
  max-width: 760px;
}

/* Text in heller Box innerhalb des Bild-Heros wieder dunkel */
.hero .trust-box,
.hero .trust-box h2,
.hero .trust-box p,
.hero .trust-box strong,
.hero .trust-box a {
  color: var(--primary);
  text-shadow: none;
}

.hero .trust-box p {
  color: var(--muted);
}

.hero .trust-box {
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(229,231,235,.95);
  box-shadow: 0 18px 40px rgba(15,42,68,.12);
}
.trust-box{
  background:rgba(255,255,255,.92);
  padding:30px;
  border-radius:16px;
  margin:40px 0 0;
  border:1px solid rgba(229,231,235,.95);
  box-shadow:0 18px 40px rgba(15,42,68,.12);
}

.trust-box h2{
  color:var(--primary);
}

.trust-box p{
  color:var(--muted);
}

.logo {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}

.logo__icon {
  height: 48px;
  width: 48px;
  border-radius: 50%;
}

.logo__text {
  font-weight: 700;
  font-size: 18px;
  line-height: 1.1;
  color: var(--primary);
}

.logo__text small {
  display: block;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--muted);
}

.logo__image {
  height: 72px;
  width: auto;
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
}
.main-nav {
  display: flex;
  gap: 28px;
  align-items: center;
}
.region-editorial{
  width:min(980px, calc(100% - 32px));
  margin:36px auto 0;
  display:grid;
  gap:24px;
}

.region-editorial__intro,
.region-editorial__card,
.region-faq-luxury{
  background:linear-gradient(135deg, rgba(255,255,255,.96) 0%, rgba(243,247,250,.96) 100%);
  border:1px solid rgba(229,231,235,.95);
  border-radius:28px;
  box-shadow:0 16px 42px rgba(15,42,68,.08);
  padding:34px;
}

.region-editorial__eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:#eef5fb;
  color:#2e6f95;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:16px;
}

.region-editorial__intro h2,
.region-faq-luxury__head h2{
  margin:0 0 14px;
  color:var(--primary);
  font-size:clamp(30px,4vw,46px);
  line-height:1.04;
  letter-spacing:-.035em;
}

.region-editorial__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

.region-editorial__card h3{
  margin:0 0 14px;
  color:var(--primary);
  font-size:30px;
  line-height:1.08;
  letter-spacing:-.03em;
}

.region-editorial p,
.region-editorial__card p,
.region-faq-luxury__item p{
  margin:0 0 16px;
  color:#59697c;
  font-size:18px;
  line-height:1.8;
}

.region-editorial p:last-child,
.region-editorial__card p:last-child,
.region-faq-luxury__item p:last-child{
  margin-bottom:0;
}

.region-faq-luxury__items{
  display:grid;
  gap:14px;
  margin-top:18px;
}

.region-faq-luxury__item{
  padding:22px 24px;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(229,231,235,.9);
}

.region-faq-luxury__item h3{
  margin:0 0 10px;
  color:var(--primary);
  font-size:22px;
  line-height:1.2;
}

@media (max-width: 820px){
  .region-editorial__grid{
    grid-template-columns:1fr;
  }

  .region-editorial__intro,
  .region-editorial__card,
  .region-faq-luxury{
    padding:24px;
    border-radius:22px;
  }

  .region-editorial__card h3{
    font-size:26px;
  }

  .region-editorial p,
  .region-editorial__card p,
  .region-faq-luxury__item p{
    font-size:17px;
    line-height:1.72;
  }
}
@media (max-width: 900px) {
  .site-header {
    position: sticky;
    top: 0;
    z-index: 120;
  }

  .site-header__inner {
    min-height: 72px;
    padding: 0 14px;
    gap: 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .logo {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
  }

  .logo__image {
    height: 42px;
    width: auto;
    display: block;
  }

  .main-nav {
    display: none !important;
  }

  .header-cta,
  .btn-primary.header-cta {
    min-height: 42px;
    padding: 0 14px;
    font-size: 13px;
    border-radius: 12px;
    white-space: nowrap;
    box-shadow: none;
  }
}

@media (max-width: 520px) {
  .site-header__inner {
    min-height: 66px;
    padding: 0 12px;
  }

  .logo__image {
    height: 36px;
  }

  .header-cta,
  .btn-primary.header-cta {
    min-height: 38px;
    padding: 0 12px;
    font-size: 12px;
    border-radius: 10px;
  }
}\n\n

/* ===== MOBILE HEADER FIX ===== */
@media (max-width: 900px) {
  .site-header {
    position: sticky;
    top: 0;
    z-index: 140;
    background: rgba(255,255,255,0.94);
    backdrop-filter: blur(14px);
  }

  .site-header__inner {
    width: min(var(--container), calc(100% - 20px));
    min-height: 72px;
    padding: 0;
    gap: 12px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
  }

  .logo {
    gap: 8px;
    min-width: 0;
  }

  .logo__image {
    height: 42px;
    width: auto;
    display: block;
  }

  .logo__text,
  .logo__mark,
  .logo__icon {
    display: none;
  }

  .main-nav {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 14px;
    min-width: 0;
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    white-space: nowrap;
  }

  .main-nav::-webkit-scrollbar {
    display: none;
  }

  .main-nav a {
    font-size: 13px;
    font-weight: 700;
    color: #607086;
    flex: 0 0 auto;
    padding: 0 2px;
  }

  .main-nav a::after {
    display: none;
  }

  .header-cta,
  .btn-primary.header-cta {
    min-height: 40px;
    padding: 0 12px;
    border-radius: 12px;
    font-size: 12px;
    box-shadow: none;
    white-space: nowrap;
  }
}

@media (max-width: 640px) {
  .site-header__inner {
    width: calc(100% - 16px);
    min-height: 64px;
    gap: 10px;
    grid-template-columns: auto 1fr auto;
  }

  .logo__image {
    height: 34px;
  }

  .main-nav {
    gap: 10px;
    justify-content: flex-start;
  }

  .main-nav a {
    font-size: 12px;
  }

  .header-cta,
  .btn-primary.header-cta {
    min-height: 36px;
    padding: 0 10px;
    font-size: 11px;
    border-radius: 10px;
  }
}

@media (max-width: 420px) {
  .logo__image {
    height: 30px;
  }

  .main-nav a {
    font-size: 11px;
  }

  .header-cta,
  .btn-primary.header-cta {
    padding: 0 8px;
    min-height: 34px;
    font-size: 10px;
  }
}
/* ===== MOBILE MENU HEADER PATCH ===== */

/* Desktop: Burger ausblenden */
.mobile-menu {
  display: none;
}

.mobile-menu__toggle {
  list-style: none;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(15,42,68,.12);
  background: rgba(255,255,255,.92);
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(15,42,68,.08);
}

.mobile-menu__toggle::-webkit-details-marker {
  display: none;
}

.mobile-menu__toggle span {
  display: block;
  width: 18px;
  height: 2px;
  background: var(--primary);
  border-radius: 999px;
  margin: 2px 0;
}

.mobile-menu__panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: min(280px, calc(100vw - 24px));
  padding: 14px;
  border-radius: 20px;
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(229,231,235,.95);
  box-shadow: 0 22px 46px rgba(15,42,68,.14);
  display: grid;
  gap: 8px;
}

.mobile-menu__panel a {
  display: flex;
  align-items: center;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 12px;
  color: var(--primary);
  font-weight: 700;
  background: #fff;
  border: 1px solid rgba(229,231,235,.9);
}

.mobile-menu__panel a:hover {
  background: #f8fbfd;
}

.mobile-menu__cta {
  background: var(--primary) !important;
  color: #fff !important;
  border-color: var(--primary) !important;
  justify-content: center;
}

@media (max-width: 900px) {
  .main-nav,
  .header-cta {
    display: none !important;
  }

  .mobile-menu {
    display: block;
    position: relative;
  }

  .site-header__inner {
    width: min(var(--container), calc(100% - 20px));
    min-height: 72px;
    gap: 12px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
  }

  .logo {
    min-width: 0;
  }

  .logo__image {
    height: 42px;
    width: auto;
    display: block;
  }
}

@media (max-width: 640px) {
  .site-header__inner {
    width: calc(100% - 16px);
    min-height: 64px;
  }

  .logo__image {
    height: 34px;
  }

  .mobile-menu__toggle {
    width: 40px;
    height: 40px;
    border-radius: 12px;
  }

  .mobile-menu__panel {
    width: min(260px, calc(100vw - 20px));
    right: -2px;
  }
}
