/* ========================================
   Seeliebi 9320 – Warm Lake Soul
   Warm-led palette, lake accent, wave motif
   ======================================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* Palette */
  --lake:#2C5F7C;--lake-deep:#1a3a4f;--lake-light:#5A9CAF;--lake-pale:#c5dfe9;
  --sand:#FDF9F3;--sand-warm:#F5EDE0;
  --sunset:#D4A657;--sunset-glow:#EDCF9B;--rose:#C27D7D;
  --drift:#7A6757;--label:#3C6C85;--charcoal:#2A2A2A;--charcoal-l:#5C5C5C;--white:#fff;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Nunito',-apple-system,sans-serif;
  --t:.35s cubic-bezier(.4,0,.2,1);
  --ease-soft:cubic-bezier(.22,.61,.36,1);

  /* Spacing scale */
  --s-1:.5rem;--s-2:.75rem;--s-3:1rem;--s-4:1.5rem;--s-5:2rem;--s-6:3rem;--s-7:4rem;

  /* Width system */
  --content:72rem;       /* standard section */
  --content-wide:84rem;  /* wide editorial rows */
  --text:40rem;          /* pure reading text, never wider */
  --gutter:clamp(1.5rem,5vw,4rem);
  --col-gap:clamp(1.5rem,3vw,3rem);

  /* Whitespace rhythm */
  --section-y:clamp(4rem,9vw,7rem);
  --section-y-lg:clamp(6rem,10vw,9rem);
  --block-gap:clamp(2rem,4vw,3.5rem);

  /* Fluid type scale */
  --fs-body:clamp(1rem,.96rem + .25vw,1.0625rem);
  --fs-lead:clamp(1.15rem,1rem + 1vw,1.5rem);
  --fs-h3:clamp(1.4rem,1.1rem + 1.4vw,2rem);
  --fs-h2:clamp(2.2rem,1.6rem + 3.2vw,4rem);
  --fs-h1:clamp(3.4rem,2rem + 8vw,7.5rem);
  --lh-head:1.12;

  /* Aspect ratios for rhythm */
  --ar-banner:21/9;--ar-wide:4/3;--ar-portrait:3/4;--ar-square:1/1;

  /* Corner radii */
  --r-sm:14px;--r-md:20px;--r-lg:28px;

  /* Lake-tinted shadows */
  --shadow-card:0 4px 24px rgba(44,95,124,.07);
  --shadow-img:0 14px 44px rgba(44,95,124,.14);
  --focus:0 0 0 3px rgba(212,166,87,.55);
}

html{scroll-behavior:smooth}
body{font-family:var(--sans);font-weight:300;color:var(--charcoal);background:var(--sand);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none;transition:color var(--t)}
ul{list-style:none}
img{max-width:100%}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:var(--lh-head)}
h2{font-size:var(--fs-h2);letter-spacing:-.02em}
h3{font-size:var(--fs-h3)}
h4{font-size:.95rem;font-family:var(--sans);font-weight:600}
p{font-size:var(--fs-body);line-height:1.75}

/* ============ UTILITIES ============ */
.wrap{max-width:var(--content);margin-inline:auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:var(--content-wide);margin-inline:auto;padding-inline:var(--gutter)}
.wrap-text{max-width:var(--text);margin-inline:auto;padding-inline:var(--gutter)}
.grid12{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--col-gap)}
.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}

.sec-head{text-align:center;max-width:var(--text);margin:0 auto var(--block-gap)}
.sec-head h2{margin-top:.3rem}
.sub{color:var(--drift);margin:.7rem auto 0;font-size:var(--fs-body);max-width:54ch}

.label{
  position:relative;display:inline-block;font-size:.7rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--label);
  margin-bottom:.9rem;padding-bottom:.7rem;
}
/* Eyebrow wave flourish (replaces the straight underline) */
.label::after{
  content:'';position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:clamp(36px,8vw,56px);height:8px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 44 8'%3E%3Cpath d='M1 5 Q6 1 11 5 T21 5 T31 5 T41 5' fill='none' stroke='%23D4A657' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center/contain;
}
/* left-aligned label variant */
.kontakt-text .label::after{left:0;transform:none}

