/* ===================================================
   Anea Cafe — Lingayen, Pangasinan
   Design rationale: Deep forest/park green (#182A1A)
   mirrors the lush Lingayen Capitol Park grounds;
   warm golden-amber accent (#D9A848) captures morning
   sunlight on the bay; terracotta highlight (#B8603C)
   evokes Pangasinan pottery and warm earth tones.
   Heading: Playfair Display — warm, elegant editorial serif
   Body: Plus Jakarta Sans — clean, modern, versatile
   =================================================== */

/* 1. RESET & CUSTOM PROPERTIES */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --dark:       #182A1A;
  --bg-alt:     #223322;
  --accent:     #D9A848;
  --highlight:  #B8603C;
  --cream:      #F8F3E8;
  --cream-dim:  rgba(248,243,232,0.65);
  --accent-dim: rgba(217,168,72,0.14);
  --border:     rgba(217,168,72,0.25);
  --shadow:     0 4px 24px rgba(24,42,26,0.28);
  --radius:     10px;
  --ff-display: 'Playfair Display', serif;
  --ff-body:    'Plus Jakarta 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; }

/* 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:var(--dark); }
.btn-primary:hover { background:#c49030; transform:translateY(-2px); box-shadow:0 6px 20px rgba(217,168,72,0.38); }
.btn-outline { border:2px solid var(--accent); color:var(--accent); background:transparent; }
.btn-outline:hover { background:var(--accent); color:var(--dark); transform:translateY(-2px); }
.btn-secondary { background:transparent; border:2px solid var(--accent); color:var(--accent); }
.btn-secondary:hover { background:var(--accent); color:var(--dark); transform:translateY(-2px); }
.btn-outline-light { border:2px solid rgba(248,243,232,0.6); color:var(--cream); background:transparent; }
.btn-outline-light: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; }
.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(248,243,232,0.65); }
.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; }
.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; }

/* 4. NAVBAR */
#navbar { position:fixed; top:0; left:0; right:0; z-index:1000; transition:background var(--transition),box-shadow var(--transition); }
#navbar .nav-inner { display:flex; align-items:center; padding:1rem 2rem; max-width:1400px; margin:0 auto; }
#navbar.scrolled { background:var(--dark); box-shadow:0 2px 16px rgba(24,42,26,0.4); }
.nav-logo { display:flex; align-items:center; gap:0.65rem; font-family:var(--ff-display); font-size:1.05rem; 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(248,243,232,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; }

/* 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; width:100%; height:100%; object-fit:cover; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(24,42,26,0.9) 0%,rgba(24,42,26,0.45) 55%,rgba(24,42,26,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:var(--cream-dim); 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:var(--cream-dim); 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);} }

/* 6. PAGE HERO */
.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(24,42,26,0.88) 0%,rgba(24,42,26,0.4) 60%,rgba(24,42,26,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:var(--cream-dim); max-width:540px; margin-top:0.5rem; }
.short-hero { min-height:30vh; }

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

/* 8. INTRO STRIP */
.intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.intro-text h2 { color:var(--dark); margin-bottom:1rem; }
.intro-text p { color:#4a5a4a; 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.5s ease; }
.intro-image:hover img { transform:scale(1.04); }

/* 9. OFFERINGS */
.offerings-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem; }
.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.05); }
.offering-body { padding:1.5rem; }
.offering-body h3 { color:var(--dark); margin-bottom:0.5rem; }
.offering-body p { color:#4a5a4a; font-size:0.88rem; margin-bottom:1rem; }

/* 10. 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:#4a5a4a; 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:var(--cream-dim); }

/* 11. VALUES */
.values-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.value-card { background:rgba(248,243,232,0.07); border:1px solid rgba(248,243,232,0.12); border-radius:var(--radius); padding:2rem; text-align:center; transition:var(--transition); }
.value-card:hover { background:rgba(248,243,232,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:var(--cream-dim); font-size:0.87rem; }

/* 12. 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(217,168,72,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(248,243,232,0.55); display:block; margin-top:0.5rem; }

/* 13. REVIEWS */
.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:#4a5a4a; font-style:italic; line-height:1.7; margin-bottom:1rem; }
.review-author { font-size:0.83rem; color:#6a7a6a; }

/* 14. FEATURED DISHES */
.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(24,42,26,0.85) 0%,transparent 100%); color:var(--cream); font-size:0.84rem; font-weight:600; }

/* 15. SOCIAL TEASER */
.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); }

/* 16. 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:var(--cream-dim); margin-bottom:2rem; }
.cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* 17. MENU PAGE */
.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:#6a7a6a; transition:var(--transition); cursor:pointer; background:transparent; }
.menu-tab:hover, .menu-tab.active { background:var(--accent); border-color:var(--accent); color:var(--dark); }
.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:#6a7a6a; 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:#6a7a6a; 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:#6a7a6a; font-size:0.83rem; text-align:center; }

/* 18. GALLERY */
.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:#6a7a6a; transition:var(--transition); cursor:pointer; background:transparent; }
.filter-btn:hover, .filter-btn.active { background:var(--accent); border-color:var(--accent); color:var(--dark); }
.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); }

/* 19. LIGHTBOX */
#lightbox { display:none; position:fixed; inset:0; z-index:2000; background:rgba(5,15,5,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:var(--cream-dim); font-size:0.82rem; text-align:center; }
.lb-close, .lb-prev, .lb-next { position:absolute; background:rgba(248,243,232,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); color:var(--dark); }
.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%); }

