:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg:#f4f7fb;--surface:#fff;--surface-soft:#f8fafc;--text:#0f172a;--text-muted:#64748b;--primary:#2563eb;--primary-strong:#1d4ed8;--border:#dce3ef;--danger:#dc2626;--warning:#f59e0b;--success:#16a34a;--info:#0284c7;--shadow-sm:0 2px 8px #0f172a0f;--shadow-md:0 10px 30px #0f172a14;--radius:14px;--radius-sm:10px;font-family:Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*,:before,:after{box-sizing:border-box}a{color:inherit;text-decoration:none}.app-shell{background:var(--bg);min-height:100vh;color:var(--text)}.sidebar{border-right:1px solid var(--border);background:var(--surface);z-index:10;flex-direction:column;gap:24px;width:272px;height:100vh;padding:24px 16px;display:flex;position:fixed;top:0;left:0}.sidebar__brand{align-items:center;gap:12px;padding:4px 8px;display:flex}.sidebar__brand-icon{color:#fff;background:linear-gradient(130deg,#2563eb,#0f766e);border-radius:12px;place-items:center;width:40px;height:40px;font-weight:700;display:grid}.sidebar__brand-title{margin:0;font-size:.95rem;font-weight:700}.sidebar__brand-subtitle{color:var(--text-muted);margin:0;font-size:.8rem}.sidebar__nav{flex-direction:column;gap:6px;padding-right:4px;display:flex;overflow:auto}.sidebar__link{color:#334155;border-radius:10px;align-items:center;gap:12px;height:42px;padding:0 12px;transition:all .2s;display:flex}.sidebar__link svg{fill:currentColor;width:18px;height:18px}.sidebar__link:hover{color:#1e3a8a;background:#eef2ff;transform:translate(2px)}.sidebar__link--active{color:#1d4ed8;background:#dbeafe;font-weight:600}.app-shell__main{flex-direction:column;min-height:100vh;margin-left:272px;display:flex}.topbar{z-index:5;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffeb;justify-content:space-between;align-items:center;gap:16px;padding:18px 24px;display:flex;position:sticky;top:0}.topbar__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:.82rem}.topbar__title{margin:4px 0 0;font-size:1.05rem}.topbar__meta{color:var(--text-muted);font-size:.85rem}.app-shell__content{flex:1;padding:24px}.page{flex-direction:column;gap:20px;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.page-header__title{margin:0;font-size:1.5rem;line-height:1.2}.page-header__subtitle{color:var(--text-muted);margin:8px 0 0}.page-header__actions{gap:8px;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px}.card h3{margin:0 0 14px;font-size:1.03rem}.stats-grid{gap:14px;display:grid}.stats-grid--dashboard{grid-template-columns:repeat(4,minmax(0,1fr))}.stat-card{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);min-height:104px;box-shadow:var(--shadow-sm);padding:14px}.stat-card__label{color:var(--text-muted);margin:0;font-size:.85rem}.stat-card__value{margin:10px 0 0;font-size:1.45rem;line-height:1.1}.stat-card__hint{color:var(--text-muted);margin:10px 0 0;font-size:.84rem}.stat-card--warning{background:#fff9ef;border-color:#f6d6a5}.stat-card--info{background:#eff6ff;border-color:#bfdbfe}.dashboard-grid{grid-template-columns:2fr 1fr;gap:16px;display:grid}.chart-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.chart-box{width:100%;height:280px}.table-wrapper{border:1px solid var(--border);border-radius:12px;overflow:auto}.data-table{border-collapse:separate;border-spacing:0;width:100%;min-width:680px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:#475569;border-bottom:1px solid var(--border);background:#f8fafc;padding:12px 14px;font-size:.81rem}.data-table td{vertical-align:middle;color:#0f172a;border-bottom:1px solid #edf2f7;padding:12px 14px}.data-table tr:last-child td{border-bottom:0}.data-table tbody tr:hover td{background:#f9fbff}.table-actions{gap:8px;display:flex}.status-badge{letter-spacing:.02em;border-radius:999px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.status-badge--success{color:#166534;background:#dcfce7}.status-badge--warning{color:#92400e;background:#fef3c7}.status-badge--danger{color:#991b1b;background:#fee2e2}.status-badge--info{color:#1e3a8a;background:#dbeafe}.status-badge--neutral{color:#334155;background:#e2e8f0}.button{background:var(--primary);color:#fff;cursor:pointer;border:0;border-radius:10px;justify-content:center;align-items:center;gap:6px;height:40px;padding:0 14px;font-weight:600;transition:all .2s;display:inline-flex}.button:hover:not(:disabled){background:var(--primary-strong);transform:translateY(-1px)}.button:disabled{opacity:.65;cursor:not-allowed}.button--ghost{color:#0f172a;background:#e2e8f0}.button--ghost:hover:not(:disabled){background:#cbd5e1}.button--danger{background:#ef4444}.button--danger:hover:not(:disabled){background:#dc2626}.button--small{border-radius:8px;height:30px;padding:0 10px;font-size:.8rem}.input,.select{color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:10px;outline:0;width:100%;height:40px;padding:0 12px;font-size:.92rem;transition:border-color .18s,box-shadow .18s}.input:focus,.select:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #2563eb1f}.input--error{border-color:#fca5a5}.search-filter-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.search-filter-bar__left,.search-filter-bar__right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.search-filter-bar__left .input{min-width:240px}.modal-overlay{z-index:50;background:#0f172a73;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);width:min(720px,100%);box-shadow:var(--shadow-md);border-radius:14px;max-height:92vh;overflow:auto}.modal--small{width:min(460px,100%)}.modal__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.modal__header h2{margin:0;font-size:1.05rem}.modal__body{padding:16px 18px 18px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.form-field{flex-direction:column;gap:6px;display:flex}.form-field label{color:#334155;font-size:.87rem;font-weight:600}.form-field__error{color:#b91c1c;margin:0;font-size:.78rem}.form-actions{grid-column:1/-1;justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.confirm-dialog__message{color:#334155;margin:0}.confirm-dialog__actions{justify-content:flex-end;gap:8px;margin-top:18px;display:flex}.toast-container{z-index:70;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:18px;right:18px}.toast{min-width:280px;max-width:420px;box-shadow:var(--shadow-md);border:1px solid #0000;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.toast p{margin:0;font-size:.86rem}.toast--success{color:#14532d;background:#dcfce7;border-color:#86efac}.toast--info{color:#1e3a8a;background:#dbeafe;border-color:#93c5fd}.toast--error{color:#7f1d1d;background:#fee2e2;border-color:#fca5a5}.empty-state{text-align:center;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:12px;padding:28px}.empty-state h3{margin:0 0 8px}.empty-state p{color:var(--text-muted);margin:0}.empty-inline{color:var(--text-muted);margin:0;padding:8px 0}.alert-list,.metric-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.alert-list__item,.metric-list__item{border:1px solid var(--border);background:#fff;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.alert-list__title,.metric-list__title{margin:0;font-weight:600}.alert-list__subtitle,.metric-list__subtitle{color:var(--text-muted);margin:3px 0 0;font-size:.82rem}.usage-bar{background:#e2e8f0;border-radius:999px;height:8px;margin-top:6px;overflow:hidden}.usage-bar span{background:linear-gradient(90deg,#2563eb,#0f766e);height:100%;display:block}.pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:14px;display:flex}.pagination__size,.pagination__controls{color:var(--text-muted);align-items:center;gap:8px;font-size:.87rem;display:flex}.select--small{width:84px;height:32px;font-size:.84rem}.loading-view{color:#475569;place-items:center;gap:10px;min-height:50vh;display:grid}.loading-view__spinner{border:3px solid #dbeafe;border-top-color:#2563eb;border-radius:50%;width:34px;height:34px;animation:.8s linear infinite spin}.text-warning{color:#b45309;font-weight:700}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=1200px){.stats-grid--dashboard{grid-template-columns:repeat(2,minmax(0,1fr))}.chart-grid{grid-template-columns:1fr}}@media (width<=940px){.sidebar{border-right:0;border-bottom:1px solid var(--border);width:100%;height:auto;padding-bottom:12px;position:static}.sidebar__nav{flex-direction:row;padding-bottom:4px;overflow:auto}.sidebar__link{min-width:max-content}.app-shell__main{margin-left:0}.app-shell__content{padding:16px}.dashboard-grid{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start;position:static}}@media (width<=700px){.page-header{flex-direction:column;align-items:stretch}.stats-grid--dashboard,.form-grid{grid-template-columns:1fr}.search-filter-bar__left .input{min-width:100%}.toast{width:calc(100vw - 32px);min-width:0}}.auth-page{background:var(--bg);place-items:center;min-height:100vh;padding:16px;display:grid}.auth-card{background:var(--surface);border:1px solid var(--border);width:min(420px,100%);box-shadow:var(--shadow-md);border-radius:14px;flex-direction:column;gap:12px;padding:20px;display:flex}.auth-form{flex-direction:column;gap:10px;display:flex}
