/* ===================================================
   Milagritos Restaurant & Encaramada Rooftop Bar
   Design rationale: Deep midnight ocean navy (#162038)
   mirrors Manila Bay at night; warm amber-gold accent
   captures rooftop sunset hues; wine highlight nods
   to Spanish heritage and rooftop bar culture.
   Heading: Libre Baskerville — refined classical serif
   Body: Work Sans — clean editorial humanist sans
   =================================================== */

/* 1. RESET & CUSTOM PROPERTIES */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --dark:       #162038;
  --bg-alt:     #1E2D48;
  --accent:     #C4853A;
  --highlight:  #8B3D5A;
  --cream:      #FAF5EE;
  --cream-dim:  rgba(250,245,238,0.65);
  --accent-dim: rgba(196,133,58,0.14);
  --border:     rgba(196,133,58,0.25);
  --shadow:     0 4px 24px rgba(22,32,56,0.32);
  --radius:     10px;
  --ff-display: 'Libre Baskerville', serif;
  --ff-body:    'Work Sans', sans-serif;
  --transition: 0.3s ease;
}
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--ff-body); background: var(--cream); color: var(--dark); line-height: 1.7; overflow-x: hidden; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { border: none; cursor: pointer; background: none; font: inherit; }

/* 2. TYPOGRAPHY */
h1,h2,h3,h4,h5 { font-family: var(--ff-display); line-height: 1.2; font-weight: 700; }
h1 { font-size: clamp(2.2rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.7rem, 3.5vw, 2.6rem); }
h3 { font-size: clamp(1.1rem, 2.5vw, 1.5rem); }
h4 { font-size: 1rem; }
p { font-size: 0.96rem; }
.section-label { display:inline-block; font-family:var(--ff-body); font-size:0.71rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent); margin-bottom:0.75rem; }

/* 3. UTILITIES */
.container { max-width: 1180px; margin: 0 auto; padding: 0 1.5rem; }
.btn { display:inline-flex; align-items:center; gap:0.5rem; padding:0.75rem 1.75rem; border-radius:6px; font-family:var(--ff-body); font-size:0.85rem; font-weight:700; letter-spacing:0.05em; transition:var(--transition); white-space:nowrap; }
.btn-primary { background:var(--accent); color:#fff; }
.btn-primary:hover { background:#b07030; transform:translateY(-2px); box-shadow:0 6px 20px rgba(196,133,58,0.38); }
.btn-outline { border:2px solid var(--accent); color:var(--accent); background:transparent; }
.btn-outline:hover { background:var(--accent); color:#fff; transform:translateY(-2px); }
.btn-ghost { border:2px solid var(--cream); color:var(--cream); }
.btn-ghost:hover { background:var(--cream); color:var(--dark); transform:translateY(-2px); }
.fade-in { opacity:0; transform:translateY(28px); transition:opacity 0.7s ease, transform 0.7s ease; }
.fade-in.visible { opacity:1; transform:none; }

/* 4. NAVBAR */
.navbar { position:fixed; top:0; left:0; right:0; z-index:1000; display:flex; align-items:center; gap:2rem; padding:1rem 2rem; background:transparent; transition:background var(--transition),box-shadow var(--transition),padding var(--transition); }
.navbar.scrolled { background:var(--dark); box-shadow:0 2px 16px rgba(22,32,56,0.45); padding:0.65rem 2rem; }
.nav-logo { display:flex; align-items:center; gap:0.65rem; font-family:var(--ff-display); font-size:1rem; font-weight:700; color:var(--cream); white-space:nowrap; flex-shrink:0; }
.nav-logo img { width:40px; height:40px; border-radius:50%; object-fit:cover; border:2px solid var(--accent); }
.nav-links { display:flex; align-items:center; gap:0.25rem; margin-left:auto; }
.nav-links a { font-size:0.83rem; font-weight:600; letter-spacing:0.04em; color:var(--cream-dim); padding:0.4rem 0.75rem; border-radius:5px; transition:var(--transition); }
.nav-links a:hover, .nav-links a.active { color:var(--cream); background:rgba(250,245,238,0.1); }
.nav-cta { margin-left:0.5rem; }
.hamburger { display:none; flex-direction:column; gap:5px; margin-left:auto; padding:0.4rem; }
.hamburger span { display:block; width:24px; height:2px; background:var(--cream); border-radius:2px; transition:var(--transition); }
.mobile-menu { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:var(--dark); z-index:999; flex-direction:column; align-items:center; justify-content:center; gap:1.5rem; padding:2rem; }
.mobile-menu.open { display:flex; }
.mobile-menu a { font-family:var(--ff-display); font-size:1.7rem; font-weight:700; color:var(--cream); transition:var(--transition); }
.mobile-menu a:hover { color:var(--accent); }

/* 5. HERO */
.hero { position:relative; min-height:100svh; display:flex; align-items:flex-end; padding:0 0 5rem; overflow:hidden; }
.hero-bg { position:absolute; inset:0; background:url('images/banner.jpg?v=1') center/cover no-repeat; transform:scale(1.04); transition:transform 8s ease; }
.hero-bg.loaded { transform:scale(1); }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(22,32,56,0.9) 0%,rgba(22,32,56,0.5) 55%,rgba(22,32,56,0.15) 100%); }
.hero-content { position:relative; z-index:2; padding:0 2.5rem; max-width:700px; }
.hero-content h1 { color:var(--cream); margin-bottom:1rem; }
.hero-content p { font-size:1.05rem; color:var(--cream-dim); margin-bottom:2rem; max-width:540px; }
.hero-btns { display:flex; flex-wrap:wrap; gap:1rem; }

/* 6. PAGE HERO */
.page-hero { position:relative; min-height:42vh; display:flex; align-items:flex-end; padding:0 0 3rem; overflow:hidden; background:var(--bg-alt) var(--page-hero-bg,none) center/cover no-repeat; }
.page-hero::before { content:''; position:absolute; inset:0; background:linear-gradient(to top,rgba(22,32,56,0.88) 0%,rgba(22,32,56,0.5) 60%,rgba(22,32,56,0.15) 100%); }
.page-hero-content { position:relative; z-index:2; padding:0 2.5rem; }
.page-hero-content h1 { color:var(--cream); }
.page-hero-content p { color:var(--cream-dim); max-width:540px; margin-top:0.5rem; }

/* 7. FEATURES STRIP */
.features-strip { background:var(--dark); padding:2rem 2.5rem; display:flex; flex-wrap:wrap; justify-content:center; gap:2rem 3.5rem; }
.feature-item { display:flex; align-items:center; gap:0.75rem; color:var(--cream-dim); font-size:0.84rem; font-weight:600; letter-spacing:0.05em; text-transform:uppercase; }
.feature-item svg { color:var(--accent); flex-shrink:0; }

/* 8. SECTION HEADER */
.section-header { text-align:center; margin-bottom:3rem; }
.section-header h2 { color:var(--dark); margin-bottom:0.5rem; }
.section-header p { color:#4a5a7a; max-width:560px; margin:0 auto; }

/* 9. OFFERINGS GRID */
.offerings { padding:5rem 0; background:var(--cream); }
.offerings-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.offering-card { position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; background:var(--bg-alt); }
.offering-card img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; }
.offering-card:hover img { transform:scale(1.06); }
.offering-card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(22,32,56,0.9) 0%,transparent 65%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.5rem; }
.offering-card-overlay h3 { color:var(--cream); font-size:1.1rem; }
.offering-card-overlay span { color:var(--cream-dim); font-size:0.8rem; margin-top:0.2rem; display:block; }
.offering-card.text-card { background:var(--dark); display:flex; flex-direction:column; justify-content:center; padding:2rem; }
.offering-card.text-card h3 { color:var(--cream); margin-bottom:0.75rem; }
.offering-card.text-card p { color:var(--cream-dim); font-size:0.87rem; }

