:root{
  --verde:#1E5C2A; --verde2:#2d7a3a; --verde-pale:#e8f5eb; --verde-mid:#4a9a5a;
  --rojo:#C5301E; --rojo2:#e03a26;
  --crema:#FBF6EE; --crema2:#F0E8D5; --crema3:#C8B890;
  --dorado:#B8860B; --dorado2:#d4a820;
  --negro:#1a1208; --gris:#5a5040; --gris2:#8a7a60;
  --r:14px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--crema);color:var(--negro);font-family:"DM Sans",system-ui,sans-serif;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{display:block;width:100%;height:100%;object-fit:cover;}

/* ---- NAV ---- */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;height:68px;transition:all .35s;}
.nav.solid{background:rgba(255,251,245,.97);backdrop-filter:blur(14px);box-shadow:0 2px 24px rgba(30,92,42,.1);}
.nav-inner{max-width:1240px;margin:0 auto;padding:0 2rem;height:100%;display:flex;align-items:center;gap:1.5rem;}
.logo-wrap{display:flex;align-items:center;gap:.65rem;cursor:pointer;}
.logo-badge{width:44px;height:44px;border-radius:50%;background:var(--verde);display:grid;place-items:center;flex-shrink:0;font-size:1.4rem;}
.logo-text-wrap{display:flex;flex-direction:column;line-height:1;}
.logo-name{font-family:"Playfair Display",serif;font-size:1.18rem;font-weight:900;color:var(--verde);letter-spacing:.02em;}
.logo-name em{font-style:italic;}
.logo-sub{font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris2);margin-top:.1rem;}
.nav-links{display:flex;gap:.2rem;margin-left:auto;list-style:none;}
.nav-links a{font-size:.82rem;letter-spacing:.04em;color:var(--gris);padding:.45rem 1rem;border-radius:22px;transition:all .2s;font-weight:500;display:block;}
.nav-links a:hover,.nav-links a.act{background:var(--verde-pale);color:var(--verde);}
.nav-cta{background:var(--rojo);color:#fff;padding:.52rem 1.35rem;border-radius:22px;font-size:.8rem;font-weight:600;letter-spacing:.03em;transition:all .2s;white-space:nowrap;}
.nav-cta:hover{background:var(--rojo2);transform:translateY(-1px);}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;margin-left:auto;}
.burger span{display:block;width:22px;height:2px;background:var(--verde);border-radius:2px;transition:all .3s;}

/* ---- DRAWER ---- */
.drawer{position:fixed;inset:0;background:var(--crema);z-index:300;padding:5rem 2.5rem 2rem;transform:translateX(110%);transition:transform .4s cubic-bezier(.4,0,.2,1);}
.drawer.open{transform:none;}
.drawer-x{position:absolute;top:1.5rem;right:1.5rem;background:none;border:2px solid var(--verde);border-radius:50%;width:40px;height:40px;color:var(--verde);font-size:1.1rem;cursor:pointer;font-weight:700;}
.drawer ul{list-style:none;display:flex;flex-direction:column;gap:1.25rem;}
.drawer a{font-family:"Playfair Display",serif;font-size:2rem;color:var(--verde);display:block;border-bottom:1px solid var(--crema2);padding-bottom:1.1rem;}

/* ---- PAGES ---- */
.page{display:none;min-height:100vh;}
.page.active{display:block;}

/* ---- HERO ---- */
.hero{position:relative;height:100vh;min-height:620px;overflow:hidden;}
.hero-bg{position:absolute;inset:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 35%;
  filter:brightness(.48);transform:scale(1.05);transition:transform 9s ease-out;}
.hero.loaded .hero-bg img{transform:scale(1);}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(to right,rgba(30,92,42,.45) 0%,rgba(0,0,0,.05) 55%,rgba(0,0,0,.2) 100%),
              linear-gradient(to bottom,rgba(0,0,0,.1) 0%,transparent 30%,transparent 65%,rgba(26,18,8,.92) 100%);}
