/* ============================================================
   PIZZA CREW — SISTEMA VISUAL
   Vibra: pizzería NYC vintage / callejera. Verde bosque + crema
   + dorado latón, tipografía de letrero, murales tipo cómic.
   ------------------------------------------------------------
   Fuentes:  Anton (letrero/numerales) · Playfair Display (serif
   editorial, nombres) · Libre Franklin (cuerpo/UI)
   ============================================================ */

/* ---------------- TOKENS ---------------- */
:root{
  /* Marca */
  --green-900:#0e2c1e;
  --green-800:#102f20;
  --green:#143f2b;        /* verde del logo */
  --green-600:#1f6b47;
  --green-500:#2a8159;
  --cream:#eae2cd;        /* crema del logo */
  --cream-50:#f6f1e3;
  --cream-100:#efe7d3;
  --paper:#f3ecda;
  --gold:#e8b830;         /* acento: latón */
  --gold-deep:#c9971c;
  --tomato:#d6492f;
  --tomato-deep:#b53a23;
  --mint:#2a9d8a;
  --ink:#14110b;

  /* Roles */
  --bg:var(--cream-50);
  --surface:#fffdf6;
  --line:rgba(20,63,43,.14);
  --line-strong:rgba(20,63,43,.28);
  --text:#1c2a20;
  --text-soft:#5a6358;
  --shadow-sm:0 1px 0 rgba(20,63,43,.06), 0 2px 6px rgba(20,63,43,.08);
  --shadow-md:0 6px 22px rgba(14,44,30,.14);
  --shadow-lg:0 22px 60px rgba(14,44,30,.26);

  /* Tipografía */
  --f-sign:'Anton', 'Arial Narrow', sans-serif;
  --f-serif:'Playfair Display', Georgia, serif;
  --f-body:'Libre Franklin', system-ui, sans-serif;

  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:30px;
  --maxw:1240px;
}

/* ---------------- RESET ---------------- */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--f-body);
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.5;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:16px;color:inherit}
img{display:block;max-width:100%}
::selection{background:var(--gold);color:var(--green-900)}

/* Grano sutil global */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------------- ROUTER ---------------- */
.view{display:none;min-height:100dvh}
.view.active{display:block}
.view.active.flexcol{display:flex;flex-direction:column}

/* Utilidad: bandera/cinta vintage */
.eyebrow{
  font-family:var(--f-sign);
  letter-spacing:.16em;text-transform:uppercase;
  font-size:13px;color:var(--gold-deep);
}

/* Botón base */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--f-sign);letter-spacing:.04em;text-transform:uppercase;
  font-size:16px;line-height:1;padding:15px 26px;border-radius:999px;
  transition:transform .14s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-gold{background:var(--gold);color:var(--green-900);box-shadow:0 4px 0 var(--gold-deep)}