/* 10. BRAND SPLIT */
.brand-split { padding:5rem 0; background:var(--dark); }
.brand-split-inner { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.brand-split-img { border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; }
.brand-split-img img { width:100%; height:100%; object-fit:cover; }
.brand-split-text h2 { color:var(--cream); margin-bottom:1rem; }
.brand-split-text p { color:var(--cream-dim); margin-bottom:1rem; font-size:0.95rem; }
.brand-split-text blockquote { border-left:3px solid var(--accent); padding-left:1rem; font-style:italic; font-size:1.05rem; color:var(--cream-dim); margin:1.25rem 0; }

/* 11. STATS ROW */
.stats-row { background:var(--accent); padding:2.5rem 0; display:flex; justify-content:center; flex-wrap:wrap; }
.stat-item { text-align:center; padding:1rem 3rem; border-right:1px solid rgba(250,245,238,0.2); }
.stat-item:last-child { border-right:none; }
.stat-num { font-family:var(--ff-display); font-size:2.4rem; font-weight:700; color:#fff; display:block; }
.stat-label { font-size:0.77rem; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.75); display:block; margin-top:0.2rem; }

/* 12. REVIEWS */
.reviews { padding:5rem 0; background:var(--cream); }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.review-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:1.75rem; transition:var(--transition); }
.review-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.review-stars { display:flex; gap:3px; margin-bottom:1rem; color:var(--accent); }
.review-text { font-size:0.9rem; color:#3a4a6a; font-style:italic; line-height:1.7; margin-bottom:1.25rem; }
.review-author { display:flex; align-items:center; gap:0.75rem; }
.review-avatar { width:38px; height:38px; border-radius:50%; background:var(--accent-dim); display:flex; align-items:center; justify-content:center; font-family:var(--ff-display); font-weight:700; color:var(--accent); font-size:1rem; flex-shrink:0; }
.review-name { font-weight:700; font-size:0.88rem; color:var(--dark); }
.review-source { font-size:0.76rem; color:#6a7a9a; }

/* 13. SOCIAL FEED */
.social-feed { padding:4rem 0; background:var(--dark); text-align:center; }
.social-feed .section-header h2 { color:var(--cream); }
.social-feed .section-header p { color:var(--cream-dim); }
.feed-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:3px; margin:2rem 0; }
.feed-item { aspect-ratio:1; overflow:hidden; position:relative; }
.feed-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s ease; }
.feed-item:hover img { transform:scale(1.08); }
.feed-item-overlay { position:absolute; inset:0; background:rgba(22,32,56,0.5); display:flex; align-items:center; justify-content:center; opacity:0; transition:var(--transition); color:var(--cream); }
.feed-item:hover .feed-item-overlay { opacity:1; }

