@import"https://fonts.googleapis.com/css2?family=Rubik:wght@300;400;500;600&display=swap";:root{font-family:Rubik,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;color:#0f172a;background-color:#f8fafc}*{box-sizing:border-box}body{margin:0}a,button{font:inherit}a{color:inherit;text-decoration:none}.layout{min-height:100vh}.sidebar{position:fixed;top:0;left:0;height:100vh;width:200px;background:#0f172a;color:#f8fafc;padding:1rem;overflow-y:auto;transition:width .2s ease}.sidebar.collapsed{width:68px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:1rem}.sidebar h1{margin:0 0 1.5rem;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}.sidebar nav a{display:block;padding:.5rem .75rem;border-radius:6px;margin-bottom:.25rem;font-size:.95rem}.sidebar nav a.active,.sidebar nav a:hover{background:#ffffff1a}.nav-item{display:inline-flex;align-items:center;gap:.5rem}.sidebar.collapsed .nav-label{display:none}.user-block{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.user-block.collapsed{justify-content:center}.user-avatar{width:42px;height:42px;border-radius:50%;background:#1e293b;display:grid;place-items:center;font-weight:700;letter-spacing:.5px}.user-meta{line-height:1.3}.user-name{font-weight:600}.user-email{opacity:.8;font-size:.9rem}.icon-button{display:inline-flex;align-items:center;gap:.5rem;background:#ffffff1a;color:#f8fafc;border:none;border-radius:10px;padding:.45rem .65rem;cursor:pointer}.icon-button.logout{width:100%;justify-content:center}.content{padding:1.5rem;margin-left:200px;transition:margin-left .2s ease}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;row-gap:1rem}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;box-shadow:0 10px 30px #0f172a0a}.table{width:100%;border-collapse:collapse;table-layout:auto}.table th,.table td{padding:.65rem;border-bottom:1px solid #e2e8f0;text-align:left;font-size:.88rem}.table a{color:#1d4ed8;text-decoration:underline;font-weight:600}.badge{display:inline-block;padding:.25rem .5rem;border-radius:999px;font-size:.75rem;background:#e2e8f0;color:#0f172a}.skeleton{background:linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0);background-size:200% 100%;animation:skeleton 1.2s ease-in-out infinite}@keyframes skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.table-wrapper{position:relative}.table-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff9;display:grid;place-items:center;font-weight:600;color:#0f172a;pointer-events:none}.page-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-weight:700;color:#0f172a;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2}.pager-row{display:flex;justify-content:space-between;align-items:center;margin:.5rem 0;gap:.75rem;flex-wrap:wrap}.pager{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.pager-button{border:1px solid #cbd5e1;background:#fff;color:#0f172a;padding:.35rem .7rem;border-radius:8px;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.pager-button.active{background:#0f172a;color:#fff;border-color:#0f172a}.pager-button:disabled{opacity:.5;cursor:not-allowed}.pager-ellipsis{padding:0 6px;color:#64748b}.input,.button{width:100%;padding:.65rem .75rem;border-radius:10px;border:1px solid #e2e8f0;font-size:1rem}.button{background:#0f172a;color:#fff;cursor:pointer;border:none}.button:disabled{opacity:.6;cursor:not-allowed}.form-stack{display:grid;gap:.75rem}.header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.pill{background:#e2e8f0;border-radius:999px;padding:.25rem .75rem;font-size:.85rem;display:inline-flex;align-items:center;gap:.35rem}.pill-on{background:#dcfce7;color:#166534;border:1px solid #86efac}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;display:grid;place-items:center;z-index:1000;padding:1rem}.modal{width:100%;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0f172a4d;border:1px solid #e2e8f0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0}.modal-body{padding:1.25rem;max-height:80vh;overflow:auto}.icon-button.dark{background:#0f172a;color:#fff}.banner{position:sticky;top:0;z-index:20;background:linear-gradient(90deg,#0f172a,#1e293b);color:#f8fafc;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:12px;box-shadow:0 14px 30px #0f172a40}.banner-light{background:#fff3e0;color:#7c2d12;border:1px solid #fdba74;box-shadow:0 12px 24px #f59e0b33}.banner-chip{background:#ffffff1f;color:#f8fafc;padding:.25rem .6rem;border-radius:999px;font-weight:400;display:inline-flex;align-items:center;gap:.35rem}.banner-chip-light{background:#fdba74;color:#7c2d12;box-shadow:0 0 0 1px #f59e0b inset}.notif-bell{position:relative;background:#0f172a;color:#f8fafc;border-radius:999px;padding:.4rem .65rem;display:inline-flex;align-items:center;gap:.35rem;border:none;cursor:pointer}.notif-bell-light{background:#fdba74;color:#7c2d12}.notif-badge{position:absolute;top:-6px;right:-6px;background:#f97316;color:#0f172a;border-radius:999px;padding:2px 6px;font-size:.7rem;font-weight:500}.notif-badge-light{background:#ef4444;color:#fff}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:min(420px,90vw);background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 14px 28px #0f172a29;padding:.6rem;z-index:40;font-size:.9rem}.notif-row{display:grid;grid-template-columns:1fr auto;gap:.35rem;padding:.4rem .25rem;border-bottom:1px solid #e2e8f0;border-radius:0}.notif-tag{font-size:.72rem;font-weight:400;color:#0f172a;background:#e2e8f0;padding:.12rem .45rem;border-radius:999px;display:inline-flex;gap:.35rem;align-items:center}.notif-tag.secondary{background:#e5e7eb}.link-pill{color:#1d4ed8;cursor:pointer;text-decoration:none;font-weight:400;border:1px solid #cbd5e1;padding:.25rem .6rem;border-radius:999px;background:#f8fafc;display:inline-block}.link-pill:hover{background:#e0f2fe;text-decoration:underline}.inline-link{color:#2563eb;cursor:pointer;text-decoration:none;font-weight:400}.inline-link:hover{text-decoration:underline}.inline-link.muted{color:#475569}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#22c55e;position:relative}.dot-warn{background:#f59e0b;box-shadow:0 0 0 3px #f59e0b2e;animation:pulse-warn 1.2s infinite ease-in-out}@keyframes pulse-warn{0%{transform:scale(.9);opacity:.85;box-shadow:0 0 0 3px #f59e0b29}50%{transform:scale(1.15);opacity:1;box-shadow:0 0 0 4px #f59e0b38}to{transform:scale(.9);opacity:.85;box-shadow:0 0 0 3px #f59e0b29}}.form-label{display:grid;gap:.35rem;color:#0f172a;font-weight:600}.form-label span{color:#64748b;font-weight:600}@media (max-width: 900px){.sidebar{width:78px;padding:.75rem}.sidebar.collapsed{width:78px}.sidebar .nav-label,.sidebar .user-meta,.sidebar h1{display:none}.user-block{justify-content:center}.content{margin-left:78px;padding:1rem}.header-row{flex-direction:column;align-items:flex-start;gap:.5rem}.table{display:block;overflow-x:auto}}@media (max-width: 640px){:root{font-size:13px}.card-grid{grid-template-columns:1fr}.pager-row{flex-direction:column;align-items:flex-start}.pager,.pager-button{width:100%;justify-content:center}.layout{min-height:100vh}}
