:root{--rojo: #c0392b;--rojo-oscuro: #96281b;--mostaza: #f2a93b;--mostaza-suave: #fbe3b7;--crema: #fff8ee;--crema-2: #fdf0dc;--cafe: #3a2a20;--cafe-suave: #7a6353;--verde: #2f7d4f;--blanco: #ffffff;--borde: #ecdcc3;--sombra: 0 6px 24px rgba(58, 42, 32, .1);--radius: 14px;--font-display: "Alfa Slab One", serif;--font-body: "Inter", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scrollbar-width:thin;scrollbar-color:#cdb99f transparent}body{font-family:var(--font-body);background:var(--crema);color:var(--cafe);-webkit-font-smoothing:antialiased;overflow-x:hidden;min-width:320px}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#7a635359;border-radius:999px;border:3px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#7a63538c;background-clip:padding-box}::-webkit-scrollbar-corner{background:transparent}h1,h2,h3{line-height:1.15}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:999px;padding:10px 20px;font-weight:700;font-size:14px;transition:transform .1s,filter .15s}.btn:hover{filter:brightness(1.06)}.btn:active{transform:scale(.97)}.btn-rojo{background:var(--rojo);color:#fff}.btn-mostaza{background:var(--mostaza);color:var(--cafe)}.btn-verde{background:var(--verde);color:#fff}.btn-ghost{background:transparent;color:var(--cafe);border:2px solid var(--borde)}.btn-sm{padding:6px 14px;font-size:13px}.btn:disabled{opacity:.45;cursor:not-allowed}.card{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--radius);box-shadow:var(--sombra)}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:700}.badge-pendiente{background:#fdecc8;color:#9a6b00}.badge-preparando{background:#dbeafe;color:#1d4ed8}.badge-lista{background:#dcfce7;color:#15803d}.badge-entregada{background:#ede9e3;color:var(--cafe-suave)}.badge-cancelada{background:#fee2e2;color:#b91c1c}.badge-online{background:var(--mostaza-suave);color:#8a5a00}.badge-mostrador{background:#e8e2da;color:var(--cafe-suave)}.badge-bajo{background:#fee2e2;color:#b91c1c}.badge-ok{background:#dcfce7;color:#15803d}.input,select.input,textarea.input{width:100%;padding:10px 12px;border:1.5px solid var(--borde);border-radius:10px;background:#fff;color:var(--cafe);outline:none}.input:focus{border-color:var(--mostaza)}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.field label{font-size:13px;font-weight:600;color:var(--cafe-suave)}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;padding:10px 12px;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--cafe-suave);border-bottom:2px solid var(--borde)}.table td{padding:10px 12px;border-bottom:1px solid var(--crema-2)}.table tr:last-child td{border-bottom:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3a2a2080;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:#fff;border-radius:var(--radius);padding:24px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal h3{font-family:var(--font-display);font-size:20px;margin-bottom:16px}.empty{text-align:center;padding:40px 20px;color:var(--cafe-suave);font-size:14px}.empty .big{font-size:40px;display:block;margin-bottom:8px}.pub-nav{position:sticky;top:0;z-index:50;background:var(--rojo);color:#fff;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:64px;box-shadow:var(--sombra)}.pub-nav .logo{font-family:var(--font-display);font-size:20px;display:flex;align-items:center;gap:10px}.pub-nav .links{display:flex;gap:4px;align-items:center}.pub-nav .links a{padding:8px 14px;border-radius:999px;font-weight:600;font-size:14px}.pub-nav .links a.active,.pub-nav .links a:hover{background:#ffffff29}.cart-btn{position:relative;background:var(--mostaza);color:var(--cafe)}.cart-count{position:absolute;top:-6px;right:-6px;background:var(--cafe);color:#fff;border-radius:999px;font-size:11px;font-weight:800;padding:2px 7px}.hero{background:linear-gradient(135deg,var(--rojo) 0%,var(--rojo-oscuro) 100%);color:#fff;padding:72px 24px 88px;text-align:center;position:relative;overflow:hidden}.hero:after{content:"";position:absolute;inset:auto 0 -2px 0;height:42px;background:var(--crema);border-radius:100% 100% 0 0}.hero .emoji{font-size:74px;display:block;margin-bottom:12px}.hero h1{font-family:var(--font-display);font-size:clamp(38px,7vw,64px);letter-spacing:.01em}.hero h1 span{color:var(--mostaza)}.hero p{font-size:18px;margin:14px auto 28px;max-width:520px;opacity:.92}.hero .acciones{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.hero .btn{font-size:16px;padding:13px 28px}.seccion{max-width:1080px;margin:0 auto;padding:48px 24px}.seccion>h2{font-family:var(--font-display);font-size:30px;text-align:center;margin-bottom:6px}.seccion>.sub{text-align:center;color:var(--cafe-suave);margin-bottom:32px}.grid-menu{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}.prod-card{padding:20px;display:flex;flex-direction:column;gap:8px}.prod-card .emoji{font-size:44px}.prod-card h3{font-size:17px;font-weight:800}.prod-card p{font-size:13.5px;color:var(--cafe-suave);flex:1}.prod-card .pie{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.prod-card .precio{font-family:var(--font-display);font-size:20px;color:var(--rojo)}.prod-card.agotado{opacity:.55}.cat-tabs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}.cat-tabs button{display:inline-flex;align-items:center;gap:8px;border:2.5px solid var(--borde);background:#fff;border-radius:999px;padding:10px 18px;font-weight:800;font-size:14.5px;color:var(--cafe);box-shadow:0 2px #3a2a2014;transition:transform .15s,box-shadow .15s,border-color .15s,background .15s}.cat-tabs button .cat-emoji{font-size:18px}.cat-tabs button .count{background:var(--crema-2);color:var(--cafe-suave);border-radius:999px;font-size:12px;font-weight:800;min-width:24px;padding:2px 8px;text-align:center;transition:background .15s,color .15s}.cat-tabs button:hover{transform:translateY(-3px);border-color:var(--mostaza);box-shadow:0 6px 14px #f2a93b59}.cat-tabs button:active{transform:translateY(-1px) scale(.97)}.cat-tabs button.active{background:linear-gradient(135deg,var(--rojo) 0%,var(--rojo-oscuro) 100%);border-color:var(--rojo-oscuro);color:#fff;transform:scale(1.07);box-shadow:0 8px 20px #c0392b73;animation:chip-pop .25s ease}.cat-tabs button.active .count{background:#ffffff47;color:#fff}@keyframes chip-pop{0%{transform:scale(.94)}60%{transform:scale(1.12)}to{transform:scale(1.07)}}.promo-card{background:linear-gradient(135deg,var(--mostaza) 0%,#f8c168 100%);border:none;padding:22px;color:var(--cafe)}.promo-card h3{font-family:var(--font-display);font-size:20px;margin-bottom:6px}.pub-footer{background:var(--cafe);color:#f3e8d9;padding:40px 24px;margin-top:40px}.pub-footer .inner{max-width:1080px;margin:0 auto;display:flex;flex-wrap:wrap;gap:32px;justify-content:space-between;font-size:14px;line-height:1.9}.pub-footer .logo{font-family:var(--font-display);font-size:20px;color:var(--mostaza)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3a2a2059;z-index:90;animation:overlay-in .3s ease}@supports (backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px)){.drawer-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}}.drawer{position:fixed;top:max(10px,env(safe-area-inset-top));right:10px;bottom:max(10px,env(safe-area-inset-bottom));width:min(420px,calc(100vw - 20px));z-index:95;padding:22px;display:flex;flex-direction:column;border-radius:24px;background:#fffaf2f5;border:1px solid rgba(255,255,255,.9);box-shadow:0 24px 60px #1a0f0847,inset 0 1px #fff;animation:drawer-in .45s cubic-bezier(.32,.72,0,1)}@supports (backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px)){.drawer{background:#fffaf2b8;-webkit-backdrop-filter:blur(24px) saturate(1.8);backdrop-filter:blur(24px) saturate(1.8)}}@keyframes drawer-in{0%{transform:translate(calc(100% + 20px));opacity:.6}to{transform:translate(0);opacity:1}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.drawer h3{font-family:var(--font-display);font-size:22px;margin-bottom:14px}.drawer .items{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.cart-item{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid rgba(255,255,255,.85);border-radius:14px;background:#ffffffa6;box-shadow:0 2px 8px #3a2a200f,inset 0 1px #ffffffe6}.cart-item .nom{flex:1;font-size:14px;font-weight:600}.qty{display:inline-flex;align-items:center;gap:8px}.qty button{width:26px;height:26px;border-radius:8px;border:1.5px solid var(--borde);background:#fff;font-weight:800}.drawer .total-row{display:flex;justify-content:space-between;font-size:18px;font-weight:800;padding:14px 0;border-top:2px solid var(--borde);margin-top:10px}.admin-shell{display:flex;min-height:100vh;background:#f6f1e8}.admin-side{width:224px;background:var(--cafe);color:#e9ddcd;padding:18px 12px;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh;overflow-y:auto;flex-shrink:0}.admin-side .logo{font-family:var(--font-display);color:var(--mostaza);font-size:17px;padding:8px 12px 18px;display:block}.admin-side a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:14px;font-weight:600}.admin-side a.active{background:var(--rojo);color:#fff}.admin-side a:hover:not(.active){background:#ffffff14}.admin-side .spacer{flex:1}.admin-side .usuario-activo{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#ffffff14;border-radius:10px;margin-bottom:4px;font-size:14px}.admin-side .usuario-activo .avatar{font-size:26px}.admin-side .usuario-activo .rol{font-size:11.5px;color:var(--mostaza);font-weight:700}.admin-side .chip{margin-left:auto;background:var(--mostaza);color:var(--cafe);font-size:11px;font-weight:800;border-radius:999px;padding:1px 8px}.admin-main{flex:1;padding:26px 30px;min-width:0}.admin-main>header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}.admin-main>header h1{font-family:var(--font-display);font-size:26px}.admin-main>header .sub{color:var(--cafe-suave);font-size:14px;margin-top:4px}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:22px}.kpi{padding:18px}.kpi .lbl{font-size:13px;font-weight:600;color:var(--cafe-suave)}.kpi .val{font-family:var(--font-display);font-size:26px;margin-top:4px}.kpi .extra{font-size:12.5px;color:var(--cafe-suave);margin-top:4px}.pos-layout{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start}.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.pos-prod{padding:12px;text-align:left;border:1.5px solid var(--borde);border-radius:12px;background:#fff;display:flex;flex-direction:column;gap:3px;transition:border-color .12s}.pos-prod:hover{border-color:var(--mostaza)}.pos-prod .emoji{font-size:26px}.pos-prod .nom{font-size:13px;font-weight:700;line-height:1.25}.pos-prod .pre{font-size:13px;color:var(--rojo);font-weight:800}.ticket{padding:18px;position:sticky;top:20px}.ticket h3{font-family:var(--font-display);font-size:18px;margin-bottom:12px}.ticket .linea{display:flex;justify-content:space-between;font-size:14px;padding:4px 0}.atiende-chips{display:flex;gap:6px;flex-wrap:wrap}.atiende-chip{border:2px solid var(--borde);background:#fff;border-radius:999px;padding:6px 12px;font-weight:700;font-size:13px;color:var(--cafe);transition:transform .12s,border-color .12s,background .12s,box-shadow .12s}.atiende-chip:hover{transform:translateY(-2px);border-color:var(--mostaza)}.atiende-chip.active{background:var(--verde);border-color:var(--verde);color:#fff;box-shadow:0 4px 12px #2f7d4f66;transform:scale(1.05)}.ticket .total{font-size:19px;font-weight:800;border-top:2px dashed var(--borde);margin-top:8px;padding-top:10px;display:flex;justify-content:space-between}.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}.kanban .col{background:#efe7d8;border-radius:var(--radius);padding:12px}.kanban .col>h3{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px;color:var(--cafe-suave);display:flex;justify-content:space-between}.comanda{padding:12px 14px;margin-bottom:10px}.comanda .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.comanda .folio{font-weight:800;font-size:15px}.comanda ul{list-style:none;font-size:13.5px;margin:6px 0}.comanda li{padding:2px 0}.comanda .hora{font-size:12px;color:var(--cafe-suave)}.comanda .acciones{display:flex;gap:6px;margin-top:8px}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.toolbar .input{width:auto}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--rojo) 0%,var(--rojo-oscuro) 100%);padding:20px}.login-card{width:100%;max-width:380px;padding:34px;text-align:center}.login-card .emoji{font-size:54px}.login-card h1{font-family:var(--font-display);font-size:24px;margin:10px 0 4px}.login-card p{color:var(--cafe-suave);font-size:14px;margin-bottom:20px}.login-card .pin{text-align:center;font-size:22px;letter-spacing:10px;font-weight:800}.login-card .error{color:#b91c1c;font-size:13px;margin-top:10px;font-weight:600}.login-back{display:inline-flex;align-items:center;gap:6px;margin-top:18px;font-size:13.5px;font-weight:700;color:var(--cafe-suave);background:none;border:none;padding:6px 10px;border-radius:999px;transition:background .15s,color .15s}.login-back:hover{background:var(--crema-2);color:var(--cafe)}.user-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:10px;margin-bottom:18px}.user-card{padding:14px 8px;border:2.5px solid var(--borde);border-radius:14px;background:#fff;display:flex;flex-direction:column;align-items:center;gap:4px;font-weight:800;font-size:14px;color:var(--cafe);transition:transform .15s,box-shadow .15s,border-color .15s,background .15s}.user-card .avatar{font-size:32px}.user-card .rol{font-size:11px;font-weight:700;color:var(--cafe-suave)}.user-card:hover{transform:translateY(-3px);border-color:var(--mostaza);box-shadow:0 6px 14px #f2a93b59}.user-card.selected{border-color:var(--rojo);background:#fdeae7;transform:scale(1.06);box-shadow:0 8px 20px #c0392b59}.user-card.selected .rol{color:var(--rojo)}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:160px;padding-top:10px}.bar-chart .bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}.bar-chart .bar{width:100%;max-width:46px;background:var(--rojo);border-radius:6px 6px 0 0;min-height:2px}.bar-chart .lbl{font-size:11px;color:var(--cafe-suave)}.bar-chart .val{font-size:11px;font-weight:700}@media (max-width: 900px){.pos-layout,.kanban{grid-template-columns:1fr}.admin-shell{flex-direction:column}.admin-side{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap}.admin-side .logo{padding:8px 12px}.pub-nav .links a:not(.cart-btn){padding:8px 10px;font-size:13px}.admin-main{padding:18px 14px}.admin-main .card{overflow-x:auto}}@media (max-width: 560px){.pub-nav{height:auto;flex-wrap:wrap;justify-content:center;padding:10px 12px 12px;gap:6px}.pub-nav .logo{font-size:18px}.pub-nav .links{flex-wrap:wrap;justify-content:center;gap:2px}.pub-nav .links a{padding:7px 10px;font-size:13.5px}.hero{padding:48px 18px 70px}.hero .emoji{font-size:58px}.hero p{font-size:16px}.seccion{padding:34px 16px}.seccion>h2{font-size:25px}.grid-menu{grid-template-columns:1fr}.cat-tabs button{padding:9px 14px;font-size:13.5px}.cat-tabs button.active{transform:scale(1.03)}.drawer{padding:18px}.pub-footer .inner{flex-direction:column;gap:18px}.kpis{grid-template-columns:1fr 1fr}.modal{padding:18px}}@supports (padding: env(safe-area-inset-left)){.pub-nav{padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}.pub-footer{padding-bottom:max(40px,env(safe-area-inset-bottom))}.admin-main{padding-bottom:max(26px,env(safe-area-inset-bottom))}}
