/* ============================================================
   Restaurant Omega – Stylesheet
   Professionell · Seriös · Dark Teal / Gold
============================================================ */
:root{
  --bg:      #0c1c1a;
  --bg2:     #091614;
  --bg3:     #0e2220;
  --bg4:     #0a1a18;
  --gold:    #c9a84c;
  --gold2:   #d4b85a;
  --cream:   #f5f0e8;
  --text:    rgba(245,240,232,.78);
  --text2:   rgba(245,240,232,.5);
  --border:  rgba(201,168,76,.14);
  --border2: rgba(245,240,232,.08);
  --serif:   'Cormorant Garamond',Georgia,serif;
  --sans:    'Josefin Sans',system-ui,sans-serif;
  --ease:    cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--bg);overflow-x:hidden;line-height:1.75}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}

::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:rgba(201,168,76,.35);border-radius:2px}

/* ── Layout ── */
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 56px}
.two-col{width:100%;max-width:1200px;margin:0 auto;padding:0 56px;display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center}
.sec{padding:112px 0}
.sec-alt{background:var(--bg3)}
.sec-dark{background:var(--bg2)}

/* ── Typography ── */
.sec-hdr{text-align:center;margin-bottom:64px}
.eyebrow{display:block;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
h2{font-family:var(--serif);font-size:clamp(38px,4.5vw,68px);font-weight:600;color:var(--cream);line-height:1.05;margin-bottom:14px}
h3{font-family:var(--serif);font-size:clamp(22px,2.2vw,30px);font-weight:600;color:var(--cream);line-height:1.2}
p{font-size:15px;color:var(--text);line-height:1.9}
.gold-rule{display:block;width:48px;height:1px;background:var(--gold);margin:20px auto;opacity:.6}
.gold-rule.left{margin-left:0}

/* ── Announcement Bar ── */
.ann-bar{background:var(--gold);padding:9px 24px;text-align:center;font-size:10px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--bg2);position:relative;z-index:910}
.ann-bar a{color:var(--bg2);border-bottom:1px solid rgba(9,22,20,.3)}

/* ── Mobile Overlay ── */
.overlay{position:fixed;inset:0;background:rgba(9,22,20,.98);z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.overlay.open{opacity:1;pointer-events:all}
.overlay-x{position:absolute;top:24px;right:28px;background:none;border:none;color:rgba(255,255,255,.5);font-size:22px;cursor:pointer;font-family:var(--sans);font-weight:300;transition:color .3s}
.overlay-x:hover{color:var(--gold)}
.overlay-nav{text-align:center;margin-bottom:40px}
.overlay-nav li{margin:2px 0}
.overlay-nav a{font-family:var(--serif);font-size:clamp(28px,5vw,44px);color:rgba(255,255,255,.85);display:block;padding:8px 40px;transition:color .3s}
.overlay-nav a:hover{color:var(--gold)}
.overlay-soc{display:flex;gap:28px;padding-top:32px;border-top:1px solid var(--border)}
.overlay-soc a{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.4);transition:color .3s}
.overlay-soc a:hover{color:var(--gold)}

/* ── Header ── */
#hdr{position:fixed;top:0;left:0;right:0;z-index:900;transition:background .4s,box-shadow .4s}
.hdr-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:22px 56px;gap:16px}
#hdr.s .hdr-inner{padding:12px 56px;background:rgba(9,22,20,.96);backdrop-filter:blur(24px);box-shadow:0 1px 0 var(--border),0 8px 32px rgba(0,0,0,.4)}
.nav-l,.nav-r-links{display:flex;align-items:center;gap:32px}
.nav-r-links{justify-content:flex-end}
.nav-l a,.nav-r-links a:not(.btn-res){font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.72);transition:color .3s;padding-bottom:2px;position:relative}
.nav-l a::after,.nav-r-links a:not(.btn-res)::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav-l a:hover,.nav-r-links a:not(.btn-res):hover{color:var(--gold)}
.nav-l a:hover::after,.nav-r-links a:not(.btn-res):hover::after{width:100%}
.logo-wrap{display:flex;align-items:center;justify-content:center}
.logo-img{height:62px;width:auto;object-fit:contain;transition:height .3s}
#hdr.s .logo-img{height:48px}
.btn-res{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:11px 26px;background:var(--gold);color:var(--bg2);transition:background .3s,transform .2s}
.btn-res:hover{background:var(--gold2);transform:translateY(-1px)}
.nav-r{display:flex;align-items:center;justify-content:flex-end;gap:20px}
.nav-soc{display:flex;align-items:center;gap:14px}
.nav-soc a{color:rgba(255,255,255,.4);transition:color .3s;display:flex;align-items:center}
.nav-soc a:hover{color:var(--gold)}
.burger{display:none;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;padding:8px;margin-left:auto}
.burger span{display:block;width:26px;height:2px;background:rgba(255,255,255,.9);transition:all .3s;border-radius:1px}

