/*
Theme Name: DON Social Bar
Theme URI: https://donsocialbar.com
Author: JEOWebs
Version: 1.1.0
License: GNU General Public License v2
Text Domain: don-social-bar
*/
:root{
  --gold:#FFB643;--gold-dark:#AA5900;--gold-mid:#EF9107;--gold-deep:#A96826;
  --silver:#D2D5D3;--bg-base:#080604;--bg-card:#0f0c06;--bg-surface:#130e07;
  --text:#ede5d8;--text-muted:#8a8070;--border:rgba(255,182,67,.12);
  --r-sm:6px;--r-md:12px;--r-lg:18px;--r-xl:26px;--r-pill:999px;
  --t:all .28s cubic-bezier(.4,0,.2,1);
  --font-body:'Inter','Helvetica Neue',Arial,sans-serif;
  --font-head:'Playfair Display','Georgia',serif;
  --font-alt:'Oswald','Impact',sans-serif;
  --shadow-gold:0 0 40px rgba(255,182,67,.2);
  --max-w:1320px;--nav-h:72px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg-base);color:var(--text);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;background:none;border:none}
ul{list-style:none}
*{scrollbar-width:thin;scrollbar-color:var(--gold) #1a1208;-webkit-tap-highlight-color:rgba(255,182,67,.08)}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#1a1208}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.1;letter-spacing:-.01em}
.section-label{font-family:var(--font-alt);font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);opacity:.9}
.section-title{font-family:var(--font-head);font-size:clamp(2.4rem,5vw,4rem);color:#fff;margin-top:.3em}
.section-title em{color:var(--gold);font-style:normal}
.section-sub{font-size:1.05rem;color:var(--text-muted);margin-top:.8em;max-width:560px;line-height:1.75}
.container{width:min(100%,var(--max-w));margin-inline:auto;padding-inline:clamp(18px,4vw,52px)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 34px;border-radius:var(--r-pill);font-family:var(--font-alt);font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;transition:var(--t);border:none;white-space:nowrap;cursor:pointer}
.btn-gold{background:linear-gradient(135deg,var(--gold-mid),var(--gold-dark));color:#080604;font-weight:700;box-shadow:0 4px 24px rgba(239,145,7,.4)}
.btn-gold:hover{background:linear-gradient(135deg,var(--gold),var(--gold-mid));box-shadow:0 8px 36px rgba(239,145,7,.6);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--gold);border:1.5px solid var(--gold)}
.btn-outline:hover{background:rgba(255,182,67,.1);box-shadow:0 0 20px rgba(255,182,67,.25);transform:translateY(-2px)}
.divider{width:52px;height:2px;background:linear-gradient(90deg,var(--gold),transparent);margin:18px 0;border-radius:1px}
.section-header{text-align:center}.section-header .section-sub,.section-header .divider{margin-inline:auto}

/* NAV */
#site-header{position:fixed;top:0;left:0;right:0;z-index:9000;padding:0 clamp(18px,4vw,52px);height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;transition:background .4s,box-shadow .4s}
#site-header.scrolled{background:rgba(8,6,4,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(255,182,67,.1)}
.nav-logo{display:flex;flex-direction:column;align-items:flex-start;line-height:1;text-decoration:none}
.nav-logo-main{font-family:var(--font-alt);font-size:1.6rem;font-weight:700;color:#fff;letter-spacing:.06em}
.nav-logo-sub{font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:1.8rem}
.nav-links a{font-family:var(--font-alt);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--silver);transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;background:var(--gold);transition:width .28s}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{width:100%}
.nav-cta-desktop{margin-left:.8rem}
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:rgba(255,182,67,.1);border:1px solid rgba(255,182,67,.25);border-radius:8px;padding:8px 10px;cursor:pointer;width:44px;height:44px;flex-shrink:0;position:relative;z-index:9100}
.nav-hamburger span{width:22px;height:2px;background:var(--silver);border-radius:1px;transition:var(--t);display:block}
@media(max-width:900px){
  .nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(8,6,4,.99);flex-direction:column;align-items:center;justify-content:center;gap:2.4rem;z-index:9050;padding-top:var(--nav-h)}
  .nav-links.open{display:flex}
  .nav-links a{font-size:1.2rem;letter-spacing:.18em}
  .nav-cta-desktop{display:none}
  .nav-hamburger{display:flex}
  /* Close btn inside mobile nav */
  .nav-close-btn{display:flex;position:absolute;top:18px;right:20px;width:40px;height:40px;background:rgba(255,255,255,.1);border:none;color:#fff;border-radius:50%;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;z-index:9200}
}
@media(min-width:901px){.nav-close-btn{display:none}}

