@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Nunito+Sans:wght@300;400;500;600;700&display=swap');
:root{--red:#C0392B;--red-dark:#9B2D22;--green:#1A5C35;--green-dark:#124026;--gold:#C8960A;--cream:#FDFAF5;--cream-2:#F6EFE3;--cream-3:#EDE3D4;--white:#FFFFFF;--brown:#2C1500;--muted:#7A5C42;--muted-lt:#A8896E;--border:rgba(44,21,0,.09);--border-2:rgba(44,21,0,.18);--radius:8px;--radius-lg:16px;--radius-pill:100px;--shadow:0 2px 20px rgba(44,21,0,.08);--shadow-lg:0 12px 48px rgba(44,21,0,.14);--transition:.25s cubic-bezier(.4,0,.2,1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scrollbar-gutter:stable}
body{background:var(--cream);color:var(--brown);font-family:'Nunito Sans',sans-serif;font-size:16px;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}
h1,h2,h3,h4{line-height:1.15}
.section-title{font-size:clamp(1.9rem,4.5vw,3rem);font-weight:700;color:var(--brown);line-height:1.12}
.section-title em{color:var(--red);font-style:italic}
.section-title span{color:var(--green)}
.label{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--green);font-weight:700;display:block;margin-bottom:.75rem}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}