.hero-body{position:absolute;bottom:0;left:0;right:0;padding:3rem 2rem 5rem;}
.hero-body-inner{max-width:1240px;margin:0 auto;}
.hero-pill{display:inline-flex;align-items:center;gap:.45rem;background:var(--rojo);color:#fff;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;padding:.32rem .85rem;border-radius:20px;font-weight:700;margin-bottom:1.2rem;}
.hero-h1{font-family:"Playfair Display",serif;font-size:clamp(3rem,7vw,6.2rem);font-weight:900;line-height:.95;color:#fff;margin-bottom:1.25rem;}
.hero-h1 em{font-style:italic;color:#9dd4a0;display:block;}
.hero-p{font-size:1rem;color:rgba(255,255,255,.82);line-height:1.72;max-width:460px;margin-bottom:2rem;}
.hero-actions{display:flex;gap:.85rem;flex-wrap:wrap;}
.hero-stars{display:flex;align-items:center;gap:.65rem;margin-top:1.5rem;}
.hero-stars-s{color:#FFD700;font-size:1.1rem;}
.hero-stars-t{font-size:.8rem;color:rgba(255,255,255,.7);}

.btn-v{display:inline-flex;align-items:center;gap:.45rem;background:var(--verde);color:#fff;padding:.82rem 1.85rem;border-radius:28px;font-size:.85rem;font-weight:600;letter-spacing:.03em;transition:all .22s;border:none;cursor:pointer;}
.btn-v:hover{background:var(--verde2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(30,92,42,.35);}
.btn-o{display:inline-flex;align-items:center;gap:.45rem;border:2px solid rgba(255,255,255,.55);color:#fff;padding:.82rem 1.85rem;border-radius:28px;font-size:.85rem;font-weight:600;letter-spacing:.03em;transition:all .22s;}
.btn-o:hover{border-color:#fff;background:rgba(255,255,255,.1);transform:translateY(-2px);}

/* ---- TICKER ---- */
.ticker{background:var(--verde);overflow:hidden;padding:.68rem 0;}
.ticker-track{display:flex;gap:2rem;width:max-content;animation:tick 32s linear infinite;white-space:nowrap;}
.ticker-track span{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.88);font-weight:500;}
.ticker-track .dot{color:#9dd4a0;}
@keyframes tick{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ---- STATS ---- */
.stats{background:#fff;border-bottom:2px solid var(--crema2);}
.stats-grid{max-width:1240px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:2rem 1.5rem;text-align:center;border-right:1px solid var(--crema2);transition:background .2s;}
.stat:last-child{border:none;}
.stat:hover{background:var(--verde-pale);}
.stat-n{display:block;font-family:"Playfair Display",serif;font-size:2.6rem;font-weight:900;color:var(--verde);line-height:1;}
.stat-l{font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;color:var(--gris2);margin-top:.3rem;display:block;}

/* ---- SHARED SECTION ---- */
.sec{padding:7rem 0;}
.container{max-width:1240px;margin:0 auto;padding:0 2rem;}
.kicker{font-size:.67rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rojo);font-weight:700;display:flex;align-items:center;gap:.5rem;margin-bottom:.65rem;}
.kicker::before{content:"";display:block;width:22px;height:2.5px;background:var(--rojo);border-radius:2px;}
.h2{font-family:"Playfair Display",serif;font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.08;color:var(--negro);margin-bottom:1.35rem;}
.h2 em{font-style:italic;color:var(--verde);}
.body-t{color:var(--gris);line-height:1.85;font-size:.94rem;}

/* ---- NOSOTROS ---- */
.nos-sec{background:var(--crema);}
.nos-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.nos-text p{color:var(--gris);line-height:1.85;font-size:.94rem;margin-bottom:.95rem;}
.nos-text strong{color:var(--verde);}
.chips{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:1.5rem;}
.chip{background:var(--verde-pale);color:var(--verde);padding:.32rem .8rem;border-radius:20px;font-size:.73rem;font-weight:600;letter-spacing:.03em;}
.nos-imgs{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;}
.ni{border-radius:var(--r);overflow:hidden;position:relative;}
.ni img{transition:transform .55s;}
.ni:hover img{transform:scale(1.05);}
.ni-main{grid-column:1/-1;height:300px;}
.ni-sm{height:185px;}
.ni-badge{position:absolute;bottom:.75rem;left:.75rem;background:var(--verde);color:#fff;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;padding:.28rem .7rem;border-radius:18px;font-weight:700;}

/* ---- PIZZAS HIGHLIGHT ---- */
.piz-sec{background:#fff;}
.piz-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:.85rem;}
.pi{border-radius:var(--r);overflow:hidden;position:relative;}
.pi img{transition:transform .5s;}
.pi:hover img{transform:scale(1.05);}
.pi-main{grid-row:1/3;}
.pi-main img{height:440px;}
.pi-sm img{height:210px;}
.pi-cap{position:absolute;bottom:0;left:0;right:0;padding:1.1rem;background:linear-gradient(transparent,rgba(26,18,8,.72));}
.pi-cap p{font-size:.73rem;color:#fff;letter-spacing:.09em;text-transform:uppercase;font-weight:600;}

/* ---- AMBIENTE ---- */
.amb-sec{background:var(--crema);}
.amb-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.85rem;}
.amb-item{border-radius:var(--r);overflow:hidden;position:relative;height:260px;}
.amb-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.amb-item:hover img{transform:scale(1.05);}
.amb-cap{position:absolute;bottom:0;left:0;right:0;padding:.9rem 1rem;background:linear-gradient(transparent,rgba(26,18,8,.7));opacity:0;transition:opacity .3s;}
.amb-item:hover .amb-cap{opacity:1;}
.amb-cap p{color:#fff;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;}

/* ---- HORARIOS / UBI ---- */
.ubi-sec{background:#fff;}
.ubi-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:start;}
.ubi-card{background:var(--crema);border-radius:var(--r);padding:2rem;border:1px solid var(--crema2);}
.ubi-item{display:flex;gap:.9rem;padding:1rem 0;border-bottom:1px solid var(--crema2);}
.ubi-item:last-child{border:none;padding-bottom:0;}
.ubi-ico{width:40px;height:40px;border-radius:10px;background:var(--verde-pale);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0;}
.ubi-item h4{font-size:.67rem;letter-spacing:.16em;text-transform:uppercase;color:var(--verde);font-weight:700;margin-bottom:.3rem;}
.ubi-item p{font-size:.86rem;color:var(--gris);line-height:1.65;}
.ubi-item a{color:var(--verde);font-weight:600;}
.hor-wrap{margin-top:1.5rem;background:var(--crema);border-radius:var(--r);padding:1.5rem;border:1px solid var(--crema2);}
.hor-row{display:flex;justify-content:space-between;align-items:center;padding:.65rem .8rem;border-radius:8px;margin-bottom:.18rem;}
.hor-row:hover{background:var(--verde-pale);}
.hor-hi{background:rgba(30,92,42,.07);}
.hor-day{font-size:.87rem;color:var(--negro);font-weight:500;}
.hor-time{font-size:.8rem;background:var(--rojo);color:#fff;padding:.24rem .85rem;border-radius:15px;font-weight:600;}
.map-wrap{border-radius:var(--r);overflow:hidden;border:2px solid var(--crema2);height:380px;}

/* ---- MENU PAGE ---- */
.menu-header{background:var(--verde);padding:8rem 0 3rem;text-align:center;}
.menu-header h1{font-family:"Playfair Display",serif;font-size:3.5rem;font-weight:900;color:#fff;}
.menu-header em{font-style:italic;color:#9dd4a0;}
.menu-header p{color:rgba(255,255,255,.75);margin-top:.75rem;font-size:.92rem;}
.menu-sticky{background:#fff;border-bottom:2px solid var(--crema2);position:sticky;top:68px;z-index:10;overflow-x:auto;scrollbar-width:none;}
.menu-sticky::-webkit-scrollbar{display:none;}
.menu-tabs{max-width:1240px;margin:0 auto;padding:0 2rem;display:flex;gap:.15rem;white-space:nowrap;}
.mtab{padding:.85rem 1.4rem;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;color:var(--gris2);background:none;border:none;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;margin-bottom:-2px;}
.mtab.act,.mtab:hover{color:var(--verde);border-bottom-color:var(--verde);}
.menu-body{background:var(--crema);}
.mcat{padding:5rem 0 1rem;}
.mcat-head{display:flex;align-items:center;gap:1.5rem;margin-bottom:2.5rem;}
.mcat-line{flex:1;height:1px;background:var(--crema3);}
.mcat-title{font-family:"Playfair Display",serif;font-size:1.85rem;font-weight:700;color:var(--negro);white-space:nowrap;}
.mcat-title em{font-style:italic;color:var(--verde);}

/* pizza cards */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:1.35rem;}
.pc{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:0 2px 18px rgba(0,0,0,.05);transition:transform .3s,box-shadow .3s;border:1px solid rgba(30,92,42,.07);}
.pc:hover{transform:translateY(-7px);box-shadow:0 14px 42px rgba(0,0,0,.11);}
.pc-top{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.25rem .65rem;}
.pc-top h3{font-family:"Playfair Display",serif;font-size:1.08rem;font-weight:700;color:var(--negro);line-height:1.2;}
.pc-price{font-family:"Playfair Display",serif;font-size:1.22rem;font-weight:900;color:var(--verde);white-space:nowrap;margin-left:.65rem;}
.pc-desc{padding:0 1.25rem 1rem;font-size:.79rem;color:var(--gris);line-height:1.65;}
.pc-tags{padding:0 1.25rem 1.25rem;display:flex;gap:.35rem;flex-wrap:wrap;}
.tag{font-size:.61rem;letter-spacing:.07em;text-transform:uppercase;padding:.18rem .55rem;border-radius:10px;font-weight:600;}
.tg{background:var(--verde-pale);color:var(--verde);}
.tr{background:#fef0ee;color:var(--rojo);}
.td{background:#fef9e7;color:var(--dorado);}
.pc-note{font-size:.72rem;color:var(--gris2);font-style:italic;padding:0 1.25rem .85rem;}
.pc-feat{border:2px solid var(--verde)!important;position:relative;}
.pc-feat-badge{position:absolute;top:-11px;left:1.2rem;background:var(--rojo);color:#fff;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .7rem;border-radius:10px;font-weight:700;}

/* entradas */
.egrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(275px,1fr));gap:1.35rem;}
.ec{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:0 2px 18px rgba(0,0,0,.05);transition:transform .3s,box-shadow .3s;border-top:4px solid var(--verde);}
.ec:hover{transform:translateY(-6px);box-shadow:0 12px 38px rgba(0,0,0,.1);}
.ec-img{height:195px;overflow:hidden;display:none;}
.ec-img img{transition:transform .5s;}
.ec:hover .ec-img img{transform:scale(1.06);}
.ec-body{padding:1.2rem;}
.ec-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;}
.ec-top h3{font-family:"Playfair Display",serif;font-size:1.04rem;font-weight:700;color:var(--negro);}
.ec-p{font-family:"Playfair Display",serif;font-size:1.08rem;font-weight:900;color:var(--verde);white-space:nowrap;margin-left:.5rem;}
.ec-desc{font-size:.79rem;color:var(--gris);line-height:1.65;}
.ec-noimg{display:flex;align-items:center;justify-content:center;font-size:4rem;background:var(--crema2);}

/* postres */
.postgrid{display:grid;grid-template-columns:1fr 1fr;gap:1.35rem;}
.postc{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:0 2px 18px rgba(0,0,0,.05);transition:transform .3s;border-top:4px solid var(--rojo);}
.postc:hover{transform:translateY(-6px);}
.postc-img{height:230px;display:none;}
.postc-body{padding:1.2rem;}
.postc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;}
.postc-top h3{font-family:"Playfair Display",serif;font-size:1.05rem;font-weight:700;color:var(--negro);}
.postc-desc{font-size:.79rem;color:var(--gris);line-height:1.65;}

/* bebidas */
.beb-2col{display:grid;grid-template-columns:1fr 1fr;gap:3rem;}
.beb-col h3{font-family:"Playfair Display",serif;font-size:1.4rem;font-weight:700;margin-bottom:1.25rem;}
.beb-col h3 em{font-style:italic;color:var(--verde);}
.bitem{display:flex;justify-content:space-between;align-items:center;padding:.72rem 0;border-bottom:1px dashed var(--crema3);}
.bitem:last-child{border:none;}
.bname{font-size:.9rem;color:var(--negro);font-weight:500;}
.bsub{font-size:.73rem;color:var(--gris2);}
.bprice{font-size:.87rem;font-weight:700;color:var(--verde);white-space:nowrap;margin-left:1rem;}

/* extras */
.extbox{background:#fff;border-radius:var(--r);padding:2rem;box-shadow:0 2px 18px rgba(0,0,0,.05);border:2px dashed var(--crema3);}
.extbox h3{font-family:"Playfair Display",serif;font-size:1.3rem;font-weight:700;margin-bottom:1.35rem;}
.ext2{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
.extlbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gris2);font-weight:600;margin-bottom:.7rem;}
.extlist{display:flex;flex-direction:column;gap:.4rem;}
.extitem{display:flex;justify-content:space-between;font-size:.85rem;padding:.38rem 0;border-bottom:1px solid var(--crema2);}
.extitem:last-child{border:none;}
.exval{font-weight:700;color:var(--rojo);}

/* ---- GALLERY PAGE ---- */
.gal-header{background:var(--negro);padding:8rem 0 3rem;text-align:center;}
.gal-header h1{font-family:"Playfair Display",serif;font-size:3rem;font-weight:900;color:#fff;}
.gal-header em{font-style:italic;color:#9dd4a0;}
.gal-header p{color:rgba(255,255,255,.65);margin-top:.75rem;}
.gal-body{background:var(--crema);padding:4rem 0 6rem;}
.masonry{columns:3;gap:1rem;}
.mi{break-inside:avoid;margin-bottom:1rem;border-radius:var(--r);overflow:hidden;position:relative;}
.mi img{width:100%;display:block;transition:transform .5s;}
.mi:hover img{transform:scale(1.04);}
.mi-cap{position:absolute;bottom:0;left:0;right:0;padding:.85rem 1rem;background:linear-gradient(transparent,rgba(26,18,8,.72));opacity:0;transition:opacity .3s;}
.mi:hover .mi-cap{opacity:1;}
.mi-cap p{color:#fff;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;}

/* ---- FOOTER ---- */
.footer{background:var(--negro);padding:4.5rem 0 2rem;}
.ftgrid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:4rem;margin-bottom:3rem;}
.ft-logo{font-family:"Playfair Display",serif;font-size:2rem;font-weight:900;color:#fff;margin-bottom:.65rem;display:block;}
.ft-logo em{font-style:italic;color:#9dd4a0;}
.ft-brand p{font-size:.84rem;color:rgba(255,255,255,.5);line-height:1.75;}
.ft-ig{display:inline-flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.55);font-size:.8rem;margin-top:1rem;transition:color .2s;}
.ft-ig:hover{color:#9dd4a0;}
.ft-col h5{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:#9dd4a0;margin-bottom:1.2rem;font-weight:600;}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:.55rem;}
.ft-col li a{font-size:.86rem;color:rgba(255,255,255,.5);transition:color .2s;cursor:pointer;}
.ft-col li a:hover{color:#fff;}
.ft-col p{font-size:.84rem;color:rgba(255,255,255,.5);line-height:1.7;}
.ft-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:1.5rem;display:flex;justify-content:space-between;font-size:.74rem;color:rgba(255,255,255,.28);}

/* REVEALS */
.fu{opacity:0;transform:translateY(32px);transition:opacity .85s cubic-bezier(.4,0,.2,1),transform .85s cubic-bezier(.4,0,.2,1);}
.fu.in{opacity:1;transform:none;}

/* RESPONSIVE */
@media(max-width:980px){
  .nav-links,.nav-cta{display:none;}
  .burger{display:flex;}
  .nos-grid,.ubi-grid,.beb-2col{grid-template-columns:1fr;gap:2.5rem;}
  .masonry{columns:2;}
  .ftgrid{grid-template-columns:1fr;gap:2.5rem;}
  .ft-bottom{flex-direction:column;gap:.5rem;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .piz-grid{grid-template-columns:1fr 1fr;}
  .pi-main{grid-column:1/-1;grid-row:auto;}
  .pi-main img{height:280px;}
  .amb-3{grid-template-columns:1fr 1fr;}
  .ext2{grid-template-columns:1fr;}
  .postgrid{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .masonry{columns:1;}
  .pgrid{grid-template-columns:1fr;}
  .egrid{grid-template-columns:1fr;}
  .piz-grid{grid-template-columns:1fr;}
  .amb-3{grid-template-columns:1fr;}
}

/* ===== LOADING SCREEN ===== */
#loader{
  position:fixed;inset:0;z-index:9999;
  background:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1.5rem;
  transition:opacity .7s ease, visibility .7s ease;
}
#loader.hide{opacity:0;visibility:hidden;pointer-events:none;}

.loader-logo-img{
  width:220px;height:auto;
  animation:loaderPop .7s cubic-bezier(.34,1.56,.64,1) both;
  filter:drop-shadow(0 6px 24px rgba(30,92,42,.2));
}
@keyframes loaderPop{
  0%{transform:scale(.4) translateY(20px);opacity:0;}
  100%{transform:scale(1) translateY(0);opacity:1;}
}

.loader-name{
  font-family:"Playfair Display",serif;
  font-size:3.5rem;font-weight:900;
  color:#1E5C2A;letter-spacing:.02em;
  animation:loaderFadeUp .5s ease .3s both;
  line-height:1;
}
.loader-name em{font-style:italic;color:#C5301E;}

.loader-tagline{
  font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;
  color:#aaa;font-family:"DM Sans",sans-serif;
  animation:loaderFadeUp .5s ease .45s both;
}

@keyframes loaderFadeUp{
  0%{transform:translateY(12px);opacity:0;}
  100%{transform:translateY(0);opacity:1;}
}

.loader-bar-wrap{
  width:200px;height:3px;background:#eee;border-radius:3px;overflow:hidden;
  animation:loaderFadeUp .4s ease .5s both;
}
.loader-bar{
  height:100%;width:0%;
  background:linear-gradient(90deg,#1E5C2A,#C5301E);
  border-radius:3px;
  animation:loaderFill 2s cubic-bezier(.4,0,.2,1) .5s forwards;
}
@keyframes loaderFill{0%{width:0%}100%{width:100%}}


/* ===== WHATSAPP FLOAT BUTTON ===== */
.wa-float{
  position:fixed;bottom:2rem;right:2rem;z-index:500;
  display:flex;align-items:center;gap:.6rem;
  background:#25D366;color:#fff;
  padding:.7rem 1.25rem .7rem .85rem;
  border-radius:50px;
  box-shadow:0 6px 28px rgba(37,211,102,.45);
  font-size:.83rem;font-weight:700;letter-spacing:.02em;
  transition:transform .2s,box-shadow .2s;
  text-decoration:none;
  font-family:"DM Sans",sans-serif;
}
.wa-float:hover{
  transform:translateY(-3px) scale(1.03);
  box-shadow:0 10px 36px rgba(37,211,102,.55);
  color:#fff;
}
.wa-float svg{width:24px;height:24px;flex-shrink:0;}
@media(max-width:600px){
  .wa-float span{display:none;}
  .wa-float{padding:.75rem;border-radius:50%;width:52px;height:52px;justify-content:center;}
}





/* ---- NAV LOGO ---- */
.nav-logo-img{
  width:46px;height:46px;
  object-fit:contain;flex-shrink:0;
  display:block;
}
.logo-text-wrap{display:flex;flex-direction:column;line-height:1;}
.logo-name{font-family:"Playfair Display",serif;font-size:1.18rem;font-weight:900;color:var(--verde);letter-spacing:.02em;}
.logo-name em{font-style:italic;}
.logo-sub{font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris2);margin-top:.15rem;}

/* ---- LOADER LOGO ---- */
.loader-icon-wrap img{
  width:240px;height:auto;
  display:block;
  filter:drop-shadow(0 6px 20px rgba(30,92,42,.18));
}


/* Fix pi-cap hover overlay */
.pi{position:relative;overflow:hidden;}
.pi-cap{
  position:absolute;bottom:0;left:0;right:0;
  padding:1rem 1.25rem;
  background:linear-gradient(transparent, rgba(26,18,8,.75));
  opacity:0;
  transition:opacity .3s ease;
  z-index:2;
}
.pi:hover .pi-cap{opacity:1;}
.pi-cap p{
  color:#fff;
  font-size:.8rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
  margin:0;
}
/* Ensure menu page doesn't overflow onto home */
#page-menu{isolation:isolate;}
#page-inicio{isolation:isolate;}


/* ===== FOOD PHOTO GRID ===== */
.food-sec{background:#fff;overflow:hidden;}
.food-grid-wrap{padding:0 2rem;max-width:1400px;margin:0 auto;}
.food-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto;
  gap:.85rem;
}
.fg-item{border-radius:14px;overflow:hidden;position:relative;}
.fg-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.4,0,.2,1);}
.fg-item:hover img{transform:scale(1.07);}
.fg-tall{grid-row:span 2;min-height:480px;}
.fg-norm{min-height:230px;}
.fg-wide{grid-column:span 2;min-height:230px;}

/* ===== SCROLL REVEAL ANIMATIONS ===== */
.reveal-fade{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1);}
.reveal-slide-left{opacity:0;transform:translateX(-50px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1);}
.reveal-slide-right{opacity:0;transform:translateX(50px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1);}
.reveal-slide-up{opacity:0;transform:translateY(50px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1);}
.revealed{opacity:1!important;transform:none!important;}

/* ===== ENHANCED SECTION TRANSITIONS ===== */
.sec{position:relative;}

/* Parallax tilt on stat items */
.stat{cursor:default;}
.stat:hover .stat-n{transform:scale(1.1);display:inline-block;}
.stat-n{transition:transform .3s cubic-bezier(.34,1.56,.64,1);}

/* Card hover lift for all cards */
.pc:hover,.ec:hover,.postc:hover,.tcard:hover{
  transform:translateY(-8px) scale(1.01)!important;
}

/* Smooth image parallax for hero */
@media(prefers-reduced-motion:no-preference){
  .hero-bg img{will-change:transform;}
}

/* Section entrance animations */
.nos-grid .nos-text{
  opacity:0;transform:translateX(-40px);
  transition:opacity .9s cubic-bezier(.4,0,.2,1) .1s,transform .9s cubic-bezier(.4,0,.2,1) .1s;
}
.nos-grid .nos-imgs{
  opacity:0;transform:translateX(40px);
  transition:opacity .9s cubic-bezier(.4,0,.2,1) .2s,transform .9s cubic-bezier(.4,0,.2,1) .2s;
}
.nos-grid.revealed .nos-text,.nos-grid.revealed .nos-imgs{opacity:1;transform:none;}

/* Stagger for stat items */
.stat:nth-child(1){transition-delay:.05s;}
.stat:nth-child(2){transition-delay:.15s;}
.stat:nth-child(3){transition-delay:.25s;}
.stat:nth-child(4){transition-delay:.35s;}

/* Photo hover scale ring */
.fg-item::after{
  content:"";position:absolute;inset:0;border-radius:14px;
  box-shadow:inset 0 0 0 0 rgba(30,92,42,.3);
  transition:box-shadow .3s;
  pointer-events:none;
}
.fg-item:hover::after{box-shadow:inset 0 0 0 3px rgba(30,92,42,.4);}

@media(max-width:768px){
  .food-grid{grid-template-columns:repeat(2,1fr);}
  .fg-tall{grid-row:span 1;min-height:220px;}
  .fg-wide{grid-column:span 2;}
  
}
@media(max-width:480px){
  .food-grid{grid-template-columns:1fr;}
  .fg-wide{grid-column:span 1;}
}


/* ===== SECTION ISOLATION ===== */
#page-inicio, #page-menu, #page-galeria {
  isolation: isolate;
  position: relative;
  z-index: 0;
}
.page { overflow: hidden; }
.food-grid-wrap { position: relative; z-index: 1; }


/* ===== AUTENTICIDAD ===== */
.autent-sec{background:#fff;}
.autent-header{text-align:center;margin-bottom:4rem;}
.autent-main-grid{display:grid;grid-template-columns:1fr 320px;gap:4rem;align-items:start;margin-bottom:5rem;}
.autent-historia-text{font-size:1rem;color:var(--gris);line-height:1.85;margin-bottom:1.25rem;max-width:560px;}
.autent-historia-text em{font-style:italic;color:var(--verde);font-weight:500;}
.autent-credenciales{display:flex;flex-direction:column;gap:.85rem;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--crema2);}
.autent-cred-item{display:flex;align-items:center;gap:.85rem;}
.autent-cred-icon{font-size:1.4rem;flex-shrink:0;width:42px;height:42px;display:grid;place-items:center;background:var(--verde-pale);border-radius:10px;}
.autent-cred-item strong{display:block;font-size:.88rem;font-weight:700;color:var(--negro);line-height:1.2;}
.autent-cred-item span{font-size:.76rem;color:var(--gris2);letter-spacing:.03em;}
.autent-chef-wrap{position:sticky;top:100px;}
.autent-chef-card{border-radius:16px;overflow:hidden;box-shadow:0 12px 48px rgba(0,0,0,.12);background:var(--crema);}
.autent-chef-img{width:100%;height:380px;object-fit:cover;object-position:center top;display:block;transition:transform .6s cubic-bezier(.4,0,.2,1);}
.autent-chef-card:hover .autent-chef-img{transform:scale(1.03);}
.autent-chef-caption{padding:1rem 1.25rem;border-top:1px solid var(--crema2);display:flex;flex-direction:column;}
.autent-chef-caption strong{font-size:.9rem;font-weight:700;color:var(--negro);}
.autent-chef-caption span{font-size:.75rem;color:var(--verde);letter-spacing:.06em;text-transform:uppercase;margin-top:.2rem;}
.autent-certs-wrap{padding-top:4rem;border-top:1px solid var(--crema2);}
.autent-certs-label{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gris2);text-align:center;margin-bottom:2rem;font-weight:600;}
.autent-certs-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:860px;margin:0 auto;}
.autent-cert-card{background:var(--crema);border:1px solid var(--crema2);border-radius:14px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.07);transition:transform .3s,box-shadow .3s;}
.autent-cert-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.13);}
.autent-cert-img-wrap{padding:1.5rem 1.5rem 0;background:white;}
.autent-cert-img-wrap img{width:100%;height:auto;object-fit:contain;display:block;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.1);max-height:240px;}
.autent-cert-info{padding:1rem 1.25rem 1.25rem;display:flex;flex-direction:column;gap:.2rem;}
.autent-cert-info strong{font-size:.88rem;font-weight:700;color:var(--negro);}
.autent-cert-info span{font-size:.73rem;color:var(--gris2);}
@media(max-width:900px){.autent-main-grid{grid-template-columns:1fr;gap:3rem;}.autent-chef-wrap{position:static;}.autent-chef-img{height:300px;}.autent-certs-grid{grid-template-columns:1fr 1fr;gap:1.25rem;}}
@media(max-width:580px){.autent-certs-grid{grid-template-columns:1fr;}}

/* ===== PIZZAS 3-GRID ===== */
.pizzas-3grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start;}
.p3-item{border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 4px 24px rgba(0,0,0,.07);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s;}
.p3-item:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.13);}
.p3-featured{transform:scale(1.03);box-shadow:0 8px 36px rgba(30,92,42,.15);border:2px solid rgba(30,92,42,.15);}
.p3-featured:hover{transform:scale(1.03) translateY(-6px);}
.p3-img-wrap{aspect-ratio:1/1;overflow:hidden;}
.p3-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1);display:block;}
.p3-item:hover .p3-img-wrap img{transform:scale(1.06);}
.p3-caption{padding:1.1rem 1.25rem 1.25rem;border-top:1px solid var(--crema2);}
.p3-caption strong{display:block;font-family:"Playfair Display",serif;font-size:1.05rem;font-weight:700;color:var(--negro);margin-bottom:.25rem;}
.p3-caption span{font-size:.78rem;color:var(--gris2);line-height:1.5;}
@media(max-width:720px){.pizzas-3grid{grid-template-columns:1fr;}.p3-featured{transform:none;}}

/* ===== RAPPI BUTTON ===== */
.rappi-float{position:fixed;bottom:5.5rem;right:2rem;z-index:500;display:flex;align-items:center;gap:.6rem;background:#FF441B;color:#fff;padding:.7rem 1.25rem .7rem .85rem;border-radius:50px;box-shadow:0 6px 28px rgba(255,68,27,.45);font-size:.83rem;font-weight:700;letter-spacing:.02em;text-decoration:none;font-family:"DM Sans",sans-serif;transition:transform .2s,box-shadow .2s;}
.rappi-float:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 10px 36px rgba(255,68,27,.55);color:#fff;}
@media(max-width:600px){.rappi-float span{display:none;}.rappi-float{padding:.75rem;border-radius:50%;width:52px;height:52px;justify-content:center;bottom:5.5rem;}}

/* ===== REVEAL SAFETY ===== */
.page.active .fu{animation:fuAutoReveal .6s ease forwards;animation-delay:1.2s;}
.page.active .fu.in{animation:none;opacity:1;transform:none;}
@keyframes fuAutoReveal{from{opacity:0;transform:translateY(35px);}to{opacity:1;transform:none;}}
.page.active .reveal-fade,.page.active .reveal-slide-left,.page.active .reveal-slide-right,.page.active .reveal-slide-up{animation:fuAutoReveal .6s ease forwards;animation-delay:1.4s;}
.page.active .reveal-fade.revealed,.page.active .reveal-slide-left.revealed,.page.active .reveal-slide-right.revealed,.page.active .reveal-slide-up.revealed{animation:none;opacity:1;transform:none;}

/* ===== MENU EXTRA ===== */
.menu-note{text-align:center;color:var(--gris2);font-size:.85rem;margin-bottom:2rem;}
.cat-sub{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:#2a4f8a;font-weight:700;margin-bottom:1.25rem;display:block;}
.pc-tags{display:flex;gap:.4rem;flex-wrap:wrap;padding:0 1.25rem 1.25rem;}
.tag-d{background:#fef9e7;color:#B8860B;border-color:rgba(184,134,11,.3)!important;}
.pc-note{font-size:.72rem;color:var(--gris2);font-style:italic;padding:0 1.25rem .5rem;}


/* ===== LANGUAGE SWITCHER ===== */
.lang-switcher {
  position: fixed;
  bottom: 2rem;
  left: 2rem;
  z-index: 500;
  display: flex;
  align-items: center;
  gap: .4rem;
  background: rgba(255,251,245,.95);
  backdrop-filter: blur(10px);
  border: 1px solid var(--crema2);
  border-radius: 30px;
  padding: .35rem .5rem;
  box-shadow: 0 4px 20px rgba(0,0,0,.1);
}
.lang-btn {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .38rem .75rem;
  border-radius: 22px;
  border: none;
  background: none;
  cursor: pointer;
  font-size: .75rem;
  font-weight: 600;
  color: var(--gris2);
  letter-spacing: .04em;
  transition: all .2s;
  font-family: "DM Sans", sans-serif;
}
.lang-btn:hover { color: var(--negro); background: var(--crema2); }
.lang-btn.active {
  background: var(--verde);
  color: #fff;
}
.lang-btn .flag { font-size: 1rem; line-height: 1; }
@media (max-width: 600px) {
  .lang-switcher { bottom: 1rem; left: 1rem; padding: .28rem .4rem; }
  .lang-btn { padding: .3rem .55rem; font-size: .7rem; }
}


/* ===== CARD LAYOUT FIXES ===== */
.menu-body { padding: 0; }
.menu-body .container { padding: 2rem 3rem; max-width: 1240px; }
.pgrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.35rem;
}
/* Fix price overflow on long price_text cards */
.pc-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: .75rem;
  padding: 1.25rem 1.25rem .65rem;
  flex-wrap: nowrap;
}
.pc-top h3 {
  font-family: "Playfair Display", serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--negro);
  line-height: 1.25;
  flex: 1;
  min-width: 0;
}
.pc-price {
  font-family: "Playfair Display", serif;
  font-size: 1.1rem;
  font-weight: 900;
  color: var(--verde);
  white-space: nowrap;
  flex-shrink: 0;
  max-width: 50%;
  text-align: right;
  font-size: .95rem;
}
/* For the Tagliere long price — wrap it nicely */
.pc-price-long {
  font-family: "Playfair Display", serif;
  font-size: .82rem;
  font-weight: 900;
  color: var(--verde);
  white-space: normal;
  flex-shrink: 0;
  max-width: 55%;
  text-align: right;
  line-height: 1.3;
}
@media (max-width: 900px) {
  .menu-body .container { padding: 1.5rem; }
}
@media (max-width: 600px) {
  .menu-body .container { padding: 1rem; }
  .pgrid { grid-template-columns: 1fr; }
}


/* ===== VINOS SECTION ===== */
.vinos-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1.75rem;
  max-width: 1000px;
  margin: 0 auto;
}
.vino-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem 1.5rem 1.75rem;
  text-align: center;
  box-shadow: 0 4px 24px rgba(0,0,0,.07);
  border: 1px solid var(--crema2);
  transition: transform .3s, box-shadow .3s;
  position: relative;
  overflow: hidden;
}
.vino-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--rojo), #8B1A1A);
}
.vino-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 42px rgba(0,0,0,.12);
}
.vino-region-badge {
  display: inline-block;
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--rojo);
  font-weight: 700;
  margin-bottom: 1rem;
  padding: .25rem .7rem;
  border: 1px solid rgba(197,48,30,.25);
  border-radius: 20px;
}
.vino-icon {
  font-size: 2.2rem;
  margin-bottom: 1rem;
  line-height: 1;
}
.vino-name {
  font-family: "Playfair Display", serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--negro);
  margin-bottom: .3rem;
  line-height: 1.25;
}
.vino-doc {
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gris2);
  font-weight: 600;
  margin-bottom: .85rem;
}
.vino-desc {
  font-size: .82rem;
  color: var(--gris);
  line-height: 1.7;
}
@media (max-width: 760px) {
  .vinos-grid { grid-template-columns: 1fr; max-width: 420px; }
}

