/* =========================================================
   Schiffsrestaurant "Marie Gerda" — maritimes Stylesheet
   Palette: Elbe-Blau, warmes Creme, Messing-Akzent
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Mulish:wght@400;500;600;700;800&display=swap');

:root{
  --navy:#102a39;
  --navy-2:#173b4f;
  --blue:#2f6f8f;
  --blue-bright:#5aa0bf;
  --sand:#f1e9da;
  --paper:#faf6ee;
  --paper-2:#f5efe3;
  --ink:#1c2a31;
  --muted:#5c6b72;
  --brass:#b9863f;
  --brass-soft:#caa066;
  --line:rgba(16,42,57,.12);
  --line-strong:rgba(16,42,57,.2);
  --shadow:0 18px 50px -22px rgba(16,42,57,.45);
  --shadow-sm:0 8px 24px -14px rgba(16,42,57,.4);
  --font-display:'Spectral',Georgia,serif;
  --font-body:'Mulish',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --maxw:1140px;
  --gutter:clamp(20px,5vw,48px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:var(--blue);text-decoration:none;}
a:hover{color:var(--navy);}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.12;color:var(--navy);margin:0;}
p{margin:0 0 1.1em;text-wrap:pretty;}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
.kicker{
  font-family:var(--font-body);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--brass);
  margin:0 0 .9rem;
  display:flex;align-items:center;gap:.65rem;
}
.kicker::before{content:"";width:26px;height:1px;background:var(--brass);display:inline-block;}
.kicker.center{justify-content:center;}

/* ---------------- Top strip ---------------- */
.topbar{
  background:var(--navy);
  color:#cfe0e8;
  font-size:.82rem;
  letter-spacing:.02em;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:40px;flex-wrap:wrap;}
