/* =============================================
   DESIGN SYSTEM – Landhotel Zum Hirsch
   ============================================= */
:root {
  --gold-50:#FAF7F0; --gold-100:#F2EDE2; --gold-200:#E0D5C0; --gold-300:#CDBF9E;
  --gold-400:#B69F6B; --gold-500:#B69F6B; --gold-600:#9E8959; --gold-700:#7D6C44;
  --forest-50:#F7F6F3; --forest-100:#EDE9E0; --forest-200:#D6CFBF; --forest-300:#B5AA95;
  --forest-400:#8A7D6B; --forest-500:#6B5F4F; --forest-600:#4A4035; --forest-700:#3A322A;
  --forest-800:#2C261F; --forest-900:#1E1A15;
  --cream:#FAF8F4; --cream-warm:#F5F0E8; --white:#FFFFFF;

  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Jost',sans-serif;

  --text-sm:clamp(0.82rem,0.8rem + 0.1vw,0.88rem);
  --text-base:clamp(1rem,0.95rem + 0.2vw,1.1rem);
  --text-lg:clamp(1.1rem,1rem + 0.3vw,1.25rem);
  --text-xl:clamp(1.25rem,1.1rem + 0.5vw,1.5rem);

  --heading-sm:clamp(1.6rem,1.4rem + 0.8vw,2.2rem);
  --heading-md:clamp(2.2rem,1.8rem + 1.5vw,3.4rem);
  --heading-lg:clamp(2.8rem,2.2rem + 2.5vw,4.5rem);
  --heading-xl:clamp(3.2rem,2.4rem + 3.5vw,5.5rem);

  --space-2xs:0.25rem; --space-xs:0.5rem; --space-sm:1rem; --space-md:1.5rem;
  --space-lg:2.5rem; --space-xl:4rem; --space-2xl:6rem; --space-3xl:8rem;

  --section-py:clamp(5rem,8vw,9rem);
  --max-width:1280px;
  --header-height:130px;

  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-in-out:cubic-bezier(0.65,0,0.35,1);
  --dur-fast:0.2s; --dur-normal:0.4s; --dur-slow:0.8s;
}

/* RESET / BASE */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
body { font-family:var(--font-body); font-weight:300; font-size:var(--text-base); color:var(--forest-800); background:var(--cream); line-height:1.75; overflow-x:hidden; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; }
button { border:none; background:none; cursor:pointer; font-family:inherit; }

.container { max-width:var(--max-width); margin:0 auto; padding:0 clamp(1.5rem,4vw,3rem); }

/* TYPOGRAPHY HELPERS */
.label-upper { font-family:var(--font-body); font-weight:500; font-size:var(--text-sm); letter-spacing:0.22em; text-transform:uppercase; }
.heading-section { font-family:var(--font-display); font-weight:400; font-size:var(--heading-md); line-height:1.12; letter-spacing:0.02em; }
.section-divider { width:50px; height:1.5px; background:var(--gold-400); margin:0 auto var(--space-lg); }