/* ===== CERVEZAS SECTION ===== */
.cervezas-wrap {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 3.5rem;
  align-items: center;
  max-width: 900px;
  margin: 0 auto;
}
.cerveza-img-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
}
.cerveza-img {
  width: 100%;
  max-width: 280px;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 12px 32px rgba(0,0,0,.18));
  transition: transform .4s cubic-bezier(.34,1.2,.64,1);
}
.cerveza-img:hover { transform: scale(1.04) rotate(-1deg); }
.cerveza-lista {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.cerveza-item {
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--crema2);
}
.cerveza-item:last-child { border: none; padding-bottom: 0; }
.cerveza-item h3 {
  font-family: "Playfair Display", serif;
  font-size: 1.08rem;
  font-weight: 700;
  color: var(--negro);
  margin-bottom: .4rem;
}
.cerveza-item p {
  font-size: .85rem;
  color: var(--gris);
  line-height: 1.7;
}
@media (max-width: 700px) {
  .cervezas-wrap {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .cerveza-img { max-width: 220px; margin: 0 auto; }
}


/* ===== CERT LINK BUTTON ===== */
.cert-link-btn {
  display: inline-block;
  margin-top: .75rem;
  padding: .45rem 1rem;
  background: var(--verde);
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .04em;
  border-radius: 20px;
  text-decoration: none;
  transition: background .2s, transform .2s;
}
.cert-link-btn:hover {
  background: var(--verde2, #2d7a3a);
  transform: translateY(-2px);
  color: #fff;
}
@media (max-width: 900px) {
  .autent-certs-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 580px) {
  .autent-certs-grid { grid-template-columns: 1fr; }
}
body{overflow-x:clip;}html{overflow-x:clip;}::selection{background:var(--verde);color:#fff;}#loader{animation:loaderSafety .01s 4.5s forwards;}@keyframes loaderSafety{to{opacity:0;pointer-events:none;visibility:hidden;}}