:root{--bg: #0d0f1a;--card: #13162a;--accent: #6c5ce7;--accent-light: #a29bfe;--text: #ffffff;--text-muted: #a0a8c0;--border: rgba(108, 92, 231, .2);--success: #00b894;--warning: #fdcb6e;--danger: #e17055;--radius: 14px;--shadow: 0 8px 32px rgba(0, 0, 0, .4)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--accent-light);text-decoration:none}button{background:var(--accent);color:#fff;border:0;padding:12px 18px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .08s ease,opacity .15s}button:hover{opacity:.92}button:active{transform:scale(.98)}button.ghost{background:transparent;border:1px solid var(--border);color:var(--text)}button.danger{background:var(--danger)}button.success{background:var(--success)}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{background:#ffffff0a;color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:15px;width:100%;font-family:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}label{display:block;color:var(--text-muted);font-size:13px;margin-bottom:6px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.container{max-width:1100px;margin:0 auto;padding:16px 16px 96px}.grid{display:grid;gap:12px}.row{display:flex;gap:12px;align-items:center}.row.between{justify-content:space-between}.muted{color:var(--text-muted)}.h1{font-size:24px;font-weight:700;margin:0 0 16px}.h2{font-size:18px;font-weight:600;margin:0 0 10px}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge.pending{background:#fdcb6e2e;color:var(--warning)}.badge.approved{background:#00b8942e;color:var(--success)}.badge.rejected{background:#e170552e;color:var(--danger)}.progress{height:8px;background:#ffffff0d;border-radius:999px;overflow:hidden}.progress>.bar{height:100%;transition:width .3s}.progress.green>.bar{background:var(--success)}.progress.yellow>.bar{background:var(--warning)}.progress.red>.bar{background:var(--danger)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--card);position:sticky;top:0;z-index:10}.app-header .brand{font-weight:700;font-size:17px}.app-header .brand small{color:var(--text-muted);margin-left:6px;font-weight:400;font-size:12px}.tabbar{position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:8px 0 max(8px,env(safe-area-inset-bottom));z-index:9}.tabbar a{flex:1;text-align:center;padding:6px 4px;font-size:12px;color:var(--text-muted)}.tabbar a.active{color:var(--accent-light);font-weight:600}.burger-btn{width:36px;height:36px;background:transparent;border:none;padding:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch}.burger-btn span{display:block;height:2px;background:var(--text, #fff);border-radius:1px}.burger-btn:hover span{background:var(--accent-light)}.burger-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:90;animation:burger-fade-in .18s ease-out}@keyframes burger-fade-in{0%{opacity:0}to{opacity:1}}.burger-drawer{position:fixed;top:0;left:0;bottom:0;width:min(280px,80vw);background:var(--card);border-right:1px solid var(--border);z-index:100;transform:translate(-100%);transition:transform .22s ease-out;display:flex;flex-direction:column;box-shadow:4px 0 18px #00000040}.burger-drawer.open{transform:translate(0)}.burger-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.burger-drawer-title{font-weight:700;font-size:16px}.burger-close{background:transparent;border:none;color:var(--text-muted);font-size:28px;line-height:1;cursor:pointer;padding:0 6px}.burger-close:hover{color:var(--text, #fff)}.burger-nav{display:flex;flex-direction:column;padding:8px 0}.burger-nav a{display:block;padding:12px 18px;font-size:15px;color:var(--text-muted);text-decoration:none;border-left:3px solid transparent}.burger-nav a:hover{background:#ffffff0a;color:var(--text, #fff)}.burger-nav a.active{color:var(--accent-light);font-weight:600;border-left-color:var(--accent-light);background:#6c5ce714}.report-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);overflow-x:auto;margin-bottom:14px}.report-tab{background:transparent;border:none;padding:10px 14px;color:var(--text-muted);cursor:pointer;font-size:14px;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px}.report-tab:hover{color:var(--text)}.report-tab.active{color:var(--accent-light);font-weight:600;border-bottom-color:var(--accent-light)}.skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:skeleton-shimmer 1.4s linear infinite;border-radius:6px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:40px 16px;color:var(--text-muted)}.empty-state .icon{font-size:36px;margin-bottom:8px;opacity:.5}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge.pending{background:#fdcb6e26;color:var(--warning)}.badge.approved{background:#00b89426;color:var(--success)}.badge.rejected{background:#e1705526;color:var(--danger)}table{width:100%;border-collapse:collapse}th,td{padding:10px;text-align:left;border-bottom:1px solid var(--border);font-size:14px}th{color:var(--text-muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}tr.pending-row{background:#fdcb6e0d}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--card);border:1px solid var(--border);padding:12px 18px;border-radius:10px;z-index:100;box-shadow:var(--shadow)}.toast.success{border-color:var(--success)}.toast.error{border-color:var(--danger)}@media (max-width: 720px){.container{padding:12px 12px 96px}table{font-size:13px}th,td{padding:8px 6px}}