/* ANNOUNCEMENT BAR */
.announcement-bar { background:linear-gradient(135deg,#141110 0%,var(--forest-900) 40%,#1a1611 70%,var(--forest-900) 100%); color:var(--gold-400); overflow:hidden; height:42px; display:flex; align-items:center; position:relative; z-index:100; border-bottom:1px solid rgba(182,159,107,0.12); }
.announcement-bar::before { content:''; position:absolute; inset:0; background:linear-gradient(90deg,transparent 0%,rgba(182,159,107,0.07) 25%,transparent 50%,rgba(182,159,107,0.07) 75%,transparent 100%); background-size:200% 100%; animation:shimmer 8s ease-in-out infinite; pointer-events:none; z-index:1; }
.announcement-bar::after { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(182,159,107,0.2) 20%,rgba(182,159,107,0.35) 50%,rgba(182,159,107,0.2) 80%,transparent); pointer-events:none; }
@keyframes shimmer { 0%,100% { background-position:200% 0; } 50% { background-position:-200% 0; } }
.announcement-track { display:flex; flex-wrap:nowrap; white-space:nowrap; animation:marquee 45s linear infinite; position:relative; z-index:2; width:max-content; }
.announcement-bar:hover .announcement-track { animation-play-state:paused; }
.announcement-track .ann-text { font-family:var(--font-body); font-weight:400; font-size:0.78rem; letter-spacing:0.18em; text-transform:uppercase; padding:0 0.6rem; color:var(--gold-400); transition:color 0.3s; display:inline-flex; align-items:center; flex-shrink:0; }
.announcement-bar:hover .ann-text { color:var(--gold-300); }
.announcement-track .ann-sep { display:inline-flex; align-items:center; padding:0 0.8rem; color:var(--gold-500); opacity:0.4; font-size:0.55rem; letter-spacing:0.5em; flex-shrink:0; }
@keyframes marquee { 0% { transform:translateX(0); } 100% { transform:translateX(-50%); } }

/* HEADER */
.site-header { position:fixed; top:42px; left:0; right:0; z-index:90; height:var(--header-height); transition:background var(--dur-normal) var(--ease-out),box-shadow var(--dur-normal) var(--ease-out),top var(--dur-normal) var(--ease-out); background:rgba(250,248,244,0.97); backdrop-filter:blur(14px); box-shadow:0 1px 0 rgba(0,0,0,0.06); }
.site-header.scrolled { top:0; }
.site-header.hero-transparent { background:transparent; backdrop-filter:none; box-shadow:none; }
.site-header.hero-transparent.scrolled { background:rgba(250,248,244,0.97); backdrop-filter:blur(14px); box-shadow:0 1px 0 rgba(0,0,0,0.06); }
.header-inner { max-width:1600px; margin:0 auto; padding:0 clamp(1.5rem,3vw,2.5rem); display:grid; grid-template-columns:auto 1fr auto; align-items:center; height:100%; gap:2rem; }
.main-nav { justify-self:center; }

.logo { display:flex; align-items:center; }
.logo-icon { width:76px; height:76px; object-fit:contain; transition:all var(--dur-normal) var(--ease-out); }
.site-header.hero-transparent:not(.scrolled) .logo-icon { width:120px; height:120px; filter:brightness(1.15); }

.main-nav { display:flex; align-items:center; gap:clamp(1.5rem,2.2vw,2.6rem); }
.main-nav a { font-family:var(--font-body); font-weight:400; font-size:var(--text-sm); letter-spacing:0.18em; text-transform:uppercase; color:var(--forest-600); position:relative; padding:0.25rem 0; transition:color var(--dur-fast); white-space:nowrap; }
.main-nav a.active { color:var(--gold-600); }
.site-header.hero-transparent:not(.scrolled) .main-nav a { color:rgba(255,255,255,0.85); }
.site-header.hero-transparent:not(.scrolled) .main-nav a:hover { color:var(--gold-400); }
.main-nav a::after { content:''; position:absolute; bottom:-2px; left:0; width:0; height:1.5px; background:var(--gold-500); transition:width var(--dur-normal) var(--ease-out); }
.main-nav a:hover::after,.main-nav a.active::after { width:100%; }

/* DOUBLE BUTTON GROUP */
.nav-cta-group { display:inline-flex; align-items:stretch; position:relative; box-shadow:0 4px 14px rgba(182,159,107,0.25); }
.nav-cta-split { display:inline-flex; align-items:center; gap:0.55rem; padding:0.85rem 1.3rem; font-family:var(--font-body); font-weight:500; font-size:var(--text-sm); letter-spacing:0.18em; text-transform:uppercase; color:var(--white); white-space:nowrap; position:relative; transition:background var(--dur-fast); }
.nav-cta-split:first-of-type { background:var(--gold-500); }
.nav-cta-split:first-of-type:hover { background:var(--gold-600); }
.nav-cta-split:last-of-type { background:var(--gold-600); }
.nav-cta-split:last-of-type:hover { background:var(--gold-700); }
.nav-cta-split::after { display:none !important; }
.nav-cta-split [data-lucide],.nav-cta-split svg { width:16px; height:16px; flex-shrink:0; transition:transform var(--dur-fast); }
.nav-cta-split:hover [data-lucide],.nav-cta-split:hover svg { transform:scale(1.12); }

/* MOBILE NAV TOGGLE */
.nav-toggle { display:none; width:44px; height:44px; position:relative; z-index:201; align-items:center; justify-content:center; padding:0; }
.nav-toggle span { display:block; width:26px; height:2px; background:var(--forest-800); position:absolute; transition:transform 0.4s var(--ease-out),opacity 0.3s,background 0.3s; }
.nav-toggle span:nth-child(1) { transform:translateY(-8px); }
.nav-toggle span:nth-child(2) { transform:translateY(0); }
.nav-toggle span:nth-child(3) { transform:translateY(8px); }
.site-header.hero-transparent:not(.scrolled) .nav-toggle span { background:var(--white); }
.nav-toggle.active span { background:var(--white); }
.nav-toggle.active span:nth-child(1) { transform:rotate(45deg); }
.nav-toggle.active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-toggle.active span:nth-child(3) { transform:rotate(-45deg); }

/* MOBILE OVERLAY MENU */
.mobile-overlay { position:fixed; inset:0; z-index:200; visibility:hidden; pointer-events:none; }
.mobile-overlay.open { visibility:visible; pointer-events:auto; }
.mobile-overlay-bg { position:absolute; inset:0; background:var(--forest-900); opacity:0; transition:opacity 0.5s var(--ease-out); }
.mobile-overlay.open .mobile-overlay-bg { opacity:1; }
.mobile-overlay-content { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:center; align-items:center; padding:6rem 1.5rem 3rem; overflow-y:auto; }
.mobile-nav-links { list-style:none; text-align:center; margin-bottom:3rem; }
.mobile-nav-links li { overflow:hidden; }
.mobile-nav-links a { display:block; font-family:var(--font-display); font-weight:400; font-size:clamp(2rem,5vw,3rem); color:var(--white); letter-spacing:0.03em; line-height:1.2; padding:0.5rem 0; transform:translateY(110%); transition:transform 0.6s var(--ease-out),color 0.3s; }
.mobile-overlay.open .mobile-nav-links a { transform:translateY(0); }
.mobile-nav-links li:nth-child(1) a { transition-delay:0.08s; }
.mobile-nav-links li:nth-child(2) a { transition-delay:0.14s; }
.mobile-nav-links li:nth-child(3) a { transition-delay:0.20s; }
.mobile-nav-links li:nth-child(4) a { transition-delay:0.26s; }
.mobile-nav-links li:nth-child(5) a { transition-delay:0.32s; }
.mobile-nav-links a:hover,.mobile-nav-links a:active,.mobile-nav-links a.active { color:var(--gold-400); }
.mobile-nav-divider { width:50px; height:1.5px; background:var(--gold-500); margin:0 auto 2rem; opacity:0; transform:scaleX(0); transition:opacity 0.5s 0.35s,transform 0.5s 0.35s var(--ease-out); }
.mobile-overlay.open .mobile-nav-divider { opacity:1; transform:scaleX(1); }
.mobile-nav-cta { opacity:0; transform:translateY(20px); transition:opacity 0.5s 0.4s,transform 0.5s 0.4s var(--ease-out); margin-bottom:2.5rem; width:100%; max-width:540px; }
.mobile-overlay.open .mobile-nav-cta { opacity:1; transform:translateY(0); }
.mobile-cta-group { display:flex; align-items:stretch; width:100%; box-shadow:0 8px 24px rgba(0,0,0,0.25); }
.mobile-cta-split { flex:1; display:inline-flex; align-items:center; justify-content:center; gap:0.7rem; padding:1.1rem 1rem; font-family:var(--font-body); font-weight:500; font-size:0.85rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--white); transition:background var(--dur-fast); }
.mobile-cta-split:first-of-type { background:var(--gold-500); }
.mobile-cta-split:first-of-type:hover,.mobile-cta-split:first-of-type:active { background:var(--gold-600); }
.mobile-cta-split:last-of-type { background:var(--gold-600); }
.mobile-cta-split:last-of-type:hover,.mobile-cta-split:last-of-type:active { background:var(--gold-700); }
.mobile-cta-split [data-lucide],.mobile-cta-split svg { width:18px; height:18px; flex-shrink:0; transition:transform var(--dur-fast); }
.mobile-cta-split:hover [data-lucide],.mobile-cta-split:hover svg { transform:scale(1.1); }
.mobile-nav-footer { text-align:center; opacity:0; transform:translateY(20px); transition:opacity 0.5s 0.48s,transform 0.5s 0.48s var(--ease-out); }
.mobile-overlay.open .mobile-nav-footer { opacity:1; transform:translateY(0); }
.mobile-nav-footer p { font-size:0.85rem; color:rgba(255,255,255,0.4); line-height:1.7; }
.mobile-nav-footer a { color:var(--gold-400); transition:color 0.2s; }
.mobile-nav-footer a:hover { color:var(--gold-300); }
body.menu-open { overflow:hidden; }
@media (max-width:480px) {
  .mobile-cta-group { flex-direction:column; }
}