.btn-gold:hover{background:#f2c948;transform:translateY(-2px);box-shadow:0 6px 0 var(--gold-deep)}
.btn-green{background:var(--green);color:var(--cream);box-shadow:0 4px 0 var(--green-900)}
.btn-green:hover{background:var(--green-600);transform:translateY(-2px);box-shadow:0 6px 0 var(--green-900)}
.btn-ghost{background:transparent;border:2px solid var(--line-strong);color:var(--green);padding:13px 24px}
.btn-ghost:hover{background:var(--green);color:var(--cream);border-color:var(--green)}
.btn-cream{background:var(--cream);color:var(--green-900)}
.btn-cream:hover{background:#fff}

/* ============================================================
   VISTA 1 — BIENVENIDA
   ============================================================ */
#view-welcome{
  position:relative;display:none;
  background:
    radial-gradient(120% 90% at 50% -10%, #1d5c3e 0%, var(--green) 42%, var(--green-900) 100%);
  color:var(--cream);overflow:hidden;
}
#view-welcome.active{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 22px}
/* Mosaico de azulejos arriba/abajo (piso de pizzería) */
.tilestrip{position:absolute;left:0;right:0;height:18px;
  background:repeating-linear-gradient(90deg,var(--cream) 0 14px,transparent 14px 28px);opacity:.5}
.tilestrip.top{top:0}
.tilestrip.bot{bottom:0}
/* Resplandor neón detrás del logo */
.welcome-glow{position:absolute;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle, rgba(232,184,48,.28), transparent 62%);
  filter:blur(8px);top:18%;pointer-events:none}
.welcome-inner{position:relative;z-index:2;max-width:520px;width:100%;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:26px}
.welcome-logo{width:min(78vw,360px);filter:drop-shadow(0 14px 30px rgba(0,0,0,.45))}
@media(prefers-reduced-motion:no-preference){
  .view.active .welcome-logo{animation:logoIn .8s cubic-bezier(.2,.9,.25,1) both}
}
@keyframes logoIn{from{transform:translateY(20px) scale(.94)}to{transform:none}}
.welcome-est{font-family:var(--f-sign);letter-spacing:.22em;font-size:12px;color:var(--gold);
  text-transform:uppercase;opacity:.9}
.welcome-tag{font-family:var(--f-serif);font-style:italic;font-size:clamp(20px,5.6vw,28px);
  line-height:1.3;color:var(--cream);max-width:18ch}
.welcome-rule{display:flex;align-items:center;gap:14px;color:rgba(234,226,205,.6);
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-family:var(--f-sign)}
.welcome-rule::before,.welcome-rule::after{content:"";height:1px;width:34px;background:rgba(234,226,205,.4)}

.lang-block{width:100%;display:flex;flex-direction:column;gap:14px;margin-top:4px}
.lang-label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(234,226,205,.65);font-family:var(--f-sign)}
.lang-toggle{display:flex;gap:0;background:rgba(0,0,0,.22);border:2px solid rgba(234,226,205,.25);
  border-radius:999px;padding:5px;width:100%}
.lang-opt{flex:1;padding:13px;border-radius:999px;font-family:var(--f-sign);letter-spacing:.06em;
  text-transform:uppercase;font-size:16px;color:var(--cream);transition:.18s;position:relative}
.lang-opt .flag{font-size:13px;opacity:.7;display:block;letter-spacing:.1em;margin-top:2px}
.lang-opt.active{background:var(--gold);color:var(--green-900)}
.welcome-cta{width:100%;font-size:19px;padding:18px}
.welcome-staff{background:none;color:rgba(234,226,205,.7);font-size:13px;letter-spacing:.04em;
  text-decoration:underline;text-underline-offset:4px;padding:6px;font-family:var(--f-body)}
.welcome-staff:hover{color:var(--gold)}

/* ============================================================
   VISTA 2 — MENÚ DEL CLIENTE (mobile-first)
   ============================================================ */
#view-menu{background:var(--paper)}
.menu-wrap{max-width:520px;margin:0 auto;background:var(--bg);min-height:100dvh;
  box-shadow:0 0 60px rgba(14,44,30,.12);position:relative}
@media(min-width:900px){
  .menu-wrap{max-width:920px}
}

/* Header tipo letrero — estático y compacto */
.menu-head{position:sticky;top:0;z-index:40;background:var(--green);color:var(--cream);
  padding:14px 18px 4px;box-shadow:0 6px 18px rgba(14,44,30,.22)}
.menu-head-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative}
.menu-logo-wrap{display:flex;justify-content:center;margin:8px 0 10px;
  transition:max-height .3s ease,opacity .3s ease,margin .3s ease;max-height:200px;overflow:hidden}
.menu-logo{height:110px;width:auto;filter:drop-shadow(0 5px 12px rgba(0,0,0,.32))}
/* Logo compacto dentro del head-bar (oculto por defecto) */
.menu-logo-compact{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  height:0;opacity:0;width:auto;
  filter:drop-shadow(0 2px 6px rgba(0,0,0,.4));
  transition:height .3s ease,opacity .3s ease;
  pointer-events:none;object-fit:contain}
.icon-btn{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:rgba(234,226,205,.12);color:var(--cream);transition:.16s;font-size:18px}
.icon-btn:hover{background:rgba(234,226,205,.24)}
.lang-pill{font-family:var(--f-sign);font-size:14px;letter-spacing:.08em;padding:0 14px;height:42px;
  border-radius:999px;background:var(--gold);color:var(--green-900);display:grid;place-items:center}
