/* ── RESET ─────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,sans-serif;background:#f5f5f5;color:#222;padding-bottom:90px}

/* ── HEADER ────────────────────────────────────── */
.header{background:#075E54;position:sticky;top:0;z-index:300;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.header-inner{max-width:1300px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px}
.menu-btn{background:rgba(255,255,255,.15);border:none;color:#fff;font-size:20px;width:38px;height:38px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0}
.menu-btn:hover{background:rgba(255,255,255,.28)}
.logo-badge{width:36px;height:36px;border-radius:10px;background:#25D366;color:#fff;font-size:18px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:-1px}
.logo-name{color:#fff;font-size:17px;font-weight:700;line-height:1.1}
.logo-sub{color:#B2DFDB;font-size:11px}
.cart-btn{background:rgba(255,255,255,.15);border:none;color:#fff;font-size:20px;padding:8px 14px;border-radius:24px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:.2s;white-space:nowrap}
.cart-btn:hover{background:rgba(255,255,255,.28)}
.cart-badge{background:#25D366;color:#fff;font-size:12px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px}

/* ── HERO ──────────────────────────────────────── */
.hero{background:linear-gradient(135deg,#075E54 0%,#128C7E 60%,#25D366 100%);padding:36px 16px 44px;text-align:center}
.hero-inner{max-width:600px;margin:0 auto}
.hero h1{color:#fff;font-size:clamp(22px,5vw,38px);line-height:1.2;margin-bottom:10px}
.hero h1 span{color:#B2DFDB}
.hero p{color:rgba(255,255,255,.85);font-size:14px;margin-bottom:18px}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.hero-badges span{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.3);padding:5px 13px;border-radius:20px;font-size:12px}

/* ── HORARIOS BAR ──────────────────────────────── */
.horarios-bar{background:#fff;border-bottom:1px solid #e8e8e8;padding:10px 16px}
.horarios-inner{max-width:1300px;margin:0 auto;display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:13px;color:#555}
.horario-item{display:flex;align-items:center;gap:6px}
.horario-sep{color:#ddd;font-size:16px}
.estado-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}
.estado-dot.abierto{background:#25D366;box-shadow:0 0 0 3px rgba(37,211,102,.2)}
.estado-dot.cerrado{background:#e53935;box-shadow:0 0 0 3px rgba(229,57,53,.15)}
@media(max-width:600px){.horario-sep{display:none}.horarios-inner{gap:8px;font-size:12px}}

/* ── BANNER OFERTA ─────────────────────────────── */
#banner-oferta{background:linear-gradient(90deg,#FF6F00,#FF8F00);color:#fff;padding:10px 16px}
.banner-inner{max-width:1300px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px;font-weight:600}
.banner-close{background:rgba(255,255,255,.25);border:none;color:#fff;width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.banner-close:hover{background:rgba(255,255,255,.4)}

/* ── MAPA ──────────────────────────────────────── */
.mapa-seccion{background:#fff;padding:32px 16px;border-top:1px solid #eee}
.mapa-inner{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:stretch}
.mapa-info h2{font-size:20px;color:#333;margin-bottom:6px}
.mapa-info p{color:#888;font-size:13px;margin-bottom:16px}
.horario-detalle{background:#f5f5f5;border-radius:10px;padding:14px;font-size:13px;color:#444;line-height:1.8;margin-bottom:16px}
.btn-como-llegar{display:inline-block;background:#075E54;color:#fff;padding:10px 20px;border-radius:24px;text-decoration:none;font-size:13px;font-weight:700;transition:.18s}
.btn-como-llegar:hover{background:#064d44}
.mapa-embed{height:260px;border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.1)}
@media(max-width:768px){.mapa-inner{grid-template-columns:1fr}.mapa-embed{height:220px}}

/* ── BADGE NUEVO ───────────────────────────────── */
.nuevo-tag{position:absolute;top:7px;left:7px;background:#1565C0;color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:8px;z-index:1}

/* ── PROMOCIONES ───────────────────────────────── */
.promo-seccion{background:linear-gradient(135deg,#0a0a0a 0%,#1a1a2e 100%);padding:32px 16px}
.promo-inner{max-width:900px;margin:0 auto;text-align:center}
.promo-label{display:inline-block;background:#25D366;color:#fff;font-size:11px;font-weight:800;padding:4px 12px;border-radius:20px;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.promo-titulo{color:#fff;font-size:clamp(18px,4vw,26px);margin-bottom:20px;font-weight:700}
.promo-video-wrap{position:relative;padding-bottom:56.25%;height:0;border-radius:14px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.5)}
.promo-video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.promo-img{width:100%;max-height:420px;object-fit:cover;border-radius:14px;box-shadow:0 8px 40px rgba(0,0,0,.4);cursor:pointer;transition:.2s}
.promo-img:hover{transform:scale(1.01)}

/* ── LAYOUT ────────────────────────────────────── */
.layout{display:flex;max-width:1300px;margin:0 auto;position:relative}

/* ── SIDEBAR ───────────────────────────────────── */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199;backdrop-filter:blur(2px)}
.sidebar-overlay.open{display:block}

.sidebar{
  width:240px;flex-shrink:0;background:#fff;
  border-right:1px solid #e8e8e8;
  min-height:calc(100vh - 64px);
  position:sticky;top:64px;
  height:calc(100vh - 64px);
  overflow-y:auto;
  transition:transform .28s ease;
}
.sidebar-header{
  display:none; /* visible only on mobile */
  background:#075E54;color:#fff;
  padding:14px 16px;
  align-items:center;justify-content:space-between;
  font-weight:700;font-size:15px;flex-shrink:0;
}
.close-sidebar{background:rgba(255,255,255,.2);border:none;color:#fff;width:30px;height:30px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.sidebar-nav{padding:8px 0}
.sidebar-item{display:flex;align-items:center;gap:10px;width:100%;padding:11px 18px;border:none;background:none;cursor:pointer;font-size:14px;color:#444;text-align:left;transition:.15s;border-left:3px solid transparent}
.sidebar-item:hover{background:#f0faf7;color:#075E54}
.sidebar-item.active{background:#E8F5E9;color:#075E54;font-weight:700;border-left-color:#075E54}
.sidebar-item .si-emoji{font-size:18px;width:24px;text-align:center}
.sidebar-item .si-count{margin-left:auto;font-size:11px;background:#f0f0f0;color:#888;padding:2px 7px;border-radius:10px;font-weight:600}
.sidebar-item.active .si-count{background:#C8E6C9;color:#2E7D32}

/* ── Mobile sidebar: off-canvas ─────────────────── */
@media(max-width:768px){
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;z-index:200;
    height:100dvh;
    transform:translateX(-100%);
    min-height:unset;
    box-shadow:4px 0 24px rgba(0,0,0,.2);
  }
  .sidebar.open{transform:translateX(0)}
  .sidebar-header{display:flex}
  .sidebar-nav{padding:4px 0}
}

/* ── MAIN ──────────────────────────────────────── */
.main{flex:1;min-width:0;padding:0}

/* ── BUSCADOR ──────────────────────────────────── */
.search-wrap{padding:14px 16px 0;background:#fff;border-bottom:1px solid #eee}
.search-inner{max-width:800px;background:#f5f5f5;border-radius:12px;display:flex;align-items:center;padding:0 14px;gap:8px}
.search-inner span{font-size:18px;color:#888;flex-shrink:0}
#buscador{flex:1;border:none;outline:none;padding:12px 4px;font-size:14px;background:transparent;color:#222}
#clear-btn{background:none;border:none;color:#999;font-size:18px;cursor:pointer}

/* ── SECCIONES ─────────────────────────────────── */
.seccion{padding:20px 16px}
.sec-titulo{font-size:17px;font-weight:700;color:#333;margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid #075E54;display:inline-block}

/* ── GRID ──────────────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:10px}
@media(min-width:500px){.grid{grid-template-columns:repeat(auto-fill,minmax(165px,1fr))}}
@media(min-width:900px){.grid{grid-template-columns:repeat(auto-fill,minmax(185px,1fr))}}

/* ── CARD ──────────────────────────────────────── */
.card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.08);transition:.18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.12)}
.card-img{background:linear-gradient(135deg,#E8F5E9,#F1F8E9);display:flex;align-items:center;justify-content:center;font-size:46px;padding:20px 0;position:relative;overflow:hidden;min-height:100px}
.card-img .firebase-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:6px;background:#fff}
.popular-tag{position:absolute;top:7px;left:7px;background:#FF6F00;color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:8px}
.card-body{padding:10px;flex:1;display:flex;flex-direction:column}
.card-nombre{font-size:12px;font-weight:600;color:#333;line-height:1.3;flex:1;margin-bottom:8px}
.btn-add{width:100%;padding:8px;background:#075E54;color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;transition:.18s}
.btn-add:hover{background:#064d44}
.btn-add.agregado{background:#25D366}

/* +/- controles en tarjeta */
.card-qty{display:flex;align-items:center;justify-content:center;gap:0;background:#f0faf7;border-radius:8px;overflow:hidden;border:1.5px solid #075E54}
.cq-btn{width:34px;height:34px;border:none;background:none;color:#075E54;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s;flex-shrink:0}
.cq-btn:hover{background:#075E54;color:#fff}
.cq-num{flex:1;text-align:center;font-size:14px;font-weight:700;color:#075E54;min-width:28px}

/* Granel */
.granel-tag{position:absolute;top:7px;right:7px;background:#E65100;color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:8px}
.granel-ctrl{display:flex;flex-direction:column;gap:5px}
.granel-input-row{display:flex;align-items:center;border:1.5px solid #ddd;border-radius:8px;overflow:hidden;background:#fff}
.granel-peso{padding:0 6px;font-size:14px;font-weight:700;color:#E65100;flex-shrink:0}
.granel-inp{flex:1;border:none;outline:none;padding:7px 4px;font-size:13px;width:0;min-width:0}
.card-qty.granel-added{background:#FFF3E0;border-color:#E65100;padding:0 6px;gap:4px}
.granel-resumen{flex:1;font-size:12px;font-weight:700;color:#E65100;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-qty.granel-added .cq-btn{color:#E65100}
.card-qty.granel-added .cq-btn:hover{background:#E65100}
.ci-granel-monto{font-size:12px;font-weight:700;color:#E65100;margin-top:4px}

/* ── VER MÁS ───────────────────────────────────── */
.ver-mas-wrap{text-align:center;padding:16px 0 8px}
.btn-ver-mas{background:#fff;border:2px solid #075E54;color:#075E54;padding:10px 32px;border-radius:24px;font-size:14px;font-weight:700;cursor:pointer;transition:.18s}
.btn-ver-mas:hover{background:#075E54;color:#fff}

/* ── EMPTY ─────────────────────────────────────── */
.empty{text-align:center;padding:48px 16px;color:#888;font-size:14px}

/* ── OVERLAY CARRITO ───────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:400;display:none;backdrop-filter:blur(2px)}
.overlay.open{display:block}

/* ── CARRITO DRAWER ────────────────────────────── */
.carrito{position:fixed;right:-100%;top:0;width:min(420px,100vw);height:100dvh;background:#fff;z-index:401;display:flex;flex-direction:column;transition:right .3s ease;box-shadow:-4px 0 24px rgba(0,0,0,.15)}
.carrito.open{right:0}
.carrito-header{background:#075E54;color:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.carrito-header h2{font-size:17px}
.carrito-header button{background:rgba(255,255,255,.2);border:none;color:#fff;width:30px;height:30px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.carrito-items{flex:1;overflow-y:auto;padding:14px}
.carrito-empty{text-align:center;color:#aaa;padding:40px 0;font-size:14px}
.carrito-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid #f0f0f0}
.ci-emoji{font-size:26px;flex-shrink:0}
.ci-info{flex:1}
.ci-nombre{font-size:12px;font-weight:600;color:#333;line-height:1.3}
.ci-qty{display:flex;align-items:center;gap:8px;margin-top:5px}
.qty-btn{width:26px;height:26px;border-radius:50%;border:2px solid #075E54;background:#fff;color:#075E54;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
.qty-btn:hover{background:#075E54;color:#fff}
.qty-num{font-size:13px;font-weight:700;min-width:20px;text-align:center}
.ci-del{background:none;border:none;color:#e53935;font-size:17px;cursor:pointer;padding:4px}

/* ── FOOTER CARRITO ────────────────────────────── */
.carrito-footer{padding:14px;border-top:1px solid #eee;flex-shrink:0;overflow-y:auto;max-height:60vh}
.form-group{margin-bottom:11px}
.form-group label{font-size:11px;font-weight:700;color:#555;display:block;margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px}
.form-group input,.form-group textarea{width:100%;border:1.5px solid #ddd;border-radius:10px;padding:9px 12px;font-size:13px;outline:none;font-family:inherit;resize:none;transition:.2s}
.form-group input:focus,.form-group textarea:focus{border-color:#075E54}
.entrega-opts{display:flex;gap:8px}
.opt-radio{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;padding:8px 10px;border:1.5px solid #ddd;border-radius:10px;flex:1;justify-content:center;transition:.2s}
.opt-radio:has(input:checked){border-color:#075E54;background:#E8F5E9;color:#075E54;font-weight:600}

/* ── UBICACIÓN ─────────────────────────────────── */
.ubicacion-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.btn-ubicacion{flex:1;min-width:180px;padding:9px 12px;background:#E3F2FD;color:#1565C0;border:1.5px solid #90CAF9;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;transition:.18s;text-align:center}
.btn-ubicacion:hover{background:#BBDEFB}
.ubicacion-hint{font-size:11px;color:#888;white-space:nowrap}

/* ── BTN WA ────────────────────────────────────── */
.btn-wa{width:100%;padding:14px;background:#25D366;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:.2s;margin-top:6px}
.btn-wa:hover{background:#1ebe5d}

/* ── FAB ───────────────────────────────────────── */
.fab{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#25D366;color:#fff;border:none;padding:13px 26px;border-radius:30px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 4px 20px rgba(37,211,102,.4);z-index:150;white-space:nowrap;transition:.2s}
.fab:hover{background:#1ebe5d;transform:translateX(-50%) scale(1.04)}

/* ── FOOTER ────────────────────────────────────── */
.footer{background:#075E54;color:#fff;text-align:center;padding:28px 16px;margin-top:40px}
.footer-logo{font-size:20px;font-weight:700;margin-bottom:6px}
.footer p{color:#B2DFDB;font-size:13px;margin-bottom:8px}
.footer-wa{display:inline-block;background:#25D366;color:#fff;padding:9px 22px;border-radius:22px;text-decoration:none;font-weight:700;font-size:13px;margin:10px 0;transition:.18s}
.footer-wa:hover{background:#1ebe5d}
