:root{color:#172033;background:#eef3f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr);background:radial-gradient(circle at top left,rgba(31,58,99,.12),transparent 32rem),#f5f7fb}.sidebar{position:sticky;top:0;height:100vh;padding:22px 18px;overflow-y:auto;color:#d8e2f2;background:linear-gradient(180deg,#142742,#0e1829);border-right:1px solid rgba(255,255,255,.08)}.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 18px}.brand-mark{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;color:#fff;font-weight:800;background:#28466f;box-shadow:inset 0 0 0 1px #ffffff24}.brand strong{display:block;color:#fff;font-size:16px}.brand span{display:block;color:#9fb0c8;font-size:12px;margin-top:2px}.nav-group-title{margin:22px 8px 8px;color:#7e90aa;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.nav-button{width:100%;min-height:42px;border:0;border-radius:12px;display:flex;align-items:center;gap:10px;padding:10px 12px;color:#b9c7dc;background:transparent;text-align:left;transition:.16s ease}.nav-button:hover{color:#fff;background:#ffffff0f}.nav-button.active{color:#fff;background:#233d63;box-shadow:inset 3px 0 #78d2aa}.main{min-width:0;padding:24px}.topbar{height:72px;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px}.page-title h1{margin:0;color:#172033;font-size:28px;letter-spacing:-.02em}.page-title p{margin:5px 0 0;color:#69768a;font-size:14px}.admin-chip{border:1px solid #dce3ee;border-radius:999px;display:flex;align-items:center;gap:10px;padding:9px 12px;color:#263650;background:#fff;box-shadow:0 8px 26px #1c2b440f}.signout-button{border:0;border-radius:999px;padding:8px 10px;color:#536178;background:#eef2f7;font-size:12px;font-weight:800}.signout-button:hover{color:#1f3a63;background:#e2eaf5}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:800;background:#1f3a63}.grid{display:grid;gap:16px}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{border:1px solid #dfe6f0;border-radius:18px;background:#fffffff0;box-shadow:0 14px 40px #1e2f4b12}.card-pad{padding:18px}.stat-card{min-height:132px;display:flex;flex-direction:column;justify-content:space-between}.stat-head{display:flex;justify-content:space-between;gap:12px;color:#718098;font-size:13px}.stat-card strong{display:block;margin-top:14px;color:#172033;font-size:28px;letter-spacing:-.03em}.trend{display:inline-flex;align-items:center;gap:4px;color:#078f61;font-size:12px;font-weight:700}.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 14px}.section-title h2{margin:0;color:#172033;font-size:16px}.section-title p{margin:3px 0 0;color:#718098;font-size:12px}.status-pill{border-radius:999px;display:inline-flex;align-items:center;gap:6px;padding:6px 9px;font-size:11px;font-weight:800}.status-live{color:#066342;background:#e6f8ef}.status-empty{color:#60708a;background:#eef2f7}.status-build{color:#95440d;background:#ffeadb}.status-secure{color:#16467a;background:#e7f1ff}.muted{color:#718098}.table{width:100%;border-collapse:collapse}.table th{color:#718098;font-size:11px;letter-spacing:.08em;text-align:left;text-transform:uppercase}.table th,.table td{border-bottom:1px solid #edf1f6;padding:12px;vertical-align:middle}.table tr:last-child td{border-bottom:0}.clickable-table tbody tr{cursor:pointer;transition:.14s ease}.clickable-table tbody tr:hover{background:#f6f9fc}.clickable-table tbody tr.selected-row{background:#edf5ff;box-shadow:inset 3px 0 #1f3a63}.metric-list{display:grid;gap:10px}.metric-row{border:1px solid #edf1f6;border-radius:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;background:#fbfcfe}.metric-row strong{color:#172033}.progress{width:100%;height:8px;border-radius:99px;overflow:hidden;background:#eef2f7}.progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#1f3a63,#16a36f)}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.search{min-width:280px;border:1px solid #dfe6f0;border-radius:12px;display:flex;align-items:center;gap:9px;padding:10px 12px;color:#718098;background:#fff}.search input{width:100%;border:0;outline:0;color:#172033;background:transparent}.action{border:1px solid #dfe6f0;border-radius:12px;display:inline-flex;align-items:center;gap:8px;padding:10px 12px;color:#1f3a63;font-weight:800;background:#fff}.action.primary{border-color:#1f3a63;color:#fff;background:#1f3a63}.module-card{min-height:180px}.module-card ul{margin:14px 0 0;padding:0;list-style:none;display:grid;gap:9px;color:#536178;font-size:13px}.module-card li{display:flex;gap:8px;align-items:flex-start}.module-card li:before{content:"";width:7px;height:7px;flex:0 0 auto;margin-top:6px;border-radius:50%;background:#78d2aa}.chart{height:220px;width:100%}.risk-banner{border:1px solid #c9d7ea;border-radius:18px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:16px;color:#1b3559;background:linear-gradient(135deg,#eef6ff,#f7fbff)}.permission-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.permission{border:1px solid #edf1f6;border-radius:12px;padding:11px;color:#536178;background:#fbfcfe}.permission strong{display:block;color:#172033;font-size:13px}.footer-note{margin-top:20px;color:#718098;font-size:12px}.empty-state{min-height:280px;display:grid;place-items:center;align-content:center;gap:10px;padding:34px;color:#718098;text-align:center}.empty-state svg{color:#9aa8bc}.empty-state strong{color:#172033;font-size:16px}.empty-state p{max-width:360px;margin:0;line-height:1.45}.empty-state.compact{min-height:160px;padding:24px}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 22% 14%,rgba(31,58,99,.16),transparent 28rem),linear-gradient(135deg,#f7f9fc,#edf3f9)}.login-card{width:min(460px,100%);border:1px solid #dfe6f0;border-radius:24px;display:grid;gap:18px;padding:26px;background:#fffffff5;box-shadow:0 24px 80px #192b461f}.login-card .brand{padding:0}.login-card .brand span{color:#718098}.login-card h1{margin:0;color:#172033;font-size:30px;letter-spacing:-.03em}.login-card p{margin:6px 0 0;color:#718098;line-height:1.5}.login-field{display:grid;gap:8px}.login-field span{color:#536178;font-size:13px;font-weight:800}.login-field input{width:100%;border:1px solid #dfe6f0;border-radius:14px;padding:13px 14px;color:#172033;outline:0;background:#fbfcfe}.login-field input:focus{border-color:#9ab3d3;box-shadow:0 0 0 4px #1f3a6314}.login-error{border:1px solid #ffd3d3;border-radius:14px;padding:12px;color:#9f1d1d;background:#fff1f1;font-size:13px;line-height:1.45}.login-success{border:1px solid #b9efd5;border-radius:14px;padding:12px;color:#057647;background:#ecfdf5;font-size:13px;line-height:1.45}.login-submit{border:0;border-radius:14px;padding:14px;color:#fff;background:#1f3a63;font-weight:900}.login-submit:disabled{cursor:wait;opacity:.72}.login-link-button{border:0;padding:2px 0;color:#1f3a63;background:transparent;font-size:13px;font-weight:800;text-align:center}.login-link-button:disabled{cursor:wait;opacity:.65}.login-note{color:#718098;font-size:12px}.user-layout{align-items:start}.user-detail{position:sticky;top:24px}.subsection-title{margin:18px 0 10px;color:#172033;font-size:14px}.legal-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:16px;margin-bottom:16px}.legal-list{border:1px solid #dfe6f0;border-radius:18px;padding:10px;background:#fbfcfe}.legal-list button{width:100%;border:0;border-radius:12px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;color:#536178;background:transparent;text-align:left}.legal-list button.active{color:#172033;background:#fff;box-shadow:0 6px 20px #1c2b4414}.legal-list button span{font-weight:800}.legal-editor{padding:16px}.legal-editor-header,.legal-actions{display:flex;align-items:center;justify-content:space-between;gap:14px}.legal-editor-header h2{margin:0}.editor-toolbar{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 12px}.editor-toolbar button{border:1px solid #dfe6f0;border-radius:10px;padding:8px 10px;color:#263650;background:#fff;font-size:12px;font-weight:800}.rich-editor{min-height:300px;border:1px solid #dfe6f0;border-radius:16px;padding:18px;outline:0;color:#263650;background:#fbfcfe;line-height:1.6}.rich-editor:focus{border-color:#9ab3d3;box-shadow:0 0 0 4px #1f3a6314}.rich-editor h2{margin-top:0;color:#172033}.legal-actions{margin-top:14px}@media(max-width:1100px){.app-shell{grid-template-columns:88px minmax(0,1fr)}.brand div:last-child,.nav-button span,.nav-group-title{display:none}.nav-button{justify-content:center}.grid.cols-4,.grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.app-shell{display:block}.sidebar{position:static;height:auto}.main{padding:16px}.topbar{align-items:flex-start;height:auto;flex-direction:column}.grid.cols-4,.grid.cols-3,.grid.cols-2,.permission-grid,.legal-shell{grid-template-columns:1fr}.user-detail{position:static}.toolbar{align-items:stretch;flex-direction:column}.search{min-width:0}}
