:root{
  --naranja:#E35205;--naranja-vivo:#FF6A00;--ambar:#F59E0B;
  --tinta:#171210;--tinta-2:#3a322d;--gris:#7a6f68;--gris-claro:#efe9e3;
  --linea:rgba(23,18,16,.12);--crema:#FCF8F3;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',sans-serif;background:#fff;color:var(--tinta);line-height:1.65;-webkit-font-smoothing:antialiased}
::selection{background:var(--naranja);color:#fff}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}

.topbar{background:var(--tinta);color:#fff;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;text-align:center;padding:9px 12px;font-weight:500}
.topbar span{color:var(--ambar)}

.brand{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;max-width:1200px;margin:0 auto}
.logo{display:flex;align-items:center;gap:13px;text-decoration:none;color:inherit}
.logo svg{width:42px;height:42px;color:var(--naranja)}
.logo .txt b{font-family:'Space Grotesk',sans-serif;font-weight:900;font-size:1.35rem;letter-spacing:-.01em;display:block;line-height:1}
.logo .txt small{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gris)}
.brand nav a{font-size:.85rem;font-weight:500;color:var(--tinta-2);text-decoration:none;margin-left:26px;transition:color .2s}
.brand nav a:hover{color:var(--naranja)}
@media(max-width:680px){.brand nav{display:none}}

/* ---------- SLIDER ---------- */
.hero{border-top:1px solid var(--linea)}
.slider{position:relative;height:min(64vh,560px);overflow:hidden;background:var(--tinta)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;background-size:cover;background-position:center;
  display:flex;align-items:center;background-image:linear-gradient(135deg,var(--g1,#FF8A33),var(--g2,#E35205))}
.slide.activo{opacity:1}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,14,11,.78) 0%,rgba(20,14,11,.45) 45%,rgba(20,14,11,.15) 100%)}
.slide-cap{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 48px;width:100%;color:#fff}
.slide-cap .kicker{display:inline-flex;align-items:center;gap:9px;font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--ambar);font-weight:600;margin-bottom:18px}
.slide-cap .kicker::before{content:"";width:34px;height:2px;background:var(--ambar)}
.slide-cap h1{font-family:'Space Grotesk',sans-serif;font-weight:900;font-size:clamp(2.6rem,7vw,5.4rem);line-height:.96;letter-spacing:-.02em;max-width:16ch}
.slide-cap h1 em{font-style:italic;font-weight:400;color:var(--ambar)}
.slide-cap p{max-width:520px;margin-top:18px;font-size:1.12rem;font-weight:300;opacity:.95}
.hero-cta{margin-top:28px;display:flex;gap:14px;flex-wrap:wrap}
.btn{font-family:'Hanken Grotesk',sans-serif;font-size:.92rem;font-weight:600;padding:13px 26px;border-radius:999px;text-decoration:none;cursor:pointer;border:2px solid #fff;transition:all .2s;display:inline-block}
.btn-primario{background:var(--naranja);border-color:var(--naranja);color:#fff}
.btn-primario:hover{background:var(--naranja-vivo);border-color:var(--naranja-vivo)}
.btn-ghost{background:transparent;color:#fff}
.btn-ghost:hover{background:#fff;color:var(--tinta)}
.slider-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:rgba(255,255,255,.18);color:#fff;border:none;width:46px;height:46px;border-radius:50%;cursor:pointer;font-size:1.1rem;backdrop-filter:blur(4px);transition:background .2s}
.slider-nav:hover{background:var(--naranja)}
.slider-nav.prev{left:22px}.slider-nav.next{right:22px}
.slider-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:9px}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.45);cursor:pointer;transition:all .25s}
.dot.activo{background:#fff;width:26px;border-radius:6px}
.hero-stats{display:flex;gap:42px;padding-top:30px;padding-bottom:30px;flex-wrap:wrap}
.stat b{font-family:'Space Grotesk',sans-serif;font-size:2.4rem;font-weight:600;color:var(--naranja);display:block;line-height:1}
.stat span{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gris)}

.secc-head{text-align:center;max-width:640px;margin:0 auto 40px}
.secc-head .et{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--naranja);font-weight:600}
.secc-head h2{font-family:'Space Grotesk',sans-serif;font-size:clamp(2rem,4vw,2.9rem);font-weight:600;margin:8px 0;letter-spacing:-.01em}
.secc-head p{color:var(--gris);font-weight:300}

.top{padding:64px 0 10px}
.top-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));max-width:1200px;margin:0 auto;padding:0 28px}
.top-card{position:relative;border-radius:20px;overflow:hidden;color:#fff;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;
  background-size:cover;background-position:center;background-image:linear-gradient(135deg,#FF8A33,#E35205);box-shadow:0 22px 44px -22px rgba(227,82,5,.6);transition:transform .3s}
.top-card.dark{background-image:linear-gradient(135deg,#FF6A00,#1c1310)}
.top-card.alt{background-image:linear-gradient(135deg,#F59E0B,#E35205)}
.top-card:hover{transform:translateY(-7px)}
.top-card .bigglifo{position:absolute;top:26px;right:24px;font-size:5rem;opacity:.92;filter:drop-shadow(0 6px 10px rgba(0,0,0,.35));z-index:2}
.top-card .rank{position:absolute;top:22px;left:24px;z-index:3;font-family:'Space Grotesk',sans-serif;font-size:1.1rem;font-weight:600;background:rgba(0,0,0,.3);padding:5px 13px;border-radius:999px;backdrop-filter:blur(3px)}
.top-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,14,11,.72) 0%,transparent 55%)}
.top-card .tcb{position:relative;z-index:3;padding:26px}
.top-card .score{display:flex;align-items:baseline;gap:6px;margin-bottom:8px}
.top-card .score b{font-family:'Space Grotesk',sans-serif;font-size:2.4rem;font-weight:600;line-height:1}
.top-card .score .of{opacity:.8;font-size:.9rem}
.top-card .stars{font-size:.9rem;letter-spacing:1px;margin-left:6px;color:var(--ambar)}
.top-card h3{font-family:'Space Grotesk',sans-serif;font-size:1.9rem;font-weight:600;line-height:1.04}
.top-card .reg{font-size:.8rem;font-weight:600;opacity:.95;letter-spacing:.04em;margin-top:5px;display:flex;align-items:center;gap:5px}

.guia{padding:70px 0 78px;background:var(--crema);margin-top:60px}
.filtros{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:42px}
.filtro{font-size:.85rem;font-weight:500;padding:9px 20px;border-radius:999px;cursor:pointer;border:1px solid var(--linea);background:#fff;color:var(--tinta-2);transition:all .2s}
.filtro:hover{border-color:var(--naranja);color:var(--naranja)}
.filtro.activo{background:var(--tinta);color:#fff;border-color:var(--tinta)}
.grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));max-width:1200px;margin:0 auto;padding:0 28px}
.card{background:#fff;border:1px solid var(--linea);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s,border-color .3s;animation:rise .55s both}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.card:hover{transform:translateY(-7px);box-shadow:0 24px 50px -22px rgba(227,82,5,.45);border-color:transparent}
.card-top{height:138px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background-size:cover;background-position:center;background-image:linear-gradient(135deg,#FF8A33,#E35205)}
.card-top.alt{background-image:linear-gradient(135deg,#F59E0B,#E35205)}
.card-top.dark{background-image:linear-gradient(135deg,#FF6A00,#1c1310)}
.card-top .glifo{font-size:3.5rem;z-index:2;filter:drop-shadow(0 4px 7px rgba(0,0,0,.3))}
.num{position:absolute;top:12px;left:16px;z-index:3;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1.05rem;color:#fff;opacity:.92}
.rate-badge{position:absolute;bottom:12px;right:14px;z-index:3;display:flex;align-items:center;gap:4px;background:#fff;color:var(--tinta);padding:4px 11px;border-radius:999px;font-size:.82rem;font-weight:700;box-shadow:0 3px 10px rgba(0,0,0,.18)}
.rate-badge .st{color:var(--ambar)}
.cat-tag{position:absolute;top:13px;right:14px;z-index:3;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;background:rgba(255,255,255,.92);color:var(--tinta);padding:4px 10px;border-radius:999px}
.card-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.card-body h3{font-family:'Space Grotesk',sans-serif;font-size:1.5rem;font-weight:600;line-height:1.06;margin-bottom:8px}
.origen{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;color:var(--naranja);margin-bottom:13px}
.desc{font-size:.93rem;color:var(--gris);font-weight:300;flex:1}

.mapa-wrap{background:var(--tinta);padding:78px 0}
.mapa-wrap .secc-head .et{color:var(--ambar)}
.mapa-wrap .secc-head h2{color:#fff}
.mapa-wrap .secc-head p{color:rgba(255,255,255,.55)}
#mapa-canvas{height:540px;border-radius:18px;overflow:hidden;max-width:1140px;margin:0 auto;border:1px solid rgba(255,255,255,.12)}
.pop h4{font-family:'Space Grotesk',sans-serif;font-size:1.2rem;color:var(--naranja);margin-bottom:4px}
.pop ul{margin:6px 0 0;padding-left:16px;font-size:.85rem;color:#333}
.pin-monarca{background:var(--naranja);width:26px;height:26px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2.5px solid #fff;box-shadow:0 3px 8px rgba(0,0,0,.5)}
.leaflet-popup-content-wrapper{border-radius:12px}

.patro{padding:78px 0;text-align:center}
.patro .et{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--naranja);font-weight:600}
.patro h2{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:600;margin:10px 0 6px}
.patro .sub{color:var(--gris);font-weight:300;max-width:560px;margin:0 auto 40px}
.slots{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));max-width:880px;margin:0 auto}
.slot{border:2px dashed var(--linea);border-radius:14px;height:108px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--gris);transition:all .25s;text-decoration:none}
.slot:hover{border-color:var(--naranja);color:var(--naranja);background:var(--crema)}
.slot.lleno{border-style:solid;border-color:var(--linea)}
.slot img{max-height:64px;max-width:80%;object-fit:contain}
.slot span{font-size:.74rem;letter-spacing:.08em;font-weight:500}
.patro-note{margin-top:34px;font-size:.86rem;color:var(--gris)}
.patro-note a{color:var(--naranja);font-weight:600;text-decoration:none}

footer{background:var(--tinta);color:rgba(255,255,255,.6);padding:54px 0 46px;font-size:.86rem;font-weight:300}
.foot-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-grid .logo .txt b{color:#fff}
.foot-grid .logo .txt small{color:var(--ambar)}
.foot-grid p{max-width:300px;margin-top:14px}
.foot-cols{display:flex;gap:54px;flex-wrap:wrap}
.foot-cols h5{color:#fff;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:12px;font-weight:600}
.foot-cols a{display:block;color:rgba(255,255,255,.6);text-decoration:none;margin-bottom:7px;transition:color .2s}
.foot-cols a:hover{color:var(--ambar)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.78rem}

/* ---- Monograma fallback cuando el platillo no tiene foto ---- */
.card-top .glifo,.top-card .bigglifo{font-family:'Space Grotesk',sans-serif;font-weight:700;color:rgba(255,255,255,.92)}
.card-top .glifo{font-size:3.6rem;line-height:1}
.top-card .bigglifo{font-size:5.5rem;line-height:1}