:root{--brand:#1565a8;--brand-bright:#e0531c;--brand-deep:#0e4e86;--brand-press:#11538c;--cream:#f4f6f9;--ink:#1a2330;--bg:var(--cream);--surface:#fff;--surface-2:#eceff4;--border:#dde3ea;--text:var(--ink);--muted:#5f6b7a;--primary:var(--brand);--primary-press:var(--brand-press);--success:#3fa535;--success-bg:#dcf0d6;--danger:#d43a2a;--danger-bg:#fce8e7;--amber:#f5a524;--amber-bg:#fff3cd;--accent-orange:#e0531c;--brand-blue:#1565a8;--radius:16px;color:var(--text);-webkit-tap-highlight-color:transparent;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);overscroll-behavior:none;-webkit-user-select:none;user-select:none}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none}input{font:inherit}.app-shell{flex-direction:column;height:100%;display:flex}.app-body{flex:1;overflow-y:auto}.screen{max-width:720px;min-height:100%;margin:0 auto;padding:16px}.topbar{background:linear-gradient(90deg, var(--brand-deep) 0%, var(--brand) 100%);border-bottom:3px solid var(--brand-bright);color:#fff;justify-content:space-between;align-items:center;gap:12px;height:56px;padding:0 16px;display:flex}.topbar-brand{align-items:center;gap:10px;min-width:0;display:flex}.topbar-wordmark{flex-shrink:0;align-items:center;gap:8px;display:flex}.topbar-logo-chip{background:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;display:grid;overflow:hidden;box-shadow:0 1px 3px #00000040}.topbar-logo-chip img{object-fit:cover;border-radius:50%;width:100%;height:100%}.topbar-title-wrap{min-width:0}.topbar h1{color:#fff;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:15px;font-weight:700;overflow:hidden}.topbar .sub{color:#ffffffbf;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.topbar .pill.grey{color:#fff;background:#ffffff2e;border:1px solid #ffffff4d;flex-shrink:0}.topbar .pill.grey:hover{background:#ffffff47}.bottomnav{border-top:2px solid var(--border);background:var(--surface);display:flex}.bottomnav a{text-align:center;color:var(--muted);flex:1;padding:14px 8px;font-size:13px;font-weight:600;text-decoration:none}.bottomnav a.active{color:var(--brand);border-top:2px solid var(--brand);background:#fff5f0;margin-top:-2px}.btn{border-radius:var(--radius);background:var(--primary);color:#fff;justify-content:center;align-items:center;gap:8px;width:100%;padding:18px;font-size:18px;font-weight:700;transition:background .12s,transform 50ms;display:flex}.btn:active{background:var(--primary-press);transform:scale(.985)}.btn.secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn.danger{background:var(--danger)}.btn.success{background:var(--success)}.btn.big{padding:26px;font-size:22px}.btn:disabled{opacity:.5}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:0 1px 4px #0000000f}.card+.card{margin-top:12px}.meal-grid{gap:12px;display:grid}.meal-target{border-radius:var(--radius);background:var(--surface);border:2px solid var(--border);text-align:center;padding:26px 18px;font-size:22px;font-weight:700;box-shadow:0 1px 3px #0000000f}.meal-target:active{border-color:var(--brand);background:#fff5f0}.scan-ready{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:18px;min-height:70vh;display:flex}.scan-icon{background:var(--surface);border:3px solid var(--brand);border-radius:50%;place-items:center;width:140px;height:140px;font-size:60px;display:grid}.scan-icon.pulse{animation:1.6s ease-in-out infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 #c8501e59}50%{box-shadow:0 0 0 24px #c8501e00}}.banner{border-radius:var(--radius);padding:16px;font-weight:600}.banner.success{background:var(--success-bg);color:#166534}.banner.danger{background:var(--danger-bg);color:#991b1b}.banner.amber{background:var(--amber-bg);color:#78350f}.overlay{z-index:50;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:24px;display:flex;position:fixed;inset:0}.overlay.success{background:var(--success);color:#fff}.overlay.danger{background:var(--danger);color:#fff}.overlay.amber{background:var(--amber);color:#1a1300}.overlay h2{margin:0;font-size:30px}.overlay p{margin:0;font-size:20px}.overlay .big-name{font-size:38px;font-weight:800}.field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.field label{color:var(--muted);font-size:13px;font-weight:500}.field input,.field select{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:14px}.field input:focus,.field select:focus{outline:2px solid var(--brand);outline-offset:1px}.text-input{background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:12px;padding:16px;font-size:18px}.text-input:focus{outline:2px solid var(--brand);outline-offset:1px}.list-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:14px 12px;display:flex}.list-row:last-child{border-bottom:none}.row-main{font-weight:600}.row-sub{color:var(--muted);font-size:13px}.pill{border-radius:999px;padding:3px 10px;font-size:12px;font-weight:700}.pill.green{background:var(--success-bg);color:#166534}.pill.grey{background:var(--surface-2);color:var(--muted);border:1px solid var(--border)}.pill.amber{background:var(--amber-bg);color:#78350f}.pill.red{background:var(--danger-bg);color:#991b1b}.pill.blue{color:var(--brand-blue);background:#e8f2fb;border:1px solid #b8d4ef}.muted{color:var(--muted)}.center{text-align:center}.stack>*+*{margin-top:12px}.row{align-items:center;gap:12px;display:flex}.grow{flex:1}h2.section{margin:18px 0 10px;font-size:18px}.keypad{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.keypad button{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:22px;font-size:24px;font-weight:700}.keypad button:active{background:var(--border)}.login-screen{background:var(--cream);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{width:100%;max-width:400px}.login-header{text-align:center;flex-direction:column;align-items:center;gap:16px;margin-bottom:24px;display:flex}.login-logo{border:3px solid var(--brand-bright);background:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:120px;height:120px;display:grid;overflow:hidden;box-shadow:0 2px 12px #8f36142e}.login-logo img{object-fit:cover;border-radius:50%;width:100%;height:100%}.login-wordmark{color:var(--ink);letter-spacing:-.5px;font-size:20px;font-weight:800}.login-wordmark span.brand{color:var(--brand)}.login-tagline{color:var(--muted);margin:0;font-size:13px}.card.accent-top{border-top:3px solid var(--brand)}.pill.orange{color:var(--accent-orange);background:#fff0e8;border:1px solid #f0c8a8}