/* BUTTONS — Design System (only two variants) */
.btn { display:inline-flex; align-items:center; gap:0.65rem; font-family:var(--font-body); font-weight:500; font-size:var(--text-sm); letter-spacing:0.2em; text-transform:uppercase; padding:1rem 2.2rem; transition:all var(--dur-normal) var(--ease-out); cursor:pointer; }
.btn [data-lucide],.btn svg { width:18px; height:18px; flex-shrink:0; transition:transform var(--dur-fast); }
.btn:hover [data-lucide],.btn:hover svg { transform:scale(1.1); }

/* Primary — gold filled, hovers darker gold (gold-600) */
.btn-primary { background:var(--gold-500); color:var(--white); }
.btn-primary:hover { background:var(--gold-600); transform:translateY(-1px); }

/* Secondary — gold outline, fills with gold on hover */
.btn-secondary { border:1.5px solid var(--gold-400); color:var(--gold-400); background:transparent; }
.btn-secondary:hover { background:var(--gold-500); border-color:var(--gold-500); color:var(--white); transform:translateY(-1px); }

/* RESERVATION MODAL */
.reservation-modal { position:fixed; inset:0; z-index:300; visibility:hidden; opacity:0; transition:opacity 0.4s var(--ease-out),visibility 0s 0.4s; display:flex; align-items:center; justify-content:center; padding:1rem; }
.reservation-modal.open { visibility:visible; opacity:1; transition:opacity 0.4s var(--ease-out); }
.reservation-modal-backdrop { position:absolute; inset:0; background:rgba(30,26,21,0.85); backdrop-filter:blur(6px); z-index:0; }
.reservation-modal-content { position:relative; max-width:720px; width:100%; height:70vh; max-height:580px; background:var(--cream); box-shadow:0 30px 80px rgba(0,0,0,0.4); display:flex; flex-direction:column; transform:translateY(30px) scale(0.96); transition:transform 0.5s var(--ease-out); overflow:hidden; z-index:1; }
.reservation-modal.open .reservation-modal-content { transform:translateY(0) scale(1); }
.reservation-modal-close { position:absolute; top:0.9rem; right:0.9rem; width:40px; height:40px; display:flex; align-items:center; justify-content:center; background:transparent; color:var(--gold-400); z-index:5; border:1.5px solid rgba(182,159,107,0.5); border-radius:0; transition:all 0.4s var(--ease-out); }
.reservation-modal-close::before { content:''; position:absolute; inset:-4px; border:1px solid var(--gold-400); opacity:0; transform:scale(0.85); transition:opacity 0.4s var(--ease-out),transform 0.4s var(--ease-out); }
.reservation-modal-close:hover { background:var(--gold-500); color:var(--white); border-color:var(--gold-500); transform:rotate(90deg); }
.reservation-modal-close:hover::before { opacity:0.4; transform:scale(1); }
.reservation-modal-close [data-lucide],.reservation-modal-close svg { width:16px; height:16px; stroke-width:1.8; }
.reservation-modal-header { background:var(--forest-800); padding:var(--space-md) var(--space-lg); padding-right:4.5rem; text-align:center; }
.reservation-modal-label { font-family:var(--font-body); font-weight:500; font-size:0.7rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold-400); display:block; margin-bottom:0.3rem; }
.reservation-modal-title { font-family:var(--font-display); font-weight:400; font-size:1.7rem; color:var(--white); letter-spacing:0.02em; line-height:1.2; }
.reservation-modal-iframe-wrap { flex:1; min-height:0; overflow:auto; background:var(--white); -webkit-overflow-scrolling:touch; }
.reservation-modal-iframe-wrap iframe { width:100%; height:100%; min-height:480px; border:none; display:block; background:var(--white); }
body.modal-open { overflow:hidden; }