/* ── Hero ── */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:var(--bg2);background-size:cover;background-position:center;transform:scale(1.05);transition:transform 10s ease-out}
.hero-bg.loaded{transform:scale(1)}
.hero-ov{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(9,22,20,.5) 0%,rgba(9,22,20,.3) 40%,rgba(9,22,20,.72) 100%)}
.hero-cnt{position:relative;z-index:2;text-align:center;padding:0 24px;max-width:880px}
.h-pre{font-family:var(--sans);font-size:13px;font-weight:400;letter-spacing:6px;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:24px}
h1{font-family:var(--serif);color:var(--cream);line-height:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.h-rest{font-size:clamp(22px,3vw,32px);font-weight:300;font-style:italic;letter-spacing:6px;opacity:.9}
.h-name{font-size:clamp(76px,13vw,148px);font-weight:700;letter-spacing:-3px;font-style:normal}
.h-sub{font-family:var(--sans);font-size:13px;font-weight:400;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:30px;margin-bottom:48px}
.btn-event{display:inline-block;padding:16px 56px;background:var(--gold);color:var(--bg2);border:2px solid var(--gold);font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:5px;text-transform:uppercase;transition:all .4s var(--ease)}
.btn-event:hover{background:transparent;color:var(--gold);transform:translateY(-2px)}
.scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2}
.scroll-hint span{display:block;width:1px;height:52px;background:linear-gradient(to bottom,transparent,var(--gold));margin:0 auto;animation:sdrop 2.2s ease-in-out infinite}
@keyframes sdrop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ── Hours Strip ── */
.hours-strip{background:var(--bg4);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:0 56px}
.hours-inner{max-width:1088px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);align-items:stretch}
.hours-item{padding:30px 32px;display:flex;flex-direction:column;gap:6px;border-right:1px solid var(--border)}
.hours-item:last-child{border-right:none}
.hours-label{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.hours-val{font-family:var(--serif);font-size:20px;color:var(--cream);line-height:1.2}

/* ── Über uns ── */
.about{background:var(--bg)}
.about-visual{position:relative}
.deco-leaf{position:absolute;top:-20px;right:-20px;width:110px;opacity:.15;pointer-events:none;z-index:0}
.deco-food{position:absolute;bottom:-20px;left:-20px;width:90px;opacity:.1;pointer-events:none}
.main-photo{position:relative;z-index:1;border:1px solid var(--border);overflow:hidden}
.main-photo img{width:100%;height:520px;object-fit:cover;transition:transform 7s ease}
.main-photo:hover img{transform:scale(1.04)}
.about-txt{padding-left:16px}
.italic-head{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.2vw,27px);color:var(--gold);line-height:1.4;margin-bottom:24px;font-weight:400}
.about-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:44px;border-top:1px solid var(--border);border-left:1px solid var(--border)}
.fact{padding:22px 18px;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.fact-num{display:block;font-family:var(--serif);font-size:36px;font-weight:600;color:var(--gold);line-height:1;margin-bottom:4px}
.fact-label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text2)}

/* ── Küche & Philosophie ── */
.kueche{background:var(--bg3)}
.kueche-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-top:64px}
.kueche-item{background:var(--bg3);padding:48px 38px;transition:background .3s;position:relative}
.kueche-item::before{content:'';position:absolute;top:0;left:38px;right:38px;height:1px;background:var(--gold);opacity:0;transition:opacity .35s}
.kueche-item:hover{background:rgba(201,168,76,.04)}
.kueche-item:hover::before{opacity:1}
.kueche-num{font-family:var(--serif);font-size:11px;color:var(--gold);letter-spacing:3px;margin-bottom:22px;display:block;font-style:italic}
.kueche-item h3{font-size:22px;margin-bottom:14px}
.kueche-item p{font-size:13px;color:var(--text2);line-height:1.95}