/* HERO */
#hero{position:relative;width:100%;height:100vh;height:100svh;min-height:600px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-bg-wrap{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;overflow:hidden}
.hero-bg-wrap img,.hero-bg-wrap video{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:100%;min-height:100%;width:auto;height:auto;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,rgba(8,6,4,.2) 0%,rgba(8,6,4,.55) 55%,rgba(8,6,4,.92) 100%);z-index:1}
.hero-content{position:relative;z-index:2;padding:0 clamp(18px,5vw,60px);max-width:920px;width:100%}
.hero-logo{font-family:var(--font-alt);font-size:clamp(3.5rem,10vw,7rem);font-weight:700;color:#fff;letter-spacing:.06em;line-height:.9;margin-bottom:.15em;text-shadow:0 4px 32px rgba(0,0,0,.6)}
.hero-logo-sub{font-family:var(--font-alt);font-size:clamp(.7rem,1.6vw,1.05rem);letter-spacing:.35em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:1.2em}
.hero-badge{display:inline-block;font-family:var(--font-alt);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(255,182,67,.45);padding:7px 22px;border-radius:var(--r-pill);margin-bottom:1.6rem;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.hero-title{font-family:var(--font-head);font-size:clamp(3.2rem,9vw,8rem);font-weight:700;color:#fff;line-height:1;letter-spacing:-.02em;text-shadow:0 4px 32px rgba(0,0,0,.7);margin-bottom:.15em}
.hero-title span{color:var(--gold);display:block;font-style:italic}
.hero-sub{font-size:clamp(1rem,1.8vw,1.25rem);color:var(--silver);margin:1rem auto 2.6rem;max-width:520px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.55}
.hero-scroll span{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--silver)}
.hero-scroll-line{width:1px;height:44px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollLine 2.2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:.3;transform:scaleY(.5)}50%{opacity:1;transform:scaleY(1)}}

/* AMBIENT */
#ambiente{padding:clamp(64px,9vw,110px) 0;background:var(--bg-surface)}
.ambient-grid{display:grid;grid-template-columns:repeat(var(--amb-cols,3),1fr);gap:var(--amb-gap,12px)}
.gal-item{position:relative;overflow:hidden;border-radius:var(--r-md);cursor:pointer;background:var(--bg-card);aspect-ratio:var(--gal-ratio,4/3)}
.gal-item.slot-empty{border:1px dashed var(--border);cursor:default}
.gal-item img,.gal-item video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s ease;display:block}
.gal-item:hover img,.gal-item:hover video{transform:scale(1.04)}
/* NO dark overlay on gallery */
.gal-expand{position:absolute;bottom:10px;right:10px;width:34px;height:34px;border-radius:50%;background:rgba(255,182,67,.88);color:#080604;display:flex;align-items:center;justify-content:center;font-size:.9rem;opacity:0;transition:opacity .28s;font-weight:700}
.gal-item:hover .gal-expand{opacity:1}
@media(max-width:768px){.ambient-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.ambient-grid{grid-template-columns:1fr}}

/* LIGHTBOX */
#don-lightbox{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:99990;background:rgba(8,6,4,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);align-items:center;justify-content:center;padding:16px}
#don-lightbox.open{display:flex}
.lb-inner{position:relative;display:flex;align-items:center;justify-content:center;gap:14px;width:100%;max-width:1200px}
.lb-media-wrap{position:relative;display:flex;align-items:center;justify-content:center;flex:1;max-height:90vh}
.lb-media-wrap img,.lb-media-wrap video{max-width:100%;max-height:88vh;width:auto;height:auto;border-radius:var(--r-md);object-fit:contain;box-shadow:0 24px 80px rgba(0,0,0,.9);display:block;margin:auto}
.lb-btn{width:46px;height:46px;border-radius:50%;flex-shrink:0;background:rgba(255,182,67,.15);border:1px solid rgba(255,182,67,.3);color:var(--gold);font-size:1.3rem;display:flex;align-items:center;justify-content:center;transition:var(--t);cursor:pointer}
.lb-btn:hover{background:rgba(255,182,67,.3)}
.lb-close{position:absolute;top:0;right:0;transform:translate(0,-110%);background:rgba(255,255,255,.1);border:none;color:#fff;width:38px;height:38px;border-radius:50%;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:var(--t);cursor:pointer}
.lb-close:hover{background:rgba(255,255,255,.25)}
@media(max-width:600px){.lb-btn{width:36px;height:36px;font-size:1.1rem}.lb-media-wrap img,.lb-media-wrap video{max-height:78vh}}

/* MENU */
#menu{padding:clamp(64px,9vw,110px) 0}
.menu-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:2.6rem}
.mtab{background:transparent;border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-alt);font-size:.72rem;letter-spacing:.12em;padding:10px 22px;border-radius:var(--r-pill);transition:var(--t);cursor:pointer}
.mtab.active,.mtab:hover{background:rgba(255,182,67,.1);border-color:var(--gold);color:var(--gold)}
.cat-panel{display:none}.cat-panel.active{display:block}
.cat-subtitle{font-family:var(--font-alt);font-size:.65rem;letter-spacing:.18em;color:var(--gold-mid);margin-bottom:1.8rem;text-transform:uppercase}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:16px}
/* Product card */
.prod-card{position:relative;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;background:var(--bg-card);border:1px solid var(--border);transition:all .3s cubic-bezier(.4,0,.2,1);aspect-ratio:16/9;min-height:160px}
.prod-card:hover{border-color:rgba(255,182,67,.4);box-shadow:0 8px 32px rgba(0,0,0,.5),var(--shadow-gold);transform:translateY(-3px)}
.prod-card.in-cart{border-color:rgba(255,182,67,.55);box-shadow:0 0 0 2px rgba(255,182,67,.25)}
.prod-bg{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;transition:transform .5s ease}
.prod-card:hover .prod-bg{transform:scale(1.05)}
.prod-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(105deg,rgba(8,6,4,.1) 0%,rgba(8,6,4,.48) 38%,rgba(8,6,4,.88) 65%,rgba(8,6,4,.97) 100%),linear-gradient(to top,rgba(8,6,4,.72) 0%,transparent 55%)}
.prod-card:not(.has-img) .prod-overlay{background:linear-gradient(135deg,rgba(22,14,2,.97),rgba(8,6,4,.99))}
.prod-card.in-cart .prod-overlay{background:linear-gradient(105deg,rgba(255,182,67,.08) 0%,rgba(8,6,4,.48) 38%,rgba(8,6,4,.88) 65%,rgba(8,6,4,.97) 100%),linear-gradient(to top,rgba(8,6,4,.72) 0%,transparent 55%)}
.prod-content{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:flex-end;justify-content:space-between;padding:14px 16px;gap:12px}
.prod-info{flex:1;min-width:0}
.prod-name{font-family:var(--font-alt);font-size:1.05rem;text-transform:uppercase;letter-spacing:.06em;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.9)}
.prod-desc{font-size:.76rem;color:rgba(255,255,255,.68);line-height:1.4;margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 6px rgba(0,0,0,.9)}
.prod-badge{display:inline-block;font-family:var(--font-alt);font-size:.5rem;letter-spacing:.1em;padding:2px 8px;border-radius:var(--r-pill);margin-left:6px;vertical-align:middle}
.badge-sg{background:rgba(239,145,7,.85);color:#fff}
.badge-v{background:rgba(50,160,60,.85);color:#fff}
.prod-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}
.prod-price{font-family:var(--font-alt);font-size:1.5rem;font-weight:700;color:var(--gold);white-space:nowrap;text-shadow:0 0 18px rgba(255,182,67,.5),0 1px 8px rgba(0,0,0,.9)}
.prod-subtotal{font-family:var(--font-alt);font-size:.8rem;color:rgba(255,182,67,.8);white-space:nowrap;text-align:right;min-height:1.1em;display:block}
.qty-row{display:flex;align-items:center;gap:5px;background:rgba(0,0,0,.55);border-radius:var(--r-pill);padding:4px;border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.qty-btn{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);color:#fff;font-size:1.05rem;display:flex;align-items:center;justify-content:center;transition:all .18s ease;cursor:pointer;line-height:1}
.qty-btn:hover{background:var(--gold);border-color:var(--gold);color:#080604;box-shadow:0 0 12px rgba(255,182,67,.6)}
.qty-num{font-family:var(--font-alt);font-size:.95rem;min-width:24px;text-align:center;color:#fff;font-weight:600}
.qty-num.nonzero{color:var(--gold)}
.prod-img-click{position:absolute;top:0;left:0;width:55%;height:100%;z-index:1;cursor:zoom-in}

/* CART FAB & DRAWER */
.cart-fab{position:fixed;bottom:100px;right:20px;z-index:8900;background:linear-gradient(135deg,#FFB643,#EF9107);color:#080604;width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;box-shadow:0 4px 22px rgba(255,182,67,.6);transition:var(--t);border:none;cursor:pointer;line-height:1}
.cart-fab:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(255,182,67,.8)}
.cart-badge{position:absolute;top:-5px;right:-5px;background:#e53e3e;color:#fff;width:22px;height:22px;border-radius:50%;font-size:.65rem;font-weight:700;display:none;align-items:center;justify-content:center;border:2px solid var(--bg-base)}
.cart-badge.show{display:flex}
/* Overlay behind drawer */
.cart-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.55);z-index:9500;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.cart-overlay.show{display:block}
/* Drawer slide-in from right */
.cart-drawer{position:fixed;top:0;right:-440px;bottom:0;width:min(420px,100vw);z-index:9600;background:linear-gradient(160deg,rgba(20,14,4,.99),rgba(8,6,4,.99));border-left:1px solid rgba(255,182,67,.18);transition:right .38s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 48px rgba(0,0,0,.8)}
.cart-drawer.open{right:0}
@media(max-width:500px){
  .cart-drawer{top:auto;right:0;bottom:-100%;left:0;width:100%;border-left:none;border-top:1px solid rgba(255,182,67,.18);border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:90vh;transition:bottom .38s cubic-bezier(.4,0,.2,1)}
  .cart-drawer.open{bottom:0;right:0}
}
.cart-drawer-header{display:flex;justify-content:space-between;align-items:center;padding:20px 22px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.cart-drawer-title{font-family:var(--font-head);font-size:1.5rem;color:#fff}
.cart-drawer-close{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);border:none;color:var(--silver);font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:var(--t);cursor:pointer}
.cart-drawer-close:hover{background:rgba(255,255,255,.18)}
.cart-drawer-body{flex:1;overflow-y:auto;padding:16px 22px}
.cart-drawer-footer{padding:16px 22px 24px;border-top:1px solid var(--border);flex-shrink:0}
.cart-empty-msg{color:var(--text-muted);font-size:.9rem;text-align:center;padding:32px 0}
.cart-item{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}
.ci-name{flex:1;font-size:.88rem;color:var(--text);line-height:1.3}
.ci-qty-controls{display:flex;align-items:center;gap:5px}
.ci-qbtn{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:#fff;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .18s;cursor:pointer}
.ci-qbtn:hover{background:var(--gold);color:#080604;border-color:var(--gold)}
.ci-qty{font-family:var(--font-alt);font-size:.85rem;min-width:20px;text-align:center;color:var(--gold)}
.ci-price{font-family:var(--font-alt);font-size:.88rem;color:var(--silver);white-space:nowrap;min-width:60px;text-align:right}
.ci-rm{background:none;border:none;color:var(--text-muted);font-size:1.1rem;padding:2px 5px;border-radius:4px;cursor:pointer;transition:color .2s;line-height:1;flex-shrink:0}
.ci-rm:hover{color:#e74c3c}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0 16px;border-top:1px solid rgba(255,182,67,.2)}
.cart-total-label{font-size:.92rem;color:var(--text-muted)}
.cart-total-val{font-family:var(--font-alt);font-size:1.8rem;color:var(--gold);font-weight:700}
.cart-form input,.cart-form select,.cart-form textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,182,67,.18);color:var(--text);border-radius:var(--r-md);padding:12px 14px;font-size:.9rem;font-family:inherit;margin-bottom:10px;transition:border-color .2s;outline:none}
.cart-form input:focus,.cart-form select:focus,.cart-form textarea:focus{border-color:var(--gold)}
.cart-form select option{background:#1a1208;color:var(--text)}
.cart-form textarea{min-height:70px;resize:vertical}
.cart-submit{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold-mid),var(--gold-dark));color:#080604;border:none;border-radius:var(--r-pill);font-family:var(--font-alt);font-size:.82rem;letter-spacing:.12em;font-weight:700;transition:var(--t);cursor:pointer}
.cart-submit:hover{background:linear-gradient(135deg,var(--gold),var(--gold-mid));box-shadow:0 6px 24px rgba(239,145,7,.5)}
.cart-submit:disabled{opacity:.5;cursor:not-allowed}

/* MODAL */
.modal-backdrop{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9800;background:rgba(8,6,4,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);align-items:flex-end;justify-content:center;padding:0}
.modal-backdrop.open{display:flex}
.modal-sheet{background:linear-gradient(160deg,rgba(22,15,4,.99),rgba(10,8,3,.99));border:1px solid rgba(255,182,67,.15);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:500px;max-height:92vh;max-height:92svh;overflow-y:auto;padding:24px 24px 36px;position:relative;animation:sheetUp .32s cubic-bezier(.4,0,.2,1);box-shadow:0 -8px 48px rgba(0,0,0,.8)}
@media(min-width:600px){.modal-sheet{border-radius:var(--r-xl);max-height:88vh;max-height:88svh}}
@keyframes sheetUp{from{transform:translateY(30px);opacity:.5}to{transform:translateY(0);opacity:1}}
.modal-close{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.1);border:none;color:var(--silver);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:var(--t);cursor:pointer}
.modal-close:hover{background:rgba(255,255,255,.22)}
.modal-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-lg);margin-bottom:16px;cursor:zoom-in;display:block}
.modal-img.hidden{display:none}
.modal-cat{font-family:var(--font-alt);font-size:.62rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;margin-bottom:4px}
.modal-name{font-family:var(--font-head);font-size:1.7rem;color:#fff;margin-bottom:10px}
.modal-desc{color:var(--text-muted);font-size:.92rem;line-height:1.75;margin-bottom:16px}
.modal-price{font-family:var(--font-alt);font-size:2.2rem;color:var(--gold);font-weight:700;margin-bottom:20px}
.modal-qty-row{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.modal-qty-btn{width:44px;height:44px;border-radius:50%;background:rgba(255,182,67,.1);border:1px solid rgba(255,182,67,.3);color:var(--gold);font-size:1.4rem;display:flex;align-items:center;justify-content:center;transition:var(--t);cursor:pointer}
.modal-qty-btn:hover{background:rgba(255,182,67,.2)}
.modal-qty-num{font-family:var(--font-alt);font-size:1.5rem;color:#fff;min-width:42px;text-align:center}
.modal-add{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold-mid),var(--gold-dark));color:#080604;border:none;border-radius:var(--r-pill);font-family:var(--font-alt);font-size:.82rem;letter-spacing:.14em;font-weight:700;transition:var(--t);cursor:pointer}
.modal-add:hover{box-shadow:0 6px 24px rgba(239,145,7,.5);transform:translateY(-2px)}

/* RESERVAS */
#reservas{padding:clamp(64px,9vw,110px) 0;background:var(--bg-surface)}
.reservas-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,7vw,88px);align-items:start}
.reservas-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:clamp(24px,4vw,42px)}
.form-title{font-family:var(--font-head);font-size:1.5rem;color:#fff;margin-bottom:6px}
.form-sub{font-size:.85rem;color:var(--text-muted);margin-bottom:1.6rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{margin-bottom:12px}
.form-group label{display:block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,182,67,.16);color:var(--text);border-radius:var(--r-md);padding:12px 14px;font-size:.9rem;font-family:inherit;transition:border-color .2s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group select option{background:#1a1208}
.form-group textarea{min-height:82px;resize:vertical}
.form-submit{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold-mid),var(--gold-dark));color:#080604;border:none;border-radius:var(--r-pill);font-family:var(--font-alt);font-size:.82rem;letter-spacing:.14em;font-weight:700;margin-top:4px;transition:var(--t);cursor:pointer}
.form-submit:hover{background:linear-gradient(135deg,var(--gold),var(--gold-mid));box-shadow:0 6px 24px rgba(239,145,7,.45);transform:translateY(-2px)}
.horario-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 18px;margin-bottom:10px}
.horario-day{font-family:var(--font-alt);font-size:.7rem;letter-spacing:.12em;color:var(--gold);margin-bottom:3px;text-transform:uppercase}
.horario-time{font-size:.9rem;color:var(--silver)}
.res-wsp{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:linear-gradient(135deg,#25d366,#128c3e);color:#fff;border-radius:var(--r-pill);font-family:var(--font-alt);font-size:.78rem;letter-spacing:.1em;transition:var(--t);border:none;cursor:pointer;text-decoration:none}
.res-wsp:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.45)}
@media(max-width:900px){.reservas-grid{grid-template-columns:1fr}}
@media(max-width:500px){.form-row{grid-template-columns:1fr}}

/* EVENTOS */
#eventos{padding:clamp(64px,9vw,110px) 0;background:var(--bg-base)}
.eventos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-top:2.6rem}
.evento-card{position:relative;border-radius:var(--r-lg);overflow:hidden;cursor:pointer;background:var(--bg-card);border:1px solid var(--border);transition:var(--t);aspect-ratio:9/16}
.evento-card:hover{border-color:rgba(255,182,67,.35);transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.5),var(--shadow-gold)}
.evento-card img,.evento-card video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.evento-card:hover img,.evento-card:hover video{transform:scale(1.04)}
.evento-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to top,rgba(8,6,4,.88) 0%,rgba(8,6,4,.15) 60%,transparent 100%)}
.evento-info{position:absolute;bottom:0;left:0;right:0;padding:18px 16px}
.evento-label{font-family:var(--font-alt);font-size:.6rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase}
.evento-title{font-family:var(--font-head);font-size:1.1rem;color:#fff;margin-top:3px;line-height:1.2}
.evento-date{font-size:.75rem;color:var(--silver);margin-top:5px}
.evento-empty{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--text-muted);font-size:.88rem;opacity:.5;min-height:300px;grid-column:1/-1}
@media(max-width:600px){.eventos-grid{grid-template-columns:1fr 1fr}}