/* PAGE HERO (for subpages) */
.page-hero { position:relative; height:46vh; min-height:420px; max-height:520px; display:flex; align-items:center; justify-content:center; overflow:hidden; padding-top:var(--header-height); box-sizing:border-box; }
.page-hero-bg { position:absolute; inset:0; }
.page-hero-content { position:relative; z-index:2; text-align:center; padding:0 var(--space-md); max-width:820px; }
.page-hero-label { font-family:var(--font-body); font-weight:400; font-size:var(--text-sm); letter-spacing:0.35em; text-transform:uppercase; color:var(--gold-400); margin-bottom:var(--space-md); display:block; opacity:0; transform:translateY(20px); animation:fadeUp 0.8s var(--ease-out) 0.3s forwards; }
.page-hero-title { font-family:var(--font-display); font-weight:300; font-size:clamp(2rem,1.6rem + 1.5vw,3rem); line-height:1.12; color:var(--white); letter-spacing:0.015em; margin-bottom:var(--space-md); opacity:0; transform:translateY(30px); animation:fadeUp 1s var(--ease-out) 0.5s forwards; }
.page-hero-subtitle { font-family:var(--font-body); font-weight:300; font-size:var(--text-lg); color:rgba(255,255,255,0.8); line-height:1.7; max-width:580px; margin:0 auto; opacity:0; transform:translateY(20px); animation:fadeUp 0.8s var(--ease-out) 0.7s forwards; }
@keyframes fadeUp { to { opacity:1; transform:translateY(0); } }

