/* ============ TOKENS ============ */
:root{
  --navy-900:#0a1430;
  --navy-850:#0c1838;
  --navy-800:#10204a;
  --navy-700:#16285c;
  --navy-600:#1d3373;
  --gold-600:#b78a4a;
  --gold-500:#cda05e;
  --gold-300:#e8cf9c;
  --gold-100:#f6ead0;
  --cream-50:#f9f5ec;
  --cream-100:#f1e9d8;
  --ink-900:#1b160f;
  --ember-600:#a8431f;
  --ember-500:#c1502f;
  --ember-400:#d9703f;
  --veg:#2e8b4f;
  --nonveg:#a8431f;
  --shadow-lg:0 30px 60px -20px rgba(0,0,0,.45);
  --shadow-md:0 14px 30px -12px rgba(0,0,0,.35);
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1180px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--navy-900);
  color:var(--cream-100);
  font-family:'Jost',sans-serif;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{
  font-family:'Marcellus',serif;
  margin:0;
  font-weight:400;
  letter-spacing:.01em;
}
.italic-serif{font-family:'Cormorant Garamond',serif;font-style:italic;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
::selection{background:var(--gold-500);color:var(--navy-900);}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.eyebrow{
  font-family:'Jost',sans-serif;
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:12px;
  color:var(--gold-500);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{content:'';width:22px;height:1px;background:var(--gold-500);display:inline-block;}
.section-title{
  font-size:clamp(30px,5vw,48px);
  color:var(--cream-50);
  margin:10px 0 0;
  line-height:1.1;
}
.section-title em{color:var(--gold-500);font-style:normal;}
.gold-rule{
  width:0;
  height:2px;
  background:linear-gradient(90deg,var(--gold-600),var(--gold-300));
  margin-top:18px;
  transition:width 1s var(--ease);
}
.in-view .gold-rule{width:76px;}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.in-view.reveal{opacity:1;transform:none;}
.reveal-stagger > *{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.in-view.reveal-stagger > *{opacity:1;transform:none;}
.in-view.reveal-stagger > *:nth-child(1){transition-delay:.05s;}
.in-view.reveal-stagger > *:nth-child(2){transition-delay:.15s;}
.in-view.reveal-stagger > *:nth-child(3){transition-delay:.25s;}
.in-view.reveal-stagger > *:nth-child(4){transition-delay:.35s;}
.in-view.reveal-stagger > *:nth-child(5){transition-delay:.45s;}
.in-view.reveal-stagger > *:nth-child(6){transition-delay:.55s;}
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal-stagger > *{opacity:1!important;transform:none!important;}
  *{animation-duration:.001s !important; transition-duration:.1s !important;}
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 30px;border-radius:2px;font-size:14px;letter-spacing:.12em;
  text-transform:uppercase;font-weight:500;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s;
  position:relative;overflow:hidden;
}
.btn-gold{background:linear-gradient(135deg,var(--gold-300),var(--gold-600));color:var(--navy-900);box-shadow:var(--shadow-md);}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 20px 34px -14px rgba(205,160,94,.55);}
.btn-gold::before,.btn-ember::before{
  content:'';position:absolute;top:0;bottom:0;left:-60%;width:40%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-20deg);animation:shimmerSweep 4.2s ease-in-out infinite;pointer-events:none;
}
@keyframes shimmerSweep{0%{left:-60%;}35%{left:130%;}100%{left:130%;}}
.btn-outline{border:1px solid rgba(232,207,156,.5);color:var(--gold-100);}
.btn-outline:hover{background:rgba(232,207,156,.08);transform:translateY(-3px);}
.btn-ember{background:linear-gradient(135deg,var(--ember-400),var(--ember-600));color:#fff8f0;box-shadow:0 14px 26px -12px rgba(168,67,31,.6);}
.btn-ember:hover{transform:translateY(-3px);box-shadow:0 18px 30px -10px rgba(168,67,31,.7);}
.btn-sm{padding:9px 16px;font-size:12px;}
.btn:active{transform:translateY(0) scale(.97);}

/* ============ PRELOADER ============ */
#preloader{position:fixed;inset:0;background:var(--navy-900);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease, visibility .6s ease;}
#preloader.done{opacity:0;visibility:hidden;pointer-events:none;}
.pre-mark{width:64px;height:64px;position:relative;}
.pre-mark svg{width:100%;height:100%;}

/* ============ FLAME MARK (signature) ============ */
.flame-mark{position:relative;display:inline-block;}
.steam path{transform-origin:bottom center;animation:steamFlicker 2.6s ease-in-out infinite;}
.steam path:nth-child(2){animation-delay:.3s;}
.steam path:nth-child(3){animation-delay:.6s;}
@keyframes steamFlicker{
  0%,100%{opacity:.35;transform:translateY(0) scaleY(1);}
  50%{opacity:1;transform:translateY(-3px) scaleY(1.12);}
}

/* ============ NAV ============ */
header{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 28px;
  transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .4s;
  background:linear-gradient(180deg,rgba(10,20,48,.85),rgba(10,20,48,0));
}
header.solid{background:rgba(10,20,48,.96);backdrop-filter:blur(10px);box-shadow:0 8px 24px -16px rgba(0,0,0,.6);padding:10px 28px;border-bottom:1px solid rgba(205,160,94,.15);}
.brand{display:flex;align-items:center;gap:10px;}
.brand img{height:40px;width:40px;border-radius:50%;object-fit:cover;border:1px solid rgba(205,160,94,.4);}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-text b{font-family:'Marcellus',serif;font-size:21px;color:var(--cream-50);letter-spacing:.02em;}
.brand-text span{font-size:8.5px;letter-spacing:.32em;color:var(--gold-500);text-transform:uppercase;margin-top:3px;}
nav.primary-nav{display:flex;gap:34px;align-items:center;}
nav.primary-nav a{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--cream-100);position:relative;padding:6px 0;transition:color .3s;}
nav.primary-nav a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold-500);transition:width .35s var(--ease);}
nav.primary-nav a:hover,nav.primary-nav a.active{color:var(--gold-300);}
nav.primary-nav a:hover::after,nav.primary-nav a.active::after{width:100%;}
.nav-actions{display:flex;align-items:center;gap:18px;}
.icon-btn{position:relative;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(232,207,156,.3);border-radius:50%;transition:border-color .3s,transform .3s;}
.icon-btn:hover{border-color:var(--gold-500);transform:translateY(-2px);}
.icon-btn svg{width:17px;height:17px;stroke:var(--cream-50);}
.cart-badge{position:absolute;top:-6px;right:-6px;background:var(--ember-500);color:#fff;font-size:10px;font-weight:600;min-width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 2px;transform:scale(0);transition:transform .35s var(--ease);}
.cart-badge.show{transform:scale(1);}
.cart-badge.bump{animation:bump .4s var(--ease);}
@keyframes bump{0%{transform:scale(1);}40%{transform:scale(1.45);}100%{transform:scale(1);}}
.user-chip{font-size:12px;color:var(--gold-200);border:1px solid rgba(232,207,156,.3);padding:7px 14px;border-radius:20px;display:flex;align-items:center;gap:8px;}
.burger{display:none;width:38px;height:38px;border:1px solid rgba(232,207,156,.3);border-radius:50%;position:relative;}
.burger span{position:absolute;left:9px;right:9px;height:1.5px;background:var(--cream-50);transition:transform .3s,opacity .3s;}
.burger span:nth-child(1){top:13px;}
.burger span:nth-child(2){top:18.5px;}
.burger span:nth-child(3){top:24px;}
.burger.open span:nth-child(1){transform:translateY(5.5px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg);}

.mobile-nav{position:fixed;top:0;right:0;width:78%;max-width:340px;height:100%;background:var(--navy-850);z-index:600;transform:translateX(100%);transition:transform .45s var(--ease);box-shadow:-20px 0 50px rgba(0,0,0,.5);padding:90px 32px 32px;display:flex;flex-direction:column;gap:26px;border-left:1px solid rgba(205,160,94,.2);}
.mobile-nav.open{transform:translateX(0);}
.mobile-nav a{font-family:'Marcellus',serif;font-size:22px;color:var(--cream-50);}
.scrim{position:fixed;inset:0;background:rgba(5,9,22,.6);backdrop-filter:blur(2px);z-index:550;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;}
.scrim.show{opacity:1;visibility:visible;}

/* ============ PAGES ============ */
.page{display:none;}
.page.active{display:block;animation:pageIn .6s var(--ease);}
@keyframes pageIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;
  background:linear-gradient(180deg,rgba(8,15,36,.55),rgba(8,15,36,.88) 70%,var(--navy-900)),url('images/hero.jpg') center 30%/cover no-repeat;
}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(205,160,94,.16),transparent 55%);}
.hero-inner{position:relative;z-index:2;max-width:780px;padding:0 24px;display:flex;flex-direction:column;align-items:center;}
.hero-mark{width:74px;height:74px;margin-bottom:18px;opacity:0;animation:fadeUp 1s var(--ease) .15s forwards, heroFloat 5s ease-in-out 1.2s infinite;}
@keyframes heroFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
.hero .eyebrow{opacity:0;animation:fadeUp 1s var(--ease) .3s forwards;}
.hero h1{font-size:clamp(44px,8vw,86px);color:var(--cream-50);margin-top:16px;line-height:1.04;opacity:0;animation:fadeUp 1s var(--ease) .45s forwards;}
.hero h1 em{font-style:italic;font-family:'Cormorant Garamond',serif;color:var(--gold-300);}
.hero p.sub{font-family:'Cormorant Garamond',serif;font-size:clamp(17px,2.4vw,22px);color:var(--cream-100);margin-top:18px;max-width:560px;line-height:1.55;opacity:0;animation:fadeUp 1s var(--ease) .6s forwards;}
.hero-ctas{display:flex;gap:16px;margin-top:34px;flex-wrap:wrap;justify-content:center;opacity:0;animation:fadeUp 1s var(--ease) .75s forwards;}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:none;}}
.scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.7;z-index:2;}
.scroll-cue span{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-300);}
.scroll-line{width:1px;height:34px;background:linear-gradient(180deg,var(--gold-300),transparent);overflow:hidden;position:relative;}
.scroll-line::after{content:'';position:absolute;width:100%;height:10px;background:var(--gold-100);top:-10px;animation:dropline 2.2s ease-in-out infinite;}
@keyframes dropline{0%{top:-10px;}100%{top:34px;}}

