/* ============================================================
   SIMONES FERIENHAUS · Coastal Editorial
   Fraunces (Display) · Manrope (Body) · JetBrains Mono (Labels)
   ============================================================ */

:root{
  --paper:#F7F2E8;
  --paper-warm:#F4EFE3;
  --sand:#E9DFCB;
  --sand-deep:#DCCFB4;
  --ink:#22323B;
  --ink-soft:#4A5B63;
  --ocean-deep:#1A2A30;
  --ocean:#2E5F6E;
  --tide:#8FBEC9;
  --terra:#C4683F;
  --terra-soft:#E4B79F;
  --line:rgba(34,50,59,.14);

  --f-display:"Fraunces",Georgia,serif;
  --f-body:"Manrope",system-ui,sans-serif;
  --f-mono:"JetBrains Mono",monospace;

  --wrap:1180px;
  --wrap-narrow:780px;
  --r:14px;
  --shadow:0 10px 40px rgba(26,42,48,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--f-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--ocean);text-decoration:none}
a:hover{color:var(--terra)}
::selection{background:var(--tide);color:var(--ocean-deep)}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:24px}
.wrap-narrow{max-width:var(--wrap-narrow);margin-inline:auto;padding-inline:24px}

/* ---------- Typo-Bausteine ---------- */
.eyebrow{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--terra);display:inline-flex;
  align-items:center;gap:10px;margin-bottom:14px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--terra)}
h1,h2,h3{font-family:var(--f-display);font-weight:480;line-height:1.08;letter-spacing:-.015em}
h1{font-size:clamp(38px,6vw,64px)}
h2{font-size:clamp(28px,4vw,42px)}
h3{font-size:clamp(20px,2.4vw,26px)}
h1 em,h2 em{font-style:italic;font-weight:340;color:var(--ocean)}
.lead{font-size:clamp(17px,2vw,20px);color:var(--ink-soft);max-width:62ch}
.platt{font-family:var(--f-display);font-style:italic;color:var(--ocean);font-size:1.15em}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  padding:15px 26px;border-radius:999px;border:1.5px solid var(--ocean-deep);
  background:var(--ocean-deep);color:var(--paper);cursor:pointer;
  transition:transform .18s ease,background .18s ease,color .18s ease;
}
.btn:hover{background:var(--terra);border-color:var(--terra);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ocean-deep)}
.btn-ghost:hover{background:var(--ocean-deep);border-color:var(--ocean-deep);color:var(--paper)}
.btn .arrow{transition:transform .18s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Topbar ---------- */
.topbar{
  background:var(--ocean-deep);color:var(--paper-warm);
  font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  padding:9px 0;
}
.topbar .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.topbar a{color:var(--tide)}
.topbar a:hover{color:#fff}
.topbar .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--terra);margin-inline:8px;vertical-align:middle}

/* ---------- Navigation ---------- */
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(247,242,232,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-block:12px}
.brand{display:flex;align-items:center;gap:13px;color:var(--ink)}
.brand-mark{width:46px;height:46px;border-radius:50%;overflow:hidden;border:2px solid var(--sand-deep);flex:none}
.brand-mark img{width:100%;height:100%;object-fit:cover}
.brand-text b{font-family:var(--f-display);font-weight:520;font-size:19px;display:block;line-height:1.1}
.brand-text small{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
.nav-links{display:flex;gap:4px;flex-wrap:wrap}
.nav-links a{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink);padding:9px 13px;border-radius:999px;
}
.nav-links a:hover{background:var(--sand)}
.nav-links a.active{background:var(--ocean-deep);color:var(--paper)}
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-burger svg{display:block;stroke:var(--ink)}
@media (max-width:980px){
  .nav-burger{display:block}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    flex-direction:column;padding:14px 24px 20px;gap:2px;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 14px}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--ocean-deep);color:var(--paper)}
