/* ============================================================
   HAUS MARIA — Modernes Design
   Mediterran: Terrakotta · Ägäisches Blau · Warmes Sand
   Playfair Display + Lato
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,800;1,400&family=Lato:wght@300;400;700;900&display=swap');

:root {
  --sand:       #f5f0e8;
  --cream:      #fdfaf4;
  --terra:      #c2694f;   /* dekorativ: Rahmen, große Flächen */
  --terra-ink:  #7a3a2a;   /* Terracotta-TEXT auf hellem Grund (AAA ≥7:1) */
  --terra-deep: #8a4230;   /* Button-/Label-Hintergrund mit weißem Text (AAA) */
  --terra-dk:   #6e3322;   /* Button-Hover */
  --aegean:     #1b3d5c;
  --aegean-mid: #2a5a80;
  --gold:       #d4a847;       /* dekorativ */
  --gold-on-dark:#f2d27e;      /* Gold-TEXT auf dunklem Grund (AAA) */
  --olive:      #4f6029;       /* Erfolg / Häkchen-Text (AAA auf hell) */
  --text:       #2c2419;
  --text-lt:    #574a3d;       /* dunkler für AAA (≈8:1) */
  --white:      #ffffff;
  --btn-fg:     #ffffff;       /* Textfarbe auf Primär-Button */
  --border:     rgba(27,61,92,.14);
  --shadow-sm:  0 2px 12px rgba(27,61,92,.08);
  --shadow:     0 4px 32px rgba(27,61,92,.12);
  --shadow-lg:  0 12px 48px rgba(27,61,92,.18);
  --radius:     8px;
  --tr:         .3s ease;
}