.lang-pill:hover{background:#f2c948}

.menu-hero{padding:0 0 12px;text-align:center;
  transition:max-height .3s ease,opacity .3s ease,padding .3s ease;max-height:120px;overflow:hidden}
.menu-hero h1{font-family:var(--f-sign);font-size:clamp(16px,4vw,24px);letter-spacing:.06em;text-transform:uppercase;color:var(--cream);line-height:1;margin-bottom:4px}
.menu-hero p{font-family:var(--f-serif);font-style:italic;color:rgba(234,226,205,.82);
  font-size:13.5px}

/* Buscador */
.menu-search{position:relative;margin:2px 0 12px}
.menu-search input{width:100%;padding:13px 16px 13px 44px;border-radius:999px;border:none;
  background:rgba(255,253,246,.95);color:var(--text);box-shadow:inset 0 0 0 2px rgba(0,0,0,.04)}
.menu-search input:focus{outline:none;box-shadow:inset 0 0 0 2px var(--gold)}
.menu-search svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-soft)}

/* Layout switcher (las 3 versiones del menú) */
.layout-switch{display:flex;gap:4px;background:rgba(0,0,0,.22);border-radius:999px;padding:4px;margin-bottom:12px;
  transition:max-height .3s ease,opacity .3s ease,margin .3s ease;max-height:60px;overflow:hidden}
.layout-switch button{flex:1;padding:9px;border-radius:999px;font-family:var(--f-sign);font-size:13px;
  letter-spacing:.06em;text-transform:uppercase;color:rgba(234,226,205,.7);transition:.16s}
.layout-switch button.active{background:var(--cream);color:var(--green-900)}

/* Barra de categorías → ver "Cat bar flotante izquierda" más abajo */

.menu-body{padding:18px 14px 90px}

/* Encabezado de sección por categoría */
.cat-section{margin-bottom:30px;scroll-margin-top:140px}
.cat-section-head{display:flex;align-items:baseline;gap:12px;margin-bottom:14px}
.cat-section-head h2{font-family:var(--f-sign);font-size:26px;text-transform:uppercase;letter-spacing:.02em;color:var(--green)}
.cat-section-head .line{flex:1;height:3px;background:repeating-linear-gradient(90deg,var(--line-strong) 0 8px,transparent 8px 14px)}
.cat-section-head .from{font-family:var(--f-sign);color:var(--gold-deep);font-size:14px}

/* ---- Card MURAL (versión grande, imagen protagonista) ---- */
.menu-grid{display:grid;gap:16px}
.layout-mural .menu-grid{grid-template-columns:1fr}
@media(min-width:760px){.layout-mural .menu-grid{grid-template-columns:1fr 1fr}}

.pcard{background:var(--surface);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);
  transition:transform .18s ease, box-shadow .22s ease;position:relative}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pcard-art{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--green-600)}
.pcard-art svg,.pcard-art img{width:100%;height:100%;object-fit:cover}
.pcard-art img{position:absolute;inset:0}
.pcard-badge{position:absolute;top:12px;left:12px;font-family:var(--f-sign);font-size:12px;
  letter-spacing:.08em;text-transform:uppercase;background:var(--green-900);color:var(--cream);
  padding:5px 11px;border-radius:999px;box-shadow:var(--shadow-sm)}
/* botón subir foto */
.photo-btn{position:absolute;bottom:10px;right:10px;display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-family:var(--f-body);font-weight:600;background:rgba(14,44,30,.78);color:var(--cream);
  padding:7px 12px;border-radius:999px;opacity:0;transform:translateY(6px);transition:.18s;backdrop-filter:blur(4px)}
.pcard:hover .photo-btn{opacity:1;transform:none}
.photo-btn:hover{background:var(--gold);color:var(--green-900)}