/* Focus */
a:focus-visible,button:focus-visible,.btn:focus-visible,summary:focus-visible,
.banner-dot:focus-visible,.specials-toggle:focus-visible{
  outline:none;box-shadow:var(--focus);border-radius:8px;
}
.btn-glass:focus-visible,.hero-status:focus-visible,
.nav:not(.scrolled) .nav-links a:focus-visible{
  box-shadow:0 0 0 3px rgba(255,255,255,.7);
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2.1rem;border-radius:50px;font-family:var(--sans);font-size:.84rem;font-weight:700;letter-spacing:.03em;transition:all var(--t);cursor:pointer;border:none}
.btn-warm{background:var(--sunset);color:var(--white)}
.btn-warm:hover{background:var(--rose);transform:translateY(-2px);box-shadow:0 10px 28px rgba(194,125,125,.3)}
.btn-glass{background:rgba(255,255,255,.15);color:var(--white);border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.btn-glass:hover{background:rgba(255,255,255,.26);border-color:rgba(255,255,255,.6);transform:translateY(-2px)}
.btn-sage{background:#7A8B6F;color:var(--white)}
.btn-sage:hover{background:#5C6B52;transform:translateY(-2px);box-shadow:0 10px 26px rgba(92,107,82,.3)}
.btn-lake{background:var(--lake);color:var(--white)}
.btn-lake:hover{background:var(--lake-deep);transform:translateY(-2px);box-shadow:0 10px 28px rgba(26,58,79,.4)}

/* ============ BANNER OVERLAY ============ */
.banner-overlay{position:fixed;inset:0;z-index:9999;background:rgba(26,58,79,.55);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}
.banner-overlay.visible{opacity:1;pointer-events:auto}
.banner-modal{position:relative;width:92%;max-width:440px;background:var(--sand);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.25);transform:translateY(20px);transition:transform .3s ease}
.banner-overlay.visible .banner-modal{transform:translateY(0)}
.banner-modal.banner-wide{max-width:680px}
.banner-close{position:absolute;top:12px;right:12px;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);border:none;cursor:pointer;font-size:1.3rem;line-height:1;color:var(--charcoal);display:flex;align-items:center;justify-content:center;transition:background .2s}
.banner-close:hover{background:#fff}
.banner-images{position:relative;width:100%;min-height:0}
.banner-images img{position:absolute;top:0;left:0;width:100%;display:block;opacity:0;transition:opacity .5s ease}
.banner-images img.active{position:relative;opacity:1}
.banner-images.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px;padding:6px}
.banner-images.gallery img{position:relative;opacity:1;aspect-ratio:1;object-fit:cover;border-radius:12px}
.banner-dots{display:flex;justify-content:center;gap:6px;padding:.5rem 0}
.banner-dots:empty{display:none}
.banner-dot{width:7px;height:7px;border-radius:50%;background:rgba(0,0,0,.15);border:none;cursor:pointer;padding:0;transition:background .2s}
.banner-dot.active{background:var(--lake)}
.banner-content{padding:1.25rem 1.5rem 1.5rem;text-align:center}
.banner-content.no-images{padding-top:2.5rem}
.banner-title{font-family:var(--serif);font-size:1.2rem;font-weight:500;color:var(--charcoal);margin-bottom:.25rem}
.banner-subtitle{font-size:.85rem;color:var(--drift);margin-bottom:.6rem}
.banner-text{font-size:.92rem;color:var(--charcoal);line-height:1.7;white-space:pre-line;margin-bottom:1rem}
.banner-cta{display:inline-block;padding:.7rem 1.8rem;background:var(--sunset);color:#fff;border-radius:50px;font-family:var(--sans);font-size:.82rem;font-weight:700;letter-spacing:.03em;text-decoration:none;transition:all .25s ease}
.banner-cta:hover{background:var(--rose);transform:translateY(-2px)}

/* ============ MOBILE BAR ============ */
.m-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1100;background:var(--white);border-top:1px solid var(--sand-warm);padding:.6rem 1.5rem;align-items:center;justify-content:space-between;box-shadow:0 -4px 20px rgba(0,0,0,.06)}
.m-bar-left{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;margin-right:.7rem}
.m-dot{width:8px;height:8px;border-radius:50%}
.m-dot.open{background:#6aba6a;box-shadow:0 0 0 0 rgba(106,186,106,.5);animation:dotPulse 2.4s ease-out infinite}
.m-dot.closed{background:var(--lake-pale)}
@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(106,186,106,.5)}70%{box-shadow:0 0 0 7px rgba(106,186,106,0)}100%{box-shadow:0 0 0 0 rgba(106,186,106,0)}}
.m-text{font-size:.78rem;font-weight:500;color:var(--charcoal);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.m-bar-btn{display:inline-flex;align-items:center;min-height:44px;background:var(--sunset);color:var(--white);padding:.5rem 1.2rem;border-radius:50px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 0;transition:all var(--t)}
.nav.scrolled{background:rgba(253,249,243,.92);backdrop-filter:blur(20px);padding:.7rem 0;box-shadow:0 2px 30px rgba(0,0,0,.05)}
.nav-inner{max-width:var(--content-wide);margin:0 auto;padding:0 var(--gutter);display:flex;justify-content:space-between;align-items:center}
.nav-logo{font-family:var(--serif);font-size:1.4rem;font-weight:500;color:var(--white);letter-spacing:.02em;text-shadow:0 2px 12px rgba(26,58,79,.4)}
.nav.scrolled .nav-logo{color:var(--lake);text-shadow:none}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a{position:relative;font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.92);text-shadow:0 1px 10px rgba(26,58,79,.45);transition:color var(--t)}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--sunset-glow);transition:width var(--t)}
.nav.scrolled .nav-links a{color:var(--drift);text-shadow:none}
.nav.scrolled .nav-links a::after{background:var(--sunset)}
.nav-links a:hover::after{width:100%}
.nav-links a:hover{color:var(--white)}
.nav.scrolled .nav-links a:hover{color:var(--charcoal)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:1001}
.nav-toggle span{width:24px;height:1.6px;background:var(--white);box-shadow:0 1px 6px rgba(26,58,79,.4);transition:all var(--t)}
.nav.scrolled .nav-toggle span{background:var(--charcoal);box-shadow:none}
.nav-overlay{position:fixed;inset:0;background:rgba(26,58,79,.3);z-index:999;opacity:0;visibility:hidden;transition:all var(--t)}
.nav-overlay.active{opacity:1;visibility:visible}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;color:var(--white)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%;transform:scale(1.05);animation:slowzoom 22s ease-in-out infinite alternate}
@keyframes slowzoom{to{transform:scale(1.12)}}
/* warm-led overlay: golden top, soft rose mid, deep lake at the waterline */
.hero-tint{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(212,166,87,.32) 0%,rgba(194,125,125,.16) 42%,rgba(26,58,79,.58) 100%),
  radial-gradient(ellipse at 50% 28%,rgba(237,207,155,.26),transparent 60%)}