/* NOSOTROS */
#nosotros{padding:clamp(64px,9vw,110px) 0;background:var(--bg-surface)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,6vw,88px);align-items:center}
.about-images{position:relative;height:500px}
.about-img-main{position:absolute;left:0;top:0;width:72%;height:82%;object-fit:cover;border-radius:var(--r-xl);box-shadow:0 24px 64px rgba(0,0,0,.7)}
.about-img-accent{position:absolute;right:0;bottom:0;width:52%;height:55%;object-fit:cover;border-radius:var(--r-xl);border:3px solid var(--bg-base);box-shadow:0 12px 40px rgba(0,0,0,.6)}
.about-badge{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);background:linear-gradient(135deg,var(--gold-mid),var(--gold-dark));color:#080604;font-family:var(--font-alt);font-size:.7rem;letter-spacing:.14em;padding:8px 22px;border-radius:var(--r-pill);white-space:nowrap;font-weight:700}
.about-text p{color:var(--text-muted);margin-bottom:1rem;line-height:1.78;font-size:1.02rem}
.about-pills{display:flex;flex-wrap:wrap;gap:8px;margin:1.4rem 0 2rem}
.about-pill{background:rgba(255,182,67,.08);border:1px solid rgba(255,182,67,.2);color:var(--gold);font-family:var(--font-alt);font-size:.65rem;letter-spacing:.12em;padding:7px 16px;border-radius:var(--r-pill)}
@media(max-width:900px){.about-grid{grid-template-columns:1fr}.about-images{height:300px;margin-bottom:2.4rem}}
@media(max-width:480px){.about-images{height:220px}}