/* ============ MARQUEE ============ */
.marquee-strip{background:var(--gold-500);overflow:hidden;padding:13px 0;position:relative;}
.marquee-track{display:flex;white-space:nowrap;animation:marquee 28s linear infinite;}
.marquee-track span{font-family:'Marcellus',serif;font-size:15px;color:var(--navy-900);letter-spacing:.05em;padding:0 22px;display:flex;align-items:center;gap:22px;}
.marquee-track span::after{content:'✦';font-size:10px;color:var(--ember-600);}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ============ GENERIC SECTION ============ */
section{padding:96px 0;position:relative;}
.section-head{text-align:center;max-width:640px;margin:0 auto 56px;}
.section-head.left{text-align:left;margin:0 0 48px;}
.section-head .gold-rule{margin-left:auto;margin-right:auto;}
.section-head.left .gold-rule{margin-left:0;}

/* feature cards */
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.feature-card{background:linear-gradient(160deg,var(--navy-800),var(--navy-850));border:1px solid rgba(205,160,94,.16);border-radius:6px;padding:30px 24px;transition:transform .4s var(--ease),border-color .4s;}
.feature-card:hover{transform:translateY(-8px);border-color:rgba(205,160,94,.5);}
.feature-card .ico{width:42px;height:42px;margin-bottom:18px;stroke:var(--gold-400);}
.feature-card h4{font-size:19px;color:var(--cream-50);margin-bottom:8px;}
.feature-card p{font-size:13.5px;color:var(--cream-100);opacity:.8;line-height:1.6;margin:0;}