/* ── DARK MODE ── */
[data-theme="dark"] {
  --sand:       #16222e;
  --cream:      #12202e;
  --terra:      #e07d62;
  --terra-ink:  #f0a48d;   /* Terracotta-TEXT auf dunkel (AAA) */
  --terra-deep: #6e3322;   /* tiefes Terracotta: Button-BG mit weißem Text (AAA) */
  --terra-dk:   #843d28;   /* Button-Hover */
  --aegean:     #a8c4e0;   /* helle Überschriften */
  --aegean-mid: #7aadd4;
  --gold:       #e8c05a;
  --gold-on-dark:#f2d27e;
  --olive:      #a2b865;
  --text:       #e8e0d4;
  --text-lt:    #c4b6a6;   /* heller für AAA auf Karten */
  --white:      #ffffff;
  --btn-fg:     #ffffff;   /* weißer Text auf tiefem Terracotta-Button (AAA) */
  --border:     rgba(168,196,224,.18);
  --shadow-sm:  0 2px 12px rgba(0,0,0,.3);
  --shadow:     0 4px 32px rgba(0,0,0,.4);
  --shadow-lg:  0 12px 48px rgba(0,0,0,.5);
}
[data-theme="dark"] body            { background:#0f1923; color:var(--text) }
[data-theme="dark"] .site-header    { background:rgba(15,25,35,.97); border-bottom-color:rgba(228,125,98,.25) }
[data-theme="dark"] .info-strip     { background:#15293a; color:#eef4fa }
[data-theme="dark"] .site-footer    { background:#0a1520 }
[data-theme="dark"] .card           { background:#1a2a3a; border:1px solid rgba(168,196,224,.12) }
[data-theme="dark"] .card-text,
[data-theme="dark"] .feature-text,
[data-theme="dark"] .section-lead,
[data-theme="dark"] p               { color:var(--text-lt) }
[data-theme="dark"] .price-table    { border-color:rgba(168,196,224,.18) }
[data-theme="dark"] .price-table th { background:#173052; color:#eef4fa; border-color:rgba(168,196,224,.14) }
[data-theme="dark"] .price-table td { border-color:rgba(168,196,224,.14); color:#e3edf6 }
[data-theme="dark"] .price-table td:first-child { color:var(--aegean) }
[data-theme="dark"] .price-table tr:nth-child(even) td { background:rgba(168,196,224,.05) }
[data-theme="dark"] .price-table tr:last-child td { background:rgba(224,125,98,.12) }
[data-theme="dark"] .service-item   { background:#1a2a3a; border:1px solid rgba(168,196,224,.12); color:#e3edf6 }
[data-theme="dark"] .gallery-tab    { background:#1a2a3a; color:#dce8f2; border-color:rgba(168,196,224,.35) }
[data-theme="dark"] .gallery-tab.active,
[data-theme="dark"] .gallery-tab:hover { background:var(--aegean); color:#0f1923 }
[data-theme="dark"] .testimonial    { background:#1a2a3a }
[data-theme="dark"] .testimonial-text{ color:#d8cabb }
[data-theme="dark"] .award-banner   { background:#15293a; border-top-color:rgba(168,196,224,.12) }
[data-theme="dark"] .feature-box    { background:#1a2a3a; border-color:rgba(168,196,224,.12) }
[data-theme="dark"] .legal-content  { background:#1a2a3a }
[data-theme="dark"] .form-card,
[data-theme="dark"] .contact-info-card { background:#1a2a3a }
[data-theme="dark"] .contact-info-value,
[data-theme="dark"] .contact-info-value a { color:#dce8f2 }
[data-theme="dark"] .form-group input,
[data-theme="dark"] .form-group select,
[data-theme="dark"] .form-group textarea { background:#0f1923; color:var(--text); border-color:rgba(168,196,224,.25) }
[data-theme="dark"] .form-success   { background:#15331f; color:#bfe6c7; border-left-color:#7fbf8a }
[data-theme="dark"] .logo-text      { color:#e8e0d4 }
[data-theme="dark"] .main-nav a     { color:#dce8f2 }
[data-theme="dark"] .hamburger span { background:#dce8f2 }
[data-theme="dark"] .btn-primary    { color:var(--btn-fg) }
[data-theme="dark"] .btn-outline    { color:var(--aegean); border-color:var(--aegean) }
[data-theme="dark"] .btn-outline:hover { background:var(--aegean); color:#0f1923 }
[data-theme="dark"] .price-note     { background:rgba(224,125,98,.12) }
[data-theme="dark"] .lightbox       { background:rgba(0,0,0,.96) }

/* Toggle button */
.dark-toggle {
  background:none;border:1.5px solid var(--terra-ink);border-radius:20px;
  padding:.3rem .6rem;cursor:pointer;font-size:1rem;line-height:1;
  color:var(--terra-ink);transition:all var(--tr);flex-shrink:0;
}
.dark-toggle:hover { background:var(--terra-deep);color:#fff;border-color:var(--terra-deep) }
[data-theme="dark"] .dark-toggle { border-color:var(--terra-ink);color:var(--terra-ink) }
[data-theme="dark"] .dark-toggle:hover { background:var(--terra-ink);color:#14110a }

/* ── ACCESSIBILITY ── */
/* Skip-Link */
.skip-link{
  position:absolute;left:8px;top:-60px;z-index:2000;
  background:var(--aegean);color:#fff;
  padding:.7rem 1.2rem;border-radius:var(--radius);
  font-weight:700;font-size:.9rem;transition:top .2s ease;
}
.skip-link:focus{top:8px}
/* Sichtbarer Tastatur-Fokus (nur bei Keyboard-Navigation) */
:focus-visible{
  outline:3px solid var(--terra-deep);
  outline-offset:2px;border-radius:2px;
}
[data-theme="dark"] :focus-visible{outline-color:var(--gold)}
/* main soll bei Skip-Sprung keinen störenden Rahmen zeigen */
main:focus{outline:none}
/* Screenreader-only Hilfstext */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
/* Reduzierte Bewegung respektieren */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;
  }
  .hero-slide{transition:none}
  .page-hero-bg{transition:none;transform:none}
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Lato',sans-serif;background:var(--cream);color:var(--text);line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
ul{list-style:none}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.2}
h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:800}
h2{font-size:clamp(1.5rem,3vw,2.4rem);font-weight:600}
h3{font-size:1.25rem;font-weight:600}
p{color:var(--text-lt)}

/* ── HEADER ── */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.8rem 2.5rem;
  background:rgba(253,250,244,.97);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(194,105,79,.15);
  box-shadow:var(--shadow-sm);
}
.logo-link{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.logo-img{height:54px;width:auto}
.logo-text{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:800;color:var(--aegean);line-height:1.1;white-space:nowrap}
.logo-text span{color:var(--terra-ink)}

.main-nav{display:flex;align-items:center;gap:0;flex-wrap:wrap}
.main-nav a{
  display:block;padding:.45rem .75rem;
  font-size:.77rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--text);white-space:nowrap;
  position:relative;transition:color var(--tr);
}
.main-nav a::after{
  content:'';position:absolute;bottom:0;left:.75rem;right:.75rem;
  height:2px;background:var(--terra);
  transform:scaleX(0);transition:transform var(--tr);transform-origin:center;
}
.main-nav a:hover,.main-nav a.active{color:var(--terra-ink)}
[data-theme="dark"] .main-nav a:hover,[data-theme="dark"] .main-nav a.active{color:var(--terra-ink)}
.main-nav a:hover::after,.main-nav a.active::after{transform:scaleX(1)}
.main-nav a.active::after{background:var(--terra-ink)}

/* ── SPRACH-DROPDOWN ── */
.lang-switch{position:relative;flex-shrink:0}
.lang-current{
  display:flex;align-items:center;gap:.4rem;
  background:none;border:1px solid var(--border);border-radius:20px;
  padding:.3rem .6rem;cursor:pointer;
  font-family:'Lato',sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  color:var(--text-lt);white-space:nowrap;transition:all var(--tr);
}
.lang-current:hover,.lang-switch.open .lang-current{border-color:var(--terra-ink);color:var(--terra-ink)}
.lang-current img{width:18px;height:13px;object-fit:cover;border-radius:2px}
.lang-caret{font-size:.65rem;transition:transform var(--tr)}
.lang-switch.open .lang-caret{transform:rotate(180deg)}
.lang-menu{
  position:absolute;top:calc(100% + 8px);right:0;z-index:1100;
  min-width:184px;padding:.4rem;margin:0;list-style:none;
  background:var(--cream);border:1px solid var(--border);border-radius:10px;
  box-shadow:var(--shadow);display:none;
}
.lang-switch.open .lang-menu{display:block;animation:fadeUp .2s ease both}
.lang-menu a{
  display:flex;align-items:center;gap:.6rem;
  padding:.5rem .7rem;border-radius:6px;
  font-size:.82rem;font-weight:700;letter-spacing:.03em;
  color:var(--text);white-space:nowrap;transition:background var(--tr),color var(--tr);
}
.lang-menu a img{width:20px;height:15px;object-fit:cover;border-radius:2px;flex-shrink:0}
.lang-menu a:hover{background:rgba(194,105,79,.1);color:var(--terra-ink)}
.lang-menu a.active{color:var(--terra-ink)}
.lang-menu a.active::after{content:'✓';margin-left:auto;font-size:.9rem}
[data-theme="dark"] .lang-current{color:#cddbe8}
[data-theme="dark"] .lang-current:hover,[data-theme="dark"] .lang-switch.open .lang-current{color:var(--terra-ink);border-color:var(--terra-ink)}
[data-theme="dark"] .lang-menu{background:#1a2a3a;border-color:rgba(168,196,224,.18)}
[data-theme="dark"] .lang-menu a{color:#dce8f2}
[data-theme="dark"] .lang-menu a:hover{background:rgba(224,125,98,.16);color:var(--terra-ink)}
[data-theme="dark"] .lang-menu a.active{color:var(--terra-ink)}

.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:6px;flex-shrink:0;background:none;border:none;width:36px;height:36px}
.hamburger span{display:block;width:24px;height:2px;background:var(--aegean);transition:all var(--tr);border-radius:1px}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── HERO (Homepage) ── */
.hero{
  margin-top:77px;
  position:relative;overflow:hidden;
  height:70vh;min-height:420px;max-height:600px;
  display:flex;align-items:center;
}
.hero-slider{position:absolute;inset:0}
.hero-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s ease;
  filter:brightness(.7);
}
.hero-slide.active{opacity:1}
/* Lesbarkeits-Scrim: dunkler Verlauf hinter dem Text (links stark, rechts transparent) */
.hero::before{
  content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(100deg,
    rgba(10,18,28,.82) 0%, rgba(10,18,28,.62) 34%,
    rgba(10,18,28,.22) 66%, rgba(10,18,28,0) 100%);
}
.hero-content{
  position:relative;z-index:2;
  max-width:720px;padding:0 3rem;
  animation:fadeUp .9s ease both;
}
.hero-label{
  display:inline-block;padding:.35rem .9rem;
  background:var(--terra-deep);color:#fff;
  font-size:.75rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  border-radius:3px;margin-bottom:1.2rem;
}
.hero-content h1{color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.7),0 1px 3px rgba(0,0,0,.5);margin-bottom:1rem}
.hero-content p{font-size:1.1rem;color:rgba(255,255,255,.95);text-shadow:0 1px 10px rgba(0,0,0,.6);max-width:540px;margin-bottom:2rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-dots{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;gap:.5rem;z-index:3;
}
.hero-dot{
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);
  cursor:pointer;transition:all var(--tr);border:none;
}
.hero-dot.active{background:#fff;transform:scale(1.3)}

/* ── PAGE HERO ── */
.page-hero{
  margin-top:77px;
  position:relative;overflow:hidden;
  height:clamp(240px,38vw,460px);
  display:flex;align-items:flex-end;
}
.page-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.58);
  transform:scale(1.05);
  transition:transform 10s ease;
}
.page-hero:hover .page-hero-bg{transform:scale(1)}
.page-hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,15,24,.85) 0%,rgba(8,15,24,.35) 45%,transparent 75%);
}
.page-hero-content{position:relative;z-index:1;padding:2.5rem 3rem}
.page-hero-content h1{color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.7),0 1px 3px rgba(0,0,0,.5)}
.breadcrumb{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.92);margin-bottom:.4rem}
.breadcrumb a{color:rgba(255,255,255,.92);transition:color var(--tr);text-decoration:underline}
.breadcrumb a:hover{color:var(--gold-on-dark)}

/* ── INFO STRIP ── */
.info-strip{
  background:var(--aegean);color:var(--white);
  padding:.9rem 2.5rem;text-align:center;
  font-size:.83rem;letter-spacing:.03em;
}
.info-strip strong{color:var(--gold-on-dark)}
.info-strip a{color:var(--gold-on-dark);font-weight:700;text-decoration:underline}

/* ── SECTIONS ── */
.section{padding:5rem 2.5rem}
.section-wide{max-width:1200px;margin-inline:auto}
.section-narrow{max-width:820px;margin-inline:auto}
.section-label{font-size:.73rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra-ink);font-weight:700;margin-bottom:.5rem}
.section-title{color:var(--aegean);margin-bottom:1rem}
.section-lead{font-size:1.05rem;color:var(--text-lt);max-width:640px;margin-bottom:2.2rem}
.divider{width:44px;height:3px;background:var(--terra);border-radius:2px;margin-bottom:1.6rem}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.72rem 1.7rem;border:none;cursor:pointer;
  font-family:'Lato',sans-serif;font-size:.83rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  border-radius:var(--radius);transition:all var(--tr);
}
.btn-primary{background:var(--terra-deep);color:var(--btn-fg);box-shadow:0 4px 16px rgba(138,66,48,.3)}
.btn-primary:hover{background:var(--terra-dk);transform:translateY(-2px);box-shadow:0 8px 24px rgba(138,66,48,.4)}
.btn-outline{background:transparent;color:var(--aegean);border:2px solid var(--aegean)}
.btn-outline:hover{background:var(--aegean);color:var(--white);transform:translateY(-2px)}
.btn-outline-white{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.7)}
.btn-outline-white:hover{background:var(--white);color:var(--aegean);transform:translateY(-2px)}
.btn-white{background:var(--white);color:var(--aegean);font-weight:700}
.btn-white:hover{background:var(--sand);transform:translateY(-2px)}

/* ── CARDS ── */
.card{
  background:var(--white);border-radius:10px;overflow:hidden;
  box-shadow:var(--shadow);transition:transform var(--tr),box-shadow var(--tr);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card-img{width:100%;aspect-ratio:16/10;object-fit:cover}
.card-body{padding:1.4rem 1.6rem 1.8rem}
.card-label{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--terra-ink);font-weight:700;margin-bottom:.3rem}
.card-title{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:600;color:var(--aegean);margin-bottom:.5rem}
.card-text{font-size:.9rem;color:var(--text-lt);margin-bottom:1rem}

/* ── GRIDS ── */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

/* ── FEATURE BOXES ── */
.feature-box{
  background:var(--white);border-radius:10px;padding:2rem;
  box-shadow:var(--shadow);border-top:3px solid var(--terra);
  transition:transform var(--tr),box-shadow var(--tr);
}
.feature-box:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feature-icon{font-size:2.2rem;margin-bottom:.8rem}
.feature-title{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--aegean);margin-bottom:.5rem}
.feature-text{font-size:.88rem;color:var(--text-lt)}

/* ── TESTIMONIALS ── */
.testimonial{
  background:var(--white);border-radius:10px;padding:2rem 2.2rem;
  box-shadow:var(--shadow);position:relative;
}
.testimonial::before{
  content:'\201C';font-family:'Playfair Display',serif;
  font-size:5rem;line-height:.7;color:var(--terra);opacity:.15;
  position:absolute;top:1rem;left:1.2rem;
}
.testimonial-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;border:3px solid var(--sand);margin-bottom:.8rem}
.testimonial-text{font-size:.93rem;color:var(--text-lt);font-style:italic;margin-bottom:.8rem}
.testimonial-author{font-weight:700;font-size:.88rem;color:var(--aegean)}

/* ── AMENITY LIST ── */
.amenity-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.1rem}
.amenity-item{display:flex;align-items:center;gap:.6rem;padding:.55rem 0;border-bottom:1px solid var(--border)}
.amenity-item:last-child{border-bottom:none}
.amenity-icon{color:var(--terra-ink);font-size:1rem;flex-shrink:0}
.amenity-text{font-size:.9rem;color:var(--text-lt)}

/* ── PRICE TABLE ── */
.price-note{background:rgba(194,105,79,.08);border-left:3px solid var(--terra);padding:.9rem 1.2rem;border-radius:0 var(--radius) var(--radius) 0;font-size:.9rem;color:var(--text-lt);margin-bottom:2rem}
.price-note strong{color:var(--terra-ink)}
.price-table-wrap{overflow-x:auto;border-radius:10px;box-shadow:var(--shadow)}
.price-table{width:100%;border-collapse:collapse;min-width:600px}
.price-table th{background:var(--aegean);color:var(--white);padding:1rem 1.2rem;font-family:'Playfair Display',serif;font-size:.92rem;text-align:left;font-weight:600}
.price-table th:first-child{border-radius:10px 0 0 0}
.price-table th:last-child{border-radius:0 10px 0 0}
.price-table td{padding:.85rem 1.2rem;border-bottom:1px solid var(--border);font-size:.9rem}
.price-table tr:nth-child(even) td{background:rgba(245,240,232,.4)}
.price-table tr:last-child td{border-bottom:none;background:rgba(194,105,79,.07);font-weight:700}
.price-table td:first-child{color:var(--aegean);font-weight:700}
.price-baby{margin-top:1.2rem;font-size:.9rem;color:var(--text-lt);display:flex;align-items:center;gap:.5rem}
.price-baby::before{content:'🍼';font-size:1.1rem}

/* ── GALLERY ── */
.gallery-section .section-wide{max-width:1300px}
.gallery-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}
.gallery-tab{
  padding:.5rem 1.2rem;border-radius:30px;
  font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;border:2px solid var(--aegean);color:var(--aegean);
  transition:all var(--tr);background:transparent;
}
.gallery-tab.active,.gallery-tab:hover{background:var(--aegean);color:var(--white)}
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;
}
.gallery-item{
  border-radius:6px;overflow:hidden;cursor:zoom-in;
  aspect-ratio:1;background:#e0d9ce;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--tr),opacity var(--tr)}
.gallery-item:hover img{transform:scale(1.05);opacity:.9}

/* lightbox */
.lightbox{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.93);align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lb-img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:6px}
.lb-close{position:absolute;top:1.5rem;right:2rem;font-size:2.8rem;color:var(--white);cursor:pointer;line-height:1;background:none;border:none;opacity:.8;transition:opacity var(--tr)}
.lb-close:hover{opacity:1}
.lb-prev,.lb-next{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.12);color:var(--white);border:none;
  font-size:2rem;padding:.5rem 1rem;cursor:pointer;border-radius:4px;
  transition:background var(--tr);
}
.lb-prev{left:1rem}.lb-next{right:1rem}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.25)}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:start}
.contact-info-card{
  background:var(--white);border-radius:10px;padding:1.6rem;
  box-shadow:var(--shadow);display:flex;align-items:flex-start;gap:1rem;
  margin-bottom:1.2rem;transition:transform var(--tr);
}
.contact-info-card:hover{transform:translateX(4px)}
.contact-info-icon{font-size:1.6rem;flex-shrink:0;margin-top:.1rem}
.contact-info-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--terra-ink);margin-bottom:.2rem}
.contact-info-value{font-size:.92rem;color:var(--aegean);font-weight:600;line-height:1.5}
.contact-info-value a{color:var(--aegean);transition:color var(--tr);text-decoration:underline}
.contact-info-value a:hover{color:var(--terra-ink)}