/* CUMPLEAÑOS */
#cumple{padding:clamp(64px,9vw,110px) 0;background:var(--bg-base)}
.cumple-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,7vw,88px);align-items:center}
.cumple-img{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:4/3;position:relative;background:var(--bg-card);border:1px dashed var(--border)}
.cumple-img img,.cumple-img video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:var(--r-xl)}
.cumple-features{display:flex;flex-direction:column;gap:14px;margin:1.6rem 0}
.cumple-feat{display:flex;align-items:flex-start;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 18px}
.cumple-feat-icon{font-size:1.6rem;flex-shrink:0}
.cumple-feat-text .feat-title{font-family:var(--font-alt);font-size:.78rem;letter-spacing:.1em;color:var(--gold);margin-bottom:3px;text-transform:uppercase}
.cumple-feat-text p{font-size:.88rem;color:var(--text-muted);line-height:1.55}
@media(max-width:900px){.cumple-inner{grid-template-columns:1fr}}

/* COCINA */
#cocina{padding:clamp(64px,9vw,110px) 0;background:var(--bg-surface)}
.cocina-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-top:2.6rem}
.cocina-item{border-radius:var(--r-md);overflow:hidden;position:relative;cursor:pointer;aspect-ratio:4/3;background:var(--bg-card)}
.cocina-item.slot-empty{border:1px dashed var(--border)}
.cocina-item img,.cocina-item video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.cocina-item:hover img,.cocina-item:hover video{transform:scale(1.06)}