/* ── Speisekarte ── */
.menu{background:var(--bg2)}
.menu-photo{border:1px solid var(--border);overflow:hidden}
.menu-photo img{width:100%;height:520px;object-fit:cover;transition:transform 7s ease}
.menu-photo:hover img{transform:scale(1.04)}
.menu-txt h2{margin-bottom:16px}
.menu-txt .eyebrow{text-align:left}
/* btn-ol and btn-outline-gold defined in button block above */

/* ── Galerie ── */
.gallery{background:var(--bg)}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:auto;gap:2px}
.gi{overflow:hidden;cursor:pointer;aspect-ratio:4/3;position:relative}
.gi:first-child{grid-column:1/3;aspect-ratio:16/7}
.gi img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .4s;filter:brightness(.9)}
.gi:hover img{transform:scale(1.06);filter:brightness(1.02)}
.gi::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(9,22,20,.45),transparent 55%);opacity:0;transition:opacity .4s;pointer-events:none}
.gi:hover::after{opacity:1}
.lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,.93);z-index:3000;align-items:center;justify-content:center}
.lb.open{display:flex}
.lb-w{max-width:88vw;max-height:88vh}
.lb-w img{max-width:100%;max-height:88vh;object-fit:contain}
.lb-x,.lb-p,.lb-n{position:fixed;background:none;border:none;color:rgba(255,255,255,.5);cursor:pointer;font-size:32px;transition:color .2s;font-family:var(--sans);font-weight:200}
.lb-x{top:22px;right:30px;font-size:20px}
.lb-p{left:24px;top:50%;transform:translateY(-50%)}
.lb-n{right:24px;top:50%;transform:translateY(-50%)}
.lb-x:hover,.lb-p:hover,.lb-n:hover{color:var(--gold)}

/* ── Team ── */
.team{background:var(--bg2)}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:64px}
.team-card{background:var(--bg2);padding:52px 36px;text-align:center;transition:background .3s}
.team-card:hover{background:rgba(201,168,76,.04)}
.team-avatar{width:76px;height:76px;border:1px solid var(--border);border-radius:50%;margin:0 auto 20px;overflow:hidden;background:var(--bg3);display:flex;align-items:center;justify-content:center}
.team-avatar img{width:100%;height:100%;object-fit:cover}
.team-avatar-init{font-family:var(--serif);font-size:28px;color:var(--gold);font-weight:600}
.team-name{font-family:var(--serif);font-size:22px;color:var(--cream);margin-bottom:6px}
.team-role{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:18px;display:block}
.team-card p{font-size:13px;color:var(--text2);line-height:1.9}

/* ── Bewertungen ── */
.reviews{background:var(--bg3)}
.rating-bar{display:flex;align-items:center;gap:40px;justify-content:center;margin-bottom:60px;padding:40px;border:1px solid var(--border);flex-wrap:wrap}
.g-score{font-family:var(--serif);font-size:68px;font-weight:600;color:var(--gold);line-height:1}
.g-divider{width:1px;height:52px;background:var(--border)}
.g-info{text-align:center}
.g-stars{display:flex;gap:4px;margin-bottom:6px;justify-content:center}
.g-stars span{display:block;width:13px;height:13px;background:var(--gold);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.g-count{font-size:10px;color:var(--text2);letter-spacing:2px;text-transform:uppercase}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.review-card{background:var(--bg3);padding:40px 32px;transition:background .3s}
.review-card:hover{background:rgba(201,168,76,.04)}
.review-stars{display:flex;gap:3px;margin-bottom:20px}
.review-stars span{display:block;width:10px;height:10px;background:var(--gold);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.review-text{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--text);line-height:1.85;margin-bottom:28px}
.review-author{display:flex;align-items:center;gap:14px}
.review-line{flex:1;height:1px;background:var(--border)}
.review-name{font-size:12px;font-weight:700;color:var(--cream);letter-spacing:1px}
.review-source{font-size:10px;color:var(--text2);letter-spacing:2px;text-transform:uppercase;margin-top:2px}

/* ── Events ── */
.events{background:var(--bg4);position:relative}
.events::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);opacity:.4}
.events-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);margin-top:64px}
.event-card{background:var(--bg4);padding:52px 48px;transition:background .3s;position:relative}
.event-card::before{content:'';position:absolute;top:0;left:48px;right:48px;height:1px;background:var(--gold);opacity:0;transition:opacity .4s}
.event-card:hover{background:rgba(201,168,76,.05)}
.event-card:hover::before{opacity:1}
.event-label{font-family:var(--sans);font-size:9px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:block}
.event-card h3{font-size:24px;margin-bottom:14px}
.event-card p{font-size:13px;color:var(--text2);line-height:1.95}
.events-cta{text-align:center;margin-top:64px}
/* btn-outline-gold defined above */