.pcard-body{padding:15px 16px 17px}
.pcard-title{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.pcard-title h3{font-family:var(--f-serif);font-weight:800;font-size:21px;line-height:1.05;color:var(--green-900)}
.pcard-price{font-family:var(--f-sign);font-size:22px;color:var(--green);white-space:nowrap}
.pcard-price small{display:block;font-size:10px;letter-spacing:.1em;color:var(--text-soft);text-align:right;font-family:var(--f-body);font-weight:600;text-transform:uppercase}
.pcard-desc{color:var(--text-soft);font-size:13.5px;margin-top:7px;line-height:1.45;text-wrap:pretty}
.pcard-sizes{display:flex;gap:7px;margin-top:13px;flex-wrap:wrap}
.size-pill{font-size:12px;font-weight:700;color:var(--green);background:var(--cream-100);
  border:1px solid var(--line);border-radius:999px;padding:5px 11px;display:flex;gap:6px;align-items:center}
.size-pill b{font-family:var(--f-sign);font-weight:400;color:var(--gold-deep);font-size:13px}

/* ---- Layout CUADRÍCULA (compacta, 2 col en móvil) ---- */
.layout-grid .menu-grid{grid-template-columns:1fr 1fr;gap:12px}
@media(min-width:760px){.layout-grid .menu-grid{grid-template-columns:repeat(3,1fr)}}
.layout-grid .pcard-art{aspect-ratio:1/1}
.layout-grid .pcard-title{flex-direction:column;gap:3px}
.layout-grid .pcard-title h3{font-size:16px}
.layout-grid .pcard-price{font-size:18px}
.layout-grid .pcard-price small{display:none}
.layout-grid .pcard-desc{font-size:12px;-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.layout-grid .pcard-sizes{display:none}
.layout-grid .pcard-body{padding:11px 12px 13px}
.layout-grid .photo-btn{opacity:1;transform:none;padding:5px 9px;font-size:11px}

/* ---- Layout LISTA (ticket de pizzería, sin imágenes) ---- */
.layout-list .menu-grid{grid-template-columns:1fr;gap:0}
.layout-list .cat-section{background:var(--surface);border-radius:var(--r-md);border:1px solid var(--line);
  padding:8px 0;box-shadow:var(--shadow-sm)}
.layout-list .cat-section-head{padding:10px 16px 6px;margin-bottom:0}
.layout-list .pcard{background:none;border:none;border-radius:0;box-shadow:none;transform:none;
  border-bottom:1px dashed var(--line);display:flex;gap:14px;align-items:center;padding:13px 16px}
.layout-list .pcard:last-child{border-bottom:none}
.layout-list .pcard:hover{transform:none;box-shadow:none;background:rgba(20,63,43,.03)}
.layout-list .pcard-art{display:none}
.layout-list .pcard-thumb{width:52px;height:52px;border-radius:10px;overflow:hidden;flex-shrink:0;
  border:2px solid var(--green);box-shadow:var(--shadow-sm)}
.layout-list .pcard-thumb svg,.layout-list .pcard-thumb img{width:100%;height:100%;object-fit:cover}
.layout-list .pcard-body{padding:0;flex:1;min-width:0}
.layout-list .pcard-title{display:block}
.layout-list .pcard-title h3{font-size:18px}
.layout-list .pcard-desc{margin-top:3px;font-size:12.5px;-webkit-line-clamp:1;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
.layout-list .pcard-sizes{display:none}
.layout-list .pcard-price{font-size:19px;text-align:right}
.layout-list .photo-btn{display:none}
.layout-list .pcard-badge{display:none}

/* Card de Arma tu pizza */
.builder-extra{display:flex;flex-wrap:wrap;gap:18px;margin-top:12px;padding-top:14px;border-top:1px dashed var(--line)}
.builder-col{flex:1;min-width:140px}
.builder-col h4{font-family:var(--f-sign);font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:7px}
.builder-col ul{list-style:none;columns:1;font-size:13px;color:var(--text-soft)}
.builder-col li{padding:2px 0;display:flex;align-items:center;gap:7px}
.builder-col li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green-600);flex-shrink:0}

.menu-empty{text-align:center;padding:60px 20px;color:var(--text-soft)}
.menu-empty .big{font-family:var(--f-sign);font-size:24px;color:var(--green);text-transform:uppercase;margin-top:10px}

/* Footer pequeño del menú */
.menu-foot{padding:26px 16px 40px;text-align:center;color:var(--text-soft);border-top:2px solid var(--line)}
.menu-foot img{height:54px;margin:0 auto 10px;opacity:.6}
.menu-foot a{color:var(--green);font-weight:600}

/* ============================================================
   VISTA 3 — LOGIN ADMIN
   ============================================================ */
#view-login{background:var(--green-900)}
#view-login.active{display:grid;grid-template-columns:1fr;min-height:100dvh}
@media(min-width:880px){#view-login.active{grid-template-columns:1.05fr 1fr}}
.login-aside{position:relative;display:none;color:var(--cream);padding:54px;overflow:hidden;
  background:radial-gradient(120% 100% at 0% 0%, var(--green-600), var(--green) 55%, var(--green-900))}
@media(min-width:880px){.login-aside{display:flex;flex-direction:column;justify-content:space-between}}
.login-aside .tilestrip{opacity:.4}
.login-aside img.logo{width:230px;filter:drop-shadow(0 12px 24px rgba(0,0,0,.4))}
.login-aside-quote{font-family:var(--f-serif);font-style:italic;font-size:30px;line-height:1.28;max-width:14ch}
.login-aside-quote span{color:var(--gold)}
.login-aside-meta{font-family:var(--f-sign);letter-spacing:.18em;text-transform:uppercase;font-size:12px;color:rgba(234,226,205,.65)}

.login-main{display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--bg)}
.login-card{width:100%;max-width:400px}
.login-card .m-logo{height:46px;margin-bottom:30px}
@media(min-width:880px){.login-card .m-logo{display:none}}
.login-card .eyebrow{margin-bottom:8px}
.login-card h1{font-family:var(--f-sign);font-size:40px;text-transform:uppercase;color:var(--green);line-height:.95}
.login-card .sub{color:var(--text-soft);margin:8px 0 26px;font-size:14.5px}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--green);margin-bottom:7px}
.field .control{position:relative}
.field input,.field select,.field textarea{width:100%;padding:14px 15px;border-radius:var(--r-sm);
  background:var(--surface);border:2px solid var(--line);transition:.16s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green-600);
  box-shadow:0 0 0 4px rgba(31,107,71,.12)}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--tomato);
  box-shadow:0 0 0 4px rgba(214,73,47,.12)}