/* favourites */
.fav-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.fav-card{position:relative;border-radius:8px;overflow:hidden;height:360px;cursor:pointer;box-shadow:var(--shadow-md);}
.fav-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);animation:ambientZoom 14s ease-in-out infinite alternate;}
.fav-card:hover img{transform:scale(1.08);animation-play-state:paused;}
@keyframes ambientZoom{0%{transform:scale(1);}100%{transform:scale(1.07);}}
.fav-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(7,12,28,.92));display:flex;flex-direction:column;justify-content:flex-end;padding:24px;}
.fav-overlay span.tag{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-300);}
.fav-overlay h4{font-size:23px;color:#fff;margin-top:6px;}
.fav-overlay p{font-family:'Cormorant Garamond',serif;font-size:14px;color:var(--cream-100);margin-top:6px;opacity:.85;}

/* stats */
.stats-row{display:flex;justify-content:center;gap:60px;flex-wrap:wrap;margin-top:10px;}
.stat{text-align:center;}
.stat b{font-family:'Marcellus',serif;font-size:38px;color:var(--gold-300);display:block;}
.stat span{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-100);opacity:.75;}

/* about */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.about-photo{position:relative;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-lg);}
.about-photo img{width:100%;}
.about-photo::after{content:'';position:absolute;inset:0;border:1px solid rgba(205,160,94,.4);border-radius:8px;pointer-events:none;margin:14px;}
.about-text p{font-size:15.5px;line-height:1.85;color:var(--cream-100);opacity:.92;margin:18px 0;}
.chip-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;}
.chip{font-size:12px;letter-spacing:.06em;padding:8px 16px;border:1px solid rgba(205,160,94,.4);border-radius:20px;color:var(--gold-200);}
.facility-list{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px;}
.facility-list li{list-style:none;font-size:13.5px;display:flex;align-items:center;gap:9px;color:var(--cream-100);}
.facility-list li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--gold-500);flex:none;}