.hero-content{position:relative;z-index:3;padding:7rem 1.5rem 10rem;max-width:760px}
.hero-logo{width:clamp(180px,30vw,300px);height:auto;display:block;margin:0 auto 1.6rem;filter:brightness(0) invert(1);opacity:.96}
.hero-eyebrow{font-size:clamp(.78rem,.7rem + .4vw,.92rem);font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--sunset-glow);margin-bottom:1.2rem;text-shadow:0 2px 14px rgba(26,58,79,.55)}
.hero-poem{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.4rem,1.1rem + 1.8vw,2.2rem);color:#fff;margin:1.3rem auto 0;max-width:24ch;line-height:1.45;text-shadow:0 2px 16px rgba(26,58,79,.75),0 4px 12px rgba(0,0,0,.35)}
.hero-poem em{color:var(--sunset-glow);font-style:italic}
.hero-status{display:inline-flex;align-items:center;gap:.6rem;margin:2rem auto 1.8rem;padding:.66rem 1.5rem;border-radius:50px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.42);backdrop-filter:blur(8px);font-family:var(--sans);font-weight:700;font-size:.95rem;color:#fff;white-space:nowrap;transition:all var(--t)}
.hero-status:hover{background:rgba(255,255,255,.26)}
.hero-status .m-dot{width:10px;height:10px}
.hero-ctas{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-waves{position:absolute;left:0;right:0;bottom:-1px;z-index:2;line-height:0}
.hero-waves svg{display:block;width:100%;height:clamp(80px,10vw,140px)}

/* Wave drift animation (shared by hero) */
.wave-layer{animation:waveDrift 14s ease-in-out infinite alternate}
.wave-layer.b{animation-duration:9s;animation-direction:alternate-reverse}
.wave-layer.c{animation-duration:19s}
@keyframes waveDrift{from{transform:translateX(-30px)}to{transform:translateX(30px)}}

/* ============ WAVE SECTION DIVIDERS ============ */
.besuch,.kontakt,.partners,.join,.fullbleed{position:relative}
.besuch::after,.kontakt::after,.partners::after,.join::after,
.fullbleed::before,.fullbleed::after{
  content:'';position:absolute;left:0;right:0;height:clamp(38px,6vw,64px);
  background-repeat:no-repeat;background-size:100% 100%;z-index:4;pointer-events:none;
}
/* bottom waves rising in the next section's colour (sand-warm) */
.besuch::after,.partners::after,.fullbleed-aerial::after{bottom:-1px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0 30 C240 55 480 10 720 32 C960 54 1200 12 1440 34 L1440 60 L0 60Z' fill='%23F5EDE0'/%3E%3C/svg%3E")}
/* bottom waves rising in the next section's colour (sand) */
.kontakt::after,.join::after,.fullbleed-heart::after{bottom:-1px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0 30 C240 55 480 10 720 32 C960 54 1200 12 1440 34 L1440 60 L0 60Z' fill='%23FDF9F3'/%3E%3C/svg%3E")}
/* top waves where a solid section flows down into a photo band */
.fullbleed-heart::before{top:-1px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0 0 L1440 0 L1440 28 C1200 52 960 6 720 28 C480 50 240 6 0 28 Z' fill='%23F5EDE0'/%3E%3C/svg%3E")}
.fullbleed-aerial::before{top:-1px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath d='M0 0 L1440 0 L1440 28 C1200 52 960 6 720 28 C480 50 240 6 0 28 Z' fill='%23FDF9F3'/%3E%3C/svg%3E")}

/* ============ KOMM VORBEI / BESUCH ============ */
.besuch{padding:var(--section-y) 0;background:var(--sand)}
.besuch-grid{display:grid;grid-template-columns:1fr;gap:var(--col-gap);align-items:stretch}
.hours-panel{display:flex;flex-direction:column;background:var(--white);border-radius:var(--r-lg);padding:1.8rem 2rem;border:1px solid rgba(44,95,124,.06);box-shadow:var(--shadow-card)}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:.66rem 0;border-bottom:1px dashed rgba(44,95,124,.18);font-size:.95rem}
.hours-row:last-child{border-bottom:none}
.hours-row span:first-child{color:var(--charcoal-l)}
.hours-row span:last-child{font-weight:600;color:var(--charcoal)}
.hours-row.closed span:last-child{font-weight:400;color:var(--drift);font-style:italic}
.hours-row.highlight{background:rgba(212,166,87,.12);border-radius:12px;margin:0 -.7rem;padding-left:.7rem;padding-right:.7rem;border-bottom-color:transparent}
.hours-row .special-day-label{color:var(--lake-light);font-weight:500;font-size:.82rem}
.hours-hint{margin-top:auto;padding-top:1rem;font-size:.8rem;color:var(--drift);font-style:italic;text-align:center}
.hours-hint a{color:var(--lake);text-decoration:underline;text-underline-offset:2px}
.weather-note{display:flex;align-items:center;justify-content:center;gap:.45rem;margin:-.2rem 0 1rem;padding:.7rem .9rem;border-radius:var(--r-sm);background:linear-gradient(135deg,#FBF1DC,var(--sunset-glow));color:var(--lake-deep);font-family:var(--serif);font-style:italic;font-size:clamp(.92rem,2.4vw,1rem);font-weight:500;text-align:center;line-height:1.3;text-wrap:balance}
.weather-note[hidden]{display:none}
.weather-note::before{content:'';flex:0 0 auto;width:16px;height:16px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23D4A657' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='12' cy='12' r='4.5'/%3E%3Cpath d='M12 2v2M12 20v2M2 12h2M20 12h2M5 5l1.5 1.5M17.5 17.5L19 19M19 5l-1.5 1.5M6.5 17.5L5 19'/%3E%3C/svg%3E") no-repeat center/contain}
.specials-list{margin-top:.75rem;border-top:1px solid rgba(0,0,0,.05);padding-top:.6rem}
.specials-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--drift);margin-bottom:.5rem}
.special-entry{padding:.45rem 0;font-size:.9rem}
.special-entry+.special-entry{margin-top:.35rem}
.special-entry .se-top{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem}
.special-entry .se-date{color:var(--charcoal-l)}
.special-entry .se-name{color:var(--lake);font-weight:500}
.special-entry .se-time{font-weight:600;color:var(--charcoal);white-space:nowrap}
.special-entry.special-closed .se-time{color:var(--drift);font-weight:400}
.special-entry .se-note{font-size:.8rem;color:var(--drift);font-style:italic;margin-top:.1rem}
.specials-toggle{display:inline-flex;align-items:center;gap:.3rem;background:none;border:none;cursor:pointer;font-size:.8rem;color:var(--lake-light);transition:color .2s;padding:.3rem 0;font-family:var(--sans)}
.specials-toggle:hover{color:var(--lake)}
.specials-toggle svg{width:12px;height:12px;transition:transform .25s}
.specials-toggle.expanded svg{transform:rotate(180deg)}
.besuch-photo{margin:0;min-height:300px}

/* Open, boxless invitation with a soft warm halo behind it.
   The halo lives on an oversized pseudo that fades fully to transparent well
   inside its own edges, so there is no hard cut against the sand. */
.besuch-welcome{position:relative;z-index:0;margin-top:var(--section-y);text-align:center;padding:clamp(1.5rem,4vw,2.5rem) 1rem}
.besuch-welcome::before{content:'';position:absolute;z-index:-1;inset:-55% -8%;pointer-events:none;
  background:radial-gradient(ellipse 56% 50% at 50% 50%,rgba(237,207,155,.46) 0%,rgba(237,207,155,0) 70%)}
.bw-flourish{display:block;width:74px;height:12px;margin:0 auto 1.3rem;opacity:.85;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 10'%3E%3Cpath d='M2 5 Q9 1 16 5 T30 5 T44 5 T58 5' fill='none' stroke='%23C27D7D' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center/contain}
.besuch-welcome .bw-main{font-family:var(--serif);font-style:italic;font-size:clamp(1.9rem,4vw,2.9rem);color:var(--lake-deep);line-height:1.12;margin:0}
.besuch-welcome .bw-sub{font-family:var(--sans);font-size:clamp(.98rem,2vw,1.12rem);color:var(--drift);line-height:1.6;max-width:42ch;margin:.95rem auto 0}
.besuch-welcome .bw-sub em{font-style:normal;font-weight:600;color:#A14E4E}

/* ============ SPEISEKARTE ============ */
.speisekarte{padding:var(--section-y) 0;background:var(--sand-warm)}
.food-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:var(--block-gap)}
.food-gallery figure{position:relative;margin:0}
.food-gallery img{aspect-ratio:var(--ar-square)}
.food-gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.5rem .9rem .8rem;color:#fff;font-size:.84rem;font-weight:600;letter-spacing:.02em;background:linear-gradient(to top,rgba(26,58,79,.74),transparent);transition:background var(--t)}
.food-gallery figure:hover figcaption{background:linear-gradient(to top,rgba(26,58,79,.84),transparent)}

.menu{display:flex;flex-direction:column;gap:var(--block-gap);max-width:var(--content);width:100%;margin-inline:auto}
.mcat{background:var(--white);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.4rem);border:1px solid rgba(44,95,124,.06);box-shadow:var(--shadow-card);transition:transform var(--t),box-shadow var(--t)}
.mcat:hover{transform:translateY(-3px);box-shadow:var(--shadow-img)}
.mcat-title{position:relative;display:block;font-size:clamp(1.5rem,3.4vw,2.2rem);color:var(--lake);font-style:italic;line-height:1;margin-bottom:.9rem;padding-bottom:.5rem}
.mcat-title::after{content:'';position:absolute;left:.08em;bottom:0;width:clamp(34px,6vw,54px);height:8px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 44 8'%3E%3Cpath d='M1 5 Q6 1 11 5 T21 5 T31 5 T41 5' fill='none' stroke='%23D4A657' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat left/contain}
.mgroups{display:flex;flex-direction:column}
.mcol{display:flex;flex-direction:column}
.mgroup{margin-top:0;margin-bottom:1.8rem}
.mgroup:last-of-type{margin-bottom:0}
.mgroup-head{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap;margin-bottom:.4rem;padding-bottom:.45rem;border-bottom:2px solid var(--sand-warm)}
.mgroup-head h4{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--charcoal)}
.mgroup-sub{font-size:.76rem;color:var(--lake-light);font-family:var(--sans);font-weight:500}
.mlist{display:flex;flex-direction:column}
.mrow{display:flex;justify-content:space-between;gap:1.25rem;align-items:baseline;padding:.62rem 0;border-bottom:1px solid rgba(44,95,124,.07)}
.mrow:last-child{border-bottom:none}
.mrow-l{flex:1 1 auto;min-width:0}
.mname{font-weight:600;color:var(--charcoal);font-size:.95rem}
.mtag{display:inline-block;margin-left:.5rem;vertical-align:middle;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--lake);background:rgba(44,95,124,.08);padding:.13rem .5rem;border-radius:50px}
.mdesc{display:block;font-size:.82rem;color:var(--drift);line-height:1.5;margin-top:.12rem;max-width:48ch}
.mopt{display:block;font-size:.8rem;color:var(--lake-light);margin-top:.22rem}
.mopt .mopt-price{color:var(--lake);font-weight:600}
.mrow-r{flex:0 0 auto;text-align:right;white-space:nowrap}
.munit{color:var(--drift);font-size:.72rem;margin-right:.55rem;font-variant-numeric:tabular-nums;white-space:nowrap}
.mprice{display:inline-block;min-width:2.6rem;text-align:right;font-weight:700;color:var(--lake);font-size:.92rem;font-variant-numeric:tabular-nums;white-space:nowrap}
.mprice.mprice-empty{color:var(--drift);font-style:italic;font-weight:400;font-size:.82rem}
.mprice-list{display:flex;flex-direction:column;gap:.18rem;align-items:flex-end}
.mprice-row{display:flex;align-items:baseline;justify-content:flex-end}
.menu-footnote{text-align:center;font-size:.84rem;color:var(--drift);max-width:560px;margin:var(--block-gap) auto 0;line-height:1.7}
.menu-footnote .mf-lead{display:block;font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--charcoal-l);margin-bottom:.4rem}
.menu-fallback{text-align:center;color:var(--drift);font-style:italic}

/* ============ FULLBLEED BANDS ============ */
.fullbleed{position:relative;width:100vw;margin-inline:calc(50% - 50vw);min-height:clamp(340px,52vh,560px);display:flex;align-items:center;justify-content:center;text-align:center;background-size:cover;background-position:center;overflow:hidden}
.fullbleed-heart{background-image:url('img/hands-heart.jpg')}
.fullbleed-aerial{background-image:url('img/arbon-aerial.jpg')}
.fb-tint{position:absolute;inset:0;z-index:1}
.fullbleed-heart .fb-tint{background:linear-gradient(180deg,rgba(212,166,87,.22),rgba(194,125,125,.3) 60%,rgba(26,58,79,.38))}
.fullbleed-aerial .fb-tint{background:linear-gradient(180deg,rgba(26,58,79,.28),rgba(26,58,79,.12) 40%,rgba(26,58,79,.5))}
.fb-content{position:relative;z-index:5;color:#fff;padding:5rem 1.5rem}
.fb-content-bottom{align-self:flex-end;width:100%;padding-bottom:clamp(4rem,7vw,5.5rem)}
.curved-word{display:block;width:min(90vw,560px);height:120px;margin:0 auto;overflow:visible}
.curved-word text{font-family:var(--serif);font-style:italic;font-size:60px;fill:#fff;filter:drop-shadow(0 2px 6px rgba(26,58,79,.85)) drop-shadow(0 4px 18px rgba(0,0,0,.45))}
.fb-sub{font-family:var(--serif);font-style:italic;font-size:var(--fs-lead);color:rgba(255,255,255,.95);margin-top:.4rem;text-shadow:0 2px 14px rgba(26,58,79,.5)}
.fb-caption{font-family:var(--serif);font-style:italic;font-size:clamp(1rem,2vw,1.3rem);color:#fff;max-width:40ch;margin:0 auto;text-shadow:0 2px 16px rgba(26,58,79,.6)}

/* ============ STORY ============ */
.story{padding:var(--section-y-lg) 0;background:var(--sand)}
.story-intro{text-align:center;max-width:var(--text);margin:0 auto var(--block-gap)}
.story-intro h2{margin-top:.3rem}
.story-body{align-items:start}
.story-text{grid-column:1/-1;max-width:var(--text)}
.story-lead{font-family:var(--serif);font-size:var(--fs-lead);font-weight:400;color:var(--charcoal);line-height:1.7;margin-bottom:1.6rem}
.story-lead em{color:var(--lake);font-style:italic}
.story-text p{color:var(--charcoal-l);line-height:1.9;margin-bottom:1rem}
.story-block-quote{margin:2rem 0;padding:2rem 2.25rem;background:linear-gradient(135deg,var(--lake-pale),#d8eaf0);border-radius:var(--r-lg);position:relative}
.story-block-quote::before{content:'\201C';position:absolute;top:.4rem;left:1.4rem;font-family:var(--serif);font-size:4rem;color:var(--lake);opacity:.2;line-height:1}
.story-block-quote blockquote{font-family:var(--serif);font-size:1.1rem;font-style:italic;color:var(--lake-deep);line-height:1.7;margin:0}
.story-block-quote cite{display:block;margin-top:.75rem;font-style:normal;font-family:var(--sans);font-size:.78rem;font-weight:700;color:var(--lake);letter-spacing:.03em}
.story-figure{grid-column:1/-1;margin:2rem 0 0}
.story-figure img{aspect-ratio:var(--ar-wide)}

/* ============ KONTAKT ============ */
.kontakt{padding:var(--section-y) 0;background:var(--sand-warm)}
.kontakt-inner{align-items:start}
.kontakt-text{grid-column:1/-1;display:flex;flex-direction:column;gap:1.8rem}
.kontakt-text h2{margin:.3rem 0 1rem}
.kontakt-lead>p{color:var(--charcoal-l);line-height:1.8;max-width:46ch}
.kontakt-extra{display:grid;grid-template-columns:1fr;gap:1.25rem;grid-column:1/-1}
.social-icons{display:flex;gap:.6rem;margin-top:.45rem}
@media(min-width:600px){
  .kontakt-extra{grid-template-columns:repeat(3,1fr);gap:1.5rem 2rem;align-items:start}
}
.ki strong{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--charcoal);margin-bottom:.15rem}
.ki p{color:var(--charcoal-l);font-size:.9rem}
.ki-note{display:inline-block;margin-top:.25rem;font-size:.76rem;font-style:italic;color:var(--drift);line-height:1.4}
.ki a:hover{color:var(--lake)}
.ki-route{display:inline-flex;align-items:center;gap:.3rem;margin-top:.35rem;font-size:.82rem;font-weight:700;color:var(--lake);text-decoration:underline;text-underline-offset:3px;transition:color var(--t),gap var(--t)}
.ki-route:hover{color:var(--sunset);gap:.5rem}
.social{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.social-lead{font-size:.82rem;font-weight:600;color:var(--drift)}
.social-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1.5px solid var(--lake);color:var(--lake);transition:all var(--t)}
.social-icon:hover{background:var(--lake);color:#fff;transform:translateY(-3px);box-shadow:0 8px 20px rgba(44,95,124,.22)}
.social-icon svg{width:20px;height:20px}
.kontakt-map{grid-column:1/-1;min-height:340px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-img)}
.kontakt-map iframe{width:100%;height:100%;min-height:340px;display:block}

/* ============ PARTNER ============ */
.partners{padding:var(--section-y) 0;background:var(--sand)}
.partner-logos{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;align-items:center;margin-bottom:1.75rem}
.partner-logo{margin:0;display:flex;align-items:center;justify-content:center;height:96px;padding:1rem 1.7rem;background:var(--white);border-radius:var(--r-md);border:1px solid rgba(44,95,124,.05);box-shadow:var(--shadow-card);transition:transform var(--t),box-shadow var(--t)}
.partner-logo:hover{transform:translateY(-4px);box-shadow:var(--shadow-img)}
.partner-logo img{max-height:60px;width:auto;object-fit:contain}
.partner-logo.partner-schott img{max-height:34px}
.partner-logo.partner-herter img{max-height:54px}
.partner-credits{text-align:center;font-size:.84rem;color:var(--drift);max-width:560px;margin:0 auto;line-height:1.8}
.partner-credits strong{color:var(--lake);font-weight:700}

/* ============ MITMACHEN / JOBS ============ */
.join{padding:var(--section-y) 0;background:var(--sand-warm);text-align:center}
.join-inner .label{margin-left:auto;margin-right:auto}
.join-inner h2{margin:.3rem 0 1rem}
.join-inner p{color:var(--charcoal-l);max-width:48ch;margin:0 auto 1.9rem;line-height:1.8}

/* ============ SCHWESTER ============ */
.schwester{padding:var(--section-y) 0;background:var(--sand)}
.schwester-inner{display:grid;grid-template-columns:1fr;gap:0;background:linear-gradient(135deg,#F3EFE4,#E1E6D4);border:1px solid rgba(122,139,111,.28);border-radius:32px;overflow:hidden}
.schwester-text{padding:clamp(2.2rem,4vw,3.4rem)}
.schwester-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:#5C6B52;margin-bottom:.5rem}
.schwester-inner h3{margin-bottom:.75rem}
.schwester-inner h3 a{color:#3F4A33;transition:color var(--t)}
.schwester-inner h3 a:hover{color:#7A8B6F}
.schwester-text>p{color:var(--charcoal-l);margin:0 0 1.5rem;line-height:1.7;max-width:48ch}
.schwester-mark{display:none;place-items:center;padding:clamp(1.6rem,3vw,2.6rem);background:linear-gradient(135deg,#E1E6D4,#cfd7be)}
.schwester-mark picture{display:block;width:min(74%,280px);margin:0 auto}
.schwester-mark img{display:block;width:100%;height:auto}

/* ============ FOOTER ============ */
.footer{background:var(--charcoal);color:rgba(255,255,255,.55);padding:3.5rem 0 2rem}
.footer-inner{text-align:center}
.footer-brand h3{font-family:var(--serif);font-size:1.4rem;color:var(--white);margin-bottom:.35rem}
.footer-brand p{font-size:.88rem;line-height:1.6;margin:0 auto 1rem}
.footer-logo{width:76px;height:76px;margin:0 auto 1rem;display:block;filter:brightness(0) invert(1);opacity:.85}
.footer .social{justify-content:center;margin-bottom:1.5rem}
.footer .social-lead{color:rgba(255,255,255,.6)}
.footer .social-icon{border-color:rgba(255,255,255,.4);color:rgba(255,255,255,.85)}
.footer .social-icon:hover{background:var(--sunset);border-color:var(--sunset);color:#fff;box-shadow:0 8px 20px rgba(212,166,87,.3)}
.footer-base{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.4rem 1rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08)}
.footer-copy{font-size:.74rem}
.footer-credit{display:inline-flex;align-items:center;gap:.5rem;font-size:.74rem;opacity:.55;transition:opacity var(--t)}
.footer-credit:hover{opacity:1}
.footer-credit img{height:14px;width:auto;filter:invert(1)}

/* ============ SHARED IMAGE FRAMES ============ */
.story-figure,.besuch-photo,.food-gallery figure{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-img)}
.story-figure img,.besuch-photo img,.food-gallery img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-soft)}
.story-figure:hover img,.besuch-photo:hover img,.food-gallery figure:hover img{transform:scale(1.04)}
.story-figure{position:relative}
.story-figure figcaption{position:absolute;left:0;right:0;bottom:0;font-family:var(--serif);font-style:italic;font-size:.84rem;color:#fff;padding:2.5rem 1.25rem .9rem;background:linear-gradient(to top,rgba(26,58,79,.8),transparent)}

/* ============ ANIMATIONS ============ */
.fade-in{opacity:0;transform:translateY(18px);animation:fadeUp .8s ease forwards}
.fade-in:nth-child(1){animation-delay:.05s}.fade-in:nth-child(2){animation-delay:.2s}
.fade-in:nth-child(3){animation-delay:.35s}.fade-in:nth-child(4){animation-delay:.5s}
.fade-in:nth-child(5){animation-delay:.65s}.fade-in:nth-child(6){animation-delay:.8s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease-soft),transform .6s var(--ease-soft);transition-delay:var(--reveal-delay,0s)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ============ DESKTOP LAYOUTS ============ */
@media(min-width:900px){
  /* Besuch: asymmetric 5/7, photo overruns to the right */
  .besuch-grid{grid-template-columns:5fr 7fr;gap:var(--col-gap)}
  .besuch-photo{min-height:420px}

  /* Speisekarte: groups split into two columns that start flush at the top */
  .mcat-title{margin-bottom:1.2rem}
  .mgroups{display:grid;grid-template-columns:1fr 1fr;gap:0 3rem;align-items:start}
  .mgroups:has(.mcol:only-child){display:block}

  /* Story: editorial sticky split */
  .story-text{grid-column:1/7}
  .story-figure{grid-column:8/13;margin:0;position:sticky;top:12vh;align-self:start;max-height:80vh}
  .story-figure img{aspect-ratio:var(--ar-portrait);max-height:80vh}

  /* Kontakt: 5/7 */
  .kontakt-text{grid-column:1/7;justify-content:space-between;gap:2rem}
  .kontakt-map{grid-column:7/13;min-height:480px}
  .kontakt-map iframe{min-height:480px}
  .kontakt-extra{grid-column:1/-1;margin-top:2.4rem}

  /* Schwester: wide asymmetric card */
  .schwester-inner{grid-template-columns:1.4fr 1fr}
  .schwester-mark{display:grid}
}

/* Subtle parallax on the photo bands (desktop only, iOS-safe via media query) */
@media(min-width:1025px) and (hover:hover){
  .fullbleed-heart,.fullbleed-aerial{background-attachment:fixed}
}

/* ============ RESPONSIVE (mobile refinements) ============ */
@media(max-width:899px){
  body{padding-bottom:56px}
  .m-bar{display:flex}
  .nav-toggle{display:flex}
  .nav-links{position:fixed;top:0;right:-100%;width:80%;max-width:300px;height:100vh;background:var(--sand);flex-direction:column;justify-content:center;gap:1.4rem;padding:2rem;transition:right .5s cubic-bezier(.4,0,.2,1);box-shadow:-10px 0 40px rgba(0,0,0,.08)}
  .nav-links.open{right:0}
  .nav-links a{color:var(--charcoal)!important;font-size:1rem;text-shadow:none!important}
  .nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
  .nav-toggle.active span:nth-child(2){opacity:0}
  .nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
  .nav-toggle.active span{background:var(--charcoal)!important;box-shadow:none}
  /* Mobile already has a fixed bar at the bottom with the live status and a
     "Komm vorbei" button, so drop both duplicates from the hero. */
  .hero-status{display:none}
  .hero-ctas .btn-lake{display:none}
  .hero-ctas{margin-top:clamp(2rem,7vw,3rem)}
}
@media(max-width:600px){
  /* Food gallery becomes a clean swipe carousel on phones */
  .food-gallery{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;margin-inline:calc(-1*var(--gutter));padding:.25rem var(--gutter) .9rem;scrollbar-width:none}
  .food-gallery::-webkit-scrollbar{display:none}
  .food-gallery figure{flex:0 0 84%;scroll-snap-align:center}
  .food-gallery img{aspect-ratio:4/3}
  .food-gallery figcaption{font-size:.82rem;padding:1.5rem .9rem .8rem}
  .hero-logo{width:min(64vw,280px)}
  .hero-ctas{flex-direction:column;align-items:center;width:100%}
  .hero-ctas .btn{width:100%;max-width:280px;justify-content:center}
  .curved-word text{font-size:46px}
  .besuch-photo{min-height:240px}
  .kontakt-map,.kontakt-map iframe{min-height:280px}
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  html{scroll-behavior:auto}
  .fade-in{opacity:1;transform:none}
  .reveal{opacity:1;transform:none}
  .hero-bg img,.wave-layer,.m-dot.open{animation:none;transform:none}
  .story-figure{position:static}
  .fullbleed-heart,.fullbleed-aerial{background-attachment:scroll!important}
}

/* ============ PRINT ============ */
@media print{
  .m-bar,.nav,.nav-overlay,.hero-waves,.kontakt-map,.banner-overlay,.footer-credit,
  .besuch::after,.kontakt::after,.partners::after,.join::after,.fullbleed::before,.fullbleed::after{display:none!important}
  body{padding-bottom:0;color:#000;background:#fff}
  .hero{min-height:auto;color:#000;background:#fff}
  .hero-bg,.hero-tint{display:none}
  .hero-content{color:#000}
  .reveal,.fade-in{opacity:1!important;transform:none!important}
  section{page-break-inside:avoid}
  .mcat,.hours-panel,.partner-logo{box-shadow:none;border:1px solid #ddd}
  a{color:#000;text-decoration:underline}
}