.hero-slides{position:absolute;inset:0}
.hero-slides .slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.4s ease;
}
.hero-slides .slide.on{opacity:1}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(26,42,48,.86) 20%,rgba(26,42,48,.45) 60%,rgba(26,42,48,.25))}
.hero-inner{position:relative;z-index:2;padding:clamp(90px,14vw,170px) 0 clamp(120px,16vw,190px)}
.hero .eyebrow{color:var(--tide)}
.hero .eyebrow::before{background:var(--tide)}
.hero h1{color:#fff;max-width:16ch}
.hero h1 em{color:var(--terra-soft)}
.hero .lead{color:rgba(244,239,227,.85);margin-top:22px}
.hero-cta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap}
.hero .btn-ghost{border-color:rgba(244,239,227,.6);color:var(--paper)}
.hero .btn-ghost:hover{background:var(--paper);color:var(--ocean-deep)}
.hero-moin{
  position:absolute;right:5%;top:14%;z-index:2;
  font-family:var(--f-display);font-style:italic;font-weight:320;
  font-size:clamp(60px,9vw,120px);color:rgba(143,190,201,.35);
  pointer-events:none;user-select:none;line-height:.9;
}
/* Wetter sitzt fest unter „Moin!“: top = 14% + Zeilenhöhe des Moin + 22px Luft */
.hero-wetter{
  position:absolute;right:5%;z-index:3;
  top:calc(14% + clamp(60px,9vw,120px) * 0.9 + 22px);
  width:min(320px,80vw);
  background:rgba(26,42,48,.42);backdrop-filter:blur(10px);
  border:1px solid rgba(244,239,227,.18);border-radius:18px;
  padding:18px 20px;color:var(--paper);
}
.hero-dots{position:absolute;bottom:76px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:8px}
.hero-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(244,239,227,.4);cursor:pointer;padding:0}
.hero-dots button.on{background:var(--terra-soft)}

/* ---------- Welle ---------- */
.wave{display:block;width:100%;height:70px;margin-top:-1px}
.wave.flip{transform:scaleY(-1)}
.wave path{fill:var(--paper)}
.wave.to-warm path{fill:var(--paper-warm)}
.wave.from-dark{background:var(--ocean-deep)}

/* ---------- Sections ---------- */
section.block{padding:clamp(60px,8vw,110px) 0}
.alt{background:var(--paper-warm)}
.section-head{max-width:680px;margin-bottom:clamp(32px,5vw,56px)}

/* ---------- Feature-Grid ---------- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:30px 28px;box-shadow:0 2px 14px rgba(26,42,48,.05);
}
.card h3{margin-bottom:10px}
.card .icon{
  width:46px;height:46px;border-radius:12px;background:var(--sand);
  display:grid;place-items:center;margin-bottom:18px;color:var(--ocean);
}
.card p{color:var(--ink-soft);font-size:15.5px}

/* ---------- Galerie ---------- */
.mosaic{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;grid-auto-rows:200px;grid-auto-flow:dense}
.mosaic figure{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;background:var(--sand)}
.mosaic figure.tall{grid-row:span 2}
.mosaic figure.wide{grid-column:span 2}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.mosaic figure:hover img{transform:scale(1.05)}
.mosaic figcaption{
  position:absolute;inset-inline:0;bottom:0;padding:26px 16px 12px;
  background:linear-gradient(transparent,rgba(26,42,48,.75));
  color:#fff;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
}
@media (max-width:640px){.mosaic figure.wide{grid-column:span 1}}
.lightbox{
  position:fixed;inset:0;z-index:200;background:rgba(26,42,48,.94);
  display:none;align-items:center;justify-content:center;padding:24px;
}
.lightbox.open{display:flex}
.lightbox img{max-width:min(92vw,1100px);max-height:82vh;object-fit:contain;border-radius:8px}
.lightbox .lb-cap{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:var(--paper);font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.lightbox button{
  position:absolute;background:rgba(247,242,232,.12);border:1px solid rgba(247,242,232,.35);
  color:var(--paper);width:46px;height:46px;border-radius:50%;cursor:pointer;font-size:20px;
}
.lightbox button:hover{background:var(--terra);border-color:var(--terra)}
.lb-close{top:22px;right:22px}
.lb-prev{left:22px;top:50%;transform:translateY(-50%)}
.lb-next{right:22px;top:50%;transform:translateY(-50%)}

/* ---------- Preise ---------- */
.price-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:22px}
.price-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:32px 28px;position:relative;overflow:hidden;
}
.price-card.hi{background:var(--ocean-deep);color:var(--paper);border-color:var(--ocean-deep)}
.price-card.hi .eyebrow{color:var(--tide)}
.price-card.hi .eyebrow::before{background:var(--tide)}
.price-card .amount{font-family:var(--f-display);font-size:44px;font-weight:480;line-height:1;margin:10px 0 4px}
.price-card .amount small{font-family:var(--f-body);font-size:14px;font-weight:500;color:inherit;opacity:.65}
.price-card .period{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.65}
.price-card ul{list-style:none;margin-top:20px;display:grid;gap:9px;font-size:15px}
.price-card ul li{display:flex;gap:10px;align-items:flex-start}
.price-card ul li::before{content:"—";color:var(--terra);flex:none}
.price-note{
  margin-top:28px;padding:20px 24px;background:var(--sand);border-radius:var(--r);
  font-size:15px;color:var(--ink-soft);
}