.field-err{display:none;color:var(--tomato);font-size:12px;font-weight:600;margin-top:6px;white-space:nowrap}
.field-err svg{flex-shrink:0}
.field.invalid .field-err{display:flex;align-items:center;gap:5px}
.pass-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:38px;height:38px;
  border-radius:8px;display:grid;place-items:center;color:var(--text-soft)}
.pass-toggle:hover{color:var(--green);background:rgba(20,63,43,.06)}
.login-error{display:none;align-items:center;gap:8px;background:rgba(214,73,47,.1);border:1px solid rgba(214,73,47,.3);
  color:var(--tomato-deep);padding:11px 14px;border-radius:var(--r-sm);font-size:13px;font-weight:600;margin-bottom:16px}
.login-error.show{display:flex;animation:shake .35s}
@keyframes shake{0%,100%{transform:none}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.login-submit{width:100%;margin-top:8px;font-size:17px;padding:16px}
.login-hint{text-align:center;color:var(--text-soft);font-size:12px;margin-top:18px}
.login-back{display:block;width:100%;text-align:center;margin-top:14px;color:var(--green);font-size:13px;font-weight:600;
  text-decoration:underline;text-underline-offset:3px;background:none}

/* ============================================================
   VISTAS 4 & 5 — PANEL ADMIN (desktop-friendly)
   ============================================================ */
.admin-shell{display:none;min-height:100dvh;background:var(--bg)}
.view.active .admin-shell{display:grid;grid-template-columns:248px 1fr}
@media(max-width:860px){.view.active .admin-shell{grid-template-columns:1fr}}

/* Sidebar */
.admin-side{background:var(--green);color:var(--cream);padding:22px 16px;display:flex;flex-direction:column;gap:6px;
  position:sticky;top:0;height:100dvh}
@media(max-width:860px){.admin-side{position:static;height:auto;flex-direction:row;align-items:center;
  gap:10px;overflow-x:auto;padding:12px}}
.admin-side .brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;margin-bottom:8px;
  border-bottom:1px solid rgba(234,226,205,.16)}
.admin-side .brand img{height:40px}
@media(max-width:860px){.admin-side .brand{border:none;padding:0 8px 0 0;margin:0;flex-shrink:0}
  .admin-side .brand img{height:32px}}
.admin-nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--r-sm);
  font-weight:600;font-size:14.5px;color:rgba(234,226,205,.78);transition:.15s;white-space:nowrap}