/* SECTION INTRO */
.section-intro { text-align:center; padding:var(--section-py) 0 var(--space-2xl); }
.section-intro .section-label { color:var(--gold-500); margin-bottom:var(--space-md); display:block; }
.section-intro .heading-section { margin-bottom:var(--space-lg); }
.section-intro p { max-width:700px; margin:0 auto; font-size:var(--text-lg); line-height:1.85; color:var(--forest-500); }

/* BOOKING CTA — bottom of subpages */
.booking-cta { background:var(--cream-warm); padding:clamp(4rem,7vw,6rem) 0; text-align:center; }
.booking-cta-header { margin-bottom:var(--space-lg); }
.booking-cta-label { color:var(--gold-500); margin-bottom:var(--space-sm); display:block; }
.booking-cta-heading { font-family:var(--font-display); font-weight:400; font-size:var(--heading-md); line-height:1.15; letter-spacing:0.02em; color:var(--forest-800); margin-bottom:var(--space-sm); }
.booking-cta-text { font-size:var(--text-lg); color:var(--forest-500); max-width:560px; margin:0 auto; }
.booking-cta-actions { display:flex; gap:var(--space-sm); justify-content:center; flex-wrap:wrap; margin-top:var(--space-md); }

/* INFO BAR (Opening hours, capacities) */
.info-bar { background:var(--forest-800); color:var(--white); padding:clamp(3.5rem,6vw,5rem) 0; position:relative; overflow:hidden; }
.info-bar::before { content:''; position:absolute; top:-100px; left:-100px; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(182,159,107,0.05) 0%,transparent 70%); pointer-events:none; }
.info-bar::after { content:''; position:absolute; bottom:-100px; right:-100px; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(182,159,107,0.05) 0%,transparent 70%); pointer-events:none; }
.info-bar > .container { position:relative; z-index:2; }
.info-bar-header { text-align:center; margin-bottom:var(--space-xl); }
.info-bar-label { color:var(--gold-400); margin-bottom:var(--space-sm); display:block; }
.info-bar-heading { font-family:var(--font-display); font-weight:400; font-size:clamp(1.8rem,3vw,2.6rem); line-height:1.15; letter-spacing:0.02em; color:var(--white); }
.info-bar-divider { width:50px; height:1.5px; background:var(--gold-400); margin:var(--space-md) auto 0; }
.info-bar-grid { display:grid; grid-template-columns:repeat(4,1fr); }
.info-item { background:var(--forest-800); padding:var(--space-lg) var(--space-md); text-align:center; position:relative; border-right:1px solid rgba(182,159,107,0.18); }
.info-item:last-child { border-right:none; }
.info-item-icon { width:32px; height:32px; margin:0 auto var(--space-md); color:var(--gold-400); stroke-width:1.5; display:block; }
.info-item-label { font-size:0.7rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--gold-400); margin-bottom:var(--space-xs); font-weight:500; }
.info-item-value { font-family:var(--font-display); font-size:1.5rem; font-weight:400; color:rgba(255,255,255,0.95); line-height:1.25; min-height:1.875rem; }
.info-item-note { font-size:0.72rem; color:var(--gold-400); margin-top:0.45rem; letter-spacing:0.05em; font-weight:400; }