.form-card{background:var(--white);border-radius:10px;padding:2.2rem;box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:.35rem}
.form-group label{font-size:.76rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--aegean)}
.form-group input,.form-group select,.form-group textarea{
  padding:.7rem 1rem;border:1.5px solid rgba(27,61,92,.18);
  border-radius:var(--radius);font-family:'Lato',sans-serif;font-size:.92rem;
  background:var(--cream);color:var(--text);
  transition:border-color var(--tr),box-shadow var(--tr);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(194,105,79,.14);
}
.form-group textarea{resize:vertical;min-height:110px}
.form-success{display:none;padding:.9rem 1.2rem;background:#e8f5e9;border-left:3px solid var(--olive);border-radius:var(--radius);color:var(--olive);font-weight:700;margin-top:1rem}
.form-error{padding:.9rem 1.2rem;background:#fde8e6;border-left:3px solid #b3261e;border-radius:var(--radius);color:#8a1c16;font-weight:600;margin-top:1rem;font-size:.9rem}
[data-theme="dark"] .form-success{background:#15331f;color:#bfe6c7;border-left-color:#7fbf8a}
[data-theme="dark"] .form-error{background:#3a1a18;color:#f3b4ad;border-left-color:#e0726a}

.map-wrap{border-radius:10px;overflow:hidden;box-shadow:var(--shadow);margin-top:2rem}
.map-wrap iframe{display:block;width:100%;height:320px;border:0}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-text h2{color:var(--aegean);margin-bottom:1rem}
.about-text p{margin-bottom:1rem}
.about-imgs{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:.75rem}
.about-img-main{grid-column:1/-1;border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}
.about-img-main img{width:100%;height:240px;object-fit:cover}
.about-img-sm{border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}
.about-img-sm img{width:100%;height:160px;object-fit:cover}
.badge-row{display:flex;gap:1.2rem;align-items:center;flex-wrap:wrap;margin-top:1.5rem}
.badge-img{height:72px;width:auto;object-fit:contain}

/* ── SERVICES ── */
.service-hero-img{width:100%;height:300px;object-fit:cover;border-radius:10px;margin-bottom:2rem;box-shadow:var(--shadow)}
.service-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:2rem}
.service-item{
  display:flex;align-items:center;gap:.7rem;
  padding:.7rem 1rem;background:var(--white);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);font-size:.9rem;color:var(--text-lt);
  transition:transform var(--tr);
}
.service-item:hover{transform:translateX(4px)}
.service-item::before{content:'✓';color:var(--olive);font-weight:900;flex-shrink:0}
.service-imgs{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.service-imgs img{width:100%;height:200px;object-fit:cover;border-radius:8px;box-shadow:var(--shadow-sm)}

/* ── NEA POTIDEA ── */
.potidea-intro{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;margin-bottom:3rem}
.potidea-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}
.potidea-gallery-item{border-radius:6px;overflow:hidden;aspect-ratio:1;cursor:zoom-in}
.potidea-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--tr)}
.potidea-gallery-item:hover img{transform:scale(1.06)}
.potidea-copyright{font-size:.75rem;color:var(--text-lt);margin-top:.5rem;font-style:italic;text-align:center}