.topbar a{color:#cfe0e8;}
.topbar a:hover{color:#fff;}
.topbar .status{display:inline-flex;align-items:center;gap:.5rem;}
.topbar .dot{width:8px;height:8px;border-radius:50%;background:var(--brass-soft);box-shadow:0 0 0 3px rgba(202,160,102,.25);}

/* ---------------- Navigation ---------------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(250,246,238,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s ease;
}
.nav.scrolled{box-shadow:0 10px 30px -20px rgba(16,42,57,.6);}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;min-height:78px;gap:1rem;}
.brand{display:flex;align-items:center;gap:.85rem;}
.brand .mark{
  width:50px;height:50px;border-radius:50%;
  border:1.5px solid var(--brass);
  display:grid;place-items:center;
  color:var(--navy);font-family:var(--font-display);
  font-weight:600;font-size:1.2rem;letter-spacing:.02em;
  background:linear-gradient(160deg,#fff,var(--paper-2));
  flex:none;
}
.brand .txt{line-height:1.05;}
.brand .txt b{display:block;font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--navy);}
.brand .txt span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
.menu{display:flex;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0;}
.menu a{
  font-weight:700;font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--navy);padding:.6rem .85rem;border-radius:8px;position:relative;
}
.menu a::after{
  content:"";position:absolute;left:.85rem;right:.85rem;bottom:.35rem;height:2px;
  background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .25s ease;
}
.menu a:hover{color:var(--blue);}
.menu a:hover::after,.menu a[aria-current="page"]::after{transform:scaleX(1);}
.menu a[aria-current="page"]{color:var(--blue);}
.nav-toggle{display:none;background:none;border:none;padding:.3rem .1rem;margin-left:auto;cursor:pointer;color:var(--navy);align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;}
.nav-toggle .bars{font-size:1.9rem;line-height:1;}

/* ---------------- Hero / Slider ---------------- */
.hero{position:relative;overflow:hidden;background:var(--navy);}
.hero.full{height:clamp(420px,76vh,680px);}
.hero.compact{height:clamp(260px,40vh,360px);}
.slides{position:absolute;inset:0;}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease, transform 6s ease;background-size:cover;background-position:center;transform:scale(1.05);}
.slide.active{opacity:1;transform:scale(1);}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,42,57,.5) 0%,rgba(16,42,57,.15) 35%,rgba(16,42,57,.78) 100%);}
.hero-inner{position:relative;z-index:3;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:clamp(34px,6vh,64px);}
.hero-inner .kicker{color:var(--brass-soft);}
.hero h1{color:#fff;font-size:clamp(2.4rem,6vw,4.4rem);text-shadow:0 2px 30px rgba(0,0,0,.35);font-weight:600;}
.hero .lead{color:#e7eef2;font-size:clamp(1.05rem,2.2vw,1.4rem);max-width:42ch;margin-top:.6rem;text-shadow:0 1px 14px rgba(0,0,0,.4);}
.hero.compact .hero-inner{justify-content:center;}
.hero.compact h1{font-size:clamp(2rem,5vw,3.2rem);}

.slider-ctrl{position:absolute;z-index:4;bottom:clamp(34px,6vh,64px);right:var(--gutter);display:flex;gap:.5rem;}
.slider-ctrl button{
  width:46px;height:46px;border-radius:50%;border:1.5px solid rgba(255,255,255,.55);
  background:rgba(16,42,57,.25);color:#fff;font-size:1.1rem;cursor:pointer;
  display:grid;place-items:center;transition:background .2s,border-color .2s;
}
.slider-ctrl button:hover{background:rgba(255,255,255,.2);border-color:#fff;}
.dots{position:absolute;z-index:4;bottom:calc(clamp(34px,6vh,64px) + 4px);left:var(--gutter);display:flex;gap:.5rem;}
.dots button{width:34px;height:4px;border:none;border-radius:4px;background:rgba(255,255,255,.4);cursor:pointer;padding:0;transition:background .25s;}
.dots button.active{background:var(--brass-soft);}

/* ---------------- Sections ---------------- */
section{padding-block:clamp(56px,9vw,104px);}
.section-head{max-width:720px;}
.section-head.center{margin-inline:auto;text-align:center;}
h2{font-size:clamp(1.9rem,4vw,3rem);margin-bottom:.5rem;}
.section-head p{color:var(--muted);font-size:1.1rem;}
.sand{background:var(--sand);}
.paper2{background:var(--paper-2);}

.lead-2{font-size:clamp(1.15rem,2.3vw,1.45rem);font-family:var(--font-display);color:var(--navy-2);line-height:1.5;font-weight:500;}

/* two-column intro */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,68px);align-items:center;}
.split.text-first{grid-template-columns:.95fr 1.05fr;}
@media(max-width:860px){.split,.split.text-first{grid-template-columns:1fr;}}

/* Figure / photo frame */
.figure{position:relative;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);background:var(--navy);}
.figure img{width:100%;height:100%;object-fit:cover;display:block;}
.figure.tall{aspect-ratio:4/3;}
.figure.wide{aspect-ratio:16/7;}
.figure .cap{position:absolute;left:0;bottom:0;padding:.7rem 1rem;background:linear-gradient(0deg,rgba(16,42,57,.8),transparent);color:#dce8ed;font-size:.8rem;letter-spacing:.04em;width:100%;}
.figure .frame-tag{position:absolute;top:14px;left:14px;background:var(--brass);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.3rem .65rem;border-radius:5px;}

/* Image placeholder (striped) */
.ph{
  position:relative;background:
    repeating-linear-gradient(45deg,#e4dac6 0 14px,#ece3d2 14px 28px);
  display:grid;place-items:center;color:#9a8a6a;
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem;letter-spacing:.04em;text-align:center;padding:1rem;
}
.figure.tall .ph,.figure.wide .ph{position:absolute;inset:0;}

/* Feature cards */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden;}
.feature{background:var(--paper);padding:clamp(24px,3vw,34px);}
.feature .num{font-family:var(--font-display);font-size:2.4rem;color:var(--brass);line-height:1;}
.feature h3{font-size:1.18rem;margin:.5rem 0 .35rem;}
.feature p{color:var(--muted);font-size:.96rem;margin:0;}

/* Info cards (Busreisen / Feiern / Camper) */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(18px,2.5vw,28px);}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  padding:clamp(26px,3vw,36px);box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
}
.card .tab{font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);margin-bottom:.7rem;}
.card h3{font-size:1.5rem;margin-bottom:.7rem;}
.card ul{list-style:none;margin:.2rem 0 0;padding:0;}
.card li{position:relative;padding-left:1.5rem;margin-bottom:.55rem;color:var(--ink);}
.card li::before{content:"";position:absolute;left:0;top:.6em;width:8px;height:8px;background:var(--blue);transform:rotate(45deg);}
.card li.dim{color:var(--muted);}
.card .foot{margin-top:auto;padding-top:1rem;color:var(--muted);font-style:italic;font-family:var(--font-display);}