/* ---------- Kalender ---------- */
.cal-status{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.cal-status .pulse{width:8px;height:8px;border-radius:50%;background:var(--terra);animation:pulse 1.6s infinite}
.cal-status.ok .pulse{background:#4C8C5C;animation:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.cal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.cal-month{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px}
.cal-month h4{font-family:var(--f-display);font-weight:500;font-size:18px;margin-bottom:12px;text-transform:capitalize}
.cal-month table{width:100%;border-collapse:collapse;font-size:13px}
.cal-month th{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;color:var(--ink-soft);padding:5px 0;text-transform:uppercase;font-weight:500}
.cal-month td{text-align:center;padding:0}
.cal-month td span{display:grid;place-items:center;width:32px;height:32px;margin:2px auto;border-radius:50%}
.cal-month td .free{background:#E4EFE6;color:#2F5D3B}
.cal-month td .busy{background:#F3DBD0;color:#8C3F1E;text-decoration:line-through}
.cal-month td .past{color:var(--line)}
.cal-legend{display:flex;gap:22px;margin-top:20px;font-size:13.5px;color:var(--ink-soft);flex-wrap:wrap}
.cal-legend i{display:inline-block;width:14px;height:14px;border-radius:50%;margin-right:7px;vertical-align:-2px}

/* ---------- Gästebuch ---------- */
.reviews{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px}
.review{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;
  display:flex;flex-direction:column;gap:14px;
}
.review .stars{color:var(--terra);letter-spacing:3px;font-size:15px}
.review blockquote{font-family:var(--f-display);font-style:italic;font-weight:380;font-size:18.5px;line-height:1.45;color:var(--ink)}
.review .who{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:auto}

/* ---------- Umgebung / Events ---------- */
.place-list{display:grid;gap:0;border-top:1px solid var(--line)}
.place{
  display:grid;grid-template-columns:110px 1fr;gap:24px;align-items:baseline;
  padding:26px 0;border-bottom:1px solid var(--line);
}
.place .dist{font-family:var(--f-mono);font-size:13px;color:var(--terra);letter-spacing:.06em}
.place h3{font-size:21px;margin-bottom:6px}
.place p{color:var(--ink-soft);font-size:15.5px}
@media (max-width:560px){.place{grid-template-columns:1fr;gap:6px}}
.events-feed .event{
  display:grid;grid-template-columns:74px 1fr;gap:20px;padding:20px 0;border-bottom:1px solid var(--line);
}
.events-feed .date{
  background:var(--ocean-deep);color:var(--paper);border-radius:12px;text-align:center;
  padding:10px 6px;height:fit-content;
}
.events-feed .date b{font-family:var(--f-display);font-size:24px;display:block;line-height:1}
.events-feed .date small{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase}
.events-feed h4{font-size:17px;font-weight:700;margin-bottom:4px}
.events-feed p{font-size:14.5px;color:var(--ink-soft)}
.events-feed a{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}

/* ---------- Kontakt ---------- */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr}}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px 32px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:7px}
.field input,.field textarea,.field select{
  width:100%;border:1.5px solid var(--line);border-radius:10px;background:var(--paper);
  padding:13px 15px;font:inherit;color:var(--ink);
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ocean)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:560px){.field-row{grid-template-columns:1fr}}
.form-note{font-size:13px;color:var(--ink-soft);margin-left:14px}
.form-msg{margin-top:16px;padding:14px 18px;border-radius:10px;font-size:14.5px;display:none}
.form-msg.ok{display:block;background:#E4EFE6;color:#2F5D3B}
.form-msg.err{display:block;background:#F3DBD0;color:#8C3F1E}
.contact-cards{display:grid;gap:16px}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;
  display:block;color:var(--ink);transition:transform .18s ease,box-shadow .18s ease;
}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);color:var(--ink)}
.contact-card b{display:block;font-size:17px;margin:4px 0 2px}
.contact-card small{color:var(--ink-soft);font-size:13.5px}
.qr-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px;text-align:center}
.qr-wrap{display:grid;place-items:center;margin:16px 0}
.qr-wrap canvas,.qr-wrap img{border-radius:10px}
.map-embed{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:36px}
.map-embed iframe{display:block;width:100%;height:380px;border:0}

