/* ============================================================
   SUSHI EN CASA — menu.css  (pagina de carta completa)
   ============================================================ */

/* ---- Cabecera de la carta ---- */
.menu-hero{
  position:relative;text-align:center;
  padding:150px 22px 60px;
  background:radial-gradient(120% 90% at 50% 0%,rgba(255,39,64,.16),transparent 58%),linear-gradient(180deg,#070608,#0e0a0d);
  border-bottom:1px solid var(--line);box-shadow:inset 0 -1px 0 rgba(255,39,64,.14);
}
.menu-hero__bg{position:absolute;inset:0;z-index:-1;opacity:.7}
.menu-hero__inner{position:relative;max-width:780px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.menu-hero__kicker{font-family:var(--serif);font-weight:600;font-size:.78rem;letter-spacing:.4em;color:var(--neon-soft);text-transform:uppercase;margin-bottom:16px;text-shadow:0 0 12px rgba(255,39,64,.55)}
.menu-hero__title{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,7vw,5.2rem);line-height:1;letter-spacing:.01em;text-transform:uppercase;padding-bottom:.08em}
.menu-hero__title .accent{color:var(--neon);text-shadow:var(--glow-red)}
.menu-hero__sub{margin:28px auto 0;max-width:560px;color:var(--muted);font-weight:300;font-size:clamp(1rem,1.5vw,1.14rem)}

/* ---- Buscador ---- */
.menu-search{position:relative;width:min(520px,92%);margin:30px auto 0}
#menu-search{width:100%;background:#16161b;border:1.5px solid rgba(255,255,255,.22);border-radius:999px;color:#fff;font-family:var(--body);font-size:1rem;font-weight:400;padding:16px 22px 16px 52px;box-shadow:0 10px 30px -12px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.06);transition:border-color .25s,box-shadow .25s,background .25s}
#menu-search::placeholder{color:rgba(255,255,255,.5)}
#menu-search:focus{outline:none;border-color:var(--neon);background:#1b1216;box-shadow:0 0 0 4px rgba(255,39,64,.18),0 10px 30px -10px rgba(255,39,64,.4)}
.menu-search__ico{position:absolute;left:20px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:rgba(255,255,255,.55);pointer-events:none}
#menu-search::-webkit-search-cancel-button{-webkit-appearance:none;height:16px;width:16px;background:linear-gradient(45deg,transparent 45%,var(--muted) 45% 55%,transparent 55%),linear-gradient(-45deg,transparent 45%,var(--muted) 45% 55%,transparent 55%);cursor:pointer}

/* ---- Texto predictivo (sugerencias) ---- */
.menu-suggest{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:60;list-style:none;margin:0;padding:6px;background:rgba(14,14,17,.98);backdrop-filter:blur(12px);border:1px solid var(--line-2);border-radius:14px;box-shadow:0 24px 60px -20px rgba(0,0,0,.9),0 0 0 1px rgba(255,39,64,.14);overflow:hidden;text-align:left}
.menu-suggest__item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:9px;color:var(--muted);font-size:.98rem;cursor:pointer;transition:background .15s,color .15s}
.menu-suggest__item svg{width:16px;height:16px;flex:none;color:var(--muted-2)}
.menu-suggest__item span{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.menu-suggest__item mark{background:none;color:var(--neon-soft);font-weight:700}
.menu-suggest__item:hover,.menu-suggest__item.is-active{background:rgba(255,39,64,.12);color:#fff}
.menu-suggest__item:hover svg,.menu-suggest__item.is-active svg{color:var(--neon-soft)}

/* destello al saltar a un producto desde el buscador */
.mcard--flash{animation:mcardFlash 1.5s var(--ease)}
@keyframes mcardFlash{0%,100%{box-shadow:none;border-color:var(--line)}25%,60%{box-shadow:0 0 28px -4px rgba(255,39,64,.6),0 0 0 1px rgba(255,39,64,.5);border-color:rgba(255,39,64,.7)}}

/* ---- Nav de categorias (sticky chips) ---- */
.catnav{position:sticky;top:0;z-index:50;background:rgba(7,6,8,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);box-shadow:inset 0 -1px 0 rgba(255,39,64,.1)}
.catnav__inner{max-width:var(--maxw);margin:0 auto;display:flex;gap:10px;overflow-x:auto;padding:14px clamp(16px,5vw,40px);scrollbar-width:none}
.catnav__inner::-webkit-scrollbar{display:none}
.catchip{flex:none;border:1px solid var(--line-2);background:rgba(255,255,255,.03);color:var(--muted);font-family:var(--body);font-weight:600;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;padding:.6em 1.15em;border-radius:999px;cursor:pointer;white-space:nowrap;transition:border-color .25s,color .25s,background .25s,box-shadow .25s}
.catchip:hover{color:#fff;border-color:rgba(255,39,64,.5)}
.catchip.is-active{color:#fff;background:var(--neon);border-color:var(--neon);box-shadow:var(--glow-red)}

/* ---- Cuerpo de la carta ---- */
.menu-body{max-width:var(--maxw);margin:0 auto;padding:clamp(40px,6vw,72px) clamp(16px,5vw,40px) clamp(60px,8vw,110px)}
.mcat{padding-top:clamp(32px,5vw,56px);scroll-margin-top:84px}
.mcat:first-child{padding-top:0}
.mcat__head{display:flex;align-items:flex-end;gap:18px;margin-bottom:30px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.mcat__kanji{font-family:var(--serif);font-weight:900;font-size:clamp(2.2rem,5vw,3.2rem);line-height:.8;color:rgba(255,39,64,.55);text-shadow:0 0 24px rgba(255,39,64,.35);flex:none}
.mcat__titles{flex:1;min-width:0}
.mcat__name{font-family:var(--display);font-weight:400;font-size:clamp(1.9rem,4vw,3rem);line-height:.95;text-transform:uppercase;letter-spacing:.02em}
.mcat__desc{color:var(--muted);font-weight:300;font-size:.98rem;margin-top:4px}

.mgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:22px}

/* ---- Tarjeta de producto ---- */
.mcard{cursor:pointer;text-align:left}
.mcard .pcard__media{display:grid;place-items:center;background:
  repeating-linear-gradient(135deg,#121215 0 12px,#0d0d0f 12px 24px)}
.mcard .pcard__ph{position:absolute;inset:0;display:grid;place-items:center;padding:0 18px;text-align:center;z-index:0}
.mcard .pcard__img{position:relative;z-index:1}
.mcard .pcard__img.is-broken{opacity:0}
.mcard .pcard__icon{position:absolute;inset:0;display:grid;place-items:center;z-index:0;font-size:3.4rem;line-height:1;filter:drop-shadow(0 4px 14px rgba(0,0,0,.55));transition:transform .5s var(--ease)}
.mcard:hover .pcard__icon{transform:scale(1.12)}
.mcard__add{appearance:none;border:1px solid var(--neon);background:transparent;color:var(--neon-soft);font-family:var(--body);font-weight:700;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:.7em 1.1em;border-radius:999px;cursor:pointer;transition:background .25s,color .25s,box-shadow .25s}
.mcard:hover .mcard__add{background:var(--neon);color:#fff;box-shadow:var(--glow-red)}
.mcard__from{font-size:.66rem;color:var(--muted-2);letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:2px}

/* ---- Selector de variantes en el modal ---- */
#pm-variants{margin-top:6px}
.pm-variants__grid{display:grid;gap:8px;margin-top:4px}
.pm-variant{display:flex;align-items:center;justify-content:space-between;gap:14px;text-align:left;padding:11px 14px;border:1.5px solid var(--line-2);border-radius:5px;background:var(--ink);color:#fff;cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s}
.pm-variant:hover{border-color:rgba(255,39,64,.55)}
.pm-variant.is-active{border-color:var(--neon);background:rgba(255,39,64,.08);box-shadow:inset 0 0 0 1px rgba(255,39,64,.4)}
.pm-variant__name{font-size:.9rem;font-weight:500;line-height:1.25}
.pm-variant__price{font-family:var(--display);font-size:1.2rem;color:var(--neon-soft);flex:none}

.pmodal__media.is-empty{background:repeating-linear-gradient(135deg,#121215 0 14px,#0d0d0f 14px 28px)}
.pmodal__media.is-empty::after{content:"FOTO PROXIMAMENTE";font-family:'Courier New',monospace;font-size:.72rem;letter-spacing:.14em;color:var(--muted-2)}
.pmodal__media.has-icon::after{content:none}
.pmodal__icon{font-size:5rem;line-height:1;filter:drop-shadow(0 6px 18px rgba(0,0,0,.55))}

/* ---- Estado de carga / error ---- */
.menu-state{text-align:center;color:var(--muted);padding:80px 20px;font-weight:300}
.menu-state b{color:#fff;font-weight:600;display:block;margin-bottom:6px;font-family:var(--display);font-size:1.4rem;letter-spacing:.04em}

@media (max-width:600px){
  .mgrid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
  .mcard .pcard__body{padding:16px 14px 18px}
  .mcard .pcard__name{font-size:1.3rem}
  .mcard .pcard__desc{display:none}
  .menu-hero{padding-top:120px}
  /* Apilar precio y boton para que el pill no se corte en tarjetas angostas */
  .mcard .pcard__foot{flex-direction:column;align-items:stretch;gap:12px}
  .mcard .pcard__price{font-size:1.45rem}
  .mcard__add{width:100%;text-align:center;padding:.78em 1em}
}