/* 14. FOOTER */
.footer { background:var(--dark); border-top:1px solid rgba(196,133,58,0.15); padding:4rem 0 0; }
.footer-grid { max-width:1180px; margin:0 auto; padding:0 1.5rem; display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:3rem; }
.footer-brand p { color:var(--cream-dim); font-size:0.87rem; margin:1rem 0 1.25rem; max-width:280px; }
.footer-social { display:flex; gap:0.75rem; }
.footer-social a { width:36px; height:36px; border-radius:50%; background:rgba(250,245,238,0.08); display:flex; align-items:center; justify-content:center; color:var(--cream-dim); transition:var(--transition); }
.footer-social a svg { width:16px; height:16px; }
.footer-social a:hover { background:var(--accent); color:#fff; }
.footer-col h4 { font-family:var(--ff-body); font-size:0.72rem; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent); margin-bottom:1.25rem; }
.footer-col ul li + li { margin-top:0.6rem; }
.footer-col ul a { color:var(--cream-dim); font-size:0.87rem; transition:var(--transition); }
.footer-col ul a:hover { color:var(--cream); padding-left:4px; }
.footer-contact-line { display:flex; align-items:flex-start; gap:0.65rem; color:var(--cream-dim); font-size:0.85rem; margin-bottom:0.85rem; }
.footer-contact-line svg { width:16px; height:16px; flex-shrink:0; margin-top:3px; color:var(--accent); }
.footer-bottom { max-width:1180px; margin:3rem auto 0; padding:1.25rem 1.5rem; border-top:1px solid rgba(196,133,58,0.12); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.footer-bottom p { color:rgba(250,245,238,0.4); font-size:0.8rem; }
.footer-badges { display:flex; gap:0.5rem; flex-wrap:wrap; }
.badge { font-size:0.72rem; font-weight:700; letter-spacing:0.08em; padding:0.25rem 0.75rem; border-radius:50px; background:rgba(196,133,58,0.18); color:var(--accent); border:1px solid rgba(196,133,58,0.3); }

/* 15. SCROLL TO TOP */
.scroll-top { position:fixed; bottom:2rem; right:2rem; z-index:900; width:42px; height:42px; border-radius:50%; background:var(--accent); color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 16px rgba(196,133,58,0.4); opacity:0; transform:translateY(12px); transition:var(--transition); pointer-events:none; }
.scroll-top.visible { opacity:1; transform:none; pointer-events:auto; }
.scroll-top:hover { background:#b07030; transform:translateY(-2px); }
.scroll-top svg { width:18px; height:18px; }

/* 16. ABOUT PAGE */
.about-origin { padding:5rem 0; background:var(--cream); }
.origin-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.origin-text h2 { margin-bottom:1rem; }
.origin-text p { color:#3a4a6a; margin-bottom:1rem; font-size:0.95rem; }
.origin-img-wrap { border-radius:var(--radius); overflow:hidden; aspect-ratio:3/4; }
.origin-img-wrap img { width:100%; height:100%; object-fit:cover; }
.philosophy { padding:5rem 0; background:var(--bg-alt); }
.philosophy .section-header h2 { color:var(--cream); }
.philosophy .section-header p { color:var(--cream-dim); }
.philosophy-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.philosophy-card { background:rgba(250,245,238,0.06); border:1px solid rgba(250,245,238,0.12); border-radius:var(--radius); padding:2rem; text-align:center; transition:var(--transition); }
.philosophy-card:hover { background:rgba(250,245,238,0.1); transform:translateY(-4px); }
.philosophy-icon { width:52px; height:52px; border-radius:50%; background:rgba(196,133,58,0.2); display:flex; align-items:center; justify-content:center; margin:0 auto 1.25rem; color:var(--accent); }
.philosophy-icon svg { width:24px; height:24px; }
.philosophy-card h3 { color:var(--cream); margin-bottom:0.5rem; font-size:1.1rem; }
.philosophy-card p { color:var(--cream-dim); font-size:0.87rem; }
.values { padding:5rem 0; background:var(--cream); }
.values-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1rem; }
.value-item { padding:1.75rem 1.25rem; border:1px solid var(--border); border-radius:var(--radius); text-align:center; background:#fff; transition:var(--transition); }
.value-item:hover { border-color:var(--accent); box-shadow:var(--shadow); transform:translateY(-3px); }
.value-num { font-family:var(--ff-display); font-size:2rem; font-weight:700; color:var(--accent-dim); display:block; }
.value-item h4 { font-size:0.95rem; margin:0.35rem 0; color:var(--dark); }
.value-item p { font-size:0.8rem; color:#6a7a9a; }
.timeline { padding:5rem 0; background:var(--dark); }
.timeline .section-header h2 { color:var(--cream); }
.timeline .section-header p { color:var(--cream-dim); }
.timeline-track { position:relative; max-width:760px; margin:0 auto; padding-left:2rem; }
.timeline-track::before { content:''; position:absolute; left:0; top:0; bottom:0; width:2px; background:rgba(196,133,58,0.4); }
.timeline-item { position:relative; padding:0 0 2.5rem 2rem; }
.timeline-item::before { content:''; position:absolute; left:-5px; top:6px; width:12px; height:12px; border-radius:50%; background:var(--accent); border:2px solid var(--dark); }
.timeline-date { font-size:0.75rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--accent); margin-bottom:0.3rem; }
.timeline-item h4 { color:var(--cream); margin-bottom:0.3rem; }
.timeline-item p { color:var(--cream-dim); font-size:0.87rem; }
.about-cta { padding:5rem 0; background:var(--highlight); text-align:center; }
.about-cta h2 { color:var(--cream); margin-bottom:0.75rem; }
.about-cta p { color:var(--cream-dim); margin-bottom:2rem; }
.about-cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* 17. MENU PAGE */
.menu-page { padding:5rem 0; background:var(--cream); }
.menu-disclaimer { background:var(--accent-dim); border:1px solid var(--border); border-radius:var(--radius); padding:0.9rem 1.25rem; text-align:center; font-size:0.83rem; color:var(--accent); font-weight:600; margin-bottom:3rem; }
.menu-categories { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:4rem; }
.menu-cat-tile { background:var(--dark); border-radius:var(--radius); padding:1.5rem; text-align:center; color:var(--cream); transition:var(--transition); cursor:pointer; }
.menu-cat-tile:hover { background:var(--bg-alt); transform:translateY(-3px); }
.menu-cat-tile svg { width:28px; height:28px; color:var(--accent); margin:0 auto 0.5rem; }
.menu-cat-tile span { font-size:0.82rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; }
.menu-section { margin-bottom:4rem; scroll-margin-top:80px; }
.menu-section-header { display:flex; align-items:center; gap:1rem; margin-bottom:2rem; padding-bottom:1rem; border-bottom:1px solid var(--border); }
.menu-section-header h2 { font-size:1.8rem; }
.menu-section-header p { font-size:0.85rem; color:#6a7a9a; margin-left:auto; }
.menu-section-header svg { width:28px; height:28px; color:var(--accent); flex-shrink:0; }
.menu-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.menu-item { background:#fff; padding:1.25rem 1.5rem; transition:var(--transition); }
.menu-item:hover { background:var(--accent-dim); }
.menu-item-name { font-weight:700; font-size:0.95rem; color:var(--dark); margin-bottom:0.2rem; }
.menu-item-desc { font-size:0.82rem; color:#6a7a9a; line-height:1.5; }

/* 18. GALLERY PAGE */
.gallery-section { padding:4rem 2.5rem; max-width:1180px; margin:0 auto; }
.filter-bar { display:flex; gap:0.5rem; flex-wrap:wrap; margin-bottom:3rem; }
.filter-btn { padding:0.5rem 1.25rem; border:2px solid var(--border); border-radius:50px; font-size:0.83rem; font-weight:700; color:#6a7a9a; transition:var(--transition); cursor:pointer; background:transparent; }
.filter-btn:hover, .filter-btn.active { background:var(--accent); border-color:var(--accent); color:#fff; }
.gallery-group { margin-bottom:3.5rem; }
.gallery-group[hidden] { display:none; }
.gallery-group-header { margin-bottom:1.25rem; }
.gallery-group-header h3 { font-size:1.5rem; color:var(--dark); }
.gallery-group-header span { font-size:0.82rem; color:#6a7a9a; }
.masonry { columns:3; column-gap:1rem; }
.masonry-item { break-inside:avoid; margin-bottom:1rem; border-radius:var(--radius); overflow:hidden; cursor:pointer; position:relative; }
.masonry-item img { width:100%; display:block; transition:transform 0.4s ease; }
.masonry-item:hover img { transform:scale(1.04); }
.masonry-item-overlay { position:absolute; inset:0; background:rgba(22,32,56,0.4); display:flex; align-items:center; justify-content:center; opacity:0; transition:var(--transition); }
.masonry-item:hover .masonry-item-overlay { opacity:1; }
.masonry-item-overlay svg { color:var(--cream); width:30px; height:30px; }

/* 19. LIGHTBOX */
.lightbox { display:none; position:fixed; inset:0; z-index:2000; background:rgba(10,15,25,0.96); align-items:center; justify-content:center; padding:2rem; }
.lightbox.open { display:flex; }
.lightbox-img { max-height:88vh; max-width:88vw; object-fit:contain; border-radius:var(--radius); }
.lightbox-close, .lightbox-prev, .lightbox-next { position:absolute; background:rgba(250,245,238,0.12); color:var(--cream); border-radius:50%; width:44px; height:44px; font-size:1.4rem; display:flex; align-items:center; justify-content:center; transition:var(--transition); cursor:pointer; }
.lightbox-close:hover, .lightbox-prev:hover, .lightbox-next:hover { background:var(--accent); }
.lightbox-close { top:1.5rem; right:1.5rem; font-size:1.6rem; }
.lightbox-prev { left:1.5rem; top:50%; transform:translateY(-50%); }
.lightbox-next { right:1.5rem; top:50%; transform:translateY(-50%); }
.lightbox-counter { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); color:var(--cream-dim); font-size:0.82rem; }
.gallery-cta { text-align:center; padding:3rem 0 4rem; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* 20. CONTACT PAGE */
.contact-section { padding:5rem 0; background:var(--cream); }
.contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:4rem; align-items:start; }
.contact-blocks { display:flex; flex-direction:column; gap:1.5rem; }
.contact-block { display:flex; align-items:flex-start; gap:1rem; padding:1.25rem; background:#fff; border:1px solid var(--border); border-radius:var(--radius); transition:var(--transition); }
.contact-block:hover { box-shadow:var(--shadow); }
.contact-block-icon { width:42px; height:42px; border-radius:8px; background:var(--accent-dim); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--accent); }
.contact-block-icon svg { width:20px; height:20px; }
.contact-block h4 { font-size:0.85rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; color:var(--dark); margin-bottom:0.25rem; }
.contact-block p, .contact-block a { font-size:0.87rem; color:#3a4a6a; }
.contact-block a:hover { color:var(--accent); text-decoration:underline; }
.contact-form-wrap { background:var(--dark); border-radius:var(--radius); padding:2.5rem; }
.contact-form-wrap h3 { color:var(--cream); margin-bottom:0.5rem; }
.contact-form-wrap > p { color:var(--cream-dim); font-size:0.87rem; margin-bottom:1.75rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.25rem; }
.form-group label { display:block; font-size:0.77rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--cream-dim); margin-bottom:0.4rem; }
.form-group input, .form-group select, .form-group textarea { width:100%; background:rgba(250,245,238,0.07); border:1px solid rgba(196,133,58,0.3); border-radius:6px; padding:0.75rem 1rem; color:var(--cream); font-family:var(--ff-body); font-size:0.9rem; transition:var(--transition); }
.form-group input::placeholder, .form-group textarea::placeholder { color:rgba(250,245,238,0.3); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:var(--accent); background:rgba(250,245,238,0.1); }
.form-group select option { background:var(--dark); color:var(--cream); }
.form-group textarea { min-height:110px; resize:vertical; }
#formSuccess { display:none; background:rgba(196,133,58,0.15); border:1px solid rgba(196,133,58,0.4); border-radius:8px; padding:1.25rem; text-align:center; color:var(--cream); margin-top:1rem; }
#formSuccess h4 { margin-bottom:0.3rem; }
#formSuccess p { font-size:0.85rem; color:var(--cream-dim); }
.map-placeholder { background:var(--dark); border-radius:var(--radius); height:260px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.75rem; margin-top:2.5rem; color:var(--cream-dim); }
.map-placeholder svg { width:36px; height:36px; color:var(--accent); }
.map-placeholder a { color:var(--accent); text-decoration:underline; font-size:0.87rem; }

/* 21. FAQ */
.faq-section { padding:5rem 0; background:var(--dark); }
.faq-section .section-header h2 { color:var(--cream); }
.faq-section .section-header p { color:var(--cream-dim); }
.faq-grid { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:0.5rem; }
.faq-item { border:1px solid rgba(196,133,58,0.2); border-radius:var(--radius); overflow:hidden; }
.faq-question { width:100%; display:flex; align-items:center; justify-content:space-between; padding:1.1rem 1.5rem; text-align:left; font-size:0.95rem; font-weight:600; color:var(--cream); background:rgba(250,245,238,0.04); transition:var(--transition); gap:1rem; }
.faq-question:hover { background:rgba(250,245,238,0.08); }
.faq-question[aria-expanded="true"] { background:rgba(196,133,58,0.15); }
.faq-icon { width:22px; height:22px; border-radius:50%; background:rgba(196,133,58,0.2); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--accent); font-size:1.1rem; transition:transform var(--transition); }
.faq-question[aria-expanded="true"] .faq-icon { transform:rotate(45deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.38s ease; }
.faq-answer-inner { padding:0 1.5rem 1.25rem; color:var(--cream-dim); font-size:0.87rem; line-height:1.7; }
.social-cta { padding:5rem 2rem; background:var(--dark); text-align:center; }
.social-cta h2 { color:var(--cream); margin-bottom:0.75rem; }
.social-cta p { color:var(--cream-dim); margin-bottom:2rem; }
.social-cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* 22. RESPONSIVE */
@media (max-width:1024px) { .offerings-grid { grid-template-columns:repeat(2,1fr); } .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; } .values-grid { grid-template-columns:repeat(3,1fr); } .menu-categories { grid-template-columns:repeat(2,1fr); } }
@media (max-width:768px) { .nav-links, .nav-cta { display:none; } .hamburger { display:flex; } .hero-content, .page-hero-content { padding:0 1.5rem; } .offerings-grid, .reviews-grid { grid-template-columns:1fr; } .brand-split-inner { grid-template-columns:1fr; } .brand-split-inner .brand-split-img { order:-1; } .feed-grid { grid-template-columns:repeat(3,1fr); } .footer-grid, .contact-grid { grid-template-columns:1fr; } .philosophy-grid { grid-template-columns:1fr; } .values-grid { grid-template-columns:repeat(2,1fr); } .origin-grid { grid-template-columns:1fr; } .masonry { columns:2; } .menu-grid { grid-template-columns:1fr; } .form-row { grid-template-columns:1fr; } .stat-item { padding:1rem 1.5rem; } .navbar { padding:1rem 1.25rem; } .navbar.scrolled { padding:0.65rem 1.25rem; } }
@media (max-width:480px) { .masonry { columns:1; } .values-grid { grid-template-columns:1fr; } .feed-grid { grid-template-columns:repeat(2,1fr); } }

/* === SUPPLEMENTAL: Bridging IDs, new component classes === */

/* NAV (ID-based overrides) */
#navbar { position:fixed; top:0; left:0; right:0; z-index:1000; transition:background var(--transition),box-shadow var(--transition),padding var(--transition); }
#navbar .nav-inner { display:flex; align-items:center; gap:2rem; padding:1rem 2rem; }
#navbar.scrolled { background:var(--dark); box-shadow:0 2px 16px rgba(22,32,56,0.45); }
#navbar.scrolled .nav-inner { padding-top:0.65rem; padding-bottom:0.65rem; }
.nav-inner { max-width:1180px; width:100%; margin:0 auto; }
#nav-links { display:flex; align-items:center; gap:0.25rem; margin-left:auto; }
#nav-links a { font-size:0.83rem; font-weight:600; letter-spacing:0.04em; color:rgba(250,245,238,0.7); padding:0.4rem 0.75rem; border-radius:5px; transition:var(--transition); }
#nav-links a:hover, #nav-links a.active { color:var(--cream); background:rgba(250,245,238,0.1); }
#hamburger { display:none; flex-direction:column; gap:5px; margin-left:auto; padding:0.4rem; }
#hamburger span { display:block; width:24px; height:2px; background:var(--cream); border-radius:2px; transition:var(--transition); }
#hamburger.active span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
#hamburger.active span:nth-child(2) { opacity:0; }
#hamburger.active span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
#nav-links.open { display:flex; position:fixed; top:0; left:0; right:0; bottom:0; background:var(--dark); z-index:999; flex-direction:column; align-items:center; justify-content:center; gap:1.5rem; padding:2rem; }
#nav-links.open a { font-family:var(--ff-display); font-size:1.7rem; font-weight:700; color:var(--cream); }
#nav-links.open a:hover { color:var(--accent); background:none; }

/* HERO extras */
.hero { position:relative; min-height:100svh; display:flex; align-items:flex-end; padding:0 0 5rem; overflow:hidden; }
.hero-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(22,32,56,0.9) 0%,rgba(22,32,56,0.45) 55%,rgba(22,32,56,0.1) 100%); }
.hero-content { position:relative; z-index:2; padding:0 2.5rem; max-width:700px; }
.hero-eyebrow { display:inline-block; font-size:0.72rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent); margin-bottom:1rem; }
.hero-content h1 { color:var(--cream); margin-bottom:1rem; }
.hero-sub { font-size:1.05rem; color:rgba(250,245,238,0.72); margin-bottom:2rem; max-width:540px; }
.hero-ctas { display:flex; flex-wrap:wrap; gap:1rem; }
.scroll-indicator { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); color:rgba(250,245,238,0.5); font-size:1.5rem; animation:bounce 2s infinite; text-decoration:none; z-index:2; }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0);} 50%{transform:translateX(-50%) translateY(8px);} }