.admin-nav-item:hover{background:rgba(234,226,205,.1);color:var(--cream)}
.admin-nav-item.active{background:var(--gold);color:var(--green-900)}
.admin-nav-item svg{width:19px;height:19px;flex-shrink:0}
.admin-side-spacer{flex:1}
@media(max-width:860px){.admin-side-spacer{display:none}}
.admin-logout{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-sm);
  color:rgba(234,226,205,.7);font-weight:600;font-size:14px;transition:.15s}
.admin-logout:hover{background:rgba(214,73,47,.22);color:#ffd7cd}

/* Main */
.admin-main{padding:28px clamp(16px,3vw,40px) 60px;min-width:0}
.admin-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.admin-topbar>div:first-child{min-width:0;flex:1 1 auto}
.admin-topbar h1{font-family:var(--f-sign);font-size:clamp(28px,4vw,40px);text-transform:uppercase;
  color:var(--green);line-height:1.02}
.admin-topbar .count{color:var(--text-soft);font-size:14px;margin-top:8px}
.admin-topbar .count b{color:var(--green);font-family:var(--f-sign);font-weight:400;font-size:18px}

/* Toolbar (búsqueda + filtros) */
.admin-toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:18px}
.admin-toolbar .search{position:relative;flex:1;min-width:200px}
.admin-toolbar .search input{width:100%;padding:12px 14px 12px 42px;border-radius:999px;background:var(--surface);
  border:2px solid var(--line)}
.admin-toolbar .search input:focus{outline:none;border-color:var(--green-600)}
.admin-toolbar .search svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--text-soft)}
.admin-filter{display:flex;gap:6px;flex-wrap:wrap}
.admin-filter button{font-size:13px;font-weight:600;padding:9px 15px;border-radius:999px;border:2px solid var(--line);
  color:var(--green);transition:.15s;background:var(--surface)}
.admin-filter button:hover{border-color:var(--green-600)}
.admin-filter button.active{background:var(--green);color:var(--cream);border-color:var(--green)}

/* Stat chips */
.admin-stats{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 18px;display:flex;
  align-items:center;gap:10px;box-shadow:var(--shadow-sm)}
.stat .dot{width:9px;height:9px;border-radius:50%}
.stat .dot.on{background:var(--green-500)}
.stat .dot.off{background:var(--text-soft)}
.stat b{font-family:var(--f-sign);font-size:20px;color:var(--green);font-weight:400}
.stat span{font-size:12px;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em}

/* Tabla / lista de productos */
.admin-table{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm)}
.admin-row{display:grid;grid-template-columns:64px 2.2fr 1fr 1.1fr 96px 116px;align-items:center;gap:14px;
  padding:13px 18px;border-bottom:1px solid var(--line);transition:background .14s}
.admin-row:last-child{border-bottom:none}
.admin-row.head{background:var(--cream-100);font-family:var(--f-sign);font-size:12px;letter-spacing:.07em;
  text-transform:uppercase;color:var(--green);padding:13px 18px}
.admin-row.head .center{text-align:center}
.admin-row.item:hover{background:rgba(20,63,43,.035)}
.admin-row.item.is-off{opacity:.62}
.admin-thumb{width:52px;height:52px;border-radius:10px;overflow:hidden;border:2px solid var(--green);box-shadow:var(--shadow-sm)}
.admin-thumb svg,.admin-thumb img{width:100%;height:100%;object-fit:cover}
.admin-pname{font-family:var(--f-serif);font-weight:700;font-size:17px;color:var(--green-900);line-height:1.1}
.admin-pname small{display:block;font-family:var(--f-body);font-weight:500;color:var(--text-soft);font-size:12px;
  margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:34ch}
.admin-cat{display:inline-flex;font-size:12px;font-weight:700;padding:5px 11px;border-radius:999px;
  background:var(--cream-100);color:var(--green);border:1px solid var(--line);text-transform:uppercase;letter-spacing:.03em}
.admin-price{font-family:var(--f-sign);font-size:15px;color:var(--green)}
.admin-price small{color:var(--text-soft);font-family:var(--f-body);font-weight:600}
.admin-actions{display:flex;gap:6px;justify-content:flex-end}
.act-btn{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;border:2px solid var(--line);
  color:var(--green);transition:.14s;background:var(--surface)}
