@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--orange:#f97316;--orange-light:#fed7aa;--orange-dark:#c2410c;--green:#16a34a;--green-light:#bbf7d0;--green-dark:#15803d;--red:#dc2626;--red-light:#fee2e2;--yellow:#eab308;--yellow-light:#fef9c3;--blue:#2563eb;--blue-light:#dbeafe;--bg:#fafaf9;--surface:#fff;--surface-2:#f5f5f4;--border:#e7e5e4;--border-strong:#d6d3d1;--muted:#a8a29e;--text:#1c1917;--text-secondary:#57534e;--radius-sm:4px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 4px #00000014, 0 0 0 1px #0000000a;--shadow-md:0 4px 12px #0000001a;--font:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--transition:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}h1{letter-spacing:-.025em;font-size:1.5rem;font-weight:700;line-height:1.25}h2{letter-spacing:-.015em;font-size:1.25rem;font-weight:600;line-height:1.3}h3{font-size:1rem;font-weight:600;line-height:1.4}h4{font-size:.875rem;font-weight:600}.container{max-width:1200px;margin:0 auto;padding:0 24px}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-4{gap:16px}.gap-2{gap:8px}.gap-6{gap:24px}.grow{flex:1}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.btn{border-radius:var(--radius);transition:background var(--transition), opacity var(--transition), transform var(--transition);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:.875rem;font-weight:500;display:inline-flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;pointer-events:none}.btn-primary{background:var(--orange);color:#fff;border-color:var(--orange-dark)}.btn-primary:hover{background:var(--orange-dark)}.btn-success{background:var(--green);color:#fff;border-color:var(--green-dark)}.btn-success:hover{background:var(--green-dark)}.btn-danger{background:var(--red);color:#fff;border-color:#b91c1c}.btn-danger:hover{background:#b91c1c}.btn-ghost{color:var(--text-secondary);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-sm{border-radius:var(--radius-sm);padding:5px 10px;font-size:.8rem}.btn-lg{border-radius:var(--radius);padding:12px 24px;font-size:1rem}.btn-icon{border-radius:var(--radius);width:36px;height:36px;padding:8px}.btn-full{width:100%}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-orange{background:var(--orange-light);color:var(--orange-dark)}.badge-green{background:var(--green-light);color:var(--green-dark)}.badge-red{background:var(--red-light);color:var(--red)}.badge-yellow{background:var(--yellow-light);color:#92400e}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-muted{background:var(--surface-2);color:var(--muted)}.input-group{flex-direction:column;gap:4px;display:flex}.label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:9px 12px;font-size:.9rem}.input:focus{border-color:var(--orange);box-shadow:0 0 0 3px #f973161f}.input::placeholder{color:var(--muted)}.select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23a8a29e' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;padding:9px 32px 9px 12px;font-size:.9rem}.select:focus{border-color:var(--orange);box-shadow:0 0 0 3px #f973161f}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}thead{background:var(--surface-2)}th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px;font-size:.78rem;font-weight:600}td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:12px 16px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-2)}.modal-backdrop{z-index:100;background:#00000059;justify-content:center;align-items:center;padding:24px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);width:100%;max-width:480px;max-height:90vh;animation:.2s slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-body{padding:20px 24px}.modal-footer{justify-content:flex-end;gap:8px;padding:0 24px 20px;display:flex}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:10;flex-direction:column;flex-shrink:0;width:220px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);padding:20px 20px 16px}.sidebar-logo .logo-mark{color:var(--orange);letter-spacing:-.04em;font-size:1.35rem;font-weight:800}.sidebar-logo .logo-sub{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.nav-item{border-radius:var(--radius);color:var(--text-secondary);transition:background var(--transition), color var(--transition);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 10px;font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--orange-light);color:var(--orange-dark);font-weight:600}.nav-item .nav-icon{flex-shrink:0;font-size:1rem}.nav-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:10px 10px 4px;font-size:.68rem;font-weight:700}.sidebar-footer{border-top:1px solid var(--border);padding:12px 10px}.sidebar-user{border-radius:var(--radius);align-items:center;gap:10px;padding:8px 10px;display:flex}.user-avatar{background:var(--orange-light);width:32px;height:32px;color:var(--orange-dark);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.user-name{color:var(--text);font-size:.82rem;font-weight:600}.user-role{color:var(--muted);text-transform:capitalize;font-size:.72rem}.main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:220px;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:5;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-title{color:var(--text);font-size:.95rem;font-weight:600}.page{flex:1;padding:24px}.page-header{margin-bottom:24px}.page-title{letter-spacing:-.02em;font-size:1.35rem;font-weight:700}.page-desc{color:var(--text-secondary);margin-top:4px;font-size:.875rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.78rem;font-weight:600}.stat-value{letter-spacing:-.03em;color:var(--text);font-size:1.75rem;font-weight:700}.stat-sub{color:var(--text-secondary);margin-top:4px;font-size:.8rem}.stat-icon{font-size:1.4rem}.empty-state{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:48px 24px;display:flex}.empty-state .empty-icon{font-size:2rem}.empty-state p{font-size:.875rem}.spinner{border:2px solid var(--border);border-top-color:var(--orange);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.board{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));align-items:start;gap:16px;display:grid}.order-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);transition:box-shadow var(--transition);overflow:hidden}.order-card:hover{box-shadow:var(--shadow-md)}.order-card.status-pending{border-top:3px solid var(--yellow)}.order-card.status-preparing{border-top:3px solid var(--orange)}.order-card.status-ready{border-top:3px solid var(--green)}.order-card.status-picked_up{border-top:3px solid var(--blue)}.order-card.status-delivered{border-top:3px solid var(--green-dark)}.order-card.status-paid{border-top:3px solid var(--muted);opacity:.65}.order-card.status-cancelled{border-top:3px solid var(--red);opacity:.65}.order-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.order-table-no{color:var(--text);letter-spacing:-.02em;font-size:1.15rem;font-weight:700}.order-card-body{padding:12px 16px}.order-card-footer{border-top:1px solid var(--border);flex-wrap:wrap;gap:6px;padding:10px 16px;display:flex}.order-items-list{flex-direction:column;gap:4px;list-style:none;display:flex}.order-item-row{justify-content:space-between;font-size:.875rem;display:flex}.order-item-name{color:var(--text)}.order-item-qty{color:var(--muted);font-weight:500}.order-time{color:var(--muted);font-size:.75rem}.toast-container{z-index:200;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);align-items:flex-start;gap:10px;max-width:320px;padding:14px 18px;font-size:.875rem;animation:.25s slideUp;display:flex}.toast.toast-success{border-left:3px solid var(--green)}.toast.toast-error{border-left:3px solid var(--red)}.toast.toast-info{border-left:3px solid var(--orange)}.divider{background:var(--border);height:1px;margin:16px 0}.text-muted{color:var(--muted)}.text-success{color:var(--green)}.text-danger{color:var(--red)}.text-orange{color:var(--orange)}.font-mono{font-family:Courier New,monospace}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:380px;box-shadow:var(--shadow-md);padding:40px 36px}.login-logo{text-align:center;margin-bottom:32px}.login-logo .logo-mark{color:var(--orange);letter-spacing:-.05em;font-size:2rem;font-weight:800}.login-logo p{color:var(--muted);margin-top:4px;font-size:.8rem}.login-form{flex-direction:column;gap:16px;display:flex}.error-msg{background:var(--red-light);color:var(--red);border-radius:var(--radius);padding:10px 14px;font-size:.85rem}@media (width<=768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
