@font-face{font-family:"Lora";font-style:normal;font-weight:400;font-display:swap;src:url("../fonts/lora-400.woff2") format("woff2")}
@font-face{font-family:"Lora";font-style:italic;font-weight:400;font-display:swap;src:url("../fonts/lora-400i.woff2") format("woff2")}
@font-face{font-family:"Lora";font-style:normal;font-weight:600;font-display:swap;src:url("../fonts/lora-600.woff2") format("woff2")}
@font-face{font-family:"Lora";font-style:normal;font-weight:700;font-display:swap;src:url("../fonts/lora-700.woff2") format("woff2")}
@font-face{font-family:"Source Sans 3";font-style:normal;font-weight:400;font-display:swap;src:url("../fonts/sourcesans-400.woff2") format("woff2")}
@font-face{font-family:"Source Sans 3";font-style:normal;font-weight:600;font-display:swap;src:url("../fonts/sourcesans-600.woff2") format("woff2")}
@font-face{font-family:"Source Sans 3";font-style:normal;font-weight:700;font-display:swap;src:url("../fonts/sourcesans-700.woff2") format("woff2")}
:root{
  --bg:#f3ebdd; --bg-2:#ecdfc8; --paper:#fdfaf3;
  --ink:#2a2018; --ink-soft:#5e4f3d; --ink-faint:#8a7c66;
  --wine:#a8492f; --wine-deep:#83361f; --wine-100:#f1ddd2;
  --wood:#5a3d28; --wood-deep:#382617;
  --gold:#c8972f; --gold-deep:#a87d22; --gold-soft:#e6c878;
  --cream-tint:#f2e6cf;
  --olive:#6f7d49;
  --line:rgba(42,32,24,.15); --line-soft:rgba(42,32,24,.08);
  --shadow-sm:0 1px 2px rgba(60,40,20,.07), 0 2px 6px rgba(60,40,20,.06);
  --shadow:0 12px 30px -14px rgba(60,40,20,.32), 0 4px 10px -6px rgba(60,40,20,.14);
  --shadow-lg:0 34px 70px -32px rgba(50,32,12,.5);
  --r:16px; --r-lg:22px; --maxw:1160px;
  --serif:"Lora", Georgia, "Times New Roman", serif;
  --sans:"Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  margin:0; font-family:var(--sans); color:var(--ink); background-color:var(--bg);
  background-image:
    radial-gradient(1100px 520px at 50% -10%, rgba(193,154,62,.16), transparent 62%),
    radial-gradient(700px 500px at 100% 8%, rgba(168,73,47,.08), transparent 60%),
    repeating-linear-gradient(135deg, rgba(124,90,40,.020) 0 2px, transparent 2px 7px);
  line-height:1.62; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:inherit}
img,svg{display:block; max-width:100%}
h1,h2,h3,h4{font-family:var(--serif); font-weight:600; line-height:1.08; margin:0; letter-spacing:-.01em}
p{margin:0}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}