/* ============ MENU PAGE ============ */
.menu-hero{padding:150px 0 50px;text-align:center;background:linear-gradient(180deg,var(--navy-850),var(--navy-900));}
.menu-toolbar{position:sticky;top:64px;z-index:60;background:rgba(10,20,48,.95);backdrop-filter:blur(10px);border-bottom:1px solid rgba(205,160,94,.18);padding:16px 0;}
.menu-toolbar-inner{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.search-box{flex:1;min-width:200px;display:flex;align-items:center;gap:10px;border:1px solid rgba(205,160,94,.3);border-radius:24px;padding:10px 18px;background:rgba(255,255,255,.03);}
.search-box svg{width:15px;height:15px;stroke:var(--gold-400);flex:none;}
.search-box input{flex:1;background:none;border:none;color:var(--cream-50);font-size:13.5px;outline:none;font-family:'Jost';}
.search-box input::placeholder{color:rgba(241,233,216,.45);}
.veg-toggle{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--cream-100);white-space:nowrap;}
.switch{position:relative;width:42px;height:23px;background:rgba(255,255,255,.12);border-radius:14px;transition:background .3s;}
.switch::after{content:'';position:absolute;top:2.5px;left:2.5px;width:18px;height:18px;border-radius:50%;background:var(--cream-50);transition:transform .3s var(--ease);}
.switch.on{background:var(--veg);}
.switch.on::after{transform:translateX(19px);}
.cat-chips{display:flex;gap:9px;overflow-x:auto;padding:14px 0 2px;scrollbar-width:none;position:relative;}
.cat-chips::-webkit-scrollbar{display:none;}
.swipe-hint{display:none;}
@media (max-width:1000px){
  .swipe-hint{display:flex;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:50%;background:rgba(205,160,94,.18);align-items:center;justify-content:center;pointer-events:none;animation:swipeNudge 1.6s ease-in-out infinite;z-index:5;}
  .swipe-hint svg{width:13px;height:13px;stroke:var(--gold-300);}
}
@keyframes swipeNudge{0%,100%{transform:translate(0,-50%);opacity:.85;}50%{transform:translate(6px,-50%);opacity:.3;}}
.cat-chip{flex:none;font-size:12px;letter-spacing:.04em;padding:8px 16px;border:1px solid rgba(205,160,94,.28);border-radius:20px;color:var(--cream-100);white-space:nowrap;transition:all .3s;}
.cat-chip.active,.cat-chip:hover{background:var(--gold-500);color:var(--navy-900);border-color:var(--gold-500);}