/* Prose (Geschichte etc.) */
.prose{max-width:74ch;}
.prose p{font-size:1.08rem;}
.prose .first::first-letter{font-family:var(--font-display);font-size:3.4rem;float:left;line-height:.8;padding:.08em .12em 0 0;color:var(--brass);font-weight:600;}
.pull{border-left:3px solid var(--brass);padding:.2rem 0 .2rem 1.4rem;margin:2rem 0;font-family:var(--font-display);font-size:1.4rem;color:var(--navy-2);font-style:italic;line-height:1.4;}

/* timeline */
.timeline{list-style:none;margin:2.4rem 0 0;padding:0;border-left:2px solid var(--line-strong);}
.timeline li{position:relative;padding:0 0 1.8rem 2rem;}
.timeline li::before{content:"";position:absolute;left:-7px;top:.4em;width:12px;height:12px;border-radius:50%;background:var(--brass);border:2px solid var(--paper);}
.timeline .yr{font-family:var(--font-display);font-weight:700;color:var(--blue);font-size:1.15rem;display:block;margin-bottom:.15rem;}

/* Event card (Termine) */
.card.event{flex-direction:row;gap:clamp(20px,3vw,32px);padding:0;overflow:hidden;align-items:stretch;}
.event-date{flex:none;width:clamp(96px,18vw,132px);background:var(--navy);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.6rem 1rem;}
.event-date .ev-wd{font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);}
.event-date .ev-d{font-family:var(--font-display);font-size:3.4rem;line-height:1;margin:.18rem 0;}
.event-date .ev-m{font-size:.92rem;color:#dce8ed;}
.event-body{padding:clamp(24px,3vw,34px);display:flex;flex-direction:column;}
.event-body h3{font-size:1.5rem;margin-bottom:.6rem;}
.event-body > p{color:var(--ink);}
.event-actions{margin-top:auto;}
.event-actions .btn{margin-top:1.4rem;}
@media(max-width:560px){
  .card.event{flex-direction:column;}
  .event-date{flex-direction:row;gap:.5rem;width:auto;padding:1rem;}
  .event-date .ev-d{font-size:2.2rem;margin:0;}
}

/* Contact + hours band (shared footer) */
.contact-band{background:var(--navy);color:#dce8ed;}
.contact-band .wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(32px,5vw,64px);}
@media(max-width:760px){.contact-band .wrap{grid-template-columns:1fr;}}
.contact-band .kicker{color:var(--brass-soft);}
.contact-band h2{color:#fff;}
.contact-band a{color:#fff;}
.contact-block .name{font-family:var(--font-display);font-size:1.4rem;color:#fff;margin-bottom:.4rem;}
.contact-block p{margin:.15rem 0;color:#bcd0d9;}
.contact-block .tel{display:inline-flex;align-items:center;gap:.6rem;margin-top:1rem;font-size:1.25rem;font-family:var(--font-display);color:#fff;}
.hours{border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:clamp(22px,3vw,30px);background:rgba(255,255,255,.04);}
.hours .open-flag{display:inline-block;background:var(--brass);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .7rem;border-radius:5px;margin-bottom:1rem;}
.hours dl{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1.5rem;margin:0;}
.hours dt{color:#bcd0d9;}
.hours dd{margin:0;text-align:right;color:#fff;font-weight:600;}
.hours .note{margin-top:1.1rem;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.14);font-size:.9rem;color:#9fb6c0;font-style:italic;}

/* Partners */
.partners{background:var(--paper-2);border-top:1px solid var(--line);}
.partners .wrap{padding-block:48px;}
.partners .lbl{text-align:center;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:1.8rem;}
.partner-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(28px,5vw,60px);}
.partner-row a{display:block;filter:grayscale(1);opacity:.62;transition:filter .25s,opacity .25s,transform .25s;}
.partner-row a:hover{filter:grayscale(0);opacity:1;transform:translateY(-2px);}
.partner-row img{height:46px;width:auto;object-fit:contain;}

/* Footer */
.site-foot{background:#0c2230;color:#9fb6c0;font-size:.9rem;}
.site-foot .wrap{padding-block:40px;display:flex;flex-direction:column;gap:1.4rem;align-items:center;text-align:center;}
.foot-links{display:flex;flex-wrap:wrap;gap:.4rem 1.6rem;justify-content:center;list-style:none;margin:0;padding:0;}
.foot-links a{color:#cfe0e8;font-weight:600;letter-spacing:.04em;}
.foot-links a:hover{color:#fff;}
.foot-meta{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;justify-content:center;color:#6f8896;font-size:.82rem;}
.foot-rule{width:100%;height:1px;background:rgba(255,255,255,.1);}

/* CTA strip */
.cta{background:linear-gradient(160deg,var(--blue),var(--navy-2));color:#fff;text-align:center;}
.cta h2{color:#fff;}
.cta p{color:#dceaf0;max-width:52ch;margin-inline:auto;}
.btn{display:inline-flex;align-items:center;gap:.6rem;background:var(--brass);color:#fff;font-weight:700;letter-spacing:.06em;padding:.85rem 1.6rem;border-radius:10px;margin-top:1.4rem;transition:transform .2s,background .2s;}
.btn:hover{background:var(--brass-soft);color:#fff;transform:translateY(-2px);}
.btn.ghost{background:transparent;border:1.5px solid rgba(255,255,255,.5);}
.btn.ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;}
.ico{width:1.05em;height:1.05em;flex:none;display:inline-block;}

/* generic content page */
.page-body{max-width:74ch;}
.page-body h2{margin-top:2.2rem;}
.page-body h3{margin:1.6rem 0 .4rem;font-size:1.25rem;}
.info-row{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1.4rem;margin:1.2rem 0;}
.info-row dt{font-weight:700;color:var(--navy);}
.info-row dd{margin:0;color:var(--ink);}

/* map */
.map-frame{border-radius:14px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);}
.map-frame iframe{display:block;width:100%;height:420px;border:0;}

/* mobile menu */
@media(max-width:880px){
  .nav-toggle{display:inline-flex;}
  .menu{
    position:absolute;top:100%;left:0;right:0;background:var(--paper);
    flex-direction:column;align-items:stretch;gap:0;padding:.25rem var(--gutter) .85rem;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm);
    display:none;
  }
  .menu.open{display:flex;}
  .menu a{
    padding:.7rem .1rem;border:none;border-radius:0;background:none;box-shadow:none;outline:none;
    -webkit-tap-highlight-color:transparent;
  }
  .menu a::after{display:none;}
  /* Top-Leiste mobil kompakt */
  .topbar{font-size:.8rem;text-align:center;}
  .topbar .wrap{flex-direction:column;align-items:center;justify-content:center;gap:.2rem;min-height:0;padding-block:.55rem;}
}

/* ---- Mobiler Header: Foto als Banner, Text darunter ---- */
@media(max-width:880px){
  .hero.full{height:auto;display:block;background:var(--navy);padding:0;}
  .hero.full::after{display:none;}
  .hero.full .slides{position:relative;height:min(62vw,360px);}
  .hero.full .slides::after{content:"";position:absolute;left:0;right:0;bottom:0;height:64px;background:linear-gradient(0deg,rgba(16,42,57,.55),transparent);z-index:2;}
  .hero.full .hero-inner{position:relative;height:auto;justify-content:flex-start;padding-top:clamp(22px,6vw,30px);padding-bottom:clamp(26px,7vw,36px);}
  .hero.full h1,.hero.full .lead{text-shadow:none;}
  .hero.full .dots{bottom:auto;top:calc(min(62vw,360px) - 22px);left:0;right:0;justify-content:center;}
  .hero.full .slider-ctrl{display:none;}
  /* kompakter Header (Unterseiten) etwas niedriger */
  .hero.compact{height:clamp(180px,34vh,260px);}
}

/* Social icons */
.social{display:flex;gap:.7rem;justify-content:center;align-items:center;}
.social a{
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);color:#cfe0e8;
  transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.social a:hover{background:var(--brass);border-color:var(--brass);color:#fff;transform:translateY(-2px);}
.social svg{width:19px;height:19px;}

/* Google-Bewertungen */
.reviews{background:var(--paper-2);border-top:1px solid var(--line);}
.review-card{
  max-width:760px;margin-inline:auto;text-align:center;
  background:var(--paper);border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow);padding:clamp(30px,5vw,52px);
}
.g-badge{display:inline-flex;align-items:center;gap:.6rem;font-weight:800;letter-spacing:.02em;color:var(--navy);font-size:1.05rem;margin-bottom:1.2rem;}
.g-badge .g{
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:#fff;border:1px solid var(--line);font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--blue);
}
.review-card h2{font-size:clamp(1.6rem,3.4vw,2.3rem);margin-bottom:.5rem;}
.review-card p{color:var(--muted);}
.stars{display:flex;gap:.25rem;justify-content:center;font-size:1.7rem;color:#f5a623;margin:.6rem 0 1.4rem;line-height:1;}
.review-btns{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;}
.review-btns .btn{margin-top:0;}
.btn.google{background:#fff;color:var(--navy);border:1.5px solid var(--line-strong);}
.btn.google:hover{background:var(--paper-2);color:var(--navy);}

/* Speisekarte */
.menu-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);}
@media(max-width:760px){.menu-cols{grid-template-columns:1fr;}}
.menu-group > h3{font-family:var(--font-display);font-size:1.45rem;color:var(--navy);margin:0 0 .2rem;padding-bottom:.55rem;border-bottom:2px solid var(--brass);display:inline-block;}
.dish-list{list-style:none;margin:1.1rem 0 0;padding:0;}
.dish{padding:.85rem 0;border-bottom:1px solid var(--line);}
.dish:last-child{border-bottom:none;}
.dish .nm{font-family:var(--font-display);font-size:1.2rem;color:var(--navy-2);display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap;line-height:1.25;}
.dish .desc{color:var(--muted);font-size:.96rem;margin-top:.2rem;}
.veg{font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#3f7d52;background:rgba(63,125,82,.12);padding:.22rem .55rem;border-radius:999px;white-space:nowrap;transform:translateY(-1px);}
.menu-note{margin-top:clamp(28px,4vw,40px);padding:clamp(20px,3vw,28px);background:var(--paper-2);border:1px solid var(--line);border-radius:14px;color:var(--muted);font-family:var(--font-display);font-style:italic;font-size:1.05rem;}

/* small print pages */
.legal{max-width:72ch;}
.legal h2{font-size:1.5rem;margin-top:2rem;}
.legal p,.legal li{color:var(--ink);font-size:.98rem;line-height:1.65;}
.legal a{word-break:break-word;}