.section-alt{background:var(--cream-2)}
.section-warm{background:var(--cream-3)}
.section{padding:3.5rem 0}
@media(min-width:900px){.section{padding:7rem 0}}
.text-center{text-align:center}
.divider{width:48px;height:2px;background:var(--red);border-radius:1px;margin:1.1rem auto}
.divider.left{margin-left:0}
.divider.green{background:var(--green)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.72rem 1.75rem;border-radius:var(--radius-pill);font-size:.84rem;font-weight:700;letter-spacing:.04em;transition:var(--transition);white-space:nowrap;cursor:pointer}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(192,57,43,.28)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(26,92,53,.28)}
.btn-outline{border:2px solid var(--red);color:var(--red);background:transparent}
.btn-outline:hover{background:var(--red);color:#fff}
.btn-outline-green{border:2px solid var(--green);color:var(--green);background:transparent}
.btn-outline-green:hover{background:var(--green);color:#fff}
.btn-outline-white{border:2px solid rgba(255,255,255,.55);color:#fff;background:transparent}
.btn-outline-white:hover{background:rgba(255,255,255,.15);border-color:#fff}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:#A67C08;transform:translateY(-1px)}
.btn-sm{padding:.42rem 1.1rem;font-size:.76rem}
.w-full{width:100%;justify-content:center}
/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:90px;background:rgba(253,250,245,.97);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:var(--transition);gap:1rem}
.navbar.scrolled{border-bottom-color:var(--border);box-shadow:0 1px 16px rgba(44,21,0,.07)}
.nav-logo{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.nav-logo-img{height:48px;width:auto;object-fit:contain}
.nav-logo-text{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--brown);line-height:1.1}
.nav-logo-text span{color:var(--red)}
.nav-logo-sub{font-size:.52rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:block;font-weight:600}
.nav-links{display:none}
@media(min-width:1100px){
  .nav-links{display:flex;gap:0;flex:1;justify-content:center;align-items:center}
  .nav-links a{padding:.4rem .75rem;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);transition:color var(--transition)}
  .nav-links a:hover,.nav-links a.active{color:var(--brown)}
}
.nav-actions{display:none;gap:.5rem;align-items:center;flex-shrink:0}
@media(min-width:1100px){.nav-actions{display:flex}}
.nav-order-btn{padding:.44rem 1.1rem;background:var(--red);color:#fff;border-radius:var(--radius-pill);font-size:.72rem;font-weight:700;letter-spacing:.04em;transition:var(--transition);white-space:nowrap}
.nav-order-btn:hover{background:var(--red-dark)}
.nav-reserve-btn{padding:.44rem 1.1rem;border:2px solid var(--green);color:var(--green);border-radius:var(--radius-pill);font-size:.72rem;font-weight:700;letter-spacing:.04em;transition:var(--transition);white-space:nowrap}
.nav-reserve-btn:hover{background:var(--green);color:#fff}
.nav-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:7px;flex-shrink:0}
.nav-toggle span{display:block;height:1.5px;background:var(--brown);border-radius:1px;transition:var(--transition);transform-origin:center}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
@media(min-width:1100px){.nav-toggle{display:none}}
.nav-overlay{display:none;position:fixed;inset:0;z-index:1001;background:rgba(44,21,0,.45);opacity:0;transition:opacity var(--transition)}
.nav-overlay.show{display:block;opacity:1}
.nav-drawer{position:fixed;top:0;right:0;bottom:0;z-index:1002;width:min(82vw,300px);background:var(--white);border-left:1px solid var(--border);padding:5rem 1.75rem 2.5rem;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);overflow-y:auto}
.nav-drawer.open{transform:translateX(0)}
.drawer-close{position:absolute;top:1.1rem;right:1.25rem;font-size:1rem;color:var(--muted);padding:.4rem}
.drawer-links{display:flex;flex-direction:column;gap:.05rem;flex:1}
.drawer-links a{padding:.9rem 0;border-bottom:1px solid var(--border);color:var(--muted);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;transition:color var(--transition),padding-left var(--transition)}
.drawer-links a:hover{color:var(--red);padding-left:.4rem}
.drawer-actions{display:flex;flex-direction:column;gap:.65rem;margin-top:2rem}
/* Hide old cart FAB globally — replaced by header cart icon */
.cart-fab{display:none!important}
/* HERO */
.hero{display:grid;grid-template-columns:1fr;padding-top:90px;min-height:100svh;background:var(--cream);overflow:hidden}
@media(min-width:960px){.hero{grid-template-columns:52% 48%}}
.hero-visual{position:relative;overflow:hidden;background:linear-gradient(150deg,var(--green-dark) 0%,var(--green) 55%,#1f7044 100%);min-height:56vw}
@media(min-width:960px){.hero-visual{min-height:calc(100svh - 70px)}}
.hero-pattern{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:32px 32px}
.hero-overlay{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 30%,rgba(18,64,38,.55) 100%)}
.hero-visual-content{position:absolute;left:2rem;top:50%;transform:translateY(-30%);z-index:3}
.hero-tagline{font-family:'Playfair Display',serif;font-size:clamp(2rem,5.5vw,3.6rem);color:#fff;line-height:1.05;font-weight:700;text-shadow:0 2px 24px rgba(0,0,0,.3)}
.hero-tagline em{color:var(--gold);font-style:italic;display:block}
.hero-tagline-sub{font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,.65);font-weight:600;margin-top:.85rem}
.hero-badge{position:absolute;top:2rem;right:2rem;z-index:3;background:var(--gold);color:#fff;border-radius:50%;width:80px;height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(0,0,0,.2);font-family:'Playfair Display',serif}
.hero-badge-num{font-size:1.4rem;font-weight:700;line-height:1}
.hero-badge-text{font-size:.42rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;text-align:center;line-height:1.3;margin-top:.15rem}
.hero-bottom-bar{position:absolute;bottom:0;left:0;right:0;z-index:4;background:var(--red);padding:.8rem 2rem;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.hbb-item{display:flex;align-items:center;gap:.5rem}
.hbb-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.4);flex-shrink:0}
.hbb-text{font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff}
.hbb-sep{width:1px;height:18px;background:rgba(255,255,255,.22)}
.hero-content{display:flex;flex-direction:column;justify-content:center;padding:3.5rem 1.5rem 3rem;background:var(--cream)}
@media(min-width:960px){.hero-content{padding:5rem 4rem 5rem 3.5rem}}
.hero-eyebrow{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--green);font-weight:700;margin-bottom:1.25rem;display:flex;align-items:center;gap:.6rem}
.hero-eyebrow::before{content:'';width:28px;height:1.5px;background:var(--green)}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,6vw,3.8rem);font-weight:700;line-height:1.06;color:var(--brown);margin-bottom:1.25rem}
.hero-title em{color:var(--red);font-style:italic;display:block}
.hero-sub{color:var(--muted);font-size:.94rem;line-height:1.85;max-width:420px;margin-bottom:2rem}
.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem;align-items:center}
.hero-stats{display:flex;gap:2rem;flex-wrap:wrap;border-top:1px solid var(--border);padding-top:1.75rem}
.stat-num{font-family:'Playfair Display',serif;font-size:1.75rem;color:var(--red);line-height:1}
.stat-label{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:.25rem;font-weight:700}
/* ORDER STRIP */
.order-strip{background:var(--brown);padding:.95rem 1.5rem}
.order-strip-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:1.75rem;flex-wrap:wrap}
.os-item{display:flex;align-items:center;gap:.55rem;color:rgba(253,250,245,.6);font-size:.74rem;font-weight:600;letter-spacing:.03em}
.os-item strong{color:var(--gold);font-weight:700}
.os-sep{color:rgba(253,250,245,.15)}
/* MARQUEE */
.marquee-wrap{overflow:hidden;background:var(--red);padding:.7rem 0}
.marquee-track{display:flex;animation:marqueeScroll 42s linear infinite;width:max-content}
.marquee-track:hover{animation-play-state:paused}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee-item{display:inline-flex;align-items:center;gap:.65rem;padding:0 1.5rem;white-space:nowrap;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.8);font-weight:700}
.marquee-dot{width:3px;height:3px;background:rgba(255,255,255,.4);border-radius:50%;flex-shrink:0}
/* ORDER CARDS */
.order-cards{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-top:3rem}
@media(min-width:640px){.order-cards{grid-template-columns:repeat(3,1fr)}}
.order-card{border-radius:var(--radius-lg);border:1.5px solid var(--border);background:var(--white);padding:2.25rem 1.75rem;text-align:center;transition:var(--transition)}
.order-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-2)}
.order-card-label{display:inline-block;padding:.32rem .9rem;border-radius:var(--radius);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin:0 auto 1.25rem}
.order-card-label.red{background:rgba(192,57,43,.09);color:var(--red);border:1.5px solid rgba(192,57,43,.15)}
.order-card-label.green{background:rgba(26,92,53,.09);color:var(--green);border:1.5px solid rgba(26,92,53,.15)}
.order-card-label.gold{background:rgba(200,150,10,.09);color:var(--gold);border:1.5px solid rgba(200,150,10,.18)}
.order-card h3{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--brown);margin-bottom:.55rem;font-weight:700}
.order-card p{font-size:.82rem;color:var(--muted);line-height:1.72;margin-bottom:1.4rem}
/* MENU */
.menu-filters{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:2.25rem}
.menu-filter{padding:.38rem 1.1rem;border-radius:var(--radius-pill);font-size:.7rem;font-weight:700;letter-spacing:.05em;border:1.5px solid var(--border);color:var(--muted);transition:var(--transition);cursor:pointer;background:none}
.menu-filter:hover{border-color:var(--red);color:var(--red)}
.menu-filter.active{background:var(--red);color:#fff;border-color:var(--red)}
.menu-grid{display:grid;grid-template-columns:1fr;gap:.85rem}
@media(min-width:640px){.menu-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.menu-grid{grid-template-columns:repeat(3,1fr)}}
.menu-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition)}
.menu-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--border-2)}
.menu-card-body{padding:1.1rem 1.25rem}
.menu-card-cat{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green);font-weight:700;margin-bottom:.32rem}
.menu-card-name{font-family:'Playfair Display',serif;font-size:.98rem;color:var(--brown);margin-bottom:.32rem;font-weight:600}
.menu-card-desc{font-size:.76rem;color:var(--muted);line-height:1.65;margin-bottom:.8rem}
.menu-card-footer{display:flex;align-items:center;justify-content:space-between}
.menu-card-price{font-family:'Playfair Display',serif;font-size:1rem;color:var(--red);font-weight:700}
.menu-card-add{width:28px;height:28px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;border:none;cursor:pointer;transition:var(--transition)}
.menu-card-add:hover{background:var(--red-dark);transform:scale(1.1)}
.menu-badge{display:inline-block;padding:.16rem .55rem;border-radius:var(--radius-pill);font-size:.56rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.55rem}
.badge-veg{background:rgba(26,92,53,.1);color:var(--green)}
.badge-spicy{background:rgba(192,57,43,.1);color:var(--red)}
.badge-popular{background:rgba(200,150,10,.12);color:#7A5500}
.menu-section-title{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--brown);font-weight:700;padding-bottom:.6rem;border-bottom:1.5px solid var(--border);margin-bottom:1.25rem}
/* LOCATIONS */
.locations-grid{display:grid;grid-template-columns:1fr;gap:1.1rem;margin-top:3rem}
@media(min-width:640px){.locations-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.locations-grid{grid-template-columns:repeat(3,1fr)}}
.location-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;transition:var(--transition)}
.location-card:hover{border-color:var(--green);box-shadow:0 6px 28px rgba(26,92,53,.1);transform:translateY(-2px)}
.location-num{display:inline-block;width:28px;height:28px;border-radius:50%;background:var(--green);color:#fff;text-align:center;line-height:28px;font-size:.68rem;font-weight:700;margin-bottom:.9rem}
.location-name{font-family:'Playfair Display',serif;font-size:1.02rem;color:var(--brown);margin-bottom:.55rem;font-weight:700}
.location-info{font-size:.78rem;color:var(--muted);line-height:1.85}
.location-info strong{color:var(--brown);font-weight:600;display:block}
.location-phone{font-size:.8rem;color:var(--green);font-weight:700;margin-top:.45rem;display:block}
.location-actions{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:1rem}
.location-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.64rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.34rem .85rem;border-radius:var(--radius-pill);border:1.5px solid var(--border-2);color:var(--muted);transition:var(--transition)}
.location-link:hover{border-color:var(--green);color:var(--green)}
.location-link.primary{background:var(--green);color:#fff;border-color:var(--green)}
.location-link.primary:hover{background:var(--green-dark)}
/* STORY */
.story-grid{display:grid;grid-template-columns:1fr;gap:3.5rem;align-items:center}
@media(min-width:900px){.story-grid{grid-template-columns:1fr 1fr}}
.story-visual{background:linear-gradient(140deg,var(--green-dark),var(--green));border-radius:var(--radius-lg);aspect-ratio:4/3;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.story-visual::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(18,64,38,.5) 100%)}
.story-stats{position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;z-index:2;background:rgba(253,250,245,.96);backdrop-filter:blur(8px);border-radius:var(--radius);padding:.85rem 1rem;display:flex;gap:1.25rem}
.story-stat-num{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--red);font-weight:700;line-height:1}
.story-stat-label{font-size:.54rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.2rem;font-weight:700}
.story-content{display:flex;flex-direction:column;gap:1.1rem}
.story-content p{font-size:.9rem;color:var(--muted);line-height:1.85}
/* TESTIMONIALS */
.t-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:2.5rem}
@media(min-width:640px){.t-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.t-grid{grid-template-columns:repeat(3,1fr)}}
.t-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;transition:var(--transition)}
.t-card:hover{border-color:var(--border-2);box-shadow:var(--shadow)}
.t-stars{color:var(--gold);font-size:.85rem;letter-spacing:.08em;margin-bottom:.75rem}
.t-text{font-size:.82rem;color:var(--muted);line-height:1.8;margin-bottom:1rem;font-style:italic}
.t-author{font-weight:700;font-size:.84rem;color:var(--brown)}
.t-loc{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-lt);margin-top:.2rem;font-weight:600}
/* CTA */
.cta-section{background:linear-gradient(140deg,var(--green-dark) 0%,var(--green) 100%);padding:5rem 1.5rem;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px}
.cta-section .label{color:rgba(255,255,255,.5)}
.cta-section .section-title{color:#fff}
.cta-section .section-title em{color:var(--gold)}
.cta-section .divider{background:rgba(255,255,255,.28)}
.cta-section p{color:rgba(255,255,255,.68);margin:1rem auto 2.25rem;max-width:460px;font-size:.9rem;line-height:1.82}
/* FOOTER */
.footer{padding:4rem 0 2rem;background:var(--brown)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;margin-bottom:2.75rem}
@media(min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-logo-img{height:42px;width:auto;object-fit:contain;margin-bottom:.85rem;filter:brightness(0) invert(1) !important;-webkit-filter:brightness(0) invert(1) !important}
.footer-brand{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--cream);margin-bottom:.3rem;font-weight:700}
.footer-brand span{color:var(--gold)}
.footer-desc{font-size:.78rem;color:rgba(253,250,245,.42);line-height:1.85;margin-bottom:1.35rem;max-width:240px}
.footer-socials{display:flex;gap:.5rem}
.social-btn{width:36px;height:36px;border-radius:50%;border:1px solid rgba(253,250,245,.16);display:flex;align-items:center;justify-content:center;color:rgba(253,250,245,.7);transition:var(--transition);text-decoration:none;flex-shrink:0}
.social-btn:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-2px)}
.social-btn svg{display:block;width:16px;height:16px}
.footer-col-title{font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(253,250,245,.28);margin-bottom:.95rem;font-weight:700}
.footer-links{display:flex;flex-direction:column;gap:.48rem}
.footer-links a{font-size:.78rem;color:rgba(253,250,245,.45);transition:color var(--transition)}
.footer-links a:hover{color:var(--cream)}
.footer-links span{font-size:.75rem;color:rgba(253,250,245,.32)}
.footer-bottom{padding-top:1.5rem;border-top:1px solid rgba(253,250,245,.08);display:flex;flex-direction:column;gap:.4rem}
@media(min-width:640px){.footer-bottom{flex-direction:row;justify-content:space-between;align-items:center}}
.footer-copy{font-size:.68rem;color:rgba(253,250,245,.22)}
.footer-copy a{color:rgba(253,250,245,.32);transition:color var(--transition)}
/* FORMS */
.form-group{margin-bottom:1rem}
.form-label{display:block;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.42rem;font-weight:700}
.form-control{width:100%;padding:.74rem 1rem;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--brown);font-size:16px;outline:none;transition:border-color var(--transition)}
.form-control:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(192,57,43,.08)}
.form-control::placeholder{color:var(--muted-lt)}
.form-row{display:grid;grid-template-columns:1fr;gap:1rem}
@media(min-width:600px){.form-row{grid-template-columns:1fr 1fr}}
textarea.form-control{resize:vertical;min-height:120px}
.alert{padding:.88rem 1.1rem;border-radius:var(--radius);font-size:.84rem;margin-bottom:1rem;line-height:1.65}
.alert-success{background:rgba(26,92,53,.08);border:1.5px solid rgba(26,92,53,.24);color:var(--green-dark)}
.alert-danger{background:rgba(192,57,43,.08);border:1.5px solid rgba(192,57,43,.24);color:var(--red-dark)}
/* REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}
/* PAGE HERO */
.page-hero{padding:calc(90px + 3rem) 1.5rem 4rem;text-align:center;background:var(--cream-2);border-bottom:1px solid var(--border)}
.page-hero .section-title{margin:.4rem 0 .9rem}
.page-hero p{color:var(--muted);max-width:500px;margin:0 auto;font-size:.9rem;line-height:1.8}
/* CART */
.cart-overlay{display:none;position:fixed;inset:0;z-index:1999;background:rgba(44,21,0,.38);opacity:0;transition:opacity var(--transition)}
.cart-overlay.show{display:block;opacity:1}
.cart-sidebar{position:fixed;top:0;right:0;bottom:0;z-index:2000;width:min(92vw,380px);background:var(--white);border-left:1px solid var(--border);transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.cart-sidebar.open{transform:translateX(0)}
.cart-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border-bottom:1px solid var(--border)}
.cart-header h3{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--brown)}
.cart-body{flex:1;overflow-y:auto;padding:1.1rem 1.4rem}
.cart-empty{text-align:center;padding:3rem 1rem;color:var(--muted);font-size:.84rem}
.cart-item{padding:.85rem 0;border-bottom:1px solid var(--border)}
.cart-item-name{font-weight:700;font-size:.84rem;color:var(--brown);margin-bottom:.2rem}
.cart-item-price{font-size:.8rem;color:var(--red);font-weight:600}
.cart-item-qty{display:flex;align-items:center;gap:.45rem;margin-top:.42rem}
.qty-btn{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border-2);display:flex;align-items:center;justify-content:center;font-size:.82rem;color:var(--brown);cursor:pointer;transition:var(--transition);background:none}
.qty-btn:hover{border-color:var(--red);color:var(--red)}
.qty-num{font-size:.82rem;font-weight:700;color:var(--brown);min-width:18px;text-align:center}
.cart-footer{padding:1.1rem 1.4rem;border-top:1px solid var(--border);background:var(--cream)}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.cart-total-label{font-size:.88rem;font-weight:700;color:var(--brown)}
.cart-total-num{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--red);font-weight:700}
.cart-fab{position:fixed;bottom:1.75rem;right:1.75rem;z-index:999;background:var(--red);color:#fff;border:none;cursor:pointer;width:52px;height:52px;border-radius:50%;display:none;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 6px 20px rgba(192,57,43,.35);transition:var(--transition)}
.cart-fab:hover{background:var(--red-dark);transform:scale(1.06)}
.cart-fab-count{position:absolute;top:-4px;right:-4px;background:var(--green);color:#fff;width:20px;height:20px;border-radius:50%;font-size:.58rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff}
/* ORDER PAGE */
.order-layout{display:grid;grid-template-columns:1fr;gap:2rem}
@media(min-width:900px){.order-layout{grid-template-columns:1fr 340px}}
.order-type-btn{display:flex;align-items:center;gap:.85rem;padding:.95rem 1.2rem;border-radius:var(--radius);border:2px solid var(--border);background:var(--white);cursor:pointer;transition:var(--transition);width:100%;text-align:left;font-family:inherit}
.order-type-btn.active{border-color:var(--red);background:rgba(192,57,43,.04)}
.order-type-btn:hover{border-color:var(--red)}
@media(max-width:999px){.navbar{height:74px;padding:0 1.1rem}.nav-logo-img{height:46px}.hero{padding-top:74px}input:focus,select:focus,textarea:focus{font-size:16px!important}.form-control{font-size:16px!important}}
@media(max-width:600px){
  /* Prevent ALL two-column form grids from overflowing on mobile */
  .form-row,.gc-form-2col,[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  /* Prevent input zoom and overflow */
  input,select,textarea{font-size:16px!important;max-width:100%;box-sizing:border-box}
  /* Prevent horizontal scroll */
  body{overflow-x:hidden}
  .container{padding-left:1rem!important;padding-right:1rem!important}
  /* Fix gift card layout */
  .gc-layout{grid-template-columns:1fr!important}
  .gc-preview{position:static!important}
}

/* ── FOOD SHOWCASE (Hero rotating panel) ─────────────── */
.food-showcase{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  flex-direction:column;padding:2rem 1.5rem 5rem;overflow:hidden;
}
.food-slide{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:2rem 1.5rem 5rem;
  opacity:0;transform:translateX(60px) scale(.97);
  transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.food-slide.active{
  opacity:1;transform:translateX(0) scale(1);pointer-events:auto;
}
.food-slide.exit{
  opacity:0;transform:translateX(-60px) scale(.97);
}

/* Plate / image area */
.food-slide-img-wrap{
  width:min(280px,65vw);height:min(280px,65vw);
  position:relative;margin-bottom:1.75rem;flex-shrink:0;
}
.food-slide-ph{
  width:100%;height:100%;border-radius:50%;
  background:rgba(255,255,255,.07);
  border:2px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  animation:plateFloat 4s ease-in-out infinite;
}
@keyframes plateFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
.food-slide-ph::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.12),transparent 60%);
}
.food-slide-ph-inner{
  width:75%;height:75%;border-radius:50%;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.food-plate-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid rgba(255,255,255,.15);
  animation:ringPulse 2.5s ease-in-out infinite;
}
@keyframes ringPulse{
  0%,100%{transform:scale(1);opacity:.5}
  50%{transform:scale(1.04);opacity:1}
}
.food-plate-center{
  width:40%;height:40%;border-radius:50%;
  background:rgba(255,255,255,.1);
  border:1.5px solid rgba(255,255,255,.2);
}
/* Real food image — added by admin */
.food-slide-img{
  width:100%;height:100%;object-fit:cover;border-radius:50%;
  display:block;
  animation:plateFloat 4s ease-in-out infinite;
}

/* Text label */
.food-slide-label{text-align:center}
.food-slide-cat{
  display:inline-block;
  font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:700;color:var(--gold);margin-bottom:.5rem;
}
.food-slide-name{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.6rem,5vw,2.4rem);font-weight:700;
  color:#fff;line-height:1.1;margin-bottom:.5rem;
  text-shadow:0 2px 16px rgba(0,0,0,.25);
}
.food-slide-desc{
  font-size:.76rem;color:rgba(255,255,255,.62);
  font-weight:500;letter-spacing:.02em;
}