/* UBICACION */
#ubicacion{padding:clamp(64px,9vw,110px) 0;background:var(--bg-base)}
.ubicacion-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,6vw,80px);align-items:start}
.info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 20px;display:flex;gap:14px;align-items:flex-start;margin-bottom:12px}
.info-card-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.info-card-body .label{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);margin-bottom:3px;font-family:var(--font-alt)}
.info-card-body p,.info-card-body a{font-size:.9rem;color:var(--silver);line-height:1.6}
.map-wrap{border-radius:var(--r-xl);overflow:hidden;height:400px;border:1px solid var(--border)}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}
@media(max-width:900px){.ubicacion-grid{grid-template-columns:1fr}}

/* FOOTER */
#site-footer{background:var(--bg-card);border-top:1px solid var(--border);padding:clamp(52px,8vw,90px) 0 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:44px;margin-bottom:44px}
.footer-brand .nav-logo-main{font-size:2rem}
.footer-brand p{color:var(--text-muted);font-size:.88rem;margin-top:1rem;line-height:1.75;max-width:290px}
.footer-social{display:flex;gap:10px;margin-top:1.2rem}
.social-btn{width:40px;height:40px;border-radius:50%;background:rgba(255,182,67,.08);border:1px solid rgba(255,182,67,.2);color:var(--silver);display:flex;align-items:center;justify-content:center;font-size:1rem;transition:var(--t)}
.social-btn:hover{background:rgba(255,182,67,.18);color:var(--gold);border-color:var(--gold)}
.footer-col h4{font-family:var(--font-alt);font-size:.72rem;letter-spacing:.16em;color:var(--gold);text-transform:uppercase;margin-bottom:1rem}
.footer-col ul li{margin-bottom:.65rem}
.footer-col ul li a{font-size:.88rem;color:var(--text-muted);transition:color .2s}
.footer-col ul li a:hover{color:var(--gold)}
.footer-col p{font-size:.88rem;color:var(--text-muted);line-height:1.75}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--border);font-size:.75rem;color:var(--text-muted);flex-wrap:wrap;gap:10px}
.footer-bottom a{color:var(--gold)}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* WSP FLOAT */
.wsp-float{position:fixed;bottom:28px;right:20px;z-index:8800;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#25d366,#128c3e);display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 6px 24px rgba(37,211,102,.45);transition:var(--t);border:none;cursor:pointer;text-decoration:none}
.wsp-float:hover{transform:scale(1.1);box-shadow:0 10px 32px rgba(37,211,102,.65)}

/* TOAST */
.don-toast{position:fixed;bottom:104px;left:50%;transform:translateX(-50%);z-index:99999;background:var(--bg-card);border:1px solid rgba(255,182,67,.35);color:var(--text);padding:12px 22px;border-radius:var(--r-lg);font-size:.88rem;box-shadow:0 8px 28px rgba(0,0,0,.6);animation:toastIn .3s ease;white-space:nowrap}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(14px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
#modal-order .modal-sheet{max-width:520px}
.order-item-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:.88rem;color:var(--text)}
.order-total-row{display:flex;justify-content:space-between;padding:14px 0 0;font-family:var(--font-alt);color:var(--gold)}
.order-total-val{font-size:1.6rem}
@supports not (inset:0){.hero-bg-wrap img,.hero-bg-wrap video,.gal-item img,.gal-item video,.prod-bg,.prod-overlay,.prod-content,.prod-img-click,.evento-card img,.evento-card video,.evento-overlay,.cocina-item img,.cocina-item video,.cumple-img img,.cumple-img video{top:0;left:0;right:0;bottom:0}}
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield;appearance:textfield}
@media(max-width:500px){.hero-title{font-size:clamp(2.8rem,14vw,5rem)}.menu-grid{grid-template-columns:1fr}.ambient-grid{grid-template-columns:1fr}}