.menu-category{padding:54px 0 18px;border-top:1px solid rgba(205,160,94,.1);}
.menu-category:first-of-type{border-top:none;}
.cat-heading{display:flex;align-items:baseline;gap:16px;margin-bottom:8px;}
.cat-heading h3{font-size:clamp(24px,3.4vw,32px);color:var(--cream-50);}
.cat-heading .count{font-size:12px;color:var(--gold-400);opacity:.7;}
.cat-note{font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--cream-100);opacity:.65;font-size:14px;margin:4px 0 22px;}
.items-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 40px;}
.menu-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 4px;border-bottom:1px dashed rgba(232,207,156,.15);transition:background .3s;}
.menu-item:hover{background:rgba(205,160,94,.05);}
.item-left{display:flex;align-items:center;gap:11px;min-width:0;}
.veg-mark{width:13px;height:13px;border:1.4px solid var(--veg);border-radius:3px;display:flex;align-items:center;justify-content:center;flex:none;}
.veg-mark::after{content:'';width:5px;height:5px;border-radius:50%;background:var(--veg);}
.veg-mark.nonveg{border-color:var(--nonveg);}
.veg-mark.nonveg::after{border-radius:50%;background:var(--nonveg);}
.item-name{font-size:14.5px;color:var(--cream-50);line-height:1.3;}
.item-note{font-size:11px;color:var(--cream-100);opacity:.55;display:block;}
.item-right{display:flex;align-items:center;gap:10px;flex:none;}
.price-tag{font-family:'Jost';font-weight:500;font-size:14px;color:var(--gold-300);white-space:nowrap;}
.add-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--gold-500);color:var(--gold-300);font-size:17px;display:flex;align-items:center;justify-content:center;transition:all .3s;flex:none;}
.add-btn:hover{background:var(--gold-500);color:var(--navy-900);transform:scale(1.08);}
.qty-pill{display:flex;align-items:center;gap:8px;border:1px solid var(--gold-500);border-radius:20px;padding:2px;}
.qty-pill button{width:24px;height:24px;border-radius:50%;color:var(--gold-300);font-size:15px;}
.qty-pill button:hover{background:rgba(205,160,94,.18);}
.qty-pill .qn{font-size:13px;color:var(--cream-50);min-width:14px;text-align:center;}
.variant-group{display:flex;gap:8px;flex-wrap:wrap;}
.variant-btn{font-size:11.5px;border:1px solid rgba(205,160,94,.4);padding:6px 11px;border-radius:16px;color:var(--cream-100);transition:all .3s;}
.variant-btn:hover{background:var(--gold-500);color:var(--navy-900);}
.no-results{display:none;text-align:center;padding:60px 0;color:var(--cream-100);opacity:.6;font-family:'Cormorant Garamond';font-size:18px;}

/* ============ GALLERY ============ */
.gallery-hero{padding:150px 0 50px;text-align:center;}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:190px;gap:14px;}
.gal-grid figure{margin:0;overflow:hidden;border-radius:6px;cursor:pointer;position:relative;}
.gal-grid figure img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);animation:ambientZoom 16s ease-in-out infinite alternate;}
.gal-grid figure:hover img{transform:scale(1.1);animation-play-state:paused;}
.gal-grid figure::after{content:'\\2807\\2807';opacity:0;position:absolute;inset:0;background:rgba(10,20,48,.35);transition:opacity .3s;}
.gal-grid figure.tall{grid-row:span 2;}
.lightbox{position:fixed;inset:0;background:rgba(5,9,20,.92);z-index:900;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;padding:40px;}
.lightbox.show{opacity:1;visibility:visible;}
.lightbox img{max-width:90vw;max-height:84vh;border-radius:6px;box-shadow:var(--shadow-lg);transform:scale(.92);transition:transform .35s var(--ease);}
.lightbox.show img{transform:scale(1);}
.lightbox-close{position:absolute;top:24px;right:30px;width:42px;height:42px;border:1px solid rgba(232,207,156,.4);border-radius:50%;color:var(--cream-50);font-size:20px;}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;}
.contact-card{background:linear-gradient(160deg,var(--navy-800),var(--navy-850));border:1px solid rgba(205,160,94,.18);border-radius:10px;padding:40px;}
.contact-row{display:flex;gap:16px;align-items:flex-start;margin-bottom:26px;}
.contact-row svg{width:20px;height:20px;stroke:var(--gold-400);flex:none;margin-top:2px;}
.contact-row h5{font-family:'Jost';font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-300);margin:0 0 5px;}
.contact-row p{margin:0;font-size:15px;color:var(--cream-50);line-height:1.6;}
.map-frame{border-radius:10px;overflow:hidden;border:1px solid rgba(205,160,94,.18);height:100%;min-height:380px;}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(.15) sepia(.08);min-height:380px;}