/* Dots */
.food-dots{
  position:absolute;bottom:4.5rem;left:50%;transform:translateX(-50%);
  display:flex;gap:.45rem;z-index:5;
}
.food-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,.3);border:none;cursor:pointer;
  transition:all .3s ease;padding:0;
}
.food-dot.active{background:#fff;width:20px;border-radius:3px;}

/* Arrows */
.food-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(255,255,255,.12);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;z-index:5;
}
.food-arrow:hover{background:rgba(255,255,255,.22)}
.food-arrow-l{left:1rem}
.food-arrow-r{right:1rem}

/* ── CART PANEL ITEMS (order.php) ─────────────────── */
.c-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;border-bottom:1px solid #F5F0EA;background:#fff}
.c-item:last-child{border-bottom:none}
.c-item-info{flex:1;min-width:0}
.c-name{font-size:.85rem;font-weight:700;color:#2C1500;line-height:1.3;margin-bottom:.18rem}
.c-spice{display:inline-flex;align-items:center;gap:.3rem;font-size:.65rem;font-weight:600;margin-bottom:.2rem}
.c-spice-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.c-note{font-size:.63rem;color:#B5A898;font-style:italic;margin-bottom:.2rem}
.c-controls{display:flex;align-items:center;gap:.5rem;margin-top:.4rem}
.cqb{width:44px;height:44px;border-radius:12px;border:1.5px solid #EDE8DF;background:#FAF7F2;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#2C1500;transition:.15s;-webkit-tap-highlight-color:transparent;flex-shrink:0;touch-action:manipulation;font-weight:400}
.cqb:hover,.cqb:active{border-color:#C0392B;color:#C0392B;background:#FEF5F4}
.cqn{font-size:1rem;font-weight:700;color:#2C1500;min-width:28px;text-align:center}
.c-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;flex-shrink:0}
.c-price{font-size:.92rem;font-weight:700;color:#2C1500;white-space:nowrap;font-family:'Playfair Display',serif}
.c-remove{width:32px;height:32px;border-radius:8px;border:1.5px solid #EDE8DF;background:#FAF7F2;cursor:pointer;color:#C4BAB0;display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:.15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;flex-shrink:0}
.c-remove:hover,.c-remove:active{background:#FEF5F4;color:#C0392B;border-color:#C0392B}

/* ── CART PANEL ITEMS (order.php) ─────────────────── */
.c-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;border-bottom:1px solid #F5F0EA;background:#fff}
.c-item:last-child{border-bottom:none}
.c-item-info{flex:1;min-width:0}
.c-name{font-size:.85rem;font-weight:700;color:#2C1500;line-height:1.3;margin-bottom:.18rem}
.c-spice{display:inline-flex;align-items:center;gap:.3rem;font-size:.65rem;font-weight:600;margin-bottom:.2rem}
.c-spice-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.c-note{font-size:.63rem;color:#B5A898;font-style:italic;margin-bottom:.2rem}
.c-controls{display:flex;align-items:center;gap:.5rem;margin-top:.4rem}
.cqb{width:44px;height:44px;border-radius:12px;border:1.5px solid #EDE8DF;background:#FAF7F2;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#2C1500;transition:.15s;-webkit-tap-highlight-color:transparent;flex-shrink:0;touch-action:manipulation;font-weight:400}
.cqb:hover,.cqb:active{border-color:#C0392B;color:#C0392B;background:#FEF5F4}
.cqn{font-size:1rem;font-weight:700;color:#2C1500;min-width:28px;text-align:center}
.c-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;flex-shrink:0}
.c-price{font-size:.92rem;font-weight:700;color:#2C1500;white-space:nowrap;font-family:'Playfair Display',serif}
.c-remove{width:32px;height:32px;border-radius:8px;border:1.5px solid #EDE8DF;background:#FAF7F2;cursor:pointer;color:#C4BAB0;display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:.15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;flex-shrink:0}
.c-remove:hover,.c-remove:active{background:#FEF5F4;color:#C0392B;border-color:#C0392B}