/* ── LEGAL ── */
.legal-content{background:var(--white);border-radius:10px;padding:2.5rem 3rem;box-shadow:var(--shadow)}
.legal-content h2{font-size:1.3rem;color:var(--aegean);margin-top:2.2rem;margin-bottom:.7rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{font-size:1rem;color:var(--terra-ink);margin-top:1.5rem;margin-bottom:.4rem}
.legal-content p,.legal-content li{font-size:.9rem;color:var(--text-lt);margin-bottom:.6rem;line-height:1.7}
.legal-content ul{list-style:disc;padding-left:1.4rem;margin-bottom:.8rem}
.legal-content a{color:var(--terra-ink);text-decoration:underline}
.legal-content ol{padding-left:1.4rem;margin-bottom:.8rem}
.legal-content ol li{margin-bottom:.4rem}

/* ── BEWERTUNGEN / REVIEWS ── */
.rating-band{
  display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap;justify-content:center;
  background:var(--white);border:1px solid var(--border);border-radius:14px;
  padding:1.6rem 2rem;box-shadow:var(--shadow);margin-bottom:2.6rem;text-align:center;
}
.rating-badge{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:96px;height:96px;border-radius:18px;background:var(--aegean);color:#fff;flex-shrink:0;
}
.rating-badge .rb-num{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;line-height:1}
.rating-badge .rb-of{font-size:.72rem;opacity:.8;letter-spacing:.1em}
.rating-info{display:flex;flex-direction:column;gap:.45rem;align-items:center}
.rating-stars{color:var(--gold);font-size:1.5rem;letter-spacing:3px}
.rating-word{font-family:'Playfair Display',serif;color:var(--aegean);font-size:1.35rem}
.rating-sub{font-size:.9rem;color:var(--text-lt)}
.review-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.review-card{
  background:var(--white);border-radius:12px;padding:1.8rem 2rem;
  box-shadow:var(--shadow);border-top:3px solid var(--terra);position:relative;
}
.review-card .stars{color:var(--gold);letter-spacing:2px;margin-bottom:.6rem;font-size:1.05rem}
.review-card blockquote{font-style:italic;color:var(--text-lt);margin-bottom:.9rem;line-height:1.75}
.review-card figcaption{font-weight:700;color:var(--aegean);font-size:.92rem}
.review-card .src{font-weight:400;color:var(--text-lt);font-size:.82rem}
.review-card .review-meta{font-weight:400;color:var(--text-lt);font-size:.8rem;display:block;margin-top:.2rem}
@media(max-width:760px){.review-grid{grid-template-columns:1fr}}

/* Kategorie-Balken */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:.9rem 2rem;margin:0 0 2.6rem}
.cat-row{display:flex;flex-direction:column;gap:.35rem}
.cat-top{display:flex;justify-content:space-between;align-items:baseline;font-size:.86rem;color:var(--text-lt)}
.cat-top .cat-val{font-weight:700;color:var(--aegean);font-family:'Playfair Display',serif}
.cat-bar{height:7px;border-radius:4px;background:var(--border);overflow:hidden}
.cat-bar span{display:block;height:100%;background:var(--terra);border-radius:4px;transition:width .6s ease}

