*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f4f8;--sidebar:#fff;--card:#fff;--border:#e2e8f0;--accent:#0ea5e9;--accent2:#0284c7;--green:#10b981;--red:#ef4444;--yellow:#f59e0b;--purple:#8b5cf6;--text:#0f172a;--muted:#64748b;--light:#f8fafc;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000d;--font:"Inter", sans-serif;--font-d:"Syne", sans-serif;--radius:12px;--radius-sm:8px}[data-theme=dark]{--bg:#0f172a;--sidebar:#1e293b;--card:#1e293b;--border:#334155;--accent:#38bdf8;--accent2:#0ea5e9;--green:#34d399;--red:#f87171;--yellow:#fbbf24;--purple:#a78bfa;--text:#f1f5f9;--muted:#94a3b8;--light:#1e293b;--shadow:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 6px #0006, 0 2px 4px #0000004d}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font)}input,select,textarea{font-family:var(--font)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.btn{border-radius:var(--radius-sm);border:none;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}.btn-ghost{color:var(--muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg);color:var(--text)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#059669}.badge{border-radius:100px;align-items:center;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-green{color:#166534;background:#dcfce7}.badge-red{color:#991b1b;background:#fee2e2}.badge-yellow{color:#854d0e;background:#fef9c3}.badge-blue{color:#1e40af;background:#dbeafe}.badge-purple{color:#5b21b6;background:#ede9fe}.badge-gray{color:#475569;background:#f1f5f9}.input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);width:100%;color:var(--text);outline:none;padding:9px 12px;font-size:14px;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--muted)}label{color:var(--muted);margin-bottom:5px;font-size:13px;font-weight:500;display:block}.table{border-collapse:collapse;width:100%}.table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--light);padding:10px 14px;font-size:12px;font-weight:600}.table td{border-bottom:1px solid var(--border);padding:12px 14px;font-size:14px}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--light)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.fade-in{animation:.3s both fadeIn}.layout{min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;min-width:0;display:flex}.page{flex:1;padding:24px;overflow-y:auto}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-title{font-family:var(--font-d);font-size:22px;font-weight:700}.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}@media (width<=768px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.page{padding:16px}}@media (width<=480px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}[data-theme=dark] .input{color:var(--text);border-color:var(--border);background:#0f172a}[data-theme=dark] .input:focus{border-color:var(--accent)}[data-theme=dark] .input option{color:var(--text);background:#1e293b}[data-theme=dark] .card{background:var(--card);border-color:var(--border)}[data-theme=dark] .btn-ghost{color:var(--muted);border-color:var(--border);background:0 0}[data-theme=dark] .btn-ghost:hover{color:var(--text);background:#334155}[data-theme=dark] .table th,[data-theme=dark] .table tr:hover td{background:#0f172a}[data-theme=dark] .badge-green{color:#34d399;background:#34d39926}[data-theme=dark] .badge-red{color:#f87171;background:#f8717126}[data-theme=dark] .badge-yellow{color:#fbbf24;background:#fbbf2426}[data-theme=dark] .badge-blue{color:#38bdf8;background:#38bdf826}[data-theme=dark] .badge-purple{color:#a78bfa;background:#a78bfa26}[data-theme=dark] .badge-gray{color:#94a3b8;background:#94a3b826}[data-theme=dark] label{color:var(--muted)}[data-theme=dark] code{color:var(--text);background:#0f172a}[data-theme=dark] strong{color:var(--text)}[data-theme=dark] select option{background:var(--card);color:var(--text)}[data-theme=dark] .btn-ghost{background:var(--bg)!important}@media print{body *{visibility:hidden}.print-receipt,.print-receipt *{visibility:visible}.print-receipt{width:80mm;font-family:Courier New,monospace;font-size:11px;line-height:1.4;position:fixed;top:0;left:0;color:#000!important;background:#fff!important}.print-receipt .no-print{display:none!important}.print-report,.print-report *{visibility:visible}.print-report{width:100%;font-family:Arial,sans-serif;font-size:12px;position:fixed;top:0;left:0;right:0;color:#000!important;background:#fff!important}.print-report .no-print{display:none!important}.print-report table{border-collapse:collapse;width:100%}.print-report th,.print-report td{color:#000;border:1px solid #ccc;padding:6px 8px}.print-report th{font-weight:700;background:#f0f0f0!important}@page{margin:10mm}@page:first{margin-top:5mm}}@media print and (width<=80mm){@page{size:80mm auto;margin:2mm}}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.4);cursor:pointer;opacity:.8}input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.4);cursor:pointer;opacity:.8}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator{filter:invert();opacity:.8}[data-theme=dark] input[type=time]::-webkit-calendar-picker-indicator{filter:invert();opacity:.8}svg{vertical-align:middle;display:inline-block}button svg,a svg{pointer-events:none}