/* ── Reservierung ── */
.res{background:var(--bg);position:relative;overflow:hidden}
.res-bg{position:absolute;inset:0;background:var(--bg);background-size:cover;background-position:center}
.res-ov{position:absolute;inset:0;background:rgba(12,28,26,.88)}
.res-in{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:start;max-width:1200px;margin:0 auto;padding:0 56px}
.res-txt .eyebrow{text-align:left}
.res-txt h2{text-align:left}
.res-s{font-size:13px;color:var(--text2);margin-bottom:28px;letter-spacing:1px}
.res-body{font-size:14px;color:var(--text)}
.res-contact-info{margin-top:36px;display:flex;flex-direction:column;gap:14px}
.res-ci{display:flex;align-items:baseline;gap:14px}
.res-ci-label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);width:76px;flex-shrink:0}
.res-ci a{font-size:14px;color:var(--cream);transition:color .3s}
.res-ci a:hover{color:var(--gold)}
.res-box{background:rgba(255,255,255,.03);border:1px solid var(--border);padding:44px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.fg{display:flex;flex-direction:column;gap:6px}
.fg.full{margin-bottom:16px}
.fg label{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text2)}
.fg input,.fg select,.fg textarea{padding:11px 14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:var(--cream);font-family:var(--sans);font-size:13px;outline:none;transition:border-color .3s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(245,240,232,.22)}
.fg select option{background:var(--bg3)}
.fg textarea{resize:vertical;min-height:90px}
.priv{margin-bottom:24px}
.cbl{
  display:flex;
  align-items:flex-start;
  gap:12px;
  cursor:pointer;
  /* prevent any external styles from breaking flex */
}
.cbl input[type="checkbox"]{
  /* fixed size, no shrink, no grow, aligned with first line of text */
  width:18px;
  height:18px;
  min-width:18px;
  flex:0 0 18px;
  margin-top:1px;
  accent-color:var(--gold);
  cursor:pointer;
  /* reset potential inherited styles */
  -webkit-appearance:checkbox;
  appearance:checkbox;
}
.cbl span{font-size:12px;color:var(--text2);line-height:1.65;flex:1}
.cbl a{color:var(--gold)}

/* ── All buttons: gold background, dark text ── */
.btn-ol{
  display:inline-block;padding:14px 48px;
  background:var(--gold);color:var(--bg2);
  border:2px solid var(--gold);
  font-family:var(--sans);font-size:10px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;
  transition:all .35s var(--ease);margin-top:8px;
}
.btn-ol:hover{background:transparent;color:var(--gold);transform:translateY(-2px)}

.btn-outline-gold{
  display:inline-block;padding:14px 56px;
  background:var(--gold);color:var(--bg2);
  border:2px solid var(--gold);
  font-family:var(--sans);font-size:10px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;
  transition:all .35s var(--ease);
}
.btn-outline-gold:hover{background:transparent;color:var(--gold);transform:translateY(-2px)}

.btn-sub{
  width:100%;padding:15px;
  background:var(--gold);color:var(--bg2);
  border:none;cursor:pointer;
  font-family:var(--sans);font-size:11px;
  font-weight:700;letter-spacing:3px;text-transform:uppercase;
  transition:background .3s,transform .2s;
}
.btn-sub:hover{background:var(--gold2);transform:translateY(-1px)}
.fnote{font-size:10px;color:var(--text2);margin-top:14px;text-align:center;letter-spacing:.5px}
.form-ok{display:none;text-align:center;padding:60px 24px}
.ok-ico{width:52px;height:52px;border:1px solid var(--gold);color:var(--gold);font-family:var(--serif);font-size:22px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.form-ok h3{font-family:var(--serif);color:var(--cream);font-size:22px;font-weight:400;margin-bottom:10px}
.form-ok p{color:var(--text2);font-size:13px}

/* ── Kontakt ── */
.contact{background:var(--bg)}
.ct-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:1px;background:var(--border);border:1px solid var(--border)}
.ct-info{background:var(--bg);display:flex;flex-direction:column}
.ct-b{padding:36px 40px;border-bottom:1px solid var(--border)}
.ct-b:last-child{border-bottom:none}
.ct-b h3{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.ct-b p{font-size:14px;color:var(--text);line-height:2}
.ct-b table{width:100%;border-collapse:collapse}
.ct-b table td{padding:5px 0;font-size:13px;color:var(--text);vertical-align:top}
.ct-b table td:first-child{color:var(--text2);width:86px}
.ct-b a{color:var(--text);transition:color .3s}
.ct-b a:hover{color:var(--gold)}
.ct-soc{display:flex;gap:18px;flex-wrap:wrap}
.ct-soc a{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text2);transition:color .3s;padding-bottom:2px;border-bottom:1px solid transparent}
.ct-soc a:hover{color:var(--gold);border-bottom-color:rgba(201,168,76,.4)}
.ct-map{background:var(--bg3);min-height:460px}
.ct-map iframe{width:100%;height:100%;border:0;min-height:460px;display:block;filter:grayscale(.25) contrast(1.04)}

/* ── Footer ── */
footer{background:var(--bg2);border-top:1px solid var(--border)}
.ft-top{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:32px;padding:52px 56px;border-bottom:1px solid var(--border)}
.ft-logo img{height:50px;object-fit:contain;opacity:.8;transition:opacity .3s}
.ft-logo:hover img{opacity:1}
.ft-nav{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.ft-nav a{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);transition:color .3s}
.ft-nav a:hover{color:var(--gold)}
.ft-soc{display:flex;gap:18px;justify-content:flex-end}
.ft-soc a{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);transition:color .3s}
.ft-soc a:hover{color:var(--gold)}
.ft-bot{display:flex;align-items:center;justify-content:space-between;padding:18px 56px;font-size:10px;color:var(--text2);letter-spacing:1px;flex-wrap:wrap;gap:12px}
.ft-bot a{transition:color .3s;margin-left:20px}
.ft-bot a:hover{color:var(--gold)}

/* ── Back to Top ── */
.top-btn{position:fixed;bottom:32px;right:28px;z-index:800;width:38px;height:38px;border:1px solid var(--border);background:var(--bg2);color:var(--text2);display:flex;align-items:center;justify-content:center;font-size:13px;font-family:var(--sans);opacity:0;pointer-events:none;transition:all .3s var(--ease)}
.top-btn.v{opacity:1;pointer-events:all}
.top-btn:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}

/* ── WhatsApp button - hidden ── */
.whatsapp-btn{display:none}