/* ── FOOTER ── */
.site-footer{background:var(--aegean);color:rgba(255,255,255,.75);padding:4rem 2.5rem 2rem}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;
  max-width:1200px;margin-inline:auto;
  padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-logo-link{display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.footer-logo{height:56px;width:auto;display:block}
.footer-logo-text{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:800;color:#f3efe8;line-height:1.1;white-space:nowrap}
.footer-logo-text span{color:#f0a48d}
.footer-brand p{font-size:.86rem;line-height:1.7;color:rgba(255,255,255,.88);margin-bottom:1.2rem}
.footer-social{display:flex;gap:.7rem}
.footer-social a{
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.85rem;transition:background var(--tr),transform var(--tr);
}
.footer-social a:hover{background:var(--terra);transform:translateY(-2px)}
.footer-social a:hover{color:#14110a}
.footer-col .footer-social a{display:flex;padding:0;font-size:1.1rem}
.footer-col h4{font-family:'Lato',sans-serif;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,.82);margin-bottom:.9rem}
.footer-col a,.footer-col p{display:block;font-size:.86rem;color:rgba(255,255,255,.9);padding:.2rem 0;transition:color var(--tr)}
.footer-col a:hover{color:var(--gold-on-dark)}
.footer-col .footer-addr{font-size:.86rem;color:rgba(255,255,255,.88);line-height:1.7}
.footer-bottom{
  max-width:1200px;margin-inline:auto;padding-top:1.4rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.78rem;color:rgba(255,255,255,.72);
}
.footer-bottom a{color:rgba(255,255,255,.82);transition:color var(--tr);text-decoration:underline}
.footer-bottom a:hover{color:var(--gold-on-dark)}

/* ── AWARD BANNER ── */
.award-banner{background:var(--sand);border-top:1px solid var(--border);padding:3rem 2.5rem}
.award-inner{max-width:1200px;margin-inline:auto;display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap}
.award-text h3{color:var(--aegean);margin-bottom:.3rem}
.award-text p{font-size:.9rem;max-width:400px}
.award-badges{display:flex;gap:1.5rem;align-items:center}
.award-badge{height:80px;width:auto;object-fit:contain;transition:transform var(--tr)}
.award-badge:hover{transform:scale(1.05)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.animate-up{animation:fadeUp .7s ease both}
.d1{animation-delay:.1s}.d2{animation-delay:.2s}.d3{animation-delay:.3s}.d4{animation-delay:.4s}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .potidea-gallery{grid-template-columns:repeat(3,1fr)}
}
/* Ab hier klappt das Hauptmenü zum Hamburger – Bedienelemente rechts gruppiert */
@media(max-width:1050px){
  .main-nav{
    display:none;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:var(--cream);border-bottom:1px solid rgba(194,105,79,.2);
    box-shadow:0 8px 24px rgba(0,0,0,.1);
  }
  .main-nav.open{display:flex}
  .main-nav a{padding:.85rem 1.5rem;border-bottom:1px solid var(--border)}
  .hamburger{display:flex;order:-1}   /* Menü-Button nach ganz links */
  .lang-switch{margin-left:auto}      /* Sprache + Theme-Knopf nach rechts */
}
@media(max-width:900px){
  .contact-grid,.about-grid,.potidea-intro{grid-template-columns:1fr}
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .service-list,.amenity-list{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .potidea-gallery{grid-template-columns:repeat(2,1fr)}
  .service-imgs{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .site-header{padding:.75rem 1.2rem}
  /* Sprachauswahl auf dem Handy kompakt – nur Flagge + Pfeil, ohne Textlabel */
  .lang-current-name{display:none}
  .lang-current{padding:.3rem .5rem}
  .section{padding:3rem 1.2rem}
  .page-hero-content{padding:2rem 1.5rem}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
  .hero-content{padding:0 1.5rem}
  .legal-content{padding:1.5rem}
  .award-inner{flex-direction:column;text-align:center}
  .service-imgs{grid-template-columns:1fr}
}
@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr 1fr}
  .potidea-gallery{grid-template-columns:1fr 1fr}
  .hero-dots{bottom:1rem}
  .logo-img{height:44px}
  .logo-text{font-size:1.1rem}
}
