/* cormorant-garamond-regular - latin */
@font-face {
  font-display: swap; 
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/cormorant-garamond-v21-latin-regular.woff2') format('woff2'); 
}
/* cormorant-garamond-500 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  src: url('fonts/cormorant-garamond-v21-latin-500.woff2') format('woff2'); 
}
/* cormorant-garamond-600 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  src: url('fonts/cormorant-garamond-v21-latin-600.woff2') format('woff2'); 
}
/* cormorant-garamond-700 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/cormorant-garamond-v21-latin-700.woff2') format('woff2'); 
}

/* montserrat-300 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  src: url('fonts/montserrat-v31-latin-300.woff2') format('woff2'); 
}
/* montserrat-regular - latin */
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/montserrat-v31-latin-regular.woff2') format('woff2'); 
}
/* montserrat-500 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  src: url('fonts/montserrat-v31-latin-500.woff2') format('woff2'); 
}
/* montserrat-600 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  src: url('fonts/montserrat-v31-latin-600.woff2') format('woff2'); 
}
/* montserrat-700 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/montserrat-v31-latin-700.woff2') format('woff2'); 
}


:root {
  --primary: #c5a065;
  --primary-dark: #a6854e;
  --ink: #141414;
  --text: #333;
  --muted: #666;
  --bg: #ffffff;
  --bg-soft: #f7f7f8;
  --bg-accent: #f4f1ea;
  --nav-h: 90px;
  --topbar-h: 36px;
  --font-heading: 'Cormorant Garamond', serif;
  --font-body: 'Montserrat', sans-serif;
  --radius: 14px;
  --shadow-sm: 0 10px 25px rgba(0,0,0,.06);
  --shadow-md: 0 18px 55px rgba(0,0,0,.10);
  --ease: cubic-bezier(.22, 1, .36, 1);
  --ease2: cubic-bezier(.2, .9, .2, 1);
  --reveal-dur: 900ms;
  --reveal-stagger: 90ms;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body); 
  color: var(--text); 
  background: var(--bg);
  line-height: 1.6; 
  overflow-x: hidden; 
  padding-top: calc(var(--nav-h) + var(--topbar-h));
  transition: background-color 0.3s ease, color 0.3s ease;
}
a { color: inherit; text-decoration: none; }
img { width: 100%; height: auto; display: block; object-fit: cover; border-radius: calc(var(--radius) - 6px); }

.container { max-width: 1120px; margin: 0 auto; padding: 0 20px; }
.bg-soft { background: var(--bg-soft); transition: background-color 0.3s ease; }
.bg-accent { background: var(--bg-accent); transition: background-color 0.3s ease; }
.text-center { text-align: center; }

body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: -2; filter: saturate(1.05);
  background: radial-gradient(1000px 600px at 10% 10%, rgba(197,160,101,.12), transparent 55%),
              radial-gradient(900px 520px at 90% 30%, rgba(20,20,20,.06), transparent 55%),
              radial-gradient(800px 520px at 50% 95%, rgba(197,160,101,.09), transparent 55%);
}
body::after {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: -1; opacity: .55; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E");
}

h1, h2, h3, h4 { font-family: var(--font-heading); color: var(--ink); letter-spacing: .3px; line-height: 1.15; }
h1 { font-size: clamp(2.4rem, 4vw, 3.8rem); font-weight: 700; }
h2 { font-size: clamp(1.9rem, 3vw, 2.7rem); font-weight: 700; text-transform: uppercase; letter-spacing: 1.4px; }
h3 { font-size: clamp(1.2rem, 1.7vw, 1.55rem); font-weight: 700; }
p { color: var(--muted); font-weight: 400; }

.subtitle { display: inline-flex; align-items: center; gap: 10px; font-size: .86rem; text-transform: uppercase; letter-spacing: 3px; color: var(--primary); font-weight: 600; }
.subtitle::before { content: ""; width: 38px; height: 1px; background: linear-gradient(90deg, transparent, var(--primary)); opacity: .9; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 14px 30px; border-radius: 999px; font-weight: 700; text-transform: uppercase; font-size: .8rem; letter-spacing: 1.7px; border: 1px solid transparent; cursor: pointer; transition: all .35s var(--ease); position: relative; }
.btn-primary { background: linear-gradient(135deg, var(--primary), #d7b57b); color: #fff; box-shadow: 0 14px 30px rgba(197,160,101,.25); }
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 18px 45px rgba(197,160,101,.33); }
.btn-secondary { background: rgba(255,255,255,.95); color: var(--ink); border: none; }
.btn-secondary:hover { transform: translateY(-3px); box-shadow: var(--shadow-sm); background: #fff; }
.btn-outline { background: transparent; color: var(--ink); border-color: rgba(0,0,0,.22); }
.btn-outline:hover { background: var(--ink); color: #fff; transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.btn-sm { padding: 10px 18px; font-size: .75rem; }

.disabled-btn { background: #ccc !important; color: #888 !important; box-shadow: none !important; cursor: not-allowed !important; transform: none !important; }

.scroll-progress { position: fixed; left: 0; top: calc(var(--nav-h) + var(--topbar-h)); height: 3px; width: 0%; background: linear-gradient(90deg, var(--primary), #e3c692); z-index: 2001; }

.navbar { position: fixed; top: 0; left: 0; right: 0; height: var(--nav-h); z-index: 2000; display: flex; align-items: center; background: var(--bg); border-bottom: 1px solid rgba(0,0,0,.06); transition: all .35s var(--ease); }
.navbar.is-scrolled { box-shadow: 0 14px 40px rgba(0,0,0,.06); }

.nav-container { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; width: 100%; max-width: 1300px; margin: 0 auto; padding: 0 20px; }
.logo { justify-self: start; }
.nav-menu { justify-self: center; list-style: none; display: flex; gap: 30px; margin: 0; padding: 0;}
.nav-cta { justify-self: end; }

.logo a { display: flex; align-items: center; }


.nav-logo { height: 76px; width: auto; object-fit: contain; border-radius: 0; display: block; filter: brightness(0) !important; opacity: 1 !important; transition: filter 0.3s; }
.m-nav-logo { height: 64px; width: auto; object-fit: contain; border-radius: 0; display: block; filter: brightness(0) !important; opacity: 1 !important; transition: filter 0.3s; }

.nav-menu a { 
    font-size: .82rem; 
    text-transform: uppercase; 
    letter-spacing: 1px; 
    font-weight: 700; 
    color: #141414 !important; /* FIX: Zwingt die inaktiven Links zu einem satten Dunkelgrau/Schwarz */
    opacity: 1 !important; 
    padding: 10px 2px; 
    position: relative; 
    transition: all .25s var(--ease); 
}
.nav-menu a::after { 
    content: ""; 
    position: absolute; 
    left: 0; 
    bottom: 6px; 
    width: 0%; 
    height: 2px; 
    background: linear-gradient(90deg, var(--primary), transparent); 
    transition: width .35s var(--ease); 
}
.nav-menu a:hover, .nav-menu a.active { 
    color: #8b6b3e !important; /* FIX: Das WCAG-konforme Gold für den ausgewählten Zustand */
    opacity: 1 !important; 
}
.nav-menu a:hover::after, .nav-menu a.active::after { width: 100%; }