/* FOOTER */
.site-footer { background:var(--forest-900); color:rgba(255,255,255,0.5); padding:var(--space-2xl) 0 var(--space-lg); }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:var(--space-xl); margin-bottom:var(--space-xl); }
.footer-brand .footer-logo { width:140px; height:140px; object-fit:contain; margin-bottom:var(--space-md); }
.footer-brand p { font-size:var(--text-base); line-height:1.7; color:rgba(255,255,255,0.45); }
.footer-col h4 { font-family:var(--font-body); font-weight:500; font-size:0.75rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold-400); margin-bottom:var(--space-md); }
.footer-col a,.footer-col p { display:block; font-size:var(--text-base); color:rgba(255,255,255,0.5); line-height:1.5; margin-bottom:0.65rem; transition:color var(--dur-fast); }
.footer-col a:hover { color:var(--gold-300); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding-top:var(--space-md); display:flex; justify-content:space-between; align-items:center; font-size:var(--text-sm); }
.footer-social { display:flex; gap:var(--space-sm); }
.footer-social a { width:40px; height:40px; border:1px solid rgba(255,255,255,0.15); border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all var(--dur-fast); }
.footer-social a:hover { border-color:var(--gold-400); background:rgba(182,159,107,0.1); }
.footer-social a [data-lucide],.footer-social a svg { width:16px; height:16px; color:rgba(255,255,255,0.5); stroke-width:1.5; transition:color var(--dur-fast); }
.footer-social a:hover [data-lucide],.footer-social a:hover svg { color:var(--gold-300); }

/* REVEAL ANIMATIONS */
.reveal { opacity:0; transform:translateY(30px); transition:opacity 0.7s var(--ease-out),transform 0.7s var(--ease-out); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:0.1s; }
.reveal-delay-2 { transition-delay:0.2s; }
.reveal-delay-3 { transition-delay:0.3s; }

/* RESPONSIVE BASE */
@media (max-width:1100px) {
  .main-nav,.nav-cta-group { display:none; }
  .nav-toggle { display:flex; }
  .site-header { z-index:202; }
}
@media (max-width:900px) {
  .info-bar-grid { grid-template-columns:repeat(2,1fr); }
  .info-item:nth-child(odd) { border-right:1px solid rgba(182,159,107,0.18); }
  .info-item:nth-child(2n) { border-right:none; }
  .info-item:nth-child(-n+2) { border-bottom:1px solid rgba(182,159,107,0.18); }
  .footer-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:600px) {
  .info-bar-grid { grid-template-columns:1fr; }
  .info-item,.info-item:nth-child(odd) { border-right:none; border-bottom:1px solid rgba(182,159,107,0.18); }
  .info-item:last-child { border-bottom:none; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:var(--space-sm); text-align:center; }
  .logo-icon { width:60px; height:60px; }
}