/* 20. CONTACT */
.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:#4a5a4a; 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:#4a5a4a; 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(217,168,72,0.12); }
.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; }

/* 21. MAP & FAQ */
.map-wrap { border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); }
.map-note { text-align:center; color:#6a7a6a; font-size:0.83rem; margin-top:1rem; }
.faq-list { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:0.5rem; }
.faq-item { border:1px solid rgba(217,168,72,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(248,243,232,0.04); transition:var(--transition); }
.faq-question:hover { background:rgba(248,243,232,0.08); }
.faq-item.open .faq-question { background:rgba(217,168,72,0.15); color:var(--cream); }
.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:var(--cream-dim); font-size:0.87rem; line-height:1.7; }

/* 22. FOOTER */
.site-footer { background:var(--dark); border-top:1px solid rgba(217,168,72,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:var(--cream-dim); font-size:0.87rem; margin-bottom:0.3rem; }
.footer-tagline { font-style:italic; font-size:0.82rem !important; color:rgba(248,243,232,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:var(--cream-dim); font-size:0.87rem; transition:var(--transition); }
.footer-links ul a:hover { color:var(--cream); padding-left:4px; }
.footer-info p { color:var(--cream-dim); font-size:0.85rem; line-height:1.7; margin-bottom:0.75rem; }
.social-links { display:flex; gap:0.75rem; flex-wrap:wrap; }
.social-links a { width:36px; height:36px; border-radius:50%; background:rgba(248,243,232,0.08); display:flex; align-items:center; justify-content:center; color:var(--cream-dim); transition:var(--transition); }
.social-links a:hover { background:var(--accent); color:var(--dark); }
.footer-bottom { border-top:1px solid rgba(217,168,72,0.1); padding:1.25rem 0; margin-top:3rem; }
.footer-bottom p { color:rgba(248,243,232,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:var(--dark); font-size:1.3rem; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 16px rgba(217,168,72,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:#c49030; transform:translateY(-2px); }

/* TIMELINE */
.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(217,168,72,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:var(--cream-dim); font-size:0.87rem; }

/* RESPONSIVE */
@media (max-width:1024px) { .offerings-grid { grid-template-columns:repeat(2,1fr); } .footer-grid { grid-template-columns:1fr 1fr; } .values-grid { grid-template-columns:repeat(2,1fr); } .dishes-grid { grid-template-columns:repeat(2,1fr); } .stats-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; } .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; } .social-grid { grid-template-columns:repeat(2,1fr); } }

/* === No-photo Hero (CSS gradient) === */
.hero-gradient { background: linear-gradient(135deg, var(--dark) 0%, var(--bg-alt) 50%, rgba(34,51,34,0.8) 100%); }
.hero-graphic { position:absolute; inset:0; background: radial-gradient(ellipse at 70% 50%, rgba(217,168,72,0.15) 0%, transparent 60%), radial-gradient(ellipse at 20% 80%, rgba(184,96,60,0.1) 0%, transparent 50%), linear-gradient(135deg, var(--dark) 0%, var(--bg-alt) 100%); }
.page-hero-gradient { background: linear-gradient(135deg, var(--dark) 0%, var(--bg-alt) 100%); min-height:30vh; display:flex; align-items:flex-end; padding:0 0 3rem; position:relative; }
.page-hero-gradient .page-hero-content { position:relative; z-index:2; padding:0 2.5rem; }

/* Feature icons */
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.feature-block { text-align:center; padding:2.5rem 1.5rem; }
.feature-icon { font-size:2.5rem; margin-bottom:1rem; display:block; }
.feature-block h3 { color:var(--dark); margin-bottom:0.5rem; }
.feature-block p { color:#4a5a4a; font-size:0.9rem; }

/* Story split */
.story-split { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.story-text h2 { color:var(--cream); margin-bottom:1rem; }
.story-text p { color:var(--cream-dim); font-size:0.95rem; margin-bottom:1rem; line-height:1.8; }
.story-card { background:rgba(248,243,232,0.07); border:1px solid rgba(217,168,72,0.2); border-radius:var(--radius); padding:2rem; }
.story-card h3 { color:var(--accent); margin-bottom:0.5rem; font-size:1rem; }
.story-card p { color:var(--cream-dim); font-size:0.87rem; }
.story-list { list-style:none; display:flex; flex-direction:column; gap:1rem; }
.story-list li { display:flex; gap:1rem; align-items:flex-start; color:var(--cream-dim); font-size:0.88rem; line-height:1.6; }
.story-list .bullet { color:var(--accent); font-size:1.2rem; flex-shrink:0; margin-top:0.1rem; }

/* Gallery no-images placeholder */
.gallery-coming { text-align:center; padding:5rem 1.5rem; background:var(--cream); }
.gallery-coming .ig-handle { font-size:1.3rem; color:var(--accent); font-weight:700; margin:1.5rem 0; }
.gallery-cta-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; max-width:900px; margin:2rem auto 0; }
.gallery-placeholder-card { background:var(--bg-alt); border-radius:var(--radius); aspect-ratio:1; display:flex; align-items:center; justify-content:center; color:var(--cream-dim); font-size:0.8rem; text-align:center; padding:1rem; overflow:hidden; position:relative; }
.gallery-placeholder-card::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at center, rgba(217,168,72,0.1) 0%, transparent 70%); }

@media (max-width:768px) { .features-grid { grid-template-columns:1fr; } .story-split { grid-template-columns:1fr; } .gallery-cta-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px) { .gallery-cta-grid { grid-template-columns:1fr; } }