/* PAGE HERO (ID-based) */
.page-hero { position:relative; min-height:40vh; display:flex; align-items:flex-end; padding:0 0 3rem; overflow:hidden; }
.page-hero img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.page-hero .hero-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(22,32,56,0.88) 0%,rgba(22,32,56,0.4) 60%,rgba(22,32,56,0.1) 100%); }
.page-hero-content { position:relative; z-index:2; padding:0 2.5rem; }
.page-hero-content h1 { color:var(--cream); }
.page-hero-content p { color:rgba(250,245,238,0.72); max-width:540px; margin-top:0.5rem; }
.short-hero { min-height:30vh; }

/* LABEL pill */
.label { display:inline-block; font-size:0.7rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent); margin-bottom:0.75rem; }

/* SECTION utility */
.section { padding:5rem 0; }
.bg-alt { background:var(--bg-alt); }
.bg-alt .section-header h2 { color:var(--cream); }
.bg-alt .section-header p { color:rgba(250,245,238,0.65); }

/* BTN extras */
.btn-secondary { background:transparent; border:2px solid var(--accent); color:var(--accent); }
.btn-secondary:hover { background:var(--accent); color:#fff; transform:translateY(-2px); }
.btn-outline-light { border:2px solid rgba(250,245,238,0.6); color:var(--cream); background:transparent; }
.btn-outline-light:hover { background:var(--cream); color:var(--dark); transform:translateY(-2px); }

/* LINK ARROW */
.link-arrow { font-size:0.84rem; font-weight:700; color:var(--accent); display:inline-flex; align-items:center; gap:0.3rem; transition:var(--transition); }
.link-arrow:hover { gap:0.6rem; }

/* INTRO STRIP */
.intro-strip { background:var(--cream); }
.intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.intro-text h2 { margin-bottom:1rem; color:var(--dark); }
.intro-text p { color:#3a4a6a; margin-bottom:1.5rem; font-size:0.95rem; }
.intro-image { border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; }
.intro-image img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; }
.intro-image:hover img { transform:scale(1.04); }

/* OFFERINGS (card with separate body) */
.offering-card { background:#fff; border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); transition:var(--transition); }
.offering-card:hover { box-shadow:var(--shadow); transform:translateY(-4px); }
.offering-card img { width:100%; aspect-ratio:16/9; object-fit:cover; transition:transform 0.5s ease; }
.offering-card:hover img { transform:scale(1.04); }
.offering-body { padding:1.5rem; }
.offering-body h3 { color:var(--dark); margin-bottom:0.5rem; }
.offering-body p { color:#4a5a7a; font-size:0.88rem; margin-bottom:1rem; }

/* STATS BANNER */
.stats-banner { background:var(--dark); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; text-align:center; }
.stat { padding:2rem 1rem; border-right:1px solid rgba(196,133,58,0.2); }
.stat:last-child { border-right:none; }
.stat-num { font-family:var(--ff-display); font-size:2.8rem; font-weight:700; color:var(--accent); display:block; line-height:1; }
.stat-label { font-size:0.75rem; letter-spacing:0.12em; text-transform:uppercase; color:rgba(250,245,238,0.55); display:block; margin-top:0.5rem; }

/* FEATURED DISHES */
.featured-dishes { background:var(--cream); }
.dishes-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.dish-card { position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:3/4; cursor:pointer; }
.dish-card img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.dish-card:hover img { transform:scale(1.07); }
.dish-label { position:absolute; bottom:0; left:0; right:0; padding:1.25rem 1rem 1rem; background:linear-gradient(to top,rgba(22,32,56,0.85) 0%,transparent 100%); color:var(--cream); font-size:0.84rem; font-weight:600; }

/* SOCIAL TEASER */
.social-teaser { background:var(--cream); }
.social-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0.5rem; margin:2rem 0; }
.social-tile { aspect-ratio:1; overflow:hidden; border-radius:var(--radius); display:block; }
.social-tile img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s ease; }
.social-tile:hover img { transform:scale(1.07); }

/* CTA BANNER */
.cta-banner { background:var(--bg-alt); }
.cta-banner-inner { text-align:center; padding:3rem 1.5rem; }
.cta-banner-inner h2 { color:var(--cream); margin-bottom:0.75rem; }
.cta-banner-inner p { color:rgba(250,245,238,0.65); margin-bottom:2rem; }
.cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* TWO COLUMN */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.two-col.reverse .two-col-text { order:1; }
.two-col.reverse .two-col-image { order:2; }
.two-col-image { border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; }
.two-col-image img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.two-col-image:hover img { transform:scale(1.04); }
.two-col-text h2 { color:var(--dark); margin-bottom:1rem; }
.two-col-text p { color:#3a4a6a; margin-bottom:1rem; font-size:0.95rem; }
.two-col-text em { color:var(--accent); font-style:italic; }
.bg-alt .two-col-text h2 { color:var(--cream); }
.bg-alt .two-col-text p { color:rgba(250,245,238,0.72); }

/* VALUES (card version) */
.value-card { background:rgba(250,245,238,0.07); border:1px solid rgba(250,245,238,0.12); border-radius:var(--radius); padding:2rem; text-align:center; transition:var(--transition); }
.value-card:hover { background:rgba(250,245,238,0.11); transform:translateY(-4px); }
.value-icon { font-size:2rem; margin-bottom:1rem; display:block; }
.value-card h3 { color:var(--cream); margin-bottom:0.5rem; font-size:1.1rem; }
.value-card p { color:rgba(250,245,238,0.65); font-size:0.87rem; }
.values-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }

/* TIMELINE (content-based) */
.timeline { position:relative; max-width:760px; margin:0 auto; padding-left:2rem; }
.timeline::before { content:''; position:absolute; left:0; top:0; bottom:0; width:2px; background:rgba(196,133,58,0.35); }
.timeline-item { position:relative; padding:0 0 2.5rem 2rem; }
.timeline-item::before { content:''; position:absolute; left:-5px; top:6px; width:12px; height:12px; border-radius:50%; background:var(--accent); border:2px solid var(--dark); }
.timeline-year { font-size:0.75rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); margin-bottom:0.3rem; }
.timeline-content h3 { color:var(--cream); margin-bottom:0.35rem; font-size:1.05rem; }
.timeline-content p { color:rgba(250,245,238,0.65); font-size:0.87rem; }