.act-btn:hover{border-color:var(--green-600);background:var(--cream-50)}
.act-btn.danger:hover{border-color:var(--tomato);color:var(--tomato);background:rgba(214,73,47,.07)}
.act-btn svg{width:17px;height:17px}

/* Toggle ON/OFF animado */
.toggle{position:relative;width:54px;height:30px;border-radius:999px;background:var(--line-strong);
  transition:background .25s ease;display:block;margin:0 auto;flex-shrink:0}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;
  background:#fff;box-shadow:0 2px 5px rgba(0,0,0,.25);transition:transform .25s cubic-bezier(.4,1.3,.5,1)}
.toggle.on{background:var(--green-500)}
.toggle.on::after{transform:translateX(24px)}
.toggle:active::after{width:28px}

/* responsive: tabla -> tarjetas en móvil */
@media(max-width:860px){
  .admin-row.head{display:none}
  .admin-row{grid-template-columns:56px 1fr auto;grid-template-areas:"thumb name toggle" "thumb meta actions";
    row-gap:8px;padding:14px 16px}
  .admin-row .admin-thumb{grid-area:thumb}
  .admin-row .col-name{grid-area:name}
  .admin-row .col-cat{grid-area:meta}
  .admin-row .col-price{display:none}
  .admin-row .col-toggle{grid-area:toggle}
  .admin-row .col-actions{grid-area:actions}
  .admin-actions{justify-content:flex-start}
}

/* ============================================================
   VISTA 5 — FORM NUEVO PRODUCTO
   ============================================================ */
.admin-form{max-width:880px}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);overflow:hidden}
.form-card-head{padding:22px 26px;border-bottom:1px solid var(--line);background:var(--cream-50)}
.form-card-head h2{font-family:var(--f-sign);font-size:28px;text-transform:uppercase;color:var(--green)}
.form-card-head p{color:var(--text-soft);font-size:13.5px;margin-top:3px}
.form-grid{padding:24px 26px;display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:680px){.form-grid{grid-template-columns:1fr}}
.form-grid .span2{grid-column:1/-1}
.field textarea{resize:vertical;min-height:84px;line-height:1.45}
.char-count{font-size:11px;color:var(--text-soft);text-align:right;margin-top:4px}

/* precios por tamaño */
.price-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.price-input{position:relative}
.price-input .sz{position:absolute;left:13px;top:9px;font-size:10px;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;color:var(--text-soft)}
.price-input .cur{position:absolute;left:13px;top:50%;transform:translateY(-20%);color:var(--text-soft);font-weight:700}
.price-input input{padding:24px 13px 11px 30px;font-family:var(--f-sign);font-size:18px}

/* dropzone imagen */
.dropzone{border:2.5px dashed var(--line-strong);border-radius:var(--r-md);padding:18px;text-align:center;
  background:var(--cream-50);transition:.16s;cursor:pointer;position:relative;overflow:hidden}
.dropzone:hover,.dropzone.drag{border-color:var(--green-600);background:rgba(31,107,71,.06)}
.dropzone .dz-icon{width:46px;height:46px;border-radius:50%;background:var(--green);color:var(--cream);
  display:grid;place-items:center;margin:0 auto 10px}
.dropzone p{font-size:13px;color:var(--text-soft);max-width:34ch;margin:0 auto}
.dropzone .strong{color:var(--green);font-weight:700}
.dz-preview{display:none;position:relative;border-radius:var(--r-md);overflow:hidden;aspect-ratio:16/10}
.dz-preview.show{display:block}
.dz-preview img,.dz-preview svg{width:100%;height:100%;object-fit:cover}
.dz-remove{position:absolute;top:8px;right:8px;background:rgba(14,44,30,.8);color:#fff;width:32px;height:32px;
  border-radius:50%;display:grid;place-items:center}
.dz-remove:hover{background:var(--tomato)}
.dz-tag{position:absolute;bottom:8px;left:8px;font-size:11px;font-weight:700;background:var(--gold);color:var(--green-900);
  padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}

/* publish toggle row */
.publish-row{display:flex;align-items:center;gap:14px;background:var(--cream-50);border:1px solid var(--line);
  border-radius:var(--r-md);padding:14px 16px}