.btn{display:inline-flex; align-items:center; gap:.55em; justify-content:center; font-family:var(--sans); font-weight:600; font-size:1rem; line-height:1; padding:.92em 1.35em; border-radius:10px; border:1.5px solid transparent; cursor:pointer; text-decoration:none; transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease; white-space:nowrap}
.btn .icon{width:18px; height:18px}
.btn-primary{background:var(--wine); color:#fbf2e6; box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--wine-deep); transform:translateY(-2px); box-shadow:var(--shadow)}
.btn-gold{background:var(--gold); color:#33240f; box-shadow:var(--shadow-sm)}
.btn-gold:hover{background:var(--gold-deep); color:#fff; transform:translateY(-2px); box-shadow:var(--shadow)}
.btn-ghost{background:transparent; color:var(--wine); border-color:rgba(124,38,48,.4)}
.btn-ghost:hover{background:var(--wine-100); border-color:var(--wine); transform:translateY(-2px)}

.topbar{background:var(--wood-deep); color:#ead9b8; font-size:.86rem; border-bottom:2px solid var(--gold)}
.topbar .wrap{display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:40px}
.topbar a{color:#ecd49a; text-decoration:none; font-weight:600}
.topbar a:hover{color:#fff}
.topbar .sep{opacity:.4; margin:0 .35em}
.top-hours{display:inline-flex; align-items:center; gap:.5em; opacity:.94}
.top-hours .icon{width:15px;height:15px;opacity:.85}
.top-links{display:inline-flex; align-items:center; gap:16px}

.site-header{position:sticky; top:0; z-index:50; background:rgba(251,244,227,.9); backdrop-filter:saturate(140%) blur(12px); -webkit-backdrop-filter:saturate(140%) blur(12px); border-bottom:1px solid var(--line); box-shadow:0 1px 0 rgba(193,154,62,.35)}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:18px; min-height:74px}
.brand{display:flex; align-items:center; gap:13px; text-decoration:none; color:var(--ink)}
.brand .brand-mark{width:48px;height:48px;flex:0 0 auto; filter:drop-shadow(0 4px 8px rgba(60,40,20,.22))}
.brand .name{font-family:var(--serif); font-size:1.55rem; font-weight:700; line-height:1; letter-spacing:-.015em}
.brand .name b{color:var(--wine); font-weight:700}
.brand .sub{display:block; font-family:var(--sans); font-size:.64rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-deep); margin-top:5px}
.nav{display:flex; align-items:center; gap:2px}
.nav a{text-decoration:none; color:var(--ink-soft); font-weight:600; font-size:.95rem; padding:.5em .62em; border-radius:8px; transition:color .18s, background .18s}
.nav a:hover{color:var(--wine); background:var(--cream-tint)}
.header-actions{display:flex; align-items:center; gap:12px}
.lang{display:inline-flex; align-items:center; background:rgba(168,73,47,.08); border:1px solid var(--line); border-radius:999px; padding:3px; gap:2px}
.lang-btn{appearance:none; border:0; background:transparent; cursor:pointer; font-family:var(--sans); font-weight:700; font-size:.78rem; letter-spacing:.04em; color:var(--ink-faint); padding:.34em .6em; border-radius:999px; transition:.18s}
.lang-btn.active{background:var(--wine); color:#fbf2e6; box-shadow:var(--shadow-sm)}
.lang-btn:not(.active):hover{color:var(--wine)}
.btn-phone{display:inline-flex; align-items:center; gap:.55em; text-decoration:none; background:var(--wine); color:#fbf2e6; font-weight:700; font-size:.95rem; padding:.62em 1.05em; border-radius:10px; box-shadow:var(--shadow-sm); transition:transform .15s, background .2s, box-shadow .2s}
.btn-phone:hover{background:var(--wine-deep); transform:translateY(-2px); box-shadow:var(--shadow)}
.btn-phone .icon{width:18px;height:18px}
.btn-phone .num{font-variant-numeric:tabular-nums}
.btn-phone .label{display:none}
.burger{display:none; appearance:none; border:1px solid var(--line); background:var(--paper); width:46px;height:46px; border-radius:10px; cursor:pointer; align-items:center; justify-content:center}
.burger .icon{width:22px;height:22px; color:var(--wine)}
.mobile-menu{display:none}


.ornament{display:flex; align-items:center; justify-content:center; gap:16px; color:var(--gold); padding:8px 0; margin:0 auto; max-width:var(--maxw)}
.ornament .rule{height:1px; width:min(180px,22vw); background:linear-gradient(90deg,transparent,var(--gold))}
.ornament .rule.r{background:linear-gradient(90deg,var(--gold),transparent)}
.ornament .icon{width:30px;height:30px; opacity:.95}

.hero{position:relative; padding:54px 0 24px}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:46px; align-items:center}
.eyebrow{display:inline-flex; align-items:center; gap:.6em; font-weight:700; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--wine); margin-bottom:18px}
.eyebrow::before{content:""; width:30px; height:1.5px; background:var(--gold)}
.hero h1{font-size:clamp(2.6rem, 6vw, 4.6rem); line-height:.97; color:var(--ink)}
.hero h1 .accent{color:var(--wine); font-style:italic; font-weight:500}
.hero .tagline{font-family:var(--serif); font-size:clamp(1.15rem,2.2vw,1.55rem); color:var(--wine); margin-top:.5em; font-style:italic}
.hero .intro{font-size:1.08rem; color:var(--ink-soft); margin-top:1.1em; max-width:34em}
.hero .signature{font-family:var(--serif); font-style:italic; font-size:1.22rem; color:var(--ink); margin-top:1em}
.hero-cta{display:flex; flex-wrap:wrap; gap:12px; margin-top:1.7em}

.js .r-up{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease}
.js .r-up.in{opacity:1; transform:none}
.d1{transition-delay:.05s}.d2{transition-delay:.12s}.d3{transition-delay:.19s}.d4{transition-delay:.26s}.d5{transition-delay:.33s}

.contact-card{background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:26px; box-shadow:var(--shadow-lg); position:relative; overflow:hidden}
.contact-card::before{content:""; position:absolute; inset:0 0 auto 0; height:5px; background:linear-gradient(90deg,var(--wine),var(--gold))}
.cc-title{font-size:1.45rem; color:var(--wine-deep); margin-bottom:.1em}
.cc-phone{display:flex; align-items:center; gap:.5em; text-decoration:none; color:var(--wine); font-family:var(--serif); font-size:2.15rem; font-weight:700; margin:.35em 0 .15em; letter-spacing:-.02em}
.cc-phone .icon{width:26px;height:26px; flex:0 0 auto}
.cc-phone:hover{color:var(--wine-deep)}
.cc-note{color:var(--ink-soft); font-size:.95rem}
.cc-mail{display:inline-flex; align-items:center; gap:.45em; margin-top:.7em; color:var(--gold-deep); font-weight:600; text-decoration:none; font-size:.95rem; overflow-wrap:anywhere; word-break:normal}
.cc-mail:hover{text-decoration:underline}
.cc-divider{height:1px; background:var(--line); margin:18px 0}
.cc-hours{display:flex; align-items:flex-start; gap:.6em; color:var(--ink-soft); font-size:.95rem}
.cc-hours .icon{width:18px;height:18px; margin-top:.18em; color:var(--wine); flex:0 0 auto}
.cc-hours .lbl{display:block; font-weight:700; color:var(--ink); font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; margin-bottom:1px}

.illus{position:relative; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-lg); background:#ece2c6}
.illus img{display:block; width:100%; height:100%; object-fit:cover}
.illus.ratio{aspect-ratio:40/27}
.illus.band img{width:100%; height:auto; object-fit:contain}
.illus-cap{display:flex; align-items:center; gap:.5em; margin-top:10px; color:var(--ink-soft); font-size:.82rem; font-style:italic}
.illus-cap .icon{width:14px;height:14px;opacity:.7; flex:0 0 auto}

.facts{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:30px}
.fact{display:flex; align-items:center; gap:13px; background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:16px 18px; box-shadow:var(--shadow-sm)}
.fact .ic{width:42px;height:42px; flex:0 0 auto; border-radius:10px; background:var(--cream-tint); color:var(--wine); display:flex; align-items:center; justify-content:center; border:1px solid rgba(193,154,62,.3)}
.fact .ic .icon{width:22px;height:22px}
.fact span{font-weight:600; color:var(--ink); font-size:.97rem; line-height:1.3}

section{scroll-margin-top:96px}
.block{padding:58px 0}
.feature{display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center}
.feature.flip .media{order:2}
.kicker{display:inline-flex; align-items:center; gap:.55em; font-weight:700; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--wine); margin-bottom:14px}
.kicker::before{content:""; width:26px; height:1.5px; background:var(--gold)}
.feature h2{font-size:clamp(2rem,3.6vw,3rem); color:var(--wine-deep)}
.feature .lead{font-size:1.18rem; color:var(--ink); margin-top:.5em; font-family:var(--serif); font-style:italic}
.feature .body{color:var(--ink-soft); margin-top:1em; font-size:1.04rem}
.cta-row{display:flex; flex-wrap:wrap; gap:12px; margin-top:1.5em}
.chips{display:flex; flex-wrap:wrap; gap:9px; margin-top:1.3em}
.chip{display:inline-flex; align-items:center; gap:.45em; background:var(--cream-tint); color:var(--wood); border:1px solid rgba(163,127,44,.3); padding:.42em .85em; border-radius:8px; font-size:.86rem; font-weight:600}
.chip .icon{width:15px;height:15px; opacity:.85; color:var(--wine)}
.pricecard,.menu-list{background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:18px 20px; margin-top:1.4em; box-shadow:var(--shadow-sm); position:relative}
.pricecard::before,.menu-list::before{content:""; position:absolute; left:0; top:14px; bottom:14px; width:3px; border-radius:3px; background:linear-gradient(var(--wine),var(--gold))}
.pricecard h3,.menu-list h3{font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; font-family:var(--sans); font-weight:700; color:var(--gold-deep); margin-bottom:8px; padding-left:10px}
.price-row{display:flex; align-items:baseline; justify-content:space-between; gap:12px; padding:.5em 0 .5em 10px; border-bottom:1px dashed var(--line-soft)}
.price-row:last-of-type{border-bottom:0}
.price-row .nm{color:var(--ink); font-weight:500}
.price-row .pr{font-family:var(--serif); font-weight:700; color:var(--wine); font-size:1.12rem; font-variant-numeric:tabular-nums; white-space:nowrap}
.price-note{margin-top:.7em; font-size:.86rem; color:var(--ink-faint); padding-left:10px}
.note-line{display:flex; align-items:flex-start; gap:.55em; margin-top:1em; color:var(--ink-soft); font-size:.92rem}
.note-line .icon{width:17px;height:17px; color:var(--wine); margin-top:.16em; flex:0 0 auto}
.media{position:relative}

.contact-block{background:linear-gradient(170deg, var(--wood-deep), var(--wood)); color:#f0e6cf; position:relative}
.contact-block::before{content:""; position:absolute; inset:0 0 auto 0; height:3px; background:linear-gradient(90deg,var(--wine),var(--gold),var(--wine))}
.contact-block .kicker{color:var(--gold-soft)} .contact-block .kicker::before{background:var(--gold-soft)}
.contact-block h2{color:#fff}
.contact-block .intro{color:#e2d3ac; max-width:42em; margin-top:.7em; font-size:1.05rem}
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:32px}
.info-card{background:rgba(255,255,255,.06); border:1px solid rgba(227,200,127,.22); border-radius:var(--r); padding:22px}
.info-card h3{color:#fff; font-size:1.2rem; margin-bottom:.5em}
.info-card .row{display:flex; gap:.6em; align-items:flex-start; margin:.55em 0; color:#e6dcc3; font-size:.97rem}
.info-card .row .icon{width:18px;height:18px; color:var(--gold-soft); margin-top:.18em; flex:0 0 auto}
.info-card a{color:#fff; text-decoration:none; font-weight:600; overflow-wrap:anywhere; word-break:normal}
.info-card a:hover{text-decoration:underline; color:var(--gold-soft)}
.info-card .muted{color:#c7b58c; font-size:.86rem; margin-top:.5em}
.info-card .lbl{font-weight:700; color:#fff; font-size:.72rem; letter-spacing:.09em; text-transform:uppercase; display:block; margin-bottom:1px}
.contact-actions{display:flex; flex-wrap:wrap; gap:12px; margin-top:14px}
.contact-actions .btn-primary{background:var(--gold); color:#33240f}
.contact-actions .btn-primary:hover{background:var(--gold-soft); color:#33240f}
.contact-actions .btn-ghost{color:#fff; border-color:rgba(227,200,127,.5)}
.contact-actions .btn-ghost:hover{background:rgba(227,200,127,.14); border-color:var(--gold-soft)}
.map-wrap{margin-top:22px; border-radius:var(--r); overflow:hidden; border:1px solid rgba(227,200,127,.25); box-shadow:var(--shadow); background:#d8cba8}
.map-wrap iframe{width:100%; height:clamp(420px,66vh,660px); border:0; display:block; filter:sepia(.12) saturate(.95)}
.impressum{margin-top:28px; padding-top:24px; border-top:1px solid rgba(227,200,127,.22); display:grid; grid-template-columns:1fr 1fr; gap:22px}
.impressum h4{color:#fff; font-size:1rem; margin-bottom:.4em}
.impressum p{color:#cdbd95; font-size:.9rem; line-height:1.7}

.site-footer{background:var(--wood-deep); color:#cdbd95; padding:50px 0 60px}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1.3fr; gap:36px}
.footer-brand .name{font-family:var(--serif); font-size:1.55rem; color:#fff; font-weight:700}
.footer-brand .name b{color:var(--gold-soft); font-weight:700}
.footer-brand p{margin-top:.6em; font-size:.92rem; max-width:26em; color:#b6a780}
.foot-title{font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-soft); font-weight:700; margin-bottom:.8em}
.foot-links{list-style:none; padding:0; margin:0; display:grid; gap:.5em}
.foot-links a{color:#cdbd95; text-decoration:none; font-size:.95rem}
.foot-links a:hover{color:#fff}
.foot-contact .row{display:flex; gap:.55em; align-items:flex-start; margin:.5em 0; font-size:.94rem; color:#cdbd95}
.foot-contact .row .icon{width:16px;height:16px; color:var(--gold-soft); margin-top:.2em; flex:0 0 auto}
.foot-contact a{color:#fff; text-decoration:none; overflow-wrap:anywhere; word-break:normal}
.foot-contact a:hover{text-decoration:underline}
.footer-bottom{border-top:1px solid rgba(227,200,127,.18); margin-top:34px; padding-top:20px; display:flex; flex-wrap:wrap; gap:10px 22px; justify-content:space-between; font-size:.84rem; color:#998a66}

.callbar{position:fixed; left:0; right:0; bottom:0; z-index:70; display:none; gap:10px; padding:10px 12px calc(10px + env(safe-area-inset-bottom)); background:rgba(251,244,227,.96); backdrop-filter:blur(10px); border-top:2px solid var(--gold)}
.callbar a{flex:1; padding:.95em; font-size:1rem}

@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} .r-up{opacity:1; transform:none; transition:none} }

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr; gap:34px}
  .feature{grid-template-columns:1fr; gap:30px}
  .feature.flip .media{order:0}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 1180px){
  .topbar{display:none}
  .nav{display:none}
  .burger{display:inline-flex}
  .btn-phone .num{display:none}
  .btn-phone .label{display:inline}
  .lang{order:-1}
  .mobile-menu{display:block; position:fixed; inset:0 0 0 auto; width:min(86vw,360px); z-index:100; background:var(--paper); box-shadow:var(--shadow-lg); transform:translateX(105%); transition:transform .32s cubic-bezier(.4,0,.2,1); padding:22px; overflow-y:auto; border-left:1px solid var(--line)}
  .mobile-menu.open{transform:translateX(0)}
  .mm-overlay{position:fixed; inset:0; background:rgba(25,16,8,.5); z-index:90; opacity:0; pointer-events:none; transition:opacity .3s}
  .mm-overlay.open{opacity:1; pointer-events:auto}
  .mm-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:18px}
  .mm-close{appearance:none; border:1px solid var(--line); background:#fff; width:42px;height:42px;border-radius:10px;cursor:pointer; color:var(--wine)}
  .mm-links{list-style:none; margin:0; padding:0; display:grid; gap:2px}
  .mm-links a{display:block; padding:.85em .6em; text-decoration:none; color:var(--ink); font-weight:600; font-size:1.08rem; border-radius:8px; border-bottom:1px solid var(--line-soft)}
  .mm-links a:hover{background:var(--cream-tint); color:var(--wine)}
  .mm-actions{display:grid; gap:10px; margin-top:20px}
  .callbar{display:flex}
  .site-footer{padding-bottom:96px}
  .ornament .rule{width:22vw}
}
@media (max-width: 560px){
  .facts{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .impressum{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
  .brand .name{font-size:1.3rem}
  .block{padding:44px 0}
  .hero{padding:30px 0 8px}
  .contact-card{padding:20px}
  .cc-phone{font-size:1.8rem}
}

.figure{margin:0}


/* embedded menu PDF */
.menu-pdf{margin-top:1.4em; border-radius:var(--r); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); background:#fff}
.menu-pdf iframe{width:100%; height:520px; border:0; display:block}
.menu-actions{margin-top:1.1em}
.menu-fallback a{color:var(--gold-deep); font-weight:600}
.menu-notes{margin-top:1.1em}

/* Anfahrt subpage */
.anfahrt-block .map-wrap{margin-top:1.5em}
.anfahrt-grid{margin-top:1.6em; max-width:560px}
.anfahrt-block .info-card{background:linear-gradient(170deg, var(--wood-deep), var(--wood)); border-color:rgba(227,200,127,.30)}
.back-link{color:var(--wine); font-weight:600; text-decoration:none}
.back-link:hover{text-decoration:underline}
.map-cta{margin-top:18px}

/* icons: referenced from files, coloured via currentColor (no inline path data) */
.icon{display:inline-block; width:18px; height:18px; flex:0 0 auto; background-color:currentColor; vertical-align:-.15em; -webkit-mask-image:var(--i); mask-image:var(--i); -webkit-mask-repeat:no-repeat; mask-repeat:no-repeat; -webkit-mask-position:center; mask-position:center; -webkit-mask-size:contain; mask-size:contain}
.mm-close .icon{width:22px; height:22px}
/* icon shapes embedded as data URIs so masks work even from file:// (sources live in assets/icons/) */
.icon-bag{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M5%208h14l-1%2012H6L5%208z%22%2F%3E%3Cpath%20d%3D%22M9%208V6a3%203%200%200%201%206%200v2%22%2F%3E%3C%2Fsvg%3E")}
.icon-bed{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M2%2020v-8a2%202%200%200%201%202-2h16a2%202%200%200%201%202%202v8%22%2F%3E%3Cpath%20d%3D%22M2%2016h20%22%2F%3E%3Cpath%20d%3D%22M6%2010V7a2%202%200%200%201%202-2h8a2%202%200%200%201%202%202v3%22%2F%3E%3C%2Fsvg%3E")}
.icon-beer{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M12%203c2%202%200%204%200%206M8%205c1%201%200%202%200%203M16%205c1%201%200%202%200%203%22%2F%3E%3Cpath%20d%3D%22M4%2012h16a8%208%200%200%201-16%200z%22%2F%3E%3C%2Fsvg%3E")}
.icon-bike{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Ccircle%20cx%3D%225.5%22%20cy%3D%2217.5%22%20r%3D%223.5%22%2F%3E%3Ccircle%20cx%3D%2218.5%22%20cy%3D%2217.5%22%20r%3D%223.5%22%2F%3E%3Cpath%20d%3D%22M5.5%2017.5%209%209h5l3%208.5M9%209l-1-4h3%22%2F%3E%3C%2Fsvg%3E")}
.icon-book{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Crect%20x%3D%223%22%20y%3D%224%22%20width%3D%2218%22%20height%3D%2216%22%20rx%3D%222%22%2F%3E%3Cpath%20d%3D%22M12%204v16%22%2F%3E%3C%2Fsvg%3E")}
.icon-briefcase{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Crect%20x%3D%223%22%20y%3D%228%22%20width%3D%2218%22%20height%3D%2212%22%20rx%3D%222%22%2F%3E%3Cpath%20d%3D%22M7%208V6a2%202%200%200%201%202-2h6a2%202%200%200%201%202%202v2%22%2F%3E%3C%2Fsvg%3E")}
.icon-building{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M5%2021v-8l7-5%207%205v8%22%2F%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%225%22%20r%3D%222%22%2F%3E%3C%2Fsvg%3E")}
.icon-calendar{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Crect%20x%3D%223%22%20y%3D%224%22%20width%3D%2218%22%20height%3D%2218%22%20rx%3D%222%22%2F%3E%3Cpath%20d%3D%22M16%202v4M8%202v4M3%2010h18%22%2F%3E%3C%2Fsvg%3E")}
.icon-cheers{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M10%203c-2%204-2%2014%200%2018M14%203c2%204%202%2014%200%2018%22%2F%3E%3Cpath%20d%3D%22M10%203h4%22%2F%3E%3C%2Fsvg%3E")}
.icon-clock{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%229%22%2F%3E%3Cpath%20d%3D%22M12%207v5l3%202%22%2F%3E%3C%2Fsvg%3E")}
.icon-close{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222.2%22%20style%3D%22width%3A22px%3Bheight%3A22px%22%3E%3Cpath%20d%3D%22M6%206l12%2012M18%206L6%2018%22%2F%3E%3C%2Fsvg%3E")}
.icon-cutlery{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M4%203v7a3%203%200%200%200%206%200V3%22%2F%3E%3Cpath%20d%3D%22M7%2010v11%22%2F%3E%3Cpath%20d%3D%22M17%203c-1.5%200-3%201.5-3%204s1.5%204%203%204%22%2F%3E%3Cpath%20d%3D%22M17%203v18%22%2F%3E%3C%2Fsvg%3E")}
.icon-drawer{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Crect%20x%3D%223%22%20y%3D%2210%22%20width%3D%2218%22%20height%3D%2210%22%20rx%3D%222%22%2F%3E%3Cpath%20d%3D%22M7%2010V7a2%202%200%200%201%202-2h6a2%202%200%200%201%202%202v3%22%2F%3E%3C%2Fsvg%3E")}
.icon-fax{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Crect%20x%3D%226%22%20y%3D%223%22%20width%3D%2212%22%20height%3D%226%22%2F%3E%3Cpath%20d%3D%22M6%2018v3h12v-3M4%209h16a2%202%200%200%201%202%202v6H2v-6a2%202%200%200%201%202-2z%22%2F%3E%3C%2Fsvg%3E")}
.icon-gift{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M20%2012v9H4v-9%22%2F%3E%3Cpath%20d%3D%22M2%207h20v5H2zM12%2022V7M12%207S10%203%207%203%204%206%206%207M12%207s2-4%205-4%203%203%201%204%22%2F%3E%3C%2Fsvg%3E")}
.icon-group{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Ccircle%20cx%3D%229%22%20cy%3D%227%22%20r%3D%223%22%2F%3E%3Ccircle%20cx%3D%2217%22%20cy%3D%229%22%20r%3D%222.5%22%2F%3E%3Cpath%20d%3D%22M3%2021v-2a5%205%200%200%201%2010%200v2M14%2021v-1a4%204%200%200%201%207-2.6%22%2F%3E%3C%2Fsvg%3E")}
.icon-house{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M3%2021V8l9-5%209%205v13%22%2F%3E%3Cpath%20d%3D%22M9%2021v-6h6v6%22%2F%3E%3C%2Fsvg%3E")}
.icon-house2{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M3%2012%2012%204l9%208%22%2F%3E%3Cpath%20d%3D%22M5%2011v9h14v-9%22%2F%3E%3C%2Fsvg%3E")}
.icon-image{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Crect%20x%3D%223%22%20y%3D%223%22%20width%3D%2218%22%20height%3D%2218%22%20rx%3D%222%22%2F%3E%3Ccircle%20cx%3D%229%22%20cy%3D%229%22%20r%3D%222%22%2F%3E%3Cpath%20d%3D%22m21%2015-5-5L5%2021%22%2F%3E%3C%2Fsvg%3E")}
.icon-mail{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Crect%20x%3D%223%22%20y%3D%225%22%20width%3D%2218%22%20height%3D%2214%22%20rx%3D%222%22%2F%3E%3Cpath%20d%3D%22m3%207%209%206%209-6%22%2F%3E%3C%2Fsvg%3E")}
.icon-menu{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222.2%22%3E%3Cpath%20d%3D%22M3%206h18M3%2012h18M3%2018h18%22%2F%3E%3C%2Fsvg%3E")}
.icon-peak{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M4%2018%20L12%206%20L20%2018%20Z%22%2F%3E%3Cpath%20d%3D%22M4%2018h16%22%2F%3E%3C%2Fsvg%3E")}
.icon-phone{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M22%2016.92v3a2%202%200%200%201-2.18%202%2019.79%2019.79%200%200%201-8.63-3.07%2019.5%2019.5%200%200%201-6-6%2019.79%2019.79%200%200%201-3.07-8.67A2%202%200%200%201%204.11%202h3a2%202%200%200%201%202%201.72c.13.96.36%201.9.7%202.81a2%202%200%200%201-.45%202.11L8.09%209.91a16%2016%200%200%200%206%206l1.27-1.27a2%202%200%200%201%202.11-.45c.91.34%201.85.57%202.81.7A2%202%200%200%201%2022%2016.92z%22%2F%3E%3C%2Fsvg%3E")}
.icon-pin{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M21%2010c0%206-9%2012-9%2012s-9-6-9-12a9%209%200%200%201%2018%200z%22%2F%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2210%22%20r%3D%223%22%2F%3E%3C%2Fsvg%3E")}
.icon-plant{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%221.6%22%3E%3Cpath%20d%3D%22M12%2022V8%22%2F%3E%3Cpath%20d%3D%22M12%208c0-3%202-5%202-5s-2%201-2%203c0-2-2-3-2-3s2%202%202%205z%22%2F%3E%3Cpath%20d%3D%22M12%2012c2-1%204%200%204%200s-1%202-3%202-1-2-1-2zM12%2012c-2-1-4%200-4%200s1%202%203%202%201-2%201-2z%22%2F%3E%3Cpath%20d%3D%22M12%2017c2-1%204%200%204%200s-1%202-3%202-1-2-1-2zM12%2017c-2-1-4%200-4%200s1%202%203%202%201-2%201-2z%22%2F%3E%3C%2Fsvg%3E")}
.icon-sofa{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M4%2020v-5a8%208%200%200%201%2016%200v5%22%2F%3E%3Cpath%20d%3D%22M2%2020h20%22%2F%3E%3C%2Fsvg%3E")}
.icon-sparkle{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Ccircle%20cx%3D%2211%22%20cy%3D%224%22%20r%3D%222%22%2F%3E%3Ccircle%20cx%3D%2218%22%20cy%3D%228%22%20r%3D%222%22%2F%3E%3Ccircle%20cx%3D%2220%22%20cy%3D%2214%22%20r%3D%222%22%2F%3E%3Ccircle%20cx%3D%225%22%20cy%3D%229%22%20r%3D%222%22%2F%3E%3Cpath%20d%3D%22M10%2012a4%204%200%200%200-4%204c0%202%202%203%204%203s3-1%205-1%203%201%203-1-1-2-2-3%22%2F%3E%3C%2Fsvg%3E")}
.icon-table{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M3%2011h18M5%2011V7a2%202%200%200%201%202-2h10a2%202%200%200%201%202%202v4M5%2011v8M19%2011v8%22%2F%3E%3C%2Fsvg%3E")}
.icon-target{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%229%22%2F%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2212%22%20r%3D%223%22%2F%3E%3C%2Fsvg%3E")}
.icon-tv{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Crect%20x%3D%222%22%20y%3D%224%22%20width%3D%2220%22%20height%3D%2213%22%20rx%3D%222%22%2F%3E%3Cpath%20d%3D%22M8%2021h8%22%2F%3E%3C%2Fsvg%3E")}
.icon-user{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M16%2021v-2a4%204%200%200%200-4-4H6a4%204%200%200%200-4%204v2%22%2F%3E%3Ccircle%20cx%3D%229%22%20cy%3D%227%22%20r%3D%224%22%2F%3E%3C%2Fsvg%3E")}
.icon-users{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M16%2021v-2a4%204%200%200%200-4-4H6a4%204%200%200%200-4%204v2%22%2F%3E%3Ccircle%20cx%3D%229%22%20cy%3D%227%22%20r%3D%224%22%2F%3E%3Cpath%20d%3D%22M22%2021v-2a4%204%200%200%200-3-3.87%22%2F%3E%3Cpath%20d%3D%22M16%203.13a4%204%200%200%201%200%207.75%22%2F%3E%3C%2Fsvg%3E")}
.icon-wifi{--i:url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22currentColor%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22M5%2012.5a10%2010%200%200%201%2014%200M8.5%2016a5%205%200%200%201%207%200%22%2F%3E%3Ccircle%20cx%3D%2212%22%20cy%3D%2219%22%20r%3D%221%22%2F%3E%3C%2Fsvg%3E")}
.btn-phone, .btn-phone .num, .top-links a{white-space:nowrap}
.feature + .feature{margin-top:clamp(2.6rem,6vw,4.6rem)}
@media (max-width:720px){ .menu-pdf{display:none} }

/* legal / privacy page */
.legal{max-width:760px}
.legal h3{margin:1.7em 0 .35em; font-family:var(--serif); font-size:1.16rem; color:var(--wine-deep)}
.legal h3:first-of-type{margin-top:.4em}
.legal p{margin:.55em 0; color:var(--ink-soft); line-height:1.75}
.legal ul{margin:.5em 0 .7em 1.25em; color:var(--ink-soft); line-height:1.7}
.legal a{color:var(--wine); text-decoration:underline; overflow-wrap:anywhere}

/* Anfahrt button keeps the wine/brown fill inside the contact box */
.contact-actions .btn-map{background:var(--wine); color:#fbf2e6; border-color:transparent}
.contact-actions .btn-map:hover{background:var(--wine-deep)}
/* Google Maps consent (two-click) */
.map-consent{display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:.95em; min-height:clamp(340px,58vh,560px); padding:30px 26px; background:linear-gradient(160deg,#efe7d4,#e2d7bc); color:var(--ink-soft)}
.map-consent .icon{width:34px;height:34px;color:var(--wine)}
.map-consent p{max-width:48ch; margin:0; line-height:1.65}
.map-consent a{color:var(--wine)}
html:not(.js) #mapLoad{display:none}

#garten,#kegeln{scroll-margin-top:96px}