/* REVIEWS (overrides) */
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.review-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:1.75rem; transition:var(--transition); }
.review-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.review-stars { color:var(--accent); font-size:1rem; margin-bottom:0.75rem; }
.review-text { font-size:0.9rem; color:#3a4a6a; font-style:italic; line-height:1.7; margin-bottom:1rem; }
.review-author { font-size:0.83rem; color:#6a7a9a; }

/* FOOTER (site-footer overrides) */
.site-footer { background:var(--dark); border-top:1px solid rgba(196,133,58,0.15); padding:4rem 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1.4fr 1fr; gap:3rem; }
.footer-brand img { width:50px; height:50px; border-radius:50%; object-fit:cover; margin-bottom:1rem; }
.footer-brand p { color:rgba(250,245,238,0.65); font-size:0.87rem; margin-bottom:0.3rem; }
.footer-tagline { font-style:italic; font-size:0.82rem !important; color:rgba(250,245,238,0.4) !important; margin-top:0.75rem !important; }
.footer-links h4, .footer-info h4, .footer-social h4 { font-size:0.72rem; font-weight:700; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent); margin-bottom:1.25rem; }
.footer-links ul li + li { margin-top:0.6rem; }
.footer-links ul a { color:rgba(250,245,238,0.65); font-size:0.87rem; transition:var(--transition); }
.footer-links ul a:hover { color:var(--cream); padding-left:4px; }
.footer-info p { color:rgba(250,245,238,0.65); font-size:0.85rem; line-height:1.7; margin-bottom:0.75rem; }
.footer-social { display:flex; gap:0.75rem; flex-wrap:wrap; }
.social-links { display:flex; gap:0.75rem; flex-wrap:wrap; }
.social-links a { width:36px; height:36px; border-radius:50%; background:rgba(250,245,238,0.08); display:flex; align-items:center; justify-content:center; color:rgba(250,245,238,0.65); transition:var(--transition); }
.social-links a:hover { background:var(--accent); color:#fff; }
.footer-bottom { border-top:1px solid rgba(196,133,58,0.1); padding:1.25rem 0; margin-top:3rem; }
.footer-bottom p { color:rgba(250,245,238,0.35); font-size:0.8rem; text-align:center; }

/* BACK TO TOP */
#back-to-top { position:fixed; bottom:2rem; right:2rem; z-index:900; width:42px; height:42px; border-radius:50%; background:var(--accent); color:#fff; font-size:1.3rem; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 16px rgba(196,133,58,0.4); opacity:0; transform:translateY(12px); transition:var(--transition); pointer-events:none; cursor:pointer; border:none; }
#back-to-top.visible { opacity:1; transform:none; pointer-events:auto; }
#back-to-top:hover { background:#b07030; transform:translateY(-2px); }

/* LIGHTBOX (ID-based) */
#lightbox { display:none; position:fixed; inset:0; z-index:2000; background:rgba(10,15,25,0.96); align-items:center; justify-content:center; padding:2rem; }
#lightbox.open { display:flex; }
.lb-img { max-height:88vh; max-width:88vw; object-fit:contain; border-radius:var(--radius); }
.lb-caption { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); color:rgba(250,245,238,0.6); font-size:0.82rem; text-align:center; }
.lb-close, .lb-prev, .lb-next { position:absolute; background:rgba(250,245,238,0.12); color:var(--cream); border-radius:50%; width:44px; height:44px; font-size:1.6rem; display:flex; align-items:center; justify-content:center; transition:var(--transition); cursor:pointer; border:none; }
.lb-close:hover, .lb-prev:hover, .lb-next:hover { background:var(--accent); }
.lb-close { top:1.5rem; right:1.5rem; }
.lb-prev { left:1.5rem; top:50%; transform:translateY(-50%); }
.lb-next { right:1.5rem; top:50%; transform:translateY(-50%); }

/* MENU PAGE (tabs) */
.menu-section { background:var(--cream); }
.menu-tabs-wrap { display:flex; gap:0.5rem; flex-wrap:wrap; margin-bottom:3rem; border-bottom:2px solid var(--border); padding-bottom:1rem; }
.menu-tab { padding:0.55rem 1.25rem; border:2px solid var(--border); border-radius:50px; font-size:0.83rem; font-weight:700; color:#6a7a9a; transition:var(--transition); cursor:pointer; background:transparent; }
.menu-tab:hover, .menu-tab.active { background:var(--accent); border-color:var(--accent); color:#fff; }
.menu-panel { display:none; }
.menu-panel.active { display:block; }
.menu-category-header { margin-bottom:2rem; padding-bottom:1rem; border-bottom:1px solid var(--border); }
.menu-category-header h2 { color:var(--dark); margin-bottom:0.3rem; }
.menu-category-header p { color:#6a7a9a; font-size:0.85rem; }
.menu-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.menu-item { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; background:var(--cream); padding:1.25rem 1.5rem; transition:var(--transition); }
.menu-item:hover { background:#fff; }
.menu-item-info h3 { font-size:0.95rem; font-weight:700; color:var(--dark); margin-bottom:0.2rem; }
.menu-item-info p { font-size:0.82rem; color:#6a7a9a; line-height:1.5; }
.menu-price { font-family:var(--ff-display); font-weight:700; color:var(--accent); font-size:0.95rem; white-space:nowrap; flex-shrink:0; }
.menu-note { padding:1.5rem 0 3rem; }
.menu-note p { color:#6a7a9a; font-size:0.83rem; text-align:center; }

/* GALLERY PAGE */
.gallery-section { padding:4rem 0; }
.gallery-masonry { columns:3; column-gap:1rem; }
.gallery-item { break-inside:avoid; margin-bottom:1rem; border-radius:var(--radius); overflow:hidden; cursor:zoom-in; }
.gallery-item img { width:100%; display:block; transition:transform 0.4s ease; }
.gallery-item:hover img { transform:scale(1.04); }

/* CONTACT PAGE */
.contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:4rem; align-items:start; }
.contact-info { display:flex; flex-direction:column; gap:1.5rem; }
.info-block { padding:1.25rem; background:#fff; border:1px solid var(--border); border-radius:var(--radius); transition:var(--transition); }
.info-block:hover { box-shadow:var(--shadow); }
.info-block h3 { font-size:0.75rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); margin-bottom:0.5rem; }
.info-block p, .info-block a { font-size:0.87rem; color:#3a4a6a; line-height:1.6; }
.info-block a:hover { color:var(--accent); text-decoration:underline; }
.contact-socials { display:flex; flex-direction:column; gap:0.4rem; }
.contact-form-wrap h2 { color:var(--dark); margin-bottom:0.5rem; }
.contact-form-wrap > p { color:#4a5a7a; font-size:0.87rem; margin-bottom:1.75rem; }
.form-group { margin-bottom:1.25rem; }
.form-group label { display:block; font-size:0.77rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--dark); margin-bottom:0.4rem; }
.form-group input, .form-group select, .form-group textarea { width:100%; background:#fff; border:1px solid var(--border); border-radius:6px; padding:0.75rem 1rem; color:var(--dark); font-family:var(--ff-body); font-size:0.9rem; transition:var(--transition); }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(196,133,58,0.1); }
.form-group input.error, .form-group select.error, .form-group textarea.error { border-color:#c0392b; }
.form-group textarea { min-height:120px; resize:vertical; }
.field-error { display:block; font-size:0.76rem; color:#c0392b; margin-top:0.3rem; min-height:1em; }

/* MAP */
.map-section { padding:0 0 4rem; }
.map-wrap { border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); }
.map-note { text-align:center; color:#6a7a9a; font-size:0.83rem; margin-top:1rem; }

/* FAQ (open-class toggle) */
.faq-section { padding:5rem 0; background:var(--dark); }
.faq-section .section-header h2 { color:var(--cream); }
.faq-list { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:0.5rem; }
.faq-item { border:1px solid rgba(196,133,58,0.2); border-radius:var(--radius); overflow:hidden; }
.faq-question { width:100%; display:flex; align-items:center; justify-content:space-between; padding:1.1rem 1.5rem; text-align:left; font-size:0.95rem; font-weight:600; color:var(--cream); background:rgba(250,245,238,0.04); transition:var(--transition); }
.faq-question:hover { background:rgba(250,245,238,0.08); }
.faq-item.open .faq-question { background:rgba(196,133,58,0.15); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.38s ease; }
.faq-item.open .faq-answer { max-height:400px; }
.faq-answer p { padding:0.75rem 1.5rem 1.25rem; color:rgba(250,245,238,0.65); font-size:0.87rem; line-height:1.7; }

/* RESPONSIVE ADDITIONS */
@media (max-width:1024px) { .footer-grid { grid-template-columns:1fr 1fr; } .two-col { gap:2.5rem; } .dishes-grid { grid-template-columns:repeat(2,1fr); } .stats-grid { grid-template-columns:repeat(2,1fr); } .values-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:768px) { #hamburger { display:flex; } #nav-links { display:none; } .intro-grid, .two-col { grid-template-columns:1fr; gap:2rem; } .two-col.reverse .two-col-text, .two-col.reverse .two-col-image { order:unset; } .offerings-grid, .reviews-grid, .social-grid { grid-template-columns:1fr; } .dishes-grid { grid-template-columns:1fr 1fr; } .contact-grid { grid-template-columns:1fr; } .footer-grid { grid-template-columns:1fr 1fr; } .gallery-masonry { columns:2; } .menu-grid { grid-template-columns:1fr; } .stats-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px) { .gallery-masonry { columns:1; } .dishes-grid { grid-template-columns:1fr; } .footer-grid { grid-template-columns:1fr; } .stats-grid { grid-template-columns:1fr 1fr; } .social-grid { grid-template-columns:repeat(2,1fr); } }