/* ============ FOOTER ============ */
footer{background:var(--navy-850);border-top:1px solid rgba(205,160,94,.15);padding:60px 0 26px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px;}
.footer-brand .brand{margin-bottom:14px;}
.footer-brand p{font-size:13.5px;color:var(--cream-100);opacity:.7;line-height:1.7;max-width:300px;}
.footer-col h5{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-300);margin-bottom:18px;}
.footer-col a, .footer-col p{display:block;font-size:13.5px;color:var(--cream-100);opacity:.75;margin-bottom:10px;line-height:1.5;}
.footer-col a:hover{color:var(--gold-300);}
.platform-badges{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;}
.platform-badges span{font-size:11px;border:1px solid rgba(205,160,94,.35);padding:6px 12px;border-radius:14px;color:var(--gold-200);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--cream-100);opacity:.55;}

/* ============ CART DRAWER ============ */
.cart-drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--navy-850);z-index:800;transform:translateX(100%);transition:transform .5s var(--ease);box-shadow:-30px 0 60px rgba(0,0,0,.5);display:flex;flex-direction:column;border-left:1px solid rgba(205,160,94,.2);}
.cart-drawer.open{transform:translateX(0);}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:24px 26px;border-bottom:1px solid rgba(205,160,94,.15);}
.cart-head h3{font-size:22px;color:var(--cream-50);}
.cart-close{width:34px;height:34px;border:1px solid rgba(232,207,156,.3);border-radius:50%;color:var(--cream-50);}
.cart-items{flex:1;overflow-y:auto;padding:10px 26px;}
.cart-line{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px dashed rgba(232,207,156,.15);gap:12px;}
.cart-line .cl-name{font-size:14px;color:var(--cream-50);}
.cart-line .cl-price{font-size:12px;color:var(--gold-300);opacity:.85;margin-top:3px;}
.cart-line .qty-pill{flex:none;}
.cart-empty{text-align:center;padding:70px 20px;opacity:.55;}
.cart-empty svg{width:54px;height:54px;stroke:var(--gold-400);margin-bottom:16px;}
.cart-empty p{font-family:'Cormorant Garamond';font-size:16px;}
.cart-foot{padding:22px 26px 28px;border-top:1px solid rgba(205,160,94,.15);}
.cart-total-row{display:flex;justify-content:space-between;font-size:15px;color:var(--cream-50);margin-bottom:18px;}
.cart-total-row b{color:var(--gold-300);font-size:20px;font-family:'Marcellus';}
.cart-foot .btn{width:100%;}
.remove-x{font-size:11px;color:var(--cream-100);opacity:.5;text-decoration:underline;margin-top:4px;display:inline-block;}

/* ============ MODALS ============ */
.modal-scrim{position:fixed;inset:0;background:rgba(5,9,20,.7);backdrop-filter:blur(3px);z-index:850;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;display:flex;align-items:center;justify-content:center;padding:20px;}
.modal-scrim.show{opacity:1;visibility:visible;}
.modal-box{background:var(--navy-850);border:1px solid rgba(205,160,94,.25);border-radius:10px;max-width:440px;width:100%;padding:38px;position:relative;transform:translateY(18px) scale(.97);opacity:0;transition:transform .4s var(--ease),opacity .4s;max-height:88vh;overflow-y:auto;}
.modal-scrim.show .modal-box{transform:none;opacity:1;}
.modal-box h3{font-size:25px;color:var(--cream-50);margin-bottom:6px;}
.modal-box .sub{font-size:13px;color:var(--cream-100);opacity:.7;margin-bottom:24px;}
.modal-close{position:absolute;top:18px;right:18px;width:30px;height:30px;border:1px solid rgba(232,207,156,.3);border-radius:50%;color:var(--cream-50);font-size:15px;}
.field{margin-bottom:16px;}
.field label{font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-300);display:block;margin-bottom:7px;}
.field input,.field textarea,.field select{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(205,160,94,.3);border-radius:5px;padding:11px 13px;color:var(--cream-50);font-size:14px;font-family:'Jost';outline:none;transition:border-color .3s;}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--gold-500);}
.field textarea{resize:vertical;min-height:64px;}
.order-type-row{display:flex;gap:8px;}
.order-type-row button{flex:1;font-size:12px;padding:10px 6px;border:1px solid rgba(205,160,94,.3);border-radius:6px;color:var(--cream-100);transition:all .25s;}
.order-type-row button.sel{background:var(--gold-500);color:var(--navy-900);border-color:var(--gold-500);}
.modal-box .btn{width:100%;margin-top:6px;}
.summary-list{max-height:200px;overflow-y:auto;margin:18px 0;border-top:1px solid rgba(205,160,94,.15);border-bottom:1px solid rgba(205,160,94,.15);padding:10px 0;}
.summary-list div{display:flex;justify-content:space-between;font-size:13px;padding:5px 0;color:var(--cream-100);}
.error-msg{color:var(--ember-400);font-size:11.5px;margin-top:4px;display:none;}