.publish-row .txt{flex:1}
.publish-row .txt strong{display:block;color:var(--green-900);font-size:14.5px}
.publish-row .txt span{font-size:12.5px;color:var(--text-soft)}

/* Botón traducir */
.translate-row{display:flex;align-items:center;padding:2px 0 6px}
.btn-translate{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;
  color:var(--green);background:var(--cream-100);border:1.5px solid var(--line-strong);
  padding:8px 16px;border-radius:999px;transition:.16s;cursor:pointer}
.btn-translate:hover{background:var(--green);color:var(--cream);border-color:var(--green)}
.btn-translate:disabled{opacity:.55;cursor:not-allowed}

.form-foot{display:flex;gap:12px;justify-content:flex-end;padding:18px 26px;border-top:1px solid var(--line);
  background:var(--cream-50);flex-wrap:wrap}
@media(max-width:520px){.form-foot{flex-direction:column-reverse}.form-foot .btn{width:100%}}

/* Toast */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(220%);z-index:2000;
  background:var(--green);color:var(--cream);padding:14px 22px;border-radius:999px;font-weight:600;
  display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;
  transition:transform .4s cubic-bezier(.2,.9,.3,1), opacity .3s ease}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast svg{color:var(--gold)}

/* preview banner para vista admin (que se vea como app real) */
.admin-hint{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--text-soft);
  background:var(--cream-100);border:1px dashed var(--line-strong);padding:6px 12px;border-radius:999px;margin-top:6px}

/* Scroll suave para anclas de categoría */
html{scroll-behavior:smooth}

/* ── Header compacto al hacer scroll ─────────────────────── */
.scrolled .menu-logo-wrap{max-height:0;opacity:0;margin:0;pointer-events:none}
.scrolled .menu-hero{max-height:0;opacity:0;padding:0}
.scrolled .layout-switch{max-height:0;opacity:0;margin:0}
.scrolled .menu-logo-compact{height:34px;opacity:1;pointer-events:auto}
.scrolled .menu-head-bar{padding:10px 16px}

/* ── Cat bar flotante izquierda ───────────────────────────── */
.cat-bar{
  position:fixed;left:0;top:50%;transform:translateY(-42%);
  z-index:39;background:transparent;padding:0;
  overflow:visible;width:auto}
.cat-bar::-webkit-scrollbar{display:none}
.cat-bar-inner{
  display:flex;flex-direction:column;gap:5px;
  padding:10px 6px;
  background:var(--green);
  border-radius:0 var(--r-md) var(--r-md) 0;
  box-shadow:var(--shadow-md);
  max-height:calc(100dvh - 140px);overflow-y:auto;
  scrollbar-width:none}
.cat-chip{
  font-family:var(--f-sign);font-size:11px;letter-spacing:.04em;text-transform:uppercase;
  padding:7px 11px;border-radius:999px;white-space:nowrap;
  background:transparent;color:var(--cream);
  border:1.5px solid rgba(234,226,205,.25);transition:.15s}
.cat-chip:hover{background:rgba(234,226,205,.12);border-color:rgba(234,226,205,.5)}
.cat-chip.active{background:var(--gold);color:var(--green-900);border-color:var(--gold)}
/* Padding para que el contenido no quede bajo el cat bar */
.menu-body{padding-left:112px!important}

/* ── Ajustes / Settings panel ────────────────────────────── */
.settings-card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-md);overflow:hidden;max-width:680px;margin-top:8px}
.settings-section-head{
  padding:20px 24px 16px;border-bottom:1px solid var(--line)}
.settings-section-head h3{
  font-family:var(--f-serif);font-size:17px;font-weight:700;margin:0 0 4px}
.settings-section-head p{font-size:13px;color:var(--text-soft);margin:0}
.settings-cat-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;border-bottom:1px solid var(--line);
  transition:opacity .2s,background .15s}
.settings-cat-row:last-child{border-bottom:none}
.settings-cat-row.is-off{opacity:.5}
.settings-cat-row:hover{background:var(--cream-50)}
.settings-cat-info{display:flex;flex-direction:column;gap:3px}
.settings-cat-name{font-weight:600;font-size:14px}
.settings-cat-count{font-size:12px;color:var(--text-soft)}

/* Reduce motion */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
}
