*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0e0d;--bg2: #1a1916;--bg3: #242320;--bg4: #2e2d2a;--border: rgba(255,255,255,.08);--border2: rgba(255,255,255,.14);--text: #f2ede8;--text2: #9e9890;--text3: #6b6560;--accent: #d4a853;--accent2: #b8893b;--accent-bg: rgba(212,168,83,.12);--red: #e05c5c;--red-bg: rgba(224,92,92,.12);--green: #6ab187;--green-bg: rgba(106,177,135,.12);--blue: #5b9bd5;--blue-bg: rgba(91,155,213,.12);--radius: 8px;--radius-lg: 12px;--font: "DM Sans", "Segoe UI", sans-serif;--mono: "DM Mono", "Courier New", monospace}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;min-width:220px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column}.sidebar-brand{padding:20px 18px 16px;border-bottom:1px solid var(--border)}.brand-icon{width:32px;height:32px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.brand-icon i{color:#0f0e0d;font-size:18px}.brand-name{font-size:13px;font-weight:600}.brand-sub{font-size:11px;color:var(--text3);margin-top:2px}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-section{margin-bottom:20px}.nav-label{font-size:10px;font-weight:600;color:var(--text3);letter-spacing:1px;text-transform:uppercase;padding:0 8px;margin-bottom:6px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;cursor:pointer;color:var(--text2);font-size:13px;text-decoration:none;transition:all .15s;margin-bottom:2px}.nav-item:hover{background:var(--bg3);color:var(--text)}.nav-item.active{background:var(--accent-bg);color:var(--accent);font-weight:500}.nav-item i{font-size:16px;width:18px;text-align:center}.nav-badge{margin-left:auto;background:var(--bg4);color:var(--text3);font-size:10px;padding:1px 6px;border-radius:10px}.sidebar-footer{padding:14px;border-top:1px solid var(--border)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:54px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;flex-shrink:0}.topbar-title{font-size:16px;font-weight:500;flex:1}.page-content{flex:1;overflow-y:auto;padding:24px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);border:1px solid var(--border2);background:transparent;color:var(--text);font-size:13px;font-family:var(--font);cursor:pointer;transition:all .15s}.btn:hover{background:var(--bg3)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#0f0e0d;font-weight:500}.btn-primary:hover:not(:disabled){background:var(--accent2);border-color:var(--accent2)}.btn-ghost{border-color:transparent}.btn-ghost:hover{background:var(--bg3);border-color:var(--border)}.btn-pdf{background:var(--red-bg);border-color:var(--red);color:var(--red)}.btn-pdf:hover{background:#e05c5c38}.btn-danger{border-color:var(--red);color:var(--red)}.btn-danger:hover{background:var(--red-bg)}.btn i{font-size:15px}.icon-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.icon-btn:hover{background:var(--bg4);color:var(--text);border-color:var(--border2)}.icon-btn.danger:hover,.icon-btn.pdf-btn:hover{background:var(--red-bg);color:var(--red);border-color:var(--red)}.icon-btn i{font-size:14px}.action-btns{display:flex;gap:4px}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg)}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.card-title{font-size:14px;font-weight:500}.card-body{padding:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}.stat-label{font-size:11px;color:var(--text3);font-weight:500;letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px}.stat-value{font-size:26px;font-weight:300;line-height:1;margin-bottom:6px;font-family:var(--mono)}.stat-meta{font-size:11px;color:var(--text3)}table{width:100%;border-collapse:collapse}thead th{font-size:11px;font-weight:500;color:var(--text3);letter-spacing:.5px;text-transform:uppercase;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg3)}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:hover{background:var(--bg3)}tbody td{padding:11px 14px;font-size:13px;color:var(--text2)}tbody td:first-child{color:var(--text);font-weight:500}tbody tr:last-child{border-bottom:none}.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:500;padding:3px 8px;border-radius:20px}.badge-amber{background:var(--accent-bg);color:var(--accent)}.badge-green{background:var(--green-bg);color:var(--green)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-gray{background:var(--bg4);color:var(--text2)}.allergen-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;background:#fef3c7;color:#92400e;border:1px solid #fde68a;white-space:nowrap}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.form-group{margin-bottom:14px}.form-label{font-size:12px;font-weight:500;color:var(--text2);margin-bottom:6px;display:block}.form-control{width:100%;padding:8px 12px;border-radius:var(--radius);border:1px solid var(--border2);background:var(--bg3);color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s}.form-control:focus{border-color:var(--accent)}.form-control::placeholder{color:var(--text3)}select.form-control{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:14px;width:580px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-title{font-size:15px;font-weight:500}.modal-body{padding:22px;overflow-y:auto;flex:1}.modal-footer{padding:16px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.summary-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-top:16px}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;color:var(--text2)}.summary-row span:last-child{font-family:var(--mono)}.summary-row.total{border-top:1px solid var(--border2);margin-top:6px;padding-top:12px;color:var(--text);font-weight:500}.summary-row.total span:last-child{color:var(--accent);font-size:16px}.search-wrap{position:relative}.search-wrap i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:15px;pointer-events:none}.search-wrap input{padding-left:34px}.cost-bar{height:3px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-top:5px}.cost-bar-fill{height:100%;background:var(--accent);border-radius:2px}.empty-state{text-align:center;padding:60px 20px;color:var(--text3)}.empty-state i{font-size:40px;margin-bottom:12px;display:block;opacity:.4}.mono{font-family:var(--mono)}.accent{color:var(--accent)}.green{color:var(--green)}.text2{color:var(--text2)}.text3{color:var(--text3)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.auth-card{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;padding:40px;width:400px}.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.auth-logo-icon{width:40px;height:40px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center}.auth-logo-icon i{color:#0f0e0d;font-size:22px}.auth-title{font-size:22px;font-weight:600;margin-bottom:4px}.auth-sub{font-size:13px;color:var(--text3);margin-bottom:24px}.auth-error{background:var(--red-bg);border:1px solid var(--red);border-radius:var(--radius);padding:10px 14px;font-size:13px;color:var(--red);margin-bottom:16px}.auth-switch{text-align:center;margin-top:20px;font-size:13px;color:var(--text3)}.auth-switch a{color:var(--accent);cursor:pointer;text-decoration:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}.ing-row{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.ing-row:last-child{border-bottom:none}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