/* ---------- Page-Head (Unterseiten) ---------- */
.page-head{background:var(--ocean-deep);color:var(--paper);padding:clamp(56px,8vw,90px) 0 clamp(70px,9vw,100px);position:relative;overflow:hidden}
.page-head .eyebrow{color:var(--tide)}
.page-head .eyebrow::before{background:var(--tide)}
.page-head h1 em{color:var(--terra-soft)}
.page-head .lead{color:rgba(244,239,227,.8);margin-top:16px}
.page-head .gull{position:absolute;right:6%;top:22%;opacity:.25;pointer-events:none}

/* ---------- Impressum / Datenschutz ---------- */
.legal section{margin-bottom:38px}
.legal h2{font-size:24px;margin-bottom:12px}
.legal ul{margin:10px 0 10px 22px;color:var(--ink-soft)}
.legal p{color:var(--ink-soft);margin-bottom:10px}
.address-block{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px 26px;margin:14px 0}
.address-block .name{font-family:var(--f-display);font-size:19px;font-weight:520;display:block;margin-bottom:6px}

/* ---------- Möwe ---------- */
.gull-fly{position:absolute;pointer-events:none;animation:gullfly 26s linear infinite;opacity:.55}
@keyframes gullfly{
  0%{transform:translate(-80px,20px) scale(.9)}
  50%{transform:translate(52vw,-24px) scale(1.05)}
  100%{transform:translate(110vw,10px) scale(.95)}
}
@media (prefers-reduced-motion:reduce){.gull-fly{animation:none;display:none}}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.12s}
.reveal[data-delay="2"]{transition-delay:.24s}
.reveal[data-delay="3"]{transition-delay:.36s}
.reveal[data-delay="4"]{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Footer ---------- */
footer{background:var(--ocean-deep);color:var(--paper-warm);padding:52px 0 30px;margin-top:0}
footer .wrap{display:grid;gap:26px}
.footer-top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:flex-start}
.footer-brand{font-family:var(--f-display);font-size:23px;font-weight:440}
.footer-brand em{font-style:italic;color:var(--tide);font-weight:320}
.footer-brand small{display:block;font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,239,227,.6);margin-top:6px}
.footer-nav{display:flex;gap:20px;font-family:var(--f-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;flex-wrap:wrap}
footer a{color:rgba(244,239,227,.85)}
footer a:hover{color:var(--terra-soft)}
.footer-bottom{border-top:1px solid rgba(244,239,227,.15);padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13.5px;color:rgba(244,239,227,.6)}
.footer-bottom .platt{color:var(--tide);font-size:15px}

/* ---------- Fokus ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2.5px solid var(--terra);outline-offset:2px;
}

/* ============================================================
   NORDFRIESLAND-FLAIR
   ============================================================ */

/* Flaggenstreifen (Gold · Rot · Blau) unter der Topbar */
.flagstripe{height:4px;background:linear-gradient(90deg,#D9A441 0 33.3%,#B5462F 33.3% 66.6%,#2E5F6E 66.6% 100%)}

/* Deich-Panorama über dem Footer */
.panorama{display:block;width:100%;height:auto;background:var(--paper);margin-bottom:-1px}
.panorama .sea-a{animation:seaShift 9s ease-in-out infinite alternate}
.panorama .sea-b{animation:seaShift 13s ease-in-out infinite alternate-reverse}
@keyframes seaShift{from{transform:translateX(0)}to{transform:translateX(-26px)}}
@media (prefers-reduced-motion:reduce){.panorama .sea-a,.panorama .sea-b{animation:none}}
.panorama.on-warm{background:var(--paper-warm)}

/* Kompassrose im Seitenkopf */
.page-head .compass{
  position:absolute;right:-40px;bottom:-60px;width:min(300px,40vw);opacity:.14;
  pointer-events:none;animation:compassTurn 140s linear infinite;transform-origin:center;
}
@media (prefers-reduced-motion:reduce){.page-head .compass{animation:none}}
@keyframes compassTurn{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* Nordfriesland-Vignetten (Startseite) */
.vignettes{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px;margin-top:14px}
.vignette{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:30px 24px 26px;text-align:center;
}
.vignette svg{display:block;margin:0 auto 16px;height:110px;width:auto}
.vignette b{font-family:var(--f-display);font-weight:520;font-size:18px;display:block}
.vignette small{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.vignette p{font-size:14.5px;color:var(--ink-soft);margin-top:8px}

/* Zweite Möwe im Hero */
.hero .gull-2{animation-duration:34s;animation-delay:-14s;top:30%}

/* ---------- Kalender-Navigation ---------- */
.cal-nav{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.cal-nav .btn{padding:11px 18px;font-size:11px}
.cal-nav .btn:disabled{opacity:.35;cursor:not-allowed;transform:none}
.cal-nav .btn:disabled:hover{background:transparent;color:var(--ocean-deep);border-color:var(--ocean-deep)}
.cal-range{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);text-align:center;flex:1}
@media (max-width:560px){.cal-range{order:-1;flex-basis:100%}}

/* ============================================================
   PREIS (einmalig) · GALERIE (Räume) · HERO-FALLBACK
   ============================================================ */

/* Hero bekommt einen küstigen Fallback-Verlauf, falls Bilder (z. B. in Edge) laden verzögert */
.hero{background:linear-gradient(135deg,#1A2A30 0%,#2E5F6E 55%,#3d7688 100%)}

/* ---------- Einzelne Preiskarte ---------- */
.price-single-wrap{max-width:820px}
.price-single{
  display:grid;grid-template-columns:minmax(240px,1fr) 1.2fr;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow);
}
@media (max-width:620px){.price-single{grid-template-columns:1fr}}
.price-single-main{background:var(--ocean-deep);color:var(--paper);padding:38px 34px}
.price-single-main .eyebrow{color:var(--tide)}
.price-single-main .eyebrow::before{background:var(--tide)}
.price-single-main .amount{font-family:var(--f-display);font-weight:480;font-size:58px;line-height:1;margin:14px 0 4px}
.price-single-main .period{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,239,227,.7)}
.price-single-main .zusatz{margin-top:26px;border-top:1px solid rgba(244,239,227,.18);padding-top:18px;display:grid;gap:9px}
.zusatz-row{display:flex;justify-content:space-between;gap:14px;font-size:14.5px}
.zusatz-row span{color:rgba(244,239,227,.8)}
.zusatz-row b{color:var(--terra-soft);font-weight:600}
.price-single-leist{padding:38px 34px}
.price-single-leist .eyebrow{color:var(--terra)}
.price-single-leist ul{list-style:none;margin-top:16px;display:grid;gap:12px}
.price-single-leist li{display:flex;gap:11px;align-items:flex-start;font-size:15.5px;color:var(--ink)}
.price-single-leist li::before{content:"✓";color:var(--ocean);font-weight:700;flex:none}

/* ---------- Galerie: Räume ---------- */
.gal-raeume{display:grid;gap:clamp(38px,6vw,64px)}
.gal-raum-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:18px;border-bottom:1px solid var(--line);padding-bottom:12px}
.gal-raum-head h3{font-size:clamp(21px,3vw,28px)}
.gal-count{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.gal-mosaik{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;grid-auto-rows:180px}
.gal-mosaik figure{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;background:var(--sand);margin:0}
.gal-mosaik figure.gross{grid-column:span 2;grid-row:span 2}
@media (max-width:560px){.gal-mosaik figure.gross{grid-column:span 2;grid-row:span 1}}
.gal-mosaik img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gal-mosaik figure:hover img{transform:scale(1.06)}
.gal-mosaik .gal-zoom{
  position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;
  background:rgba(26,42,48,.55);color:#fff;display:grid;place-items:center;
  opacity:0;transition:opacity .25s ease;backdrop-filter:blur(3px);
}
.gal-mosaik figure:hover .gal-zoom{opacity:1}
/* Platzhalter für noch fehlende Fotos */
.gal-mosaik figure.fehlt{background:repeating-linear-gradient(45deg,var(--sand),var(--sand) 12px,var(--sand-deep) 12px,var(--sand-deep) 24px)}
.gal-mosaik figure.fehlt img{display:none}
.gal-mosaik figure.fehlt::after{
  content:"Foto folgt";position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);
}

/* ============================================================
   WETTER-WIDGET (Hero) · EVENTS-NAVIGATION
   ============================================================ */

/* Wetter unter „Moin!“ */
.hero-wetter{
  width:100%;z-index:3;
  background:rgba(26,42,48,.42);backdrop-filter:blur(10px);
  border:1px solid rgba(244,239,227,.18);border-radius:18px;
  padding:18px 20px;color:var(--paper);
}
.hero-wetter:empty{display:none}
@media (max-width:900px){
  /* Auf schmalen Bildschirmen fließt das Wetter normal unter den Hero-Text */
  .hero-moin{position:static;display:block;text-align:right;margin-bottom:8px}
  .hero-wetter{position:static;width:100%;max-width:340px;margin-top:20px;background:rgba(26,42,48,.55)}
}
.wetter-lade{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(244,239,227,.7);text-align:center;padding:8px 0}
.wetter-now{display:flex;align-items:center;gap:14px}
.wetter-now-icon{width:52px;height:52px;flex:none}
.wetter-temp{font-family:var(--f-display);font-weight:480;font-size:38px;line-height:1;display:flex;align-items:baseline}
.wetter-temp span{font-family:var(--f-body);font-size:15px;font-weight:500;margin-left:3px;opacity:.75}
.wetter-desc{font-family:var(--f-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--tide);margin-top:3px}
.wetter-meta{font-size:12px;color:rgba(244,239,227,.7);margin-top:4px}
.wetter-tage{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:16px;border-top:1px solid rgba(244,239,227,.15);padding-top:14px}
.wetter-tag{
  background:rgba(244,239,227,.06);border:1px solid transparent;border-radius:12px;
  padding:9px 4px;cursor:pointer;color:var(--paper);
  display:flex;flex-direction:column;align-items:center;gap:3px;transition:background .18s ease,border-color .18s ease;
}
.wetter-tag:hover{background:rgba(244,239,227,.14)}
.wetter-tag.on{background:rgba(143,190,201,.22);border-color:var(--tide)}
.wt-tag{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(244,239,227,.75)}
.wt-icon{width:30px;height:30px}
.wt-max{font-family:var(--f-display);font-size:16px;font-weight:500;line-height:1}
.wt-min{font-size:11px;color:rgba(244,239,227,.6)}
.wetter-detail{margin-top:12px;font-size:13px;color:rgba(244,239,227,.85);border-top:1px solid rgba(244,239,227,.15);padding-top:10px;line-height:1.4}
.wetter-detail strong{color:var(--tide)}

/* Events: Monats-Navigation */
.events-nav{display:flex;align-items:center;justify-content:center;gap:18px;margin-bottom:28px}
.events-nav .btn{padding:10px 14px}
.events-nav .btn:disabled{opacity:.3;cursor:not-allowed;transform:none}
.events-nav .btn:disabled:hover{background:transparent;color:var(--ocean-deep);border-color:var(--ocean-deep)}
.events-monat{font-family:var(--f-display);font-size:clamp(20px,3vw,26px);font-weight:480;min-width:180px;text-align:center}
.events-liste{display:grid;gap:0}
.events-liste .event{
  display:grid;grid-template-columns:74px 1fr;gap:20px;padding:22px 0;border-bottom:1px solid var(--line);
}
.event-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:5px}
.event-head h4{font-size:18px;font-weight:700;margin:0}
.event-ort{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--terra)}
.event-span{display:inline-block;font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:var(--ocean);margin-bottom:6px}
.events-liste .event p{font-size:14.5px;color:var(--ink-soft);margin-top:2px}
.events-liste .event a{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;display:inline-block;margin-top:8px}
