/* ============================================================
   Gasthaus Brandlhof – gemeinsame Gestaltung für alle Seiten
   ============================================================ */
:root{
  --gruen:#2f5d3a;
  --gruen-dunkel:#23472c;
  --rot:#a32a23;
  --creme:#f7f3ea;
  --creme-dunkel:#efe7d6;
  --text:#2b2620;
  --grau:#6f685c;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;
  color:var(--text);background:var(--creme);line-height:1.65;-webkit-font-smoothing:antialiased;
  display:flex;flex-direction:column;min-height:100vh;
}
img{display:block;max-width:100%}
a{color:var(--gruen)}
main{flex:1}

/* ---------- Navigation ---------- */
header.nav{position:sticky;top:0;z-index:50;background:var(--gruen);color:var(--creme);box-shadow:0 2px 12px rgba(0,0,0,.18)}
.nav-inner{max-width:1100px;margin:0 auto;padding:.7rem 1.3rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.brand{display:flex;align-items:baseline;gap:.6rem;font-weight:700;text-decoration:none;color:var(--creme)}
.brand .name{font-size:1.35rem;letter-spacing:.5px}
.brand .sub{font-size:.8rem;opacity:.85;font-style:italic}
nav ul{list-style:none;display:flex;gap:1.4rem;flex-wrap:wrap}
nav a{color:var(--creme);text-decoration:none;font-size:1rem;padding-bottom:2px;border-bottom:2px solid transparent;transition:border-color .2s}
nav a:hover,nav a.active{border-color:var(--creme)}

/* ---------- Seitenkopf (kleiner Titelbalken auf Unterseiten) ---------- */
.pagehead{background:var(--gruen-dunkel);color:var(--creme);text-align:center;padding:3rem 1.3rem}
.pagehead h1{font-size:clamp(2rem,5vw,3rem)}
.pagehead p{margin-top:.5rem;font-style:italic;opacity:.9}

/* ---------- Abschnitte ---------- */
section{max-width:1100px;margin:0 auto;padding:3.5rem 1.3rem}
.section-title{font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--gruen);text-align:center;margin-bottom:.4rem}
.section-title::after{content:"";display:block;width:64px;height:3px;background:var(--rot);margin:.7rem auto 0;border-radius:2px}
.lead{text-align:center;max-width:760px;margin:1.2rem auto 0;font-size:1.15rem;color:var(--grau)}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:3px;font-weight:700;text-decoration:none;font-size:1.02rem;transition:transform .12s,box-shadow .2s}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--rot);color:#fff;box-shadow:0 4px 14px rgba(0,0,0,.25)}

/* ---------- Hauptbild (Startseite) ---------- */
.hero{position:relative;width:100%;height:82vh;min-height:420px;background:#000;overflow:hidden}
.hero img{width:100%;height:100%;object-fit:cover}
.hero-title{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:2.5rem 1.3rem;color:#fff;text-align:center;background:linear-gradient(0deg,rgba(0,0,0,.6),transparent);text-shadow:0 2px 16px rgba(0,0,0,.7)}
.hero-title h1{font-size:clamp(2.2rem,6vw,4rem);line-height:1.05}

/* ---------- Slideshow (Startseite) ---------- */
.slideshow{position:relative;width:100%;height:82vh;min-height:420px;background:#000;overflow:hidden}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
.slide.active{opacity:1}
.slide img{width:100%;height:100%;object-fit:cover}
/* Bilder, die ganz zu sehen sein sollen (z.B. Tellerfotos auf weißem Grund) */
.slide.contain{background:#fff}
.slide.contain img{object-fit:contain;padding:2rem}
.slideshow .title{
  position:absolute;left:0;right:0;bottom:0;z-index:3;padding:2.5rem 1.3rem;
  color:#fff;text-align:center;
  background:linear-gradient(0deg,rgba(0,0,0,.6),transparent);
  text-shadow:0 2px 16px rgba(0,0,0,.7);
}
.slideshow .title h1{font-size:clamp(2.2rem,6vw,4rem);line-height:1.05}
/* Punkte zum Umschalten */
.dots{position:absolute;left:0;right:0;bottom:1rem;z-index:4;display:flex;justify-content:center;gap:.6rem}
.dots button{width:12px;height:12px;border-radius:50%;border:2px solid #fff;background:transparent;cursor:pointer;padding:0;transition:background .2s}
.dots button.active{background:#fff}
/* Pfeile */
.arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;background:rgba(0,0,0,.35);color:#fff;border:none;font-size:2rem;line-height:1;width:48px;height:48px;cursor:pointer;border-radius:50%;transition:background .2s}
.arrow:hover{background:rgba(0,0,0,.6)}
.arrow.prev{left:1rem}
.arrow.next{right:1rem}
@media(max-width:520px){.arrow{display:none}}

/* ---------- Öffnungszeiten-Dokument ---------- */
.doc-wrap{max-width:680px;margin:2.5rem auto 0;text-align:center}
.doc-wrap img{width:100%;border-radius:8px;box-shadow:0 10px 30px rgba(0,0,0,.18);border:1px solid var(--creme-dunkel)}
.doc-actions{margin-top:1.5rem}

/* ---------- Kontakt ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:2.5rem}
.card{background:#fff;border:1px solid var(--creme-dunkel);border-radius:8px;padding:1.8rem;box-shadow:0 6px 20px rgba(0,0,0,.06)}
.card h3{color:var(--gruen);font-size:1.3rem;margin-bottom:1rem}
.info-line{display:flex;gap:.7rem;align-items:flex-start;padding:.6rem 0;font-size:1.1rem}
.info-line .ic{font-size:1.2rem;line-height:1.4;width:1.6rem;text-align:center}
.info-line a{font-weight:700;text-decoration:none}
.map-frame{border:0;width:100%;height:100%;min-height:340px;border-radius:8px;box-shadow:0 6px 20px rgba(0,0,0,.1)}

/* ---------- Rechtstexte (Impressum/Datenschutz) ---------- */
.legal{max-width:820px}
.legal h3{color:var(--gruen);font-size:1.2rem;margin:1.8rem 0 .4rem}
.legal p{margin-bottom:.8rem}
.legal .hinweis{font-size:.92rem;color:var(--grau)}
.legal-sep{border:0;border-top:1px solid var(--creme-dunkel);margin:3rem 0}
.legal .section-title{text-align:left}
.legal .section-title::after{margin-left:0}

/* ---------- Footer ---------- */
footer{background:var(--gruen-dunkel);color:var(--creme);text-align:center;padding:2.2rem 1.3rem;margin-top:1rem}
footer .name{font-size:1.15rem;font-weight:700}
footer a{color:#cfe0c8}
footer .small{opacity:.7;font-size:.85rem;margin-top:.8rem}

/* ---------- Responsiv ---------- */
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}.gallery{grid-template-columns:1fr 1fr}.gallery .wide{grid-column:span 2}}
@media(max-width:520px){.gallery{grid-template-columns:1fr}.gallery .wide{grid-column:span 1}.brand .sub{display:none}}
