:root{--bg: #f3f5fb;--panel: #ffffff;--border: #e7ecf5;--text: #16203a;--muted: #74819e;--accent: #4361ff;--accent-dark: #2f49d6;--blue: #4361ff;--blue-soft: #e9edff;--violet: #8b5cf6;--violet-soft: #f0eafe;--green: #16a34a;--green-soft: #e3f8ec;--red: #ef4444;--red-soft: #fdeaea;--amber: #b8860b;--amber-soft: #fbf2da;--shadow-sm: 0 1px 2px rgba(16, 32, 58, .05);--shadow: 0 10px 30px rgba(16, 32, 58, .07);--radius: 14px}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}.loading{padding:48px;color:var(--muted)}.muted{color:var(--muted)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(900px 500px at 90% 10%,#e9ecff 0%,transparent 55%),radial-gradient(800px 600px at 0% 100%,#eef0ff 0%,transparent 50%),linear-gradient(135deg,#eef2ff,#f3f5fb,#eaf0ff)}.auth-split{display:grid;grid-template-columns:1.1fr 1fr;width:100%;max-width:980px;background:var(--panel);border-radius:26px;overflow:hidden;box-shadow:0 30px 80px #16203a2e;border:1px solid rgba(255,255,255,.7);animation:authIn .5s cubic-bezier(.22,1,.36,1)}@keyframes authIn{0%{opacity:0;transform:translateY(16px) scale(.99)}to{opacity:1;transform:none}}.auth-hero{position:relative;overflow:hidden;color:#fff;padding:48px 44px;display:flex;align-items:center;background:linear-gradient(155deg,#3b34d6,#4361ff 42%,#7c5cff);isolation:isolate}.hero-blob{position:absolute;border-radius:50%;filter:blur(8px);z-index:-1;opacity:.55}.hero-blob-1{width:280px;height:280px;top:-90px;right:-60px;background:radial-gradient(circle,rgba(255,255,255,.45),transparent 65%);animation:float1 9s ease-in-out infinite}.hero-blob-2{width:240px;height:240px;bottom:-80px;left:-50px;background:radial-gradient(circle,rgba(124,92,255,.6),transparent 65%);animation:float2 11s ease-in-out infinite}@keyframes float1{0%,to{transform:translate(0)}50%{transform:translate(-18px,22px)}}@keyframes float2{0%,to{transform:translate(0)}50%{transform:translate(20px,-18px)}}.hero-grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background-image:linear-gradient(rgba(255,255,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.07) 1px,transparent 1px);background-size:34px 34px;-webkit-mask-image:radial-gradient(circle at 30% 30%,#000 0%,transparent 75%);mask-image:radial-gradient(circle at 30% 30%,#000 0%,transparent 75%)}.auth-hero-inner{position:relative;display:flex;flex-direction:column;gap:26px;width:100%}.hero-brand{display:flex;align-items:center;gap:12px}.hero-logo{height:44px;border-radius:12px;background:#fff;display:grid;place-items:center;padding:7px 12px;box-shadow:0 6px 18px #0000002e}.hero-logo img{height:26px;width:auto;display:block}.hero-brand-name{font-weight:700;font-size:16px;letter-spacing:.2px}.hero-copy h2{margin:0 0 14px;font-size:30px;line-height:1.2;letter-spacing:-.5px}.hero-copy p{margin:0;color:#ffffffdb;line-height:1.65;font-size:14.5px;max-width:360px}.hero-points{list-style:none;padding:0;margin:0;display:grid;gap:14px}.hero-points li{display:flex;align-items:center;gap:12px;color:#fffffff2;font-size:14px}.hp-icon{width:30px;height:30px;flex-shrink:0;border-radius:9px;background:#ffffff29;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;color:#fff}.hero-foot{margin-top:4px;padding-top:22px;border-top:1px solid rgba(255,255,255,.16);font-size:12.5px;color:#ffffffb8}.auth-card{display:flex;align-items:center;justify-content:center;padding:48px 44px}.auth-card-inner{width:100%;max-width:340px}.auth-badge{display:inline-block;font-size:11.5px;font-weight:600;letter-spacing:.4px;color:var(--accent);background:var(--blue-soft);border:1px solid rgba(67,97,255,.18);padding:5px 12px;border-radius:999px;margin-bottom:18px}.auth-card h1{margin:0 0 6px;font-size:27px;letter-spacing:-.4px}.auth-subtitle{margin:0 0 26px;color:var(--muted);font-size:14px}.auth-form label{margin-top:16px}.auth-form label:first-of-type{margin-top:0}.alert.error{display:flex;align-items:center;gap:9px}.input-icon{position:relative;display:flex;align-items:center}.input-icon .ii-lead{position:absolute;left:13px;color:#9aa7c2;pointer-events:none}.input-icon input{padding-left:42px;padding-right:42px;height:46px}.ii-toggle{position:absolute;right:8px;background:transparent;border:none;cursor:pointer;color:#9aa7c2;padding:6px;border-radius:8px;display:grid;place-items:center}.ii-toggle:hover{color:var(--accent);background:var(--blue-soft)}.auth-submit{display:flex;align-items:center;justify-content:center;gap:9px;height:48px;margin-top:24px;box-shadow:0 10px 24px #4361ff4d}.auth-submit:hover:not(:disabled){box-shadow:0 12px 28px #4361ff61}.spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-foot{margin-top:26px;display:flex;flex-direction:column;gap:12px}.role-note{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted)}.role-note svg{color:var(--green)}.demo-creds{display:flex;gap:8px;flex-wrap:wrap}.demo-creds span{font-size:12px;font-family:SF Mono,Consolas,monospace;color:#56648a;background:#f1f4fb;border:1px solid var(--border);padding:4px 10px;border-radius:7px}@media (max-width: 760px){.auth-split{grid-template-columns:1fr;max-width:420px}.auth-hero{display:none}.auth-card{padding:38px 28px}}label{display:block;font-size:13px;font-weight:600;margin:14px 0 6px;color:#3b496b}input{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:10px;font-size:14px;background:#fbfcff;transition:border-color .15s,box-shadow .15s}input::placeholder{color:#aab4cc}input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4361ff24}button{font-family:inherit;font-size:14px}.primary{background:var(--accent);color:#fff;border:none;padding:11px 20px;border-radius:10px;cursor:pointer;font-weight:600;transition:background .15s,transform .05s}.primary:hover{background:var(--accent-dark)}.primary:active{transform:translateY(1px)}.primary:disabled{opacity:.6;cursor:default}.primary.block{width:100%;margin-top:20px;padding:12px}.secondary{background:#fff;color:var(--accent);border:1px solid var(--border);padding:9px 16px;border-radius:10px;cursor:pointer;font-weight:600;box-shadow:var(--shadow-sm)}.secondary:hover{border-color:var(--accent)}.button-link{display:inline-block;text-decoration:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:248px;background:#0f1830;color:#cdd8f2;display:flex;flex-direction:column;padding:24px 16px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;padding:0 6px 4px}.sidebar-close{display:none}.brand-logo{flex-shrink:0;display:grid;place-items:center}.brand-logo img{height:38px;width:auto;display:block}.brand-text{min-width:0}.brand h2{margin:0;font-size:16px;color:#fff;letter-spacing:-.2px;line-height:1.2}.role-pill{display:inline-block;margin-top:6px;font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;background:#4361ff47;color:#b8c7ff;padding:2px 9px;border-radius:999px;font-weight:600}.sidebar nav{margin-top:26px;display:flex;flex-direction:column;gap:4px;flex:1}.sidebar nav a{display:flex;align-items:center;gap:11px;color:#9aa8cb;padding:11px 14px;border-radius:10px;font-size:14px;font-weight:500;transition:background .15s,color .15s}.sidebar nav a .nav-icon{display:grid;place-items:center;opacity:.85}.sidebar nav a:hover{background:#ffffff0f;color:#fff}.sidebar nav a.active{background:linear-gradient(135deg,var(--accent),#6b5cff);color:#fff;box-shadow:0 6px 16px #4361ff59}.sidebar nav a.active .nav-icon{opacity:1}.sidebar-footer{border-top:1px solid rgba(255,255,255,.08);padding-top:16px}.sidebar-footer .who{display:flex;align-items:center;gap:11px;margin-bottom:12px;padding:0 4px}.who-avatar{width:36px;height:36px;flex-shrink:0;border-radius:50%;background:linear-gradient(135deg,var(--accent),#7c5cff);color:#fff;font-weight:700;font-size:15px;display:grid;place-items:center}.who-meta{display:flex;flex-direction:column;min-width:0}.who-meta strong{font-size:13.5px;color:#eaf0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.who-meta small{font-size:11.5px;color:#8a98bd}.sidebar-footer button{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:transparent;border:1px solid rgba(255,255,255,.18);color:#cdd8f2;padding:9px;border-radius:10px;cursor:pointer;font-weight:600}.sidebar-footer button:hover{background:#ffffff14}.content{flex:1;padding:30px 36px;overflow-x:auto;min-width:0}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-head h1{font-size:24px;margin:0;letter-spacing:-.3px}.page-sub{margin:6px 0 0;color:var(--muted);font-size:14px}.topbar{display:none}.hamburger{display:grid;place-items:center;width:42px;height:42px;background:transparent;border:none;color:#fff;border-radius:10px;cursor:pointer}.hamburger:hover{background:#ffffff1a}.topbar-brand img{height:30px;width:auto;display:block}.sidebar-overlay{display:none}@media (max-width: 860px){.app-shell{flex-direction:column}.topbar{display:flex;align-items:center;gap:12px;background:#0f1830;color:#fff;padding:10px 14px;position:sticky;top:0;z-index:40}.sidebar{position:fixed;top:0;left:0;z-index:60;width:270px;max-width:82vw;height:100vh;transform:translate(-100%);transition:transform .25s ease;box-shadow:0 0 40px #00000073}.sidebar.is-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#080c188c}.sidebar-close{display:grid;place-items:center;margin-left:auto;width:36px;height:36px;background:transparent;border:none;color:#cdd8f2;border-radius:8px;cursor:pointer}.sidebar-close:hover{background:#ffffff14}.content{padding:20px 16px}.page-head{flex-direction:column;align-items:stretch}body.no-scroll{overflow:hidden}}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:24px}.cards-2{grid-template-columns:repeat(2,1fr)}.cards-3{grid-template-columns:repeat(3,1fr)}.cards-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 980px){.cards-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 720px){.cards-2,.cards-3,.cards-4{grid-template-columns:1fr}}.stat{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:20px 18px 20px 22px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease;overflow:hidden}.stat:after{content:"";position:absolute;right:-30px;bottom:-40px;width:120px;height:120px;border-radius:50%;opacity:.06;background:currentColor}.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.stat-accent{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:var(--radius) 0 0 var(--radius)}.stat-icon{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;flex-shrink:0;box-shadow:inset 0 0 0 1px #fff6}.stat-body{display:flex;flex-direction:column;min-width:0;gap:3px}.stat-label{color:var(--muted);font-size:12.5px;font-weight:500;text-transform:uppercase;letter-spacing:.4px}.stat-value{font-size:28px;font-weight:800;letter-spacing:-.8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.1}.stat-value-fit{font-size:clamp(16px,2.1vw,26px);overflow:visible;text-overflow:clip;letter-spacing:-.5px}.stat-hint{position:absolute;top:16px;right:16px;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px}.tone-blue{color:var(--blue)}.tone-violet{color:var(--violet)}.tone-green{color:var(--green)}.tone-red{color:var(--red)}.tone-amber{color:var(--amber)}.tone-blue .stat-icon{background:linear-gradient(135deg,#e9edff,#dce3ff);color:var(--blue)}.tone-violet .stat-icon{background:linear-gradient(135deg,#f0eafe,#e7dcff);color:var(--violet)}.tone-green .stat-icon{background:linear-gradient(135deg,#e3f8ec,#d2f5e0);color:var(--green)}.tone-red .stat-icon{background:linear-gradient(135deg,#fdeaea,#ffdede);color:var(--red)}.tone-amber .stat-icon{background:linear-gradient(135deg,#fbf2da,#f6e8bf);color:var(--amber)}.tone-blue .stat-accent{background:linear-gradient(var(--blue),#7c5cff)}.tone-violet .stat-accent{background:linear-gradient(var(--violet),#b58bff)}.tone-green .stat-accent{background:linear-gradient(var(--green),#34d27e)}.tone-red .stat-accent{background:linear-gradient(var(--red),#f87171)}.tone-amber .stat-accent{background:linear-gradient(var(--amber),#e3b34b)}.tone-blue .stat-value,.tone-violet .stat-value,.tone-green .stat-value,.tone-red .stat-value,.tone-amber .stat-value{color:var(--text)}.tone-blue .stat-hint{background:var(--blue-soft);color:var(--blue)}.tone-violet .stat-hint{background:var(--violet-soft);color:var(--violet)}.tone-green .stat-hint{background:var(--green-soft);color:var(--green)}.tone-red .stat-hint{background:var(--red-soft);color:var(--red)}.tone-amber .stat-hint{background:var(--amber-soft);color:var(--amber)}.section-title{font-size:15px;font-weight:700;color:var(--text);margin:26px 0 12px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;margin-bottom:22px;box-shadow:var(--shadow-sm)}.panel h2{font-size:16px;margin:0 0 16px;display:flex;align-items:center;gap:8px}.panel h2 svg{color:var(--accent)}.empty{padding:28px;text-align:center;color:var(--muted);background:#f8fafe;border:1px dashed var(--border);border-radius:10px}.bar-row{margin-bottom:16px}.bar-row:last-child{margin-bottom:0}.bar-label{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}.bar{background:#eef2fa;border-radius:999px;height:10px;overflow:hidden}.bar-fill{height:100%;border-radius:999px;transition:width .5s ease}.bar-fill.reco{background:linear-gradient(90deg,#16a34a,#34d27e)}.bar-fill.extra{background:linear-gradient(90deg,#ef4444,#f87171)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border);white-space:nowrap}th{color:var(--text);font-size:12px;text-transform:uppercase;letter-spacing:.4px;font-weight:700;background:#eef2fa;position:sticky;top:0}tbody tr{transition:background .12s}tbody tr:hover{background:#f8faff}tr:last-child td{border-bottom:none}.audits-table tbody td{text-transform:uppercase}th.asset-col{background:#4472c4;color:#fff;border-bottom-color:#2f528f}th.audit-col{background:#ed7d31;color:#fff;border-bottom-color:#c45911}th.group-start{border-left:3px solid #fff}tbody td.asset-cell{background:#f1f5fd}tbody td.audit-cell{background:#fdf3ec}tbody td.group-start{border-left:3px solid var(--border)}.muted-cell{color:var(--muted);text-transform:none}.badge{font-size:12px;padding:4px 11px;border-radius:999px;font-weight:600;display:inline-block}.badge.reco{background:var(--green-soft);color:var(--green)}.badge.extra{background:var(--red-soft);color:var(--red)}.badge.pending{background:var(--amber-soft);color:var(--amber)}.alert{padding:12px 15px;border-radius:10px;font-size:14px;margin-bottom:16px}.alert.error{background:var(--red-soft);color:#c0392b}.alert.success{background:var(--green-soft);color:#15803d}.alert.warn{background:var(--amber-soft);color:var(--amber)}.table-wrap.is-loading{opacity:.55;transition:opacity .15s}.pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid var(--border);flex-wrap:wrap}.pagination-left{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.pagination-info{color:var(--muted);font-size:13px}.per-page{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--muted)}.per-page select{padding:7px 10px;border:1px solid var(--border);border-radius:9px;background:#fff;font-size:13px;font-weight:600;color:var(--text);cursor:pointer}.pagination-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.page-status{font-size:13px;color:var(--muted);white-space:nowrap}.page-jump{display:flex;align-items:center;gap:6px}.page-jump input{width:84px;padding:8px 10px;border:1px solid var(--border);border-radius:9px;background:#fbfcff;font-size:13px}.page-btn{background:#fff;color:var(--accent);border:1px solid var(--border);padding:8px 14px;border-radius:9px;cursor:pointer;font-weight:600;box-shadow:var(--shadow-sm)}.page-btn:hover:not(:disabled){border-color:var(--accent)}.page-btn:disabled{opacity:.45;cursor:default;color:var(--muted)}.chart-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:22px;margin-bottom:22px}@media (max-width: 880px){.chart-grid{grid-template-columns:1fr}}.panel-sub{font-size:12px;font-weight:500;color:var(--muted);margin-left:6px}.chart-empty{display:grid;place-items:center;color:var(--muted);font-size:14px;background:#f8fafe;border:1px dashed var(--border);border-radius:10px}.donut{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center}.donut-total{font-size:30px;font-weight:700;fill:var(--text)}.donut-sub{font-size:12px;fill:var(--muted);text-transform:uppercase;letter-spacing:.5px}.legend{display:flex;flex-direction:column;gap:10px}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.legend-item .dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}.legend-label{color:var(--muted);min-width:92px}.legend-val{font-weight:700}.trend{display:block}.trend .axis{font-size:11px;fill:#9aa7c2}.hbars{display:flex;flex-direction:column;gap:14px}.hbar-row{display:grid;grid-template-columns:120px 1fr 34px;align-items:center;gap:12px}.hbar-name{font-size:13px;color:#46557a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hbar-track{background:#eef2fa;border-radius:999px;height:12px;overflow:hidden}.hbar-fill{height:100%;border-radius:999px;transition:width .5s ease}.hbar-val{font-size:13px;font-weight:700;text-align:right}.users-grid{display:grid;grid-template-columns:340px 1fr;gap:22px;align-items:start}@media (max-width: 880px){.users-grid{grid-template-columns:1fr}}.add-user-panel{position:sticky;top:30px}.user-cell{display:flex;align-items:center;gap:10px}.user-avatar{width:32px;height:32px;flex-shrink:0;border-radius:50%;background:linear-gradient(135deg,var(--accent),#7c5cff);color:#fff;font-weight:700;font-size:13px;display:grid;place-items:center}.row-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}.icon-btn{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);color:var(--accent);padding:7px 11px;border-radius:9px;cursor:pointer;font-weight:600;font-size:13px;box-shadow:var(--shadow-sm);transition:border-color .15s,background .15s}.icon-btn:hover{border-color:var(--accent);background:var(--blue-soft)}.icon-btn.danger{color:var(--red)}.icon-btn.danger:hover{border-color:var(--red);background:var(--red-soft)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#10183080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:20px;animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--panel);border-radius:18px;padding:26px;width:100%;max-width:400px;box-shadow:0 30px 70px #1018304d;animation:modalIn .22s cubic-bezier(.22,1,.36,1)}@keyframes modalIn{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}.modal h3{margin:0 0 6px;font-size:19px;display:flex;align-items:center;gap:9px}.modal h3 svg{color:var(--accent)}.modal p{margin:0 0 14px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.bulk-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--blue-soft);border:1px solid rgba(67,97,255,.2);border-radius:12px;padding:12px 16px;margin-bottom:16px;animation:fadeIn .18s ease}.bulk-bar span{font-size:14px;color:#34406b}.bulk-actions{display:flex;align-items:center;gap:10px}.col-check{width:40px;text-align:center}.col-check input{width:16px;height:16px;cursor:pointer;accent-color:var(--accent)}.col-actions{text-align:right}tbody tr.row-selected{background:#eef3ff}tbody tr.row-selected:hover{background:#e6edff}.danger-btn{display:inline-flex;align-items:center;gap:7px;background:var(--red);color:#fff;border:none;padding:9px 15px;border-radius:10px;cursor:pointer;font-weight:600;box-shadow:0 6px 16px #ef444447}.danger-btn:hover{background:#dc2626}.danger-btn:disabled{opacity:.6;cursor:default}.modal.modal-wide{max-width:640px}.modal-wide .grid-form{gap:0 18px}.grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:2px 20px}.grid-form .field label{margin-top:12px}.form-actions{grid-column:1 / -1;margin-top:18px}
