/* ===== Mono Loco Digital Menu ===== */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#0f0e0c;--bg-raised:#161412;--card:#1a1816;--card-hover:#201d1a;
  --border:#252220;--border-light:#302c28;
  --terracotta:#c4501a;--amber:#e8913a;--gold:#f5c342;--sage:#7a9a6d;
  --text:#ede9e1;--text-2:#a09789;--text-3:#635c54;
  --font-d:'Oswald',sans-serif;--font-s:'Caveat',cursive;--font-b:'Nunito Sans',sans-serif;
  --max-w:480px;--radius:14px;
}

html{-webkit-tap-highlight-color:transparent;scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.sheet-open{overflow:hidden}

/* Grain */
body::before{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px}

.app{max-width:var(--max-w);margin:0 auto;min-height:100dvh;position:relative;overflow-x:hidden}

/* ===== Header ===== */
.header{position:relative;text-align:center;padding:40px 20px 36px;overflow:hidden;
  background:linear-gradient(180deg,#1a140e 0%,var(--bg) 100%)}
.header-glow{position:absolute;top:-10%;left:50%;transform:translateX(-50%);width:120%;height:70%;
  background:radial-gradient(ellipse at center,#e8913a0c,transparent 60%);pointer-events:none}
.monkey{font-size:36px;display:block;margin-bottom:10px;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-5px) rotate(1deg)}}
.title{font-family:var(--font-d);font-weight:900;font-size:clamp(2.8rem,13vw,4.2rem);letter-spacing:.05em;line-height:.95;text-shadow:0 2px 20px #0004}
.tagline{font-family:var(--font-s);font-weight:700;font-size:1.25rem;color:var(--amber);margin-top:4px}
.picado{position:absolute;bottom:-1px;left:0;right:0;height:16px;z-index:2;background:var(--bg);
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 16'%3E%3Cpath d='M0,0 L4,0 L8,13 L12,0 L16,0 L20,13 L24,0 L28,0 L32,13 L36,0 L40,0 L44,13 L48,0 L52,0 L56,13 L60,0 L64,0 L68,13 L72,0 L76,0 L80,13 L84,0 L88,0 L92,13 L96,0 L100,0 L100,16 L0,16Z' fill='white'/%3E%3C/svg%3E");
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 16'%3E%3Cpath d='M0,0 L4,0 L8,13 L12,0 L16,0 L20,13 L24,0 L28,0 L32,13 L36,0 L40,0 L44,13 L48,0 L52,0 L56,13 L60,0 L64,0 L68,13 L72,0 L76,0 L80,13 L84,0 L88,0 L92,13 L96,0 L100,0 L100,16 L0,16Z' fill='white'/%3E%3C/svg%3E");
  mask-size:100px 16px;-webkit-mask-size:100px 16px;mask-repeat:repeat-x;-webkit-mask-repeat:repeat-x}

/* ===== Language ===== */
.lang{position:absolute;top:14px;right:14px;z-index:10;display:flex;gap:2px;
  background:var(--card);border:1px solid var(--border);border-radius:20px;padding:3px}
.lang button{font-family:var(--font-b);font-size:.68rem;font-weight:700;letter-spacing:.04em;
  padding:4px 10px;border:none;border-radius:16px;background:transparent;color:var(--text-3);cursor:pointer;transition:.2s}
.lang button.active{background:var(--terracotta);color:#fff}

/* ===== Pages ===== */
.page{display:none;opacity:0;transition:opacity .3s ease,transform .3s ease}
.page.active{display:block}
.page.visible{opacity:1;transform:translateX(0)}
.page.out-left{transform:translateX(-20px);opacity:0}
.page.in-right{transform:translateX(20px);opacity:0}

/* ===== Category Grid ===== */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:20px 14px 32px}
.grid-card{position:relative;border-radius:var(--radius);min-height:110px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;cursor:pointer;overflow:hidden;
  border:1px solid var(--border);background:var(--card);
  transition:transform .15s ease,border-color .15s ease;
  opacity:0;transform:translateY(16px)}
.grid-card.in{opacity:1;transform:translateY(0);transition:opacity .4s cubic-bezier(.22,1,.36,1),transform .4s cubic-bezier(.22,1,.36,1)}
.grid-card:active{transform:scale(.97)}
.grid-card:hover{border-color:var(--border-light)}
.grid-card-name{font-family:var(--font-d);font-size:1.15rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--text);line-height:1.2}
.grid-card-count{font-size:.7rem;font-weight:600;color:var(--text-3);margin-top:4px}

/* ===== Detail Page ===== */
.detail-bar{display:flex;align-items:center;gap:12px;padding:18px 14px 12px}
.back{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:var(--card);
  color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:.15s}
.back:active{background:var(--border)}
.back svg{width:18px;height:18px}
.detail-name{font-family:var(--font-d);font-size:1.4rem;font-weight:700;letter-spacing:.03em}
.detail-count{font-size:.72rem;color:var(--text-3);font-weight:500}
.items-list{padding:0 14px 32px;display:flex;flex-direction:column;gap:10px}

/* ===== Item Card ===== */
.item{display:flex;gap:12px;padding:12px;background:var(--card);border:1px solid var(--border);
  border-radius:12px;cursor:pointer;transition:.15s;
  opacity:0;transform:translateY(12px)}
.item.in{opacity:1;transform:translateY(0);transition:opacity .35s ease,transform .35s ease}
.item:active{background:var(--card-hover)}
.item-thumb{width:72px;height:72px;border-radius:10px;flex-shrink:0;overflow:hidden;background:var(--bg-raised)}
.item-thumb svg{width:100%;height:100%;display:block}
.item-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}
.item-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.item-title{font-weight:700;font-size:1rem;color:var(--text);line-height:1.3}
.item-price{font-family:var(--font-d);font-weight:700;font-size:1.1rem;color:var(--gold);white-space:nowrap;flex-shrink:0}
.item-desc{font-size:.82rem;color:var(--text-2);line-height:1.4;margin-top:3px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.item-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px}
.item-spicy{font-size:.65rem}
.item-allergen{font-size:.6rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
  padding:1px 6px;border-radius:4px}
.a-gluten{background:#8B691414;color:#c4a040;border:1px solid #8B691420}
.a-dairy{background:#4a90d914;color:#7ab0e0;border:1px solid #4a90d920}
.a-nuts{background:#8B451314;color:#b87a50;border:1px solid #8B451320}
.a-shellfish{background:#d9304014;color:#e07070;border:1px solid #d9304020}
.a-eggs{background:#f5c34214;color:#d8b850;border:1px solid #f5c34220}
.a-soy{background:#7a9a6d14;color:#90b484;border:1px solid #7a9a6d20}

/* ===== Bottom Sheet ===== */
.backdrop{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.6);
  opacity:0;pointer-events:none;transition:opacity .3s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.backdrop.open{opacity:1;pointer-events:auto}
.sheet{position:fixed;bottom:0;left:0;right:0;z-index:201;max-width:var(--max-w);margin:0 auto;
  background:var(--bg-raised);border-top-left-radius:20px;border-top-right-radius:20px;
  max-height:80vh;transform:translateY(100%);transition:transform .35s cubic-bezier(.22,1,.36,1);
  display:flex;flex-direction:column;border:1px solid var(--border);border-bottom:none}
.sheet.open{transform:translateY(0)}
.sheet-handle{display:flex;justify-content:center;padding:10px 0 4px;cursor:grab}
.sheet-handle-bar{width:36px;height:4px;border-radius:2px;background:var(--border-light)}
.sheet-scroll{overflow-y:auto;padding:0 20px 28px;flex:1}
.sheet-img{width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;margin-bottom:16px;background:var(--bg)}
.sheet-img svg{width:100%;height:100%;display:block}
.sheet-title{font-family:var(--font-d);font-size:1.7rem;font-weight:700;letter-spacing:.02em;margin-bottom:2px}
.sheet-price{font-family:var(--font-d);font-size:1.35rem;color:var(--gold);margin-bottom:10px}
.sheet-desc{font-size:.92rem;color:var(--text-2);line-height:1.55;margin-bottom:14px}
.sheet-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.sheet-spicy{font-size:.8rem}
.sheet-allergen{font-size:.68rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;
  padding:3px 8px;border-radius:6px}

/* ===== Footer ===== */
.footer{text-align:center;padding:28px 20px 36px;border-top:1px solid var(--border);margin-top:8px}
.footer-brand{font-family:var(--font-d);font-size:1.3rem;font-weight:900;letter-spacing:.05em;margin-bottom:2px}
.footer-script{font-family:var(--font-s);font-size:1rem;color:var(--amber);margin-bottom:14px;display:block}
.footer-line{font-size:.8rem;color:var(--text-2);margin-bottom:4px;display:flex;align-items:center;justify-content:center;gap:6px}
.footer-line svg{width:14px;height:14px;color:var(--amber);opacity:.6;flex-shrink:0}
.footer-actions{display:flex;justify-content:center;gap:12px;margin:16px 0}
.footer-act{width:44px;height:44px;border-radius:50%;background:var(--card);border:1px solid var(--border);
  color:var(--text-2);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:.2s}
.footer-act:active,.footer-act:hover{background:var(--amber);color:var(--bg);border-color:var(--amber)}
.footer-copy{font-size:.68rem;color:var(--text-3)}

/* ===== Light Mode ===== */
body.light{
  --bg:#f5f2ed;--bg-raised:#fffdf9;--card:#ffffff;--card-hover:#f0ede8;
  --border:#e0dbd4;--border-light:#d0c9c0;
  --text:#1a1816;--text-2:#6b6259;--text-3:#a09789;
  --terracotta:#c4501a;--amber:#d4782a;--gold:#b08018;--sage:#5a7a4d;
}
body.light::before{opacity:.015}
body.light .header{background:linear-gradient(180deg,#ede8e0 0%,var(--bg) 100%)}
body.light .header-glow{background:radial-gradient(ellipse at center,#e8913a08,transparent 60%)}
body.light .title{text-shadow:none;color:var(--text)}
body.light .picado{background:var(--bg)}
body.light .lang button.active{background:var(--terracotta);color:#fff}
body.light .cat-nav,.light .cat-nav-fade--left,.light .cat-nav-fade--right{background:var(--bg)}
body.light .backdrop{background:rgba(0,0,0,.3)}
body.light .sheet{background:var(--card);border-color:var(--border)}
body.light .sheet-handle-bar{background:var(--border)}
body.light .grid-card{background:var(--card);border-color:var(--border);box-shadow:0 1px 3px #0001}
body.light .item{background:var(--card);border-color:var(--border);box-shadow:0 1px 3px #0001}
body.light .back{background:var(--card);border-color:var(--border);color:var(--text)}
body.light .footer{border-color:var(--border);background:var(--bg-raised)}
body.light .footer-act{background:var(--card);border-color:var(--border);color:var(--text-2)}
body.light .footer-act:active,body.light .footer-act:hover{background:var(--amber);color:#fff;border-color:var(--amber)}
body.light .a-gluten{background:#8B691418;color:#8B6914;border-color:#8B691430}
body.light .a-dairy{background:#4a90d918;color:#3070b0;border-color:#4a90d930}
body.light .a-nuts{background:#8B451318;color:#6b3410;border-color:#8B451330}
body.light .a-shellfish{background:#d9304018;color:#b02020;border-color:#d9304030}
body.light .a-eggs{background:#b8960e18;color:#8a7010;border-color:#b8960e30}
body.light .a-soy{background:#7a9a6d18;color:#4a6a3d;border-color:#7a9a6d30}

/* Theme toggle button */
.theme-btn{position:absolute;top:14px;left:14px;z-index:10;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--border);background:var(--card);cursor:pointer;display:flex;
  align-items:center;justify-content:center;transition:.2s;color:var(--text-2)}
.theme-btn:active{transform:scale(.9)}
.theme-btn svg{width:16px;height:16px}

@supports(padding-bottom:env(safe-area-inset-bottom)){
  .footer{padding-bottom:calc(36px + env(safe-area-inset-bottom))}
  .sheet{padding-bottom:env(safe-area-inset-bottom)}
}
