/* ══════════════════════════════════════════════════════
   RUSTICA KITCHEN — Warm Earthy Boutique Template
   Design System by Logic Layer Pvt. Ltd.
   ══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root {
    --font-sans: 'Source Sans 3', sans-serif;
    --font-serif: 'Playfair Display', serif;
    --bg: #f8f6f0;
    --bg-card: #ffffff;
    --cream: #eee9df;
    --navy: #1a2744;
    --navy-dark: #0f1b33;
    --navy-light: #2d4a7a;
    --olive-muted: rgba(26,39,68,0.08);
    --burgundy: #8b2252;
    --burgundy-light: #b44370;
    --charcoal: #1a1a1a;
    --text-primary: #1a1a1a;
    --text-secondary: #4a4a4a;
    --text-muted: #8a8a8a;
    --border: #e8e0d5;
    --border-hover: #d0c5b5;
    --shadow-sm: 0 2px 8px rgba(26,26,26,0.06);
    --shadow-md: 0 8px 30px rgba(26,26,26,0.08);
    --shadow-lg: 0 20px 60px rgba(26,26,26,0.12);
    --radius: 14px;
    --radius-lg: 22px;
    --transition: 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font-sans); color:var(--text-primary); background:var(--bg); line-height:1.6; font-size:15px; }
a { text-decoration:none; color:inherit; transition:color var(--transition); }
img { max-width:100%; display:block; }
button { border:none; cursor:pointer; background:none; font-family:inherit; }
.container { max-width:1280px; margin:0 auto; padding:0 24px; }
.section { padding:120px 0; }

.serif-italic { font-family:var(--font-serif); font-style:italic; }
.accent-text { color:var(--navy); }
.section-label { display:flex; align-items:center; gap:16px; justify-content:center; margin-bottom:20px; }
.label-line { width:40px; height:1px; background:rgba(26,39,68,0.08); }
.section-label span:not(.label-line) { font-size:0.7rem; letter-spacing:0.25em; text-transform:uppercase; color:var(--navy); font-weight:500; }
.section-header { text-align:center; margin-bottom:60px; }
.section-title { font-family:var(--font-serif); font-size:clamp(2rem,4vw,3.2rem); font-weight:400; line-height:1.2; }
.section-desc { color:var(--text-muted); font-size:0.95rem; max-width:550px; margin:16px auto 0; line-height:1.8; }

.btn { display:inline-flex; align-items:center; gap:10px; padding:16px 36px; border-radius:100px; font-size:0.78rem; font-weight:500; letter-spacing:0.12em; text-transform:uppercase; transition:all var(--transition); }
.btn-primary { background:var(--navy); color:#fff; }
.btn-primary:hover { background:var(--navy-dark); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-outline { border:1.5px solid var(--border); color:var(--text-primary); }
.btn-outline:hover { border-color:var(--navy); color:var(--navy); }
.btn-arrow { transition:transform 0.3s; }
.btn:hover .btn-arrow { transform:translateX(4px); }

nav { position:fixed; top:0; left:0; right:0; z-index:100; padding:20px 40px; display:flex; align-items:center; justify-content:space-between; transition:all 0.5s; }
nav.scrolled { background:rgba(250,247,242,0.97); backdrop-filter:blur(20px); box-shadow:var(--shadow-sm); padding:14px 40px; }
.nav-logo { font-family:var(--font-serif); font-size:1.6rem; font-weight:500; color:var(--charcoal); }
.logo-dot { color:var(--navy); }
.nav-links { display:flex; align-items:center; gap:36px; }
.nav-link { font-size:0.72rem; font-weight:500; letter-spacing:0.15em; text-transform:uppercase; color:var(--text-secondary); }
.nav-link:hover, .nav-link.active { color:var(--navy); }
.nav-cta { font-size:0.72rem; font-weight:500; letter-spacing:0.12em; text-transform:uppercase; padding:12px 28px; background:var(--navy); border-radius:100px; color:#fff; }
.nav-cta:hover { background:var(--navy-dark); }
.nav-toggle { display:none; flex-direction:column; gap:5px; }
.nav-toggle span { width:24px; height:2px; background:var(--charcoal); }
.mobile-menu { position:fixed; inset:0; background:var(--bg); z-index:200; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:30px; transform:translateX(100%); transition:transform 0.5s; }
.mobile-menu.open { transform:translateX(0); }
.mobile-close { position:absolute; top:24px; right:24px; font-size:1.5rem; color:var(--charcoal); }
.mobile-link { font-family:var(--font-serif); font-size:1.8rem; color:var(--text-secondary); }

.hero { height:100vh; min-height:700px; position:relative; display:flex; align-items:center; overflow:hidden; }
.hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg, rgba(26,26,26,0.75) 0%, rgba(26,26,26,0.15) 70%); }
.hero-content { position:relative; z-index:2; max-width:700px; padding-left:48px; }
.hero-title { font-family:var(--font-serif); font-size:clamp(3rem,6vw,5rem); font-weight:400; line-height:1.1; margin-bottom:20px; color:#fff; }
.hero-desc { color:rgba(255,255,255,0.7); font-size:1.05rem; line-height:1.8; max-width:500px; margin-bottom:36px; }

.page-hero { height:45vh; min-height:320px; position:relative; display:flex; align-items:center; justify-content:center; text-align:center; }
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.page-hero-overlay { position:absolute; inset:0; background:rgba(26,26,26,0.6); }
.page-hero-content { position:relative; z-index:2; }
.page-hero-title { font-family:var(--font-serif); font-size:clamp(2rem,4vw,3.2rem); font-weight:400; color:#fff; }

.featured-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.featured-card { border-radius:var(--radius-lg); overflow:hidden; position:relative; aspect-ratio:3/4; }
.featured-card img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s; }
.featured-card:hover img { transform:scale(1.06); }
.featured-card-overlay { position:absolute; bottom:0; left:0; right:0; padding:30px; background:linear-gradient(transparent, rgba(26,26,26,0.85)); }
.featured-card-title { font-family:var(--font-serif); font-size:1.3rem; color:#fff; }
.featured-card-price { color:var(--burgundy-light); font-size:0.9rem; margin-top:4px; }

.menu-tabs { display:flex; justify-content:center; gap:8px; margin-bottom:50px; flex-wrap:wrap; }
.menu-tab { padding:10px 28px; border:1.5px solid var(--border); border-radius:100px; font-size:0.75rem; font-weight:500; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-secondary); cursor:pointer; transition:all 0.3s; }
.menu-tab.active, .menu-tab:hover { background:var(--navy); color:#fff; border-color:var(--navy); }
.menu-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:30px; }
.menu-item { display:flex; gap:20px; padding:24px; border:1px solid var(--border); border-radius:var(--radius-lg); transition:all var(--transition); background:var(--bg-card); }
.menu-item:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); border-color:rgba(26,39,68,0.08); }
.menu-item-img { width:100px; height:100px; border-radius:var(--radius); overflow:hidden; flex-shrink:0; }
.menu-item-img img { width:100%; height:100%; object-fit:cover; }
.menu-item-info { flex:1; }
.menu-item-header { display:flex; justify-content:space-between; margin-bottom:6px; }
.menu-item-name { font-family:var(--font-serif); font-size:1.15rem; }
.menu-item-price { font-family:var(--font-serif); font-size:1.1rem; color:var(--burgundy); white-space:nowrap; }
.menu-item-desc { font-size:0.85rem; color:var(--text-muted); line-height:1.6; }
.menu-item-tags { display:flex; gap:6px; margin-top:8px; }
.menu-item-tag { font-size:0.6rem; padding:3px 10px; border:1px solid var(--navy-light); border-radius:100px; color:var(--navy); letter-spacing:0.05em; text-transform:uppercase; }

.menu-card-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.menu-card { border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); transition:all var(--transition); background:var(--bg-card); }
.menu-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.menu-card-image { aspect-ratio:4/3; overflow:hidden; }
.menu-card-image img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s; }
.menu-card:hover .menu-card-image img { transform:scale(1.05); }
.menu-card-body { padding:24px; }
.menu-card-name { font-family:var(--font-serif); font-size:1.2rem; margin-bottom:6px; }
.menu-card-desc { font-size:0.85rem; color:var(--text-muted); line-height:1.6; margin-bottom:12px; }
.menu-card-footer { display:flex; justify-content:space-between; align-items:center; }
.menu-card-price { font-family:var(--font-serif); font-size:1.2rem; color:var(--burgundy); }

.dish-detail { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; margin-top:40px; }
.dish-gallery { border-radius:var(--radius-lg); overflow:hidden; }
.dish-gallery img { width:100%; aspect-ratio:4/3; object-fit:cover; }
.dish-info .dish-name { font-family:var(--font-serif); font-size:2.2rem; font-weight:400; }
.dish-info .dish-price { font-family:var(--font-serif); font-size:1.5rem; color:var(--burgundy); margin-top:10px; }
.dish-info .dish-desc { color:var(--text-secondary); line-height:1.9; margin-top:20px; }
.nutrition-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:30px; }
.nutrition-item { text-align:center; padding:16px; background:var(--cream); border-radius:var(--radius); }
.nutrition-num { font-family:var(--font-serif); font-size:1.3rem; color:var(--navy); }
.nutrition-label { font-size:0.65rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-muted); margin-top:4px; }

.reservation-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; margin-top:50px; }
.reservation-form { padding:40px; border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--bg-card); }
.reservation-hours { margin-top:30px; }
.hours-row { display:flex; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--border); font-size:0.9rem; }
.hours-row span:first-child { color:var(--text-secondary); }
.hours-row span:last-child { font-weight:500; color:var(--navy); }

.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-text { color:var(--text-secondary); font-size:0.95rem; line-height:1.9; margin-bottom:16px; }
.about-image { border-radius:var(--radius-lg); overflow:hidden; }
.about-image img { width:100%; aspect-ratio:4/5; object-fit:cover; }
.timeline { margin-top:40px; }
.timeline-item { display:flex; gap:24px; padding:20px 0; border-bottom:1px solid var(--border); }
.timeline-year { font-family:var(--font-serif); font-size:1.3rem; color:var(--navy); min-width:80px; }
.timeline-text { font-size:0.9rem; color:var(--text-secondary); line-height:1.7; }

.chefs-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:60px; }
.chef-card { text-align:center; padding:30px 20px; border:1px solid var(--border); border-radius:var(--radius-lg); transition:all var(--transition); background:var(--bg-card); }
.chef-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.chef-avatar { width:130px; height:130px; border-radius:50%; overflow:hidden; margin:0 auto 20px; border:3px solid var(--navy-light); }
.chef-avatar img { width:100%; height:100%; object-fit:cover; }
.chef-name { font-family:var(--font-serif); font-size:1.2rem; margin-bottom:4px; }
.chef-role { font-size:0.72rem; color:var(--navy); letter-spacing:0.15em; text-transform:uppercase; margin-bottom:12px; }
.chef-bio { font-size:0.85rem; color:var(--text-muted); line-height:1.7; }
.chef-detail-grid { display:grid; grid-template-columns:400px 1fr; gap:60px; align-items:start; }
.chef-specialties { display:flex; gap:8px; flex-wrap:wrap; margin-top:16px; }

.gallery-masonry { columns:3; gap:16px; margin-top:50px; }
.gallery-item { break-inside:avoid; margin-bottom:16px; border-radius:var(--radius); overflow:hidden; }
.gallery-item img { width:100%; display:block; transition:transform 0.6s; }
.gallery-item:hover img { transform:scale(1.05); }

.services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.service-card { padding:40px 28px; border:1px solid var(--border); border-radius:var(--radius-lg); text-align:center; transition:all var(--transition); background:var(--bg-card); }
.service-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.service-icon { font-size:2.2rem; margin-bottom:20px; }
.service-title { font-family:var(--font-serif); font-size:1.1rem; margin-bottom:10px; }
.service-desc { font-size:0.85rem; color:var(--text-muted); line-height:1.7; }

.events-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:30px; margin-top:50px; }
.event-card { display:grid; grid-template-columns:200px 1fr; border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; background:var(--bg-card); transition:all var(--transition); }
.event-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.event-card-image { overflow:hidden; }
.event-card-image img { width:100%; height:100%; object-fit:cover; }
.event-card-body { padding:28px; }
.event-date { font-size:0.7rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--navy); margin-bottom:8px; }
.event-name { font-family:var(--font-serif); font-size:1.2rem; margin-bottom:8px; }
.event-desc { font-size:0.85rem; color:var(--text-muted); line-height:1.6; }

.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:50px; }
.testimonial-card { padding:36px; border:1px solid var(--border); border-radius:var(--radius-lg); text-align:center; background:var(--bg-card); }
.testimonial-stars { color:var(--burgundy); font-size:1rem; letter-spacing:3px; margin-bottom:16px; }
.testimonial-text { font-family:var(--font-serif); font-size:1.1rem; font-style:italic; color:var(--text-secondary); line-height:1.7; margin-bottom:20px; }
.testimonial-author { font-weight:600; font-size:0.85rem; }
.testimonial-role { font-size:0.75rem; color:var(--text-muted); }

.offers-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:30px; margin-top:50px; }
.offer-card { position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:16/9; }
.offer-card img { width:100%; height:100%; object-fit:cover; }
.offer-card-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(26,39,68,0.85) 0%,rgba(26,26,26,0.7) 100%); display:flex; flex-direction:column; justify-content:center; align-items:center; text-align:center; padding:40px; }
.offer-card-title { font-family:var(--font-serif); font-size:1.8rem; color:#fff; margin-bottom:8px; }
.offer-card-desc { color:rgba(255,255,255,0.8); font-size:0.9rem; margin-bottom:20px; max-width:300px; }

.order-grid { display:grid; grid-template-columns:1fr 340px; gap:40px; margin-top:50px; }
.order-sidebar { position:sticky; top:100px; padding:30px; border:1px solid var(--border); border-radius:var(--radius-lg); background:var(--bg-card); }
.cart-item { display:flex; justify-content:space-between; padding:14px 0; border-bottom:1px solid var(--border); }
.cart-item-name { font-size:0.88rem; }
.cart-item-price { font-weight:500; color:var(--burgundy); }
.cart-total { display:flex; justify-content:space-between; padding:16px 0; font-weight:600; font-size:1.1rem; margin-top:10px; }

.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; }
.form-group { margin-bottom:20px; }
.form-label { display:block; font-size:0.7rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px; font-weight:500; }
.form-input { width:100%; padding:14px 16px; border:1.5px solid var(--border); border-radius:var(--radius); font-size:0.95rem; color:var(--text-primary); background:var(--bg-card); font-family:var(--font-sans); outline:none; transition:border-color var(--transition); }
.form-input:focus { border-color:var(--navy); }
.form-input::placeholder { color:var(--text-muted); }
textarea.form-input { resize:vertical; min-height:120px; }
.form-input-box { width:100%; padding:14px 16px; font-size:0.95rem; border:1.5px solid var(--border); border-radius:var(--radius); background:var(--bg-card); color:var(--text-primary); font-family:var(--font-sans); transition:border-color var(--transition); outline:none; }
.form-input-box:focus { border-color:var(--navy); }
.form-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.contact-details { margin-top:40px; }
.contact-item { padding:20px 0; border-bottom:1px solid var(--border); }
.contact-label-txt { font-size:0.7rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--text-muted); margin-bottom:6px; }
.social-links { display:flex; gap:10px; }
.social-btn { width:40px; height:40px; border:1px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.7rem; color:var(--text-muted); transition:all 0.3s; }
.social-btn:hover { border-color:var(--navy); color:var(--navy); }

.blog-grid { display:grid; grid-template-columns:1fr 1fr; gap:30px; margin-top:50px; }
.blog-card { border:1px solid var(--border); border-radius:var(--radius-lg); overflow:hidden; transition:all var(--transition); background:var(--bg-card); }
.blog-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.blog-card-image { aspect-ratio:16/9; overflow:hidden; }
.blog-card-image img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s; }
.blog-card:hover .blog-card-image img { transform:scale(1.05); }
.blog-card-body { padding:28px; }
.blog-card-meta { display:flex; gap:16px; font-size:0.72rem; color:var(--text-muted); margin-bottom:12px; }
.blog-card-title { font-family:var(--font-serif); font-size:1.3rem; font-weight:400; line-height:1.4; margin-bottom:10px; }
.blog-card-title a:hover { color:var(--navy); }
.blog-card-excerpt { font-size:0.88rem; color:var(--text-muted); line-height:1.7; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.blog-read-more { display:inline-flex; align-items:center; gap:6px; font-size:0.75rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--navy); font-weight:500; margin-top:16px; }
.post-header { text-align:center; max-width:800px; margin:0 auto; }
.post-cover { border-radius:var(--radius-lg); overflow:hidden; margin:40px 0; aspect-ratio:16/9; }
.post-cover img { width:100%; height:100%; object-fit:cover; }
.post-body { max-width:760px; margin:0 auto; font-size:1.05rem; color:var(--text-secondary); line-height:1.9; }
.post-body h2 { font-family:var(--font-serif); font-size:1.6rem; font-weight:400; color:var(--text-primary); margin:40px 0 16px; }
.post-body p { margin-bottom:20px; }
.post-body blockquote { border-left:3px solid var(--navy); padding:20px 30px; margin:30px 0; font-family:var(--font-serif); font-size:1.2rem; font-style:italic; background:var(--cream); border-radius:0 var(--radius) var(--radius) 0; }
.post-tags { display:flex; gap:8px; flex-wrap:wrap; margin-top:40px; }
.post-tag { padding:6px 16px; border:1px solid var(--border); border-radius:100px; font-size:0.72rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-muted); }
.post-tag:hover { border-color:var(--navy); color:var(--navy); }

.auth-page { min-height:100vh; display:grid; grid-template-columns:1fr 1fr; }
.auth-image { background-size:cover; background-position:center; position:relative; }
.auth-image::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(26,39,68,0.5) 0%,rgba(26,26,26,0.6) 100%); }
.auth-form-wrap { display:flex; align-items:center; justify-content:center; padding:60px; }
.auth-form { width:100%; max-width:420px; }
.auth-form h1 { font-family:var(--font-serif); font-size:2.2rem; font-weight:400; margin-bottom:10px; }
.auth-form p { color:var(--text-muted); margin-bottom:40px; }
.auth-link { font-size:0.88rem; color:var(--text-muted); text-align:center; margin-top:24px; }
.auth-link a { color:var(--navy); font-weight:500; }
.social-auth { display:flex; gap:12px; margin-bottom:20px; }
.social-auth-btn { flex:1; padding:14px; border:1.5px solid var(--border); border-radius:100px; text-align:center; font-size:0.8rem; font-weight:500; color:var(--text-secondary); transition:all 0.3s; }
.social-auth-btn:hover { border-color:var(--navy); }
.auth-divider { text-align:center; margin:24px 0; font-size:0.8rem; color:var(--text-muted); position:relative; }
.auth-divider::before,.auth-divider::after { content:''; position:absolute; top:50%; width:calc(50% - 20px); height:1px; background:var(--border); }
.auth-divider::before { left:0; } .auth-divider::after { right:0; }
.checkbox-item { display:flex; align-items:center; gap:10px; font-size:0.88rem; color:var(--text-secondary); cursor:pointer; }
.checkbox-item input[type="checkbox"] { accent-color:var(--navy); }

.faq-list { max-width:800px; margin:50px auto 0; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-question { display:flex; justify-content:space-between; padding:24px 0; cursor:pointer; font-size:1.05rem; font-weight:500; }
.faq-question::after { content:'+'; font-size:1.4rem; color:var(--navy); font-weight:300; }
.faq-item.open .faq-question::after { content:'−'; }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.4s; }
.faq-item.open .faq-answer { max-height:300px; padding-bottom:24px; }
.faq-answer p { font-size:0.95rem; color:var(--text-secondary); line-height:1.8; }

.error-page { min-height:80vh; display:flex; align-items:center; justify-content:center; text-align:center; padding:40px; }
.error-code { font-family:var(--font-serif); font-size:clamp(6rem,15vw,12rem); font-weight:400; color:var(--navy-light); line-height:1; opacity:0.2; }
.error-title { font-family:var(--font-serif); font-size:1.8rem; font-weight:400; margin-top:-20px; margin-bottom:16px; }
.coming-soon-page { min-height:100vh; display:flex; align-items:center; justify-content:center; text-align:center; background:var(--cream); padding:40px; }
.countdown { display:flex; gap:24px; justify-content:center; margin:40px 0; }
.countdown-item { text-align:center; }
.countdown-num { font-family:var(--font-serif); font-size:3rem; color:var(--navy); font-weight:400; width:80px; height:80px; display:flex; align-items:center; justify-content:center; border:1.5px solid var(--border); border-radius:var(--radius-lg); background:var(--bg-card); }
.countdown-label { font-size:0.65rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--text-muted); margin-top:8px; }
.subscribe-form { display:flex; gap:10px; max-width:420px; margin:0 auto; }
.subscribe-form input { flex:1; padding:14px 20px; border:1.5px solid var(--border); border-radius:100px; font-size:0.9rem; outline:none; background:var(--bg-card); }
.subscribe-form input:focus { border-color:var(--navy); }
.map-container { width:100%; height:400px; background:var(--cream); border-radius:var(--radius-lg); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-muted); }

.footer { padding:80px 0 30px; background:var(--charcoal); color:#fff; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; margin-bottom:60px; }
.footer-logo { font-family:var(--font-serif); font-size:1.6rem; margin-bottom:16px; display:inline-block; color:#fff; }
.footer-tagline { color:rgba(255,255,255,0.5); font-size:0.88rem; line-height:1.7; }
.footer-heading { font-size:0.7rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--navy-light); margin-bottom:20px; font-weight:600; }
.footer-link { display:block; color:rgba(255,255,255,0.5); font-size:0.88rem; padding:6px 0; }
.footer-link:hover { color:var(--navy-light); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:24px; border-top:1px solid rgba(255,255,255,0.1); font-size:0.78rem; color:rgba(255,255,255,0.3); }
.footer-legal { display:flex; gap:20px; }
.footer-legal a { color:rgba(255,255,255,0.3); }
.footer-legal a:hover { color:var(--navy-light); }

.hero-slider{position:relative;height:100vh;min-height:600px;overflow:hidden}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s}.hero-slide.active{opacity:1}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-slide-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(26,26,26,0.8) 0%,transparent 60%)}
.hero-slide-content{position:relative;z-index:2;max-width:650px;padding:0 48px;height:100%;display:flex;flex-direction:column;justify-content:center}
.hero-slide-content h1{font-family:var(--font-serif);font-size:clamp(2.8rem,5vw,4.5rem);font-weight:400;color:#fff;line-height:1.1;margin-bottom:20px}
.hero-slide-content p{color:rgba(255,255,255,0.7);font-size:1.05rem;line-height:1.8;margin-bottom:30px}
.hero-dots{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:5}
.hero-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.3);cursor:pointer;transition:all 0.3s}
.hero-dot.active{background:var(--navy);transform:scale(1.3)}
.hero-arrows{position:absolute;top:50%;width:100%;display:flex;justify-content:space-between;padding:0 24px;z-index:5;transform:translateY(-50%)}
.hero-arrow{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;cursor:pointer;transition:all 0.3s;border:1px solid rgba(255,255,255,0.2)}
.hero-arrow:hover{background:rgba(255,255,255,0.3)}
.hero-search{position:absolute;bottom:60px;left:50%;transform:translateX(-50%);width:90%;max-width:900px;background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:20px 28px;display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:16px;align-items:end;z-index:5;box-shadow:var(--shadow-lg)}
.search-field label{display:block;font-size:0.65rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
.search-field select,.search-field input{width:100%;padding:10px 0;border:none;border-bottom:1.5px solid var(--border);font-size:0.9rem;color:var(--text-primary);background:transparent;font-family:var(--font-sans);outline:none;appearance:none}
.search-field select:focus,.search-field input:focus{border-color:var(--navy)}
.search-btn{padding:14px 32px;background:var(--navy);color:#fff;border-radius:100px;font-size:0.78rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;border:none;transition:all var(--transition)}
.search-btn:hover{background:var(--navy-dark)}

.reveal-up { opacity:0; transform:translateY(30px); transition:opacity 0.8s,transform 0.8s; }
.reveal-left { opacity:0; transform:translateX(-30px); transition:opacity 0.8s,transform 0.8s; }
.reveal-right { opacity:0; transform:translateX(30px); transition:opacity 0.8s,transform 0.8s; }
.revealed { opacity:1; transform:translate(0); }

@media(max-width:1024px) {
    .nav-links{display:none}.nav-toggle{display:flex}
    .featured-grid,.menu-card-grid{grid-template-columns:repeat(2,1fr)}
    .menu-grid{grid-template-columns:1fr}
    .chefs-grid,.services-grid{grid-template-columns:repeat(2,1fr)}
    .about-grid,.contact-grid,.reservation-grid,.dish-detail,.chef-detail-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:repeat(2,1fr)}
    .auth-page{grid-template-columns:1fr}.auth-image{display:none}
    .order-grid,.events-grid{grid-template-columns:1fr}
    .event-card{grid-template-columns:1fr}
    .gallery-masonry{columns:2}
    .hero-search{grid-template-columns:1fr 1fr}
}
@media(max-width:768px) {
    .featured-grid,.menu-card-grid,.chefs-grid,.services-grid,.testimonials-grid,.blog-grid,.offers-grid{grid-template-columns:1fr}
    nav{padding:16px 20px}.section{padding:80px 0}.hero-content{padding-left:24px}
    .gallery-masonry{columns:1}
    .form-grid-2{grid-template-columns:1fr}
    .nutrition-grid{grid-template-columns:repeat(2,1fr)}
    .countdown{gap:12px}.countdown-num{font-size:2rem;width:60px;height:60px}
    .hero-search{grid-template-columns:1fr;bottom:20px;width:95%}
    .hero-arrows{display:none}
}