/* ── Cookie Banner ── */
/* ── Cookie Banner: slides from TOP on mobile, bottom on desktop ── */
.cookie-bar{
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:9999;
  background:rgba(9,22,20,.99);
  border-top:1px solid var(--border);
  backdrop-filter:blur(16px);
  padding:18px 40px;
  transform:translateY(110%);
  transition:transform .4s ease;
}
.cookie-bar.show{transform:translateY(0)}
.cookie-inner{
  max-width:1100px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.cookie-inner p{font-size:13px;color:var(--text2);line-height:1.7;flex:1;min-width:200px}
.cookie-inner a{color:var(--gold)}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
.cookie-decline{
  padding:12px 24px;background:transparent;
  border:1px solid rgba(245,240,232,.25);color:var(--text2);
  font-family:var(--sans);font-size:12px;letter-spacing:1px;
  cursor:pointer;transition:all .3s;white-space:nowrap;
}
.cookie-decline:hover{border-color:rgba(245,240,232,.5);color:var(--cream)}
.cookie-accept{
  padding:12px 24px;background:var(--gold);color:var(--bg2);
  border:none;font-family:var(--sans);font-size:12px;
  font-weight:700;letter-spacing:1px;white-space:nowrap;
  cursor:pointer;transition:background .3s;
}
.cookie-accept:hover{background:var(--gold2)}

/* On mobile: cookie slides from TOP to avoid conflict with bottom nav */
@media(max-width:960px){
  .cookie-bar{
    bottom:auto;
    top:0;
    border-top:none;
    border-bottom:1px solid var(--border);
    transform:translateY(-110%);
    padding:16px 20px;
  }
  .cookie-bar.show{transform:translateY(0)}
  .cookie-inner{flex-direction:column;gap:12px;align-items:stretch}
  .cookie-inner p{font-size:12px;min-width:0}
  .cookie-btns{gap:10px}
  .cookie-decline,.cookie-accept{
    flex:1;padding:13px 16px;font-size:13px;text-align:center;
  }
}

/* ── Scroll Reveal ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.rd1{transition-delay:.12s}
.rd2{transition-delay:.24s}
.rd3{transition-delay:.36s}

/* ── Divider ── */
.divider{display:inline-block;max-width:160px;opacity:.5}
.divider-w{margin:18px 0}
.divider-w.center{text-align:center}

/* ── Responsive ── */
@media(max-width:1100px){
  .kueche-grid{grid-template-columns:1fr 1fr}
  .events-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:960px){
  /* Header always visible on mobile */
  #hdr .hdr-inner{grid-template-columns:auto 1fr;padding:12px 20px;background:rgba(9,22,20,.97);backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border)}
  #hdr.s .hdr-inner{padding:10px 20px}
  .logo-img{height:44px}
  #hdr.s .logo-img{height:40px}
  .nav-l,.nav-r{display:none}
  .burger{display:flex;justify-self:end}
  .two-col,.res-in{grid-template-columns:1fr;gap:48px;padding:0 28px}
  .container{padding:0 28px}
  .sec{padding:72px 0}
  .ft-top{grid-template-columns:1fr;text-align:center;padding:36px 28px;gap:24px}
  .ft-nav,.ft-soc{justify-content:center}
  .ft-bot{padding:16px 28px}
  .hours-strip{padding:0 28px}
  .hours-inner{grid-template-columns:1fr 1fr}
  .hours-item:nth-child(2){border-right:none}
  .hours-item:nth-child(1),.hours-item:nth-child(2){border-bottom:1px solid var(--border)}
  .ct-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr 1fr}
  .gi:first-child{grid-column:1/-1}
  .reviews-grid{grid-template-columns:1fr;background:none;gap:2px}
  .res-box{padding:28px 20px}
  .about-txt{padding-left:0}
}

/* ── Mobile Bottom Navigation Bar ── */
/* Always hidden on desktop */
.mobile-bottom-nav{display:none !important}

/* Show only on mobile */
@media(max-width:960px){
  .mobile-bottom-nav{
    display:flex !important;
    position:fixed;
    bottom:0;left:0;right:0;
    /* iOS safe area support */
    padding-bottom:env(safe-area-inset-bottom, 0px);
    z-index:2000;
    background:rgba(9,22,20,.98);
    border-top:1px solid rgba(201,168,76,.2);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    min-height:60px;
    height:calc(60px + env(safe-area-inset-bottom, 0px));
  }
  body{
    padding-bottom:calc(60px + env(safe-area-inset-bottom, 0px));
  }
  .top-btn{bottom:calc(70px + env(safe-area-inset-bottom, 0px))}
}
.mbn-item{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:4px;
  color:rgba(245,240,232,.5);
  font-family:var(--sans);font-size:9px;
  letter-spacing:1px;text-transform:uppercase;
  text-decoration:none;transition:color .2s;
  border:none;background:none;cursor:pointer;
  padding:8px 2px;
  -webkit-tap-highlight-color:transparent;
  min-height:60px;
}
.mbn-item svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.5;flex-shrink:0}
.mbn-item:active,.mbn-item.mbn-active{color:var(--gold)}
.mbn-item.mbn-res{
  color:var(--bg2) !important;
  background:var(--gold);
  font-weight:700;
}
.mbn-item.mbn-res svg{stroke:var(--bg2)}
.mbn-item.mbn-res:active{background:var(--gold2)}
@media(max-width:600px){
  .kueche-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .events-grid{grid-template-columns:1fr}
  .about-facts{grid-template-columns:repeat(3,1fr)}
  .gal-grid{grid-template-columns:1fr}
  .gi:first-child{grid-column:1;aspect-ratio:4/3}
  .frow{grid-template-columns:1fr}
  .hours-inner{grid-template-columns:1fr}
  .hours-item{border-right:none;border-bottom:1px solid var(--border)}
  .hours-item:last-child{border-bottom:none}
  .rating-bar{gap:20px}
  .g-divider{display:none}
}

/* ============================================================
   KONTAKT FORM (Split Layout)
============================================================ */
.contact-form-wrap {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-top: 64px;
}
.cf-info {
  background: var(--bg);
  padding: 52px 44px;
}
.cf-info h3 {
  font-size: clamp(22px,2.4vw,30px);
  margin-bottom: 14px;
}
.cf-info .gold-rule { margin-left:0; }
.cf-info p {
  color: var(--text2);
  font-size: 14px;
  line-height: 1.9;
  margin-bottom: 36px;
}
.cf-detail {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.cf-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cf-row-label {
  font-size: 9px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
}
.cf-row-val {
  font-size: 15px;
  color: var(--cream);
}
.cf-row-val a {
  color: var(--cream);
  transition: color .3s;
}
.cf-row-val a:hover { color: var(--gold); }
.cf-form {
  background: var(--bg3);
  padding: 52px 44px;
}
.cf-form .fg { margin-bottom: 14px; }
.cf-form label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text2);
  display: block;
  margin-bottom: 6px;
}
.cf-form input,
.cf-form select,
.cf-form textarea {
  padding: 11px 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--cream);
  font-family: var(--sans);
  font-size: 13px;
  outline: none;
  transition: border-color .3s;
  width: 100%;
}
.cf-form input:focus,
.cf-form select:focus,
.cf-form textarea:focus { border-color: var(--gold); }
.cf-form input::placeholder,
.cf-form textarea::placeholder { color: rgba(245,240,232,.22); }
.cf-form select option { background: var(--bg3); }
.cf-form textarea { resize: vertical; min-height: 100px; }
.cf-form .frow { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cf-ok {
  display: none;
  text-align: center;
  padding: 72px 24px;
}
.cf-ok .ok-ico { margin: 0 auto 20px; }
.cf-ok h3 { font-family: var(--serif); font-size: 22px; font-weight:400; color: var(--cream); margin-bottom:10px; }
.cf-ok p   { color: var(--text2); font-size:13px; }

/* ============================================================
   EVENT INQUIRY FORM
============================================================ */
.event-inquiry {
  background: var(--bg2);
  position: relative;
}
.event-inquiry::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold), transparent);
  opacity: .35;
}
.eq-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-top: 64px;
}
.eq-txt {
  background: var(--bg2);
  padding: 52px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.eq-txt .eyebrow { text-align: left; }
.eq-txt h2  { text-align: left; margin-bottom: 14px; }
.eq-txt p   { color: var(--text2); font-size: 14px; line-height: 1.9; }
.eq-items {
  margin-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--border);
}
.eq-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.eq-item-label {
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text2);
}
.eq-item-val {
  font-family: var(--serif);
  font-size: 15px;
  color: var(--cream);
}
.eq-form {
  background: var(--bg3);
  padding: 52px 44px;
}
.eq-form label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text2);
  display: block;
  margin-bottom: 6px;
}
.eq-form input,
.eq-form select,
.eq-form textarea {
  padding: 11px 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--cream);
  font-family: var(--sans);
  font-size: 13px;
  outline: none;
  transition: border-color .3s;
  width: 100%;
}
.eq-form input:focus,
.eq-form select:focus,
.eq-form textarea:focus { border-color: var(--gold); }
.eq-form input::placeholder,
.eq-form textarea::placeholder { color: rgba(245,240,232,.22); }
.eq-form select option { background: var(--bg3); }
.eq-form textarea { resize: vertical; min-height: 90px; }
.eq-form .frow  { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.eq-form .fg    { margin-bottom: 14px; }
.eq-ok {
  display: none;
  text-align: center;
  padding: 72px 24px;
}
.eq-ok h3 { font-family: var(--serif); font-size: 22px; font-weight:400; color: var(--cream); margin-bottom:10px; }
.eq-ok p  { color: var(--text2); font-size:13px; }

/* ── Responsive new sections ── */
@media(max-width:960px){
  .contact-form-wrap { grid-template-columns: 1fr; }
  .eq-grid { grid-template-columns: 1fr; }
  .cf-info, .cf-form, .eq-txt, .eq-form { padding: 36px 24px; }
  .cf-form .frow, .eq-form .frow { grid-template-columns: 1fr; }
}

/* ── Ambience parallax strip ── */
@media(max-width:768px){
  [style*="background-attachment:fixed"]{
    background-attachment:scroll !important;
  }
}