.nav-cta a { background: var(--ink); color: var(--bg); border-radius: 999px; padding: 11px 18px; font-weight: 800; font-size: .78rem; text-transform: uppercase; box-shadow: 0 14px 28px rgba(0,0,0,.12); transition: all .35s var(--ease); }
.nav-cta a:hover { background: linear-gradient(135deg, var(--primary-dark), var(--primary)); transform: translateY(-2px); box-shadow: 0 18px 45px rgba(197,160,101,.22); color: #fff; }
.menu-icon { display: none; justify-self: end; font-size: 1.8rem; cursor: pointer; color: var(--ink); padding: 10px 12px; border-radius: 12px; border: 1px solid rgba(0,0,0,.08); background: rgba(255,255,255,.75); transition: all .3s var(--ease); }

.top-info-bar { position: fixed; top: var(--nav-h); left: 0; right: 0; height: var(--topbar-h); background: #0b1526; color: #fff; z-index: 2050; display: flex; align-items: center; justify-content: center; font-size: 0.75rem; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; }

.mobile-nav { position: fixed; inset: 0; z-index: 2500; pointer-events: none; opacity: 0; transition: opacity .35s var(--ease); }
.mobile-nav.active { pointer-events: auto; opacity: 1; }
.mobile-backdrop { position: absolute; inset: 0; background: rgba(10,10,10,.35); backdrop-filter: blur(10px); }
.mobile-panel { position: absolute; top: 0; right: 0; width: min(420px, 88vw); height: 100%; background: var(--bg); backdrop-filter: blur(14px); border-left: 1px solid rgba(0,0,0,.06); transform: translateX(110%); transition: transform .45s var(--ease); display: flex; flex-direction: column; padding: 22px; gap: 18px; }
.mobile-nav.active .mobile-panel { transform: translateX(0); }
.mobile-top { display: flex; align-items: center; justify-content: space-between; padding: 6px 4px 10px 4px; }
.mobile-close { width: 44px; height: 44px; border-radius: 14px; border: 1px solid rgba(0,0,0,.08); background: rgba(255,255,255,.8); cursor: pointer; font-size: 1.4rem; color: var(--ink); }
.mobile-links { display: flex; flex-direction: column; gap: 8px; }
.m-link { font-family: var(--font-heading); font-size: 1.55rem; color: var(--ink); padding: 14px 12px; border-radius: 16px; border: 1px solid transparent; transition: all .35s var(--ease); }
.m-link:hover { background: rgba(197,160,101,.10); border-color: rgba(197,160,101,.28); transform: translateX(4px); }
.m-cta { margin-top: auto; padding-top: 18px; border-top: 1px solid rgba(0,0,0,.07); }
.m-cta .btn { width: 100%; }

section { padding: 92px 0; scroll-margin-top: var(--nav-h); position: relative; }
.section-divider { position: absolute; left: 0; right: 0; top: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(0,0,0,.08), transparent); opacity: .7; }


.hero { min-height: calc(100vh - var(--nav-h) - var(--topbar-h)); display: grid; place-items: center; position: relative; overflow: hidden; padding: 0; background: #141414; }
.hero-bg { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; border-radius: 0; animation: heroZoom 30s ease-in-out infinite alternate; transform-origin: center; }
@keyframes heroZoom { 0% { transform: scale(1); } 100% { transform: scale(1.08); } }
.hero-overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(rgba(0,0,0,.25), rgba(0,0,0,.65)); }

.hero-content-centered { position: relative; z-index: 3; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; width: 100%; padding: 0 20px; }

.hero-welcome-logo { width: 100%; max-width: 750px; height: auto; margin: 0 auto; display: block; filter: brightness(0) invert(1) drop-shadow(0 4px 10px rgba(0,0,0,0.4)); border-radius: 0; }
.hero-action-area { display: flex; flex-direction: column; align-items: center; position: relative; z-index: 10; margin-top: -160px; transform: translateX(205px); }
.hero-rooftop-subtitle { font-family: var(--font-heading); font-size: clamp(2rem, 3.5vw, 2.6rem); font-weight: 600; color: #fff; letter-spacing: 4px; margin-bottom: 15px; text-shadow: 0 4px 10px rgba(0,0,0,0.5); }
.hero-buttons-stacked { display: flex; flex-direction: column; gap: 12px; width: 250px; }
.hero-buttons-stacked .btn { width: 100%; padding: 13px 20px; font-size: 0.75rem; border-radius: 999px; font-weight: 800; letter-spacing: 1.5px; }
.hero-bottom-stats { color: #fff; font-family: var(--font-body); font-weight: 700; font-size: clamp(0.7rem, 1.5vw, 0.85rem); letter-spacing: 3px; text-transform: uppercase; margin-top: 25px; text-shadow: 0 2px 4px rgba(0,0,0,0.5); }

.hero-down { position: absolute; left: 50%; bottom: 22px; transform: translateX(-50%); width: 46px; height: 46px; border-radius: 999px; border: 1px solid rgba(255,255,255,.28); background: rgba(0,0,0,.22); backdrop-filter: blur(10px); display: grid; place-items: center; color: #fff; cursor: pointer; animation: bounce 2.2s var(--ease) infinite; z-index: 4; }

.two-column { display: grid; grid-template-columns: 1.05fr .95fr; gap: 46px; align-items: center; }
.about-lead { font-size: 1.08rem; color: rgba(0,0,0,.68); margin-top: 10px; margin-bottom: 18px; }
.frame { position: relative; padding: 14px; border-radius: 22px; background: rgba(255,255,255,.62); border: 1px solid rgba(0,0,0,.06); box-shadow: var(--shadow-md); }


.filter-nav { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; margin-top: 30px; margin-bottom: 20px; }
.filter-btn { background: transparent; border: 1px solid rgba(0,0,0,.15); padding: 10px 22px; border-radius: 999px; font-family: var(--font-body); font-weight: 700; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); cursor: pointer; transition: all 0.3s var(--ease); }
.filter-btn:hover { border-color: var(--primary); color: var(--primary-dark); }
.filter-btn.active { background: #438b78; color: var(--bg); border-color: #438b78; box-shadow: 0 8px 20px rgba(67, 139, 120, 0.3); }

.menu-slider-container { position: relative; max-width: 940px; margin: 0 auto; }
.page-btn-side { position: absolute; top: 50%; transform: translateY(-50%); width: 48px; height: 48px; border-radius: 50%; background: rgba(255,255,255,0.7); border: 1px solid rgba(0,0,0,0.1); color: var(--ink); font-size: 1.2rem; cursor: pointer; z-index: 10; transition: all 0.3s var(--ease); display: none; place-items: center; box-shadow: var(--shadow-sm); backdrop-filter: blur(5px); }
.page-btn-side:hover:not(:disabled) { background: var(--primary); color: #fff; opacity: 1; border-color: var(--primary); }
.page-btn-side:disabled { opacity: 0; pointer-events: none; }
.prev-btn { left: -65px; }
.next-btn { right: -65px; }

.menu-wrap { display: grid; gap: 10px; overflow: hidden; touch-action: pan-y; }

.filter-item { display: none !important; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 18px; border-radius: 16px; background: var(--bg); border: 1px solid rgba(0,0,0,.06); box-shadow: 0 10px 25px rgba(0,0,0,.04); transition: box-shadow .3s var(--ease), border-color .3s var(--ease); }
.filter-item.active-item { display: flex !important; }
.filter-item.slide-in { animation: fadeInSlide 0.4s var(--ease) forwards; }
@keyframes fadeInSlide { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }
.filter-item:hover { box-shadow: var(--shadow-sm); border-color: rgba(197,160,101,.26); }
.menu-info h3 { margin-bottom: 6px; }
.menu-info p { margin: 0; color: var(--muted); }
.menu-price { flex: 0 0 auto; min-width: 86px; text-align: right; font-family: var(--font-heading); font-weight: 800; font-size: 1.35rem; color: var(--primary-dark); }


.reviews-layout { display: grid; grid-template-columns: 280px 1fr; gap: 40px; align-items: center; }
.reviews-summary { text-align: center; padding: 20px; background: var(--bg); border-radius: 16px; box-shadow: var(--shadow-sm); border: 1px solid rgba(0,0,0,.04); }
.r-title { font-family: var(--font-body); font-weight: 800; font-size: 1.1rem; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 5px; color: var(--ink); }
.r-main-stars { color: #fbbc04; font-size: 1.8rem; margin: 10px 0; }
.r-based { font-size: 0.9rem; color: var(--muted); margin-bottom: 10px; }
.r-based strong { color: var(--ink); }
.g-logo-text { font-family: 'Product Sans', Arial, sans-serif; font-size: 1.6rem; font-weight: bold; letter-spacing: -1px; }

.reviews-slider-wrap { position: relative; display: flex; align-items: center; gap: 15px; }
.reviews-track-container { overflow: hidden; flex: 1; border-radius: 16px; padding: 10px 0; margin: -10px 0; touch-action: pan-y; }
.reviews-track { display: flex; gap: 20px; transition: transform 0.5s var(--ease); }

.review-card {
    flex: 0 0 calc(33.333% - 13.33px); 
    background: var(--bg);
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 16px;
    padding: 24px;
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    text-decoration: none !important; 
    color: inherit;
    transition: transform .3s var(--ease), box-shadow .3s var(--ease);
    cursor: pointer;
}
.review-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: rgba(0,0,0,.15); }
.r-header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; position: relative; }
.r-avatar { width: 42px; height: 42px; border-radius: 50%; color: #fff; display: grid; place-items: center; font-weight: bold; font-family: var(--font-heading); font-size: 1.3rem; }
.r-meta { display: flex; flex-direction: column; }
.r-name { font-weight: 700; color: var(--ink); font-size: 0.95rem; }
.r-date { font-size: 0.75rem; color: var(--muted); }
.r-g-icon { position: absolute; right: 0; top: 0; font-size: 1.2rem; }
.r-stars { color: #fbbc04; font-size: 0.9rem; margin-bottom: 12px; }
.r-text { font-size: 0.9rem; line-height: 1.6; color: var(--muted); display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }

.review-btn { width: 44px; height: 44px; border-radius: 50%; background: var(--bg); border: 1px solid rgba(0,0,0,.1); color: var(--ink); cursor: pointer; display: grid; place-items: center; box-shadow: var(--shadow-sm); transition: all .3s var(--ease); z-index: 2; flex-shrink: 0; }
.review-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }


.gallery-grid { margin-top: 40px; display: grid; grid-template-columns: repeat(12, 1fr); gap: 16px; }
.g-item { position: relative; overflow: hidden; border-radius: 18px; cursor: zoom-in; }
.g-item img { height: 100%; transition: transform .9s var(--ease), filter .9s var(--ease); }
.g-item::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.40), transparent 60%); opacity: 0; transition: opacity .6s var(--ease); pointer-events: none; }
.g-item:hover::after { opacity: .85; }
.g-item:hover img { transform: scale(1.12); filter: brightness(1.02); }
.g-cap { position: absolute; left: 14px; right: 14px; bottom: 14px; color: #fff; display: flex; justify-content: space-between; opacity: 0; transform: translateY(12px); transition: all .6s var(--ease); z-index: 2; }
.g-item:hover .g-cap { opacity: 1; transform: translateY(0); }
.g1, .g2, .g3 { grid-column: span 4; height: 360px; }
.g4, .g5 { grid-column: span 6; height: 420px; }


.lightbox { position: fixed; inset: 0; z-index: 3000; display: none; place-items: center; padding: 22px; background: rgba(8,8,8,.85); backdrop-filter: blur(12px); }
.lightbox.open { display: grid; }
.lightbox-inner { width: min(1200px, 94vw); border-radius: 22px; overflow: hidden; background: transparent; }
.lightbox-img { width: 100%; height: min(75vh, 750px); object-fit: contain; background: transparent; }
.lightbox-bar { display: flex; justify-content: space-between; align-items: center; padding: 14px 20px; background: rgba(0,0,0,.65); color: #fff; border-radius: 0 0 22px 22px; }
.lb-actions { display: flex; gap: 8px; }
.lb-btn { width: 44px; height: 44px; border-radius: 14px; border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.08); color: #fff; cursor: pointer; transition: all .2s; }
.lb-btn:hover { background: rgba(255,255,255,.2); }


.reservation-box { max-width: 700px; margin: 0 auto; padding: 44px 34px; border-radius: 22px; background: var(--bg); border: 1px solid rgba(0,0,0,.06); box-shadow: var(--shadow-md); position: relative; overflow: hidden; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.field { position: relative; margin-bottom: 14px; }
.field input, .field select { width: 100%; padding: 24px 14px 10px 14px; border-radius: 14px; border: 1px solid rgba(0,0,0,.15); font-size: 1rem; outline: none; transition: all .3s var(--ease); background: var(--bg); font-family: var(--font-body); color: var(--text);}
.field input:focus, .field select:focus { border-color: rgba(197,160,101,.65); box-shadow: 0 0 0 5px rgba(197,160,101,.10); }
.field select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23c5a065'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; background-size: 20px; padding-right: 40px; cursor: pointer; }
.field label { position: absolute; left: 14px; top: 8px; font-size: .72rem; text-transform: uppercase; font-weight: 800; color: var(--primary); pointer-events: none; transition: all .25s var(--ease); }
.field input::placeholder { color: transparent; }
.field input:placeholder-shown:not(:focus):not([type="date"]) + label { transform: translateY(12px); opacity: .6; color: var(--muted); font-size: .85rem; }
.field input:not(:placeholder-shown) + label, .field input:focus + label, .field select + label, .field input[type="date"] + label { transform: translateY(0); opacity: 1; color: var(--primary); }

.checkbox-field { display: flex; align-items: flex-start; gap: 12px; margin: 20px 0; cursor: pointer; }
.checkbox-field input[type="checkbox"] { width: 20px; height: 20px; cursor: pointer; margin-top: 2px; accent-color: var(--primary); }
.checkbox-field span { font-size: 0.85rem; color: var(--muted); font-weight: 500; line-height: 1.5; text-transform: none; }
.checkbox-field a { color: var(--primary); text-decoration: underline; transition: 0.3s; }
.checkbox-field a:hover { color: var(--primary-dark); }
.full-width { width: 100%; margin-top: 8px; }

.map-scroll-wrapper { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 12px; padding-bottom: 10px; }
.map-container { position: relative; width: 100%; max-width: 600px; margin: 0 auto; border-radius: 12px; overflow: hidden; }
.mobile-swipe-hint { display: none; }
.map-table-dot { position: absolute; width: 24px; height: 24px; background: #28a745; border: 3px solid #fff; border-radius: 50%; transform: translate(-50%, -50%); cursor: pointer; box-shadow: 0 4px 10px rgba(0,0,0,0.3); transition: transform 0.2s; animation: pulseGreen 2s infinite; }
.map-table-dot:hover { transform: translate(-50%, -50%) scale(1.3); z-index: 10; }
@keyframes pulseGreen { 0% { box-shadow: 0 0 0 0 rgba(40, 167, 69, 0.7); } 70% { box-shadow: 0 0 0 10px rgba(40, 167, 69, 0); } 100% { box-shadow: 0 0 0 0 rgba(40, 167, 69, 0); } }

@keyframes alertFade { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
.form-alert { padding: 14px 20px; border-radius: 12px; font-size: 0.95rem; font-weight: 600; text-align: center; margin-top: 15px; margin-bottom: 15px; display: none; animation: alertFade 0.3s ease forwards; }
.form-alert.error { background: #fdf2f2; color: #dc3545; border: 1px solid #f5c6cb; box-shadow: 0 4px 12px rgba(220, 53, 69, 0.08); }
.form-alert.success { background: #f2fdf4; color: #28a745; border: 1px solid #c3e6cb; box-shadow: 0 4px 12px rgba(40, 167, 69, 0.08); }
.form-alert i { margin-right: 8px; font-size: 1.1rem; }


.v-card { 
    padding: 40px 30px; 
    border-radius: 22px; 
    background: #ffffff !important; 
    box-shadow: 0 15px 45px rgba(0,0,0,0.09) !important; 
    border: 1px solid rgba(0,0,0,0.04);
}
.v-card .icon { width: 66px; height: 66px; display: grid; place-items: center; border-radius: 18px; background: rgba(197,160,101,.14); color: var(--primary-dark); font-size: 1.8rem; margin-bottom: 20px; }


#location { padding-bottom: 0; }
.map-wrapper { width: 100%; margin-top: 40px; }
.map-frame { width: 100%; height: 550px; border: 0; display: block; filter: var(--map-filter, none); }

footer { background: #121212; color: #fff; padding: 80px 0 28px; }
.footer-grid { display: grid; grid-template-columns: 1.2fr 1fr .8fr; gap: 42px; max-width: 1120px; margin: 0 auto; padding: 0 20px; }
.footer-item h4 { color: #fff; font-size: 1.3rem; margin-bottom: 14px; }
.footer-item p, .footer-item a { color: rgba(255,255,255,.72); }
.footer-item a:hover { color: #fff; text-decoration: underline; }
.social { display: flex; gap: 10px; margin-top: 14px; }
.social a { width: 44px; height: 44px; border-radius: 14px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.14); transition: all .3s var(--ease); text-decoration: none !important;}
.copyright { margin-top: 52px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.10); text-align: center; color: rgba(255,255,255,.45); font-size: .82rem; }

#back-to-top { position: fixed; right: 22px; bottom: 22px; z-index: 2200; width: 52px; height: 52px; border-radius: 18px; background: rgba(255,255,255,.9); cursor: pointer; opacity: 0; pointer-events: none; transition: all .35s var(--ease); color: #141414; }
#back-to-top.show { opacity: 1; pointer-events: auto; }

.reveal { opacity: 0; transform: translateY(18px) scale(.98); filter: blur(6px); transition: all var(--reveal-dur) var(--ease); }
.reveal.in-view { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
.reveal-left { opacity: 0; transform: translateX(-22px); transition: all var(--reveal-dur) var(--ease); }
.reveal-left.in-view { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX(22px); transition: all var(--reveal-dur) var(--ease); }
.reveal-right.in-view { opacity: 1; transform: translateX(0); }


.modal { display: none; position: fixed; inset: 0; z-index: 4000; background: rgba(0,0,0,0.6); backdrop-filter: blur(5px); place-items: center; padding: 20px; opacity: 0; transition: opacity .3s ease; }
.modal.open { display: grid; opacity: 1; }
.modal-content { background: var(--bg); width: 100%; max-width: 700px; max-height: 85vh; border-radius: 20px; display: flex; flex-direction: column; overflow: hidden; box-shadow: var(--shadow-md); position: relative; transform: translateY(20px); transition: transform .3s ease; }
.modal.open .modal-content { transform: translateY(0); }
.modal-header { padding: 20px 25px; border-bottom: 1px solid rgba(0,0,0,0.08); display: flex; justify-content: space-between; align-items: center; }
.modal-header h3 { margin: 0; font-size: 1.4rem; color: var(--ink); font-family: var(--font-heading); }
.modal-body { padding: 25px; overflow-y: auto; font-size: 0.95rem; color: var(--text); line-height: 1.7; }
.modal-body p { margin-bottom: 15px; }
.modal-close { background: transparent; border: none; font-size: 1.5rem; cursor: pointer; color: var(--ink); transition: color .2s; }
.modal-close:hover { color: var(--primary); }

.modal.cookie-modal-blocker .modal-close { display: none; }
.modal.cookie-modal-blocker { pointer-events: auto; }

.cookie-trigger-btn { position: fixed; bottom: 22px; left: 22px; z-index: 2200; width: 52px; height: 52px; border-radius: 18px; background: var(--ink); color: var(--bg); border: none; font-size: 1.4rem; cursor: pointer; display: none; place-items: center; box-shadow: var(--shadow-md); transition: all .3s var(--ease); }
.cookie-trigger-btn.show { display: grid; }
.cookie-trigger-btn:hover { background: var(--primary); transform: scale(1.05); color: #fff;}


.a11y-trigger-btn { position: fixed; top: 140px; right: 20px; z-index: 2200; width: 52px; height: 52px; border-radius: 50%; background: #d4b177; color: #fff; border: none; font-size: 1.6rem; cursor: pointer; display: grid; place-items: center; box-shadow: var(--shadow-md); transition: all .3s var(--ease); }
.a11y-trigger-btn:hover { background: #b89760; transform: scale(1.08); }

.a11y-menu { position: fixed; top: 200px; right: 20px; z-index: 2200; width: 320px; background: var(--bg); border-radius: 16px; box-shadow: 0 15px 40px rgba(0,0,0,0.15); border: 1px solid rgba(0,0,0,0.08); transform: translateX(120%); opacity: 0; pointer-events: none; transition: all .4s var(--ease); display: flex; flex-direction: column; overflow: hidden; }
.a11y-menu.open { transform: translateX(0); opacity: 1; pointer-events: auto; }
.a11y-header { display: flex; justify-content: space-between; align-items: center; padding: 15px 20px; border-bottom: 1px solid rgba(0,0,0,0.08); background: var(--bg-soft); }
.a11y-header h4 { margin: 0; font-size: 1.1rem; color: var(--ink); }
.a11y-close { background: transparent; border: none; font-size: 1.2rem; cursor: pointer; color: var(--ink); }
.a11y-options { padding: 15px; display: flex; flex-direction: column; gap: 8px; }
.a11y-opt-btn { display: flex; align-items: center; gap: 12px; padding: 12px 15px; border-radius: 10px; background: var(--bg-soft); border: 1px solid rgba(0,0,0,0.05); color: var(--ink); font-weight: 600; font-size: 0.9rem; cursor: pointer; transition: all .2s; text-align: left; }
.a11y-opt-btn i { font-size: 1.1rem; width: 24px; text-align: center; color: var(--primary); }
.a11y-opt-btn:hover { background: rgba(197,160,101,.1); border-color: var(--primary); }
.a11y-opt-btn.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.a11y-opt-btn.active i { color: #fff; }
.a11y-opt-btn.reset { margin-top: 10px; background: transparent; border: 1px dashed #ccc; color: #dc3545; justify-content: center; }
.a11y-opt-btn.reset i { color: #dc3545; width: auto; }
.a11y-opt-btn.reset:hover { background: #fdf2f2; border-color: #dc3545; }


body.a11y-large-text { font-size: 115% !important; }
body.a11y-large-text h1 { font-size: clamp(2.8rem, 5vw, 4.4rem) !important; }
body.a11y-large-text h2 { font-size: clamp(2.2rem, 4vw, 3.2rem) !important; }
body.a11y-large-text .btn { font-size: 0.95rem !important; padding: 16px 34px !important; }

body.a11y-high-contrast { 
    --bg: #000000 !important; 
    --bg-soft: #111111 !important; 
    --bg-accent: #222222 !important; 
    --text: #ffffff !important; 
    --muted: #dddddd !important; 
    --ink: #ffff00 !important; 
    --primary: #00ff00 !important; 
    --primary-dark: #00cc00 !important; 
    --map-filter: contrast(120%) grayscale(100%) invert(100%) !important;
}
body.a11y-high-contrast .btn-primary { background: #ffff00 !important; color: #000 !important; }
body.a11y-high-contrast .btn-secondary, body.a11y-high-contrast .btn-outline { background: #fff !important; color: #000 !important; border-color: #fff !important; }
body.a11y-high-contrast .nav-logo, body.a11y-high-contrast .m-nav-logo { filter: brightness(0) invert(1) !important; }
body.a11y-high-contrast .section-divider { background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent) !important; }
body.a11y-high-contrast .hero-welcome-logo { filter: brightness(0) invert(1) drop-shadow(0 0 10px #000) !important; }
body.a11y-high-contrast .v-card { background: #000 !important; border: 1px solid #fff !important; }

body.a11y-readable-font, body.a11y-readable-font * { font-family: Arial, Helvetica, sans-serif !important; letter-spacing: 0px !important; }

body.a11y-highlight-links a { text-decoration: underline !important; text-decoration-thickness: 3px !important; text-underline-offset: 4px !important; color: #0055cc !important; font-weight: 800 !important; }
body.a11y-high-contrast.a11y-highlight-links a { color: #ffff00 !important; background: #000 !important; }
body.a11y-highlight-links .btn { text-decoration: none !important; outline: 3px solid #0055cc !important; outline-offset: 2px !important; }
body.a11y-high-contrast.a11y-highlight-links .btn { outline-color: #ffff00 !important; }



@media (max-width: 1080px) {
    .prev-btn, .next-btn { display: none !important; } 
}
@media (max-width: 980px) {
  .nav-container { display: flex; justify-content: space-between; }
  .nav-menu, .nav-cta { display: none; }
  .menu-icon { display: inline-flex; align-items: center; justify-content: center; }
  .top-info-bar { display: none; }
  :root { --topbar-h: 0px; } 

  .two-column, .v-grid, .footer-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: repeat(6, 1fr); }
  .g1,.g2,.g3 { grid-column: span 6; height: 340px; }
  .g4,.g5 { grid-column: span 6; height: 360px; }
  .page-btn-side { display: none !important; }

  
  .reviews-layout { grid-template-columns: 1fr; }
  .reviews-summary { margin-bottom: 20px; }
  .review-card { flex: 0 0 calc(50% - 10px); }
}
@media (max-width: 768px) {
  .hero-action-area { transform: translateX(0); margin-top: -30px; }
  .hero-welcome-logo { max-width: 95%; margin-bottom: 15px; }
  .hero-rooftop-subtitle { font-size: 1.4rem; }
}
@media (max-width: 600px) {
  .reservation-box { padding: 35px 18px; border-radius: 18px; }
  .map-container { min-width: 500px; } 
  .mobile-swipe-hint { display: block; font-size: 0.85rem; color: var(--primary); margin-bottom: 12px; font-weight: 600;}
  .map-frame { height: 400px; } 
  
  
  .reviews-slider-wrap { display: none !important; }
  .reviews-layout { display: block; padding: 0; }
  .reviews-summary { box-shadow: var(--shadow-sm); border-radius: 16px; padding: 30px 20px; }

  .cookie-trigger-btn { bottom: 15px; left: 15px; width: 46px; height: 46px; font-size: 1.2rem; }
  .a11y-trigger-btn { top: 110px; right: 15px; width: 46px; height: 46px; font-size: 1.3rem; }
  .a11y-menu { top: 165px; right: 15px; width: calc(100vw - 30px); }
}

.menu-swipe-indicator { display: none; text-align: center; color: var(--primary); font-size: 0.85rem; font-weight: 600; margin-bottom: 15px; transition: all 0.5s ease; opacity: 1; }
.menu-swipe-indicator.hide-hint { opacity: 0; pointer-events: none; height: 0; margin: 0; overflow: hidden; }
.swipe-anim { display: inline-block; font-size: 1.1rem; margin-right: 8px; animation: swipeHand 2.5s infinite ease-in-out; }

@keyframes swipeHand {
    0% { transform: translateX(10px) rotate(0deg); opacity: 0; }
    20% { opacity: 1; }
    80% { transform: translateX(-20px) rotate(-15deg); opacity: 1; }
    100% { transform: translateX(-20px) rotate(-15deg); opacity: 0; }
}

@media (max-width: 980px) {
    .menu-swipe-indicator { display: block; }
}