/* ============ WHATSAPP FLOAT ============ */
.wa-float{position:fixed;bottom:26px;right:26px;width:58px;height:58px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px -8px rgba(0,0,0,.5);z-index:400;animation:floatPulse 2.6s ease-in-out infinite;}
.wa-float::before,.wa-float::after{content:'';position:absolute;inset:0;border-radius:50%;border:2px solid #25D366;animation:sonarPing 2.6s ease-out infinite;pointer-events:none;}
.wa-float::after{animation-delay:1.3s;}
@keyframes sonarPing{0%{transform:scale(1);opacity:.7;}100%{transform:scale(1.9);opacity:0;}}
.wa-float svg{width:28px;height:28px;fill:#fff;position:relative;z-index:1;}
@keyframes floatPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.07);}}

/* ============ TOAST ============ */
#toast-wrap{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);z-index:950;display:flex;flex-direction:column;gap:8px;align-items:center;}
.toast{background:var(--navy-850);border:1px solid var(--gold-500);color:var(--cream-50);font-size:13px;padding:12px 22px;border-radius:24px;box-shadow:var(--shadow-md);opacity:0;transform:translateY(14px);transition:all .4s var(--ease);}
.toast.show{opacity:1;transform:none;}

/* ============ MY ORDERS PAGE ============ */
.orders-account-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;padding:16px 22px;background:rgba(205,160,94,.08);border:1px solid rgba(205,160,94,.25);border-radius:8px;margin-bottom:28px;font-size:13.5px;color:var(--cream-100);}
.link-btn{color:var(--gold-300);text-decoration:underline;font-size:12.5px;background:none;border:none;cursor:pointer;}
.orders-empty{text-align:center;padding:70px 24px;border:1px dashed rgba(205,160,94,.28);border-radius:10px;}
.orders-empty svg{width:46px;height:46px;stroke:var(--gold-400);margin-bottom:16px;}
.orders-empty p{font-family:'Cormorant Garamond';font-size:16px;color:var(--cream-100);opacity:.8;margin-bottom:22px;max-width:380px;margin-left:auto;margin-right:auto;}
.order-card{background:linear-gradient(160deg,var(--navy-800),var(--navy-850));border:1px solid rgba(205,160,94,.18);border-radius:8px;padding:22px 24px;margin-bottom:18px;transition:border-color .3s;}
.order-card:hover{border-color:rgba(205,160,94,.4);}
.order-card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;flex-wrap:wrap;gap:6px;}
.order-id{font-size:12px;color:var(--gold-300);letter-spacing:.05em;margin-right:12px;}
.order-date{font-size:12px;color:var(--cream-100);opacity:.6;}
.order-total{font-family:'Marcellus',serif;font-size:19px;color:var(--gold-300);}
.order-items-list{list-style:none;margin:0 0 16px;padding:0;border-top:1px dashed rgba(232,207,156,.15);padding-top:10px;}
.order-items-list li{font-size:13.5px;color:var(--cream-100);padding:3px 0;opacity:.9;}
.order-card-foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.order-type-badge{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--gold-200);border:1px solid rgba(205,160,94,.3);padding:5px 12px;border-radius:12px;}

/* ============ RESPONSIVE ============ */
@media (max-width:1000px){
  nav.primary-nav{display:none;}
  .burger{display:flex;}
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .fav-grid{grid-template-columns:1fr;}
  .about-grid{grid-template-columns:1fr;gap:36px;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px;}
}
@media (max-width:680px){
  .items-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:30px;}
  .stats-row{gap:30px;}
  .stat b{font-size:30px;}
  .menu-toolbar{top:58px;}
  .cart-drawer{width:100%;}
  .hero h1{font-size:clamp(36px,11vw,56px);}
}