@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Newsreader:opsz,wght@6..72,400;6..72,600&display=swap";*{box-sizing:border-box}body{margin:0}.app-shell{background:var(--bg);min-height:100vh;color:var(--ink);flex-direction:column;display:flex}.app-main{flex-direction:column;min-height:100vh;display:flex}.app-content{padding:24px 32px 48px;animation:.6s both rise-in}.app-footer{color:var(--muted);text-align:right;padding:10px 32px 18px;font-size:12px}.sidebar{border-right:1px solid var(--border);background:#f7f9fc;flex-direction:column;height:100vh;padding:28px 24px;display:flex;position:sticky;top:0}.sidebar-brand{align-items:center;gap:12px;margin-bottom:24px;display:flex}.brand-mark{background:var(--accent);color:#fff;letter-spacing:.6px;border-radius:14px;place-items:center;width:40px;height:40px;font-weight:700;display:grid}.brand-title{font-family:var(--display-font);font-size:18px;font-weight:700}.brand-subtitle{color:var(--muted);font-size:12px}.sidebar-nav{flex:1;padding-right:8px;overflow-y:auto}.nav-section{margin-bottom:20px}.nav-title{text-transform:uppercase;letter-spacing:2px;color:var(--muted);margin-bottom:10px;font-size:11px}.nav-items{gap:6px;display:grid}.nav-link{color:var(--ink);background:0 0;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;transition:transform .2s,background .2s;display:flex}.nav-link:hover{background:#0a6ed11f;transform:translate(2px)}.nav-link-active{color:var(--accent-2);background:#0a6ed124}.nav-dot{background:var(--accent);border-radius:999px;width:8px;height:8px}.nav-label{font-size:14px;font-weight:500}.sidebar-footer{background:var(--panel);border:1px solid var(--border);box-shadow:none;border-radius:10px;align-items:center;gap:10px;padding:14px 12px;display:flex}.status-pill{color:var(--accent-2);text-transform:uppercase;letter-spacing:1px;background:#0a6ed11f;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600}.status-text{color:var(--muted);font-size:12px}.topbar{border-bottom:1px solid var(--border);z-index:10;background:#f7f9fc;flex-direction:column;gap:12px;padding:18px 32px 12px;display:flex;position:sticky;top:0}.topbar-row{align-items:center;gap:16px;display:flex}.topbar-nav-row{border-top:1px solid var(--border);padding-top:10px}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-title{font-family:var(--display-font);font-size:18px;font-weight:700}.topbar-chip{border:1px solid var(--border);background:var(--panel);color:var(--muted);border-radius:999px;padding:4px 10px;font-size:12px}.topbar-search{flex:1;max-width:520px}.topbar-search input{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;padding:10px 14px;font-size:14px}.topbar-actions{align-items:center;gap:16px;margin-left:auto;display:flex}.top-nav{flex-wrap:wrap;gap:10px;display:flex}.top-nav-group{position:relative}.top-nav-button{border:1px solid var(--border);color:var(--ink);cursor:pointer;text-transform:uppercase;letter-spacing:1px;background:#fff;border-radius:999px;padding:8px 12px;font-size:12px;transition:background .2s,color .2s,border-color .2s}.top-nav-button:hover{color:var(--accent-2);background:#0a6ed11a;border-color:#0a6ed133}.top-nav-button-active{color:var(--accent-2);background:#0a6ed11f;border-color:#0a6ed133}.top-nav-panel{border:1px solid var(--border);min-width:220px;box-shadow:var(--shadow-lg);z-index:12;background:#fff;border-radius:12px;gap:6px;padding:10px;display:grid;position:absolute;top:calc(100% + 10px);left:0}.top-nav-item-row{grid-template-columns:1fr auto;align-items:center;gap:8px;display:grid}.top-nav-item{color:var(--ink);border-radius:8px;padding:8px 10px;font-size:13px;text-decoration:none}.top-nav-item:hover{background:#0a6ed11f}.top-nav-item-active{color:var(--accent-2);background:#0a6ed129}.top-nav-fav{cursor:pointer;color:var(--muted);background:0 0;border:none;font-size:14px}.top-nav-fav.active{color:var(--accent)}.top-nav-empty{color:var(--muted);padding:8px 10px;font-size:12px}.readiness-badge{text-transform:uppercase;letter-spacing:.6px;border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.readiness-low{color:#b42318;background:#b423181f}.readiness-medium{color:#b54708;background:#bf66001f}.readiness-ready{color:#027a48;background:#027a481f}.status-badge{text-transform:uppercase;letter-spacing:.6px;color:#344054;background:#10182814;border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.compliance-badge{text-transform:uppercase;letter-spacing:.6px;border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.compliance-valid{color:#027a48;background:#027a481f}.compliance-expiringsoon{color:#b54708;background:#bf66001f}.compliance-expired,.compliance-missing{color:#b42318;background:#b423181f}.readiness-panel{border:1px solid var(--border);background:#fffc;border-radius:12px;padding:14px}.readiness-score{align-items:center;gap:8px;margin-bottom:10px;display:flex}.readiness-cell{flex-direction:column;gap:6px;display:flex}.readiness-bar{background:#10182814;border-radius:999px;width:100%;height:6px;overflow:hidden}.readiness-bar-fill{background:linear-gradient(90deg,#0a6ed1b3,#0a6ed133);border-radius:999px;height:100%}.readiness-label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-size:12px;font-weight:600}.readiness-list{color:var(--muted);margin:0;padding-left:16px;font-size:13px}.topbar-badge{width:32px;height:32px;color:var(--accent);background:#0a6ed11f;border-radius:8px;place-items:center;font-weight:700;display:grid}.topbar-user{align-items:center;gap:12px;display:flex}.avatar{background:var(--ink);color:#fff;border-radius:8px;place-items:center;width:36px;height:36px;font-weight:700;display:grid}.user-meta{flex-direction:column;gap:2px;display:flex}.user-name{font-size:13px;font-weight:600}.user-role{color:var(--muted);font-size:11px}.ghost-button{border:1px solid var(--border);color:var(--ink);cursor:pointer;background:#fff;border-radius:8px;padding:8px 12px;font-size:12px}.ghost-button:hover{background:#1b1a170f}.login-shell{background:var(--bg);grid-template-columns:minmax(320px,420px) 1fr;gap:40px;min-height:100vh;padding:48px;display:grid}.login-card{background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:28px;flex-direction:column;gap:14px;padding:32px;display:flex}.login-brand{align-items:center;gap:12px;display:flex}.login-card h1{font-family:var(--display-font);margin:0;font-size:28px}.muted{color:var(--muted)}.login-form{flex-direction:column;gap:14px;display:flex}.login-form label{color:var(--muted);text-transform:uppercase;letter-spacing:1px;gap:6px;font-size:12px;display:grid}.login-form input{border:1px solid var(--border);border-radius:14px;padding:12px 14px;font-size:14px}.login-form .primary-button{border-radius:999px}.primary-button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:6px;padding:12px 16px;font-weight:600}.primary-button:hover{filter:brightness(1.05)}.error-text{color:#b42318;font-size:12px}.login-footer{align-items:center;gap:10px;margin-top:auto;display:flex}.login-art{background:linear-gradient(140deg,#0854a033,#0a6ed133);border-radius:32px;align-items:flex-end;display:flex;position:relative;overflow:hidden}.login-copy{max-width:420px;padding:48px}.login-copy h2{font-family:var(--display-font);margin:0 0 12px;font-size:32px}.login-metrics{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px;display:grid}.metric-value{font-size:18px;font-weight:700}.metric-label{color:var(--muted);font-size:12px}.orb{filter:blur();border-radius:50%;position:absolute}.orb-1{background:#0a6ed159;width:220px;height:220px;top:-40px;right:-20px}.orb-2{background:#0854a066;width:180px;height:180px;bottom:40px;right:100px}.orb-3{background:#0f223333;width:140px;height:140px;bottom:-30px;left:40px}.gridlines{opacity:.25;background-image:linear-gradient(#ffffff59 1px,#0000 1px),linear-gradient(90deg,#ffffff59 1px,#0000 1px);background-size:40px 40px;position:absolute;inset:0}.fade-in{animation:.4s both fade-in}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes rise-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.MuiDataGrid-root{border:none}@media (max-width:1100px){.topbar{flex-direction:column;align-items:flex-start;gap:12px}.topbar-row{flex-wrap:wrap;width:100%}.topbar-actions{justify-content:space-between;width:100%}.topbar-search{width:100%;max-width:none;margin:0}}@media (max-width:900px){.login-shell{grid-template-columns:1fr;padding:24px}.login-art{min-height:360px}.login-metrics{grid-template-columns:1fr}}.module-dashboard{gap:28px;display:grid}.module-hero{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#e8f0fa;border-radius:16px;gap:16px;padding:28px;display:grid}.module-hero h1{font-family:var(--display-font);margin:8px 0 6px;font-size:clamp(24px,3vw,36px)}.module-hero p{color:var(--muted);max-width:520px;margin:0}.hero-actions{flex-wrap:wrap;gap:12px;display:flex}.eyebrow{text-transform:uppercase;letter-spacing:2px;color:var(--muted);font-size:11px}.module-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;display:grid}.module-card{border:1px solid var(--border);background:var(--panel);min-height:260px;box-shadow:none;border-radius:14px;gap:16px;padding:20px;animation:.6s both rise-in;display:grid;position:relative;overflow:hidden}.module-glow{opacity:.5;filter:blur();background:#0a6ed12e;border-radius:999px;width:180px;height:180px;position:absolute;inset:-40px auto auto -40px}.module-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.module-label{letter-spacing:2px;text-transform:uppercase;color:var(--accent-2);font-size:12px;font-weight:700}.module-header h3{margin:8px 0 0;font-size:16px;font-weight:600}.module-badge{letter-spacing:1px;width:46px;height:46px;color:var(--accent);background:#0a6ed129;border-radius:8px;place-items:center;font-weight:700;display:grid}.module-meta{flex-wrap:wrap;gap:10px;display:flex}.meta-pill{color:var(--accent-2);background:#0a6ed11f;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600}.module-links{flex-wrap:wrap;gap:8px;display:flex}.module-link{cursor:pointer;background:#fffc;border:1px solid #1b1a171f;border-radius:8px;padding:6px 12px;font-size:12px;transition:transform .2s,box-shadow .2s}.module-link:hover{transform:translateY(-1px);box-shadow:0 8px 18px #1b1a171f}.module-cta{color:#fff;background:var(--accent);cursor:pointer;border:none;border-radius:8px;align-self:flex-start;padding:10px 16px;font-weight:600}.module-page{gap:20px;display:grid}.module-page-header{background:var(--panel);border:1px solid var(--border);box-shadow:none;border-radius:14px;justify-content:space-between;align-items:flex-start;gap:16px;padding:22px;display:flex}.module-page-header h2{font-family:var(--display-font);margin:8px 0 6px;font-size:clamp(22px,2.2vw,30px)}.module-page-header p{color:var(--muted);max-width:520px;margin:0}.module-page-actions{flex-wrap:wrap;gap:12px;display:flex}.module-toolbar{border:1px solid var(--border);background:#fffc;border-radius:12px;flex-wrap:wrap;justify-content:space-between;gap:12px;padding:14px 18px;display:flex}.toolbar-search{flex:1;min-width:240px}.toolbar-search input{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;padding:10px 14px;font-size:13px}.toolbar-actions{flex-wrap:wrap;gap:10px;display:flex}.module-table{background:var(--panel);border:1px solid var(--border);box-shadow:none;border-radius:12px;padding:12px}@media (max-width:900px){.module-page-header{flex-direction:column}.hero-actions,.module-page-actions{width:100%}}:root{--bg:#eff3f7;--panel:#fff;--ink:#0f2233;--muted:#556374;--accent:#0a6ed1;--accent-2:#0854a0;--border:#d4dde5;--shadow-sm:0 10px 22px #0f223314;--shadow-lg:0 18px 42px #0f223324;--display-font:"Newsreader","Manrope","Segoe UI",serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--ink);background-color:var(--bg);font-family:Manrope,Segoe UI,system-ui,sans-serif;font-weight:400;line-height:1.5}body{background:radial-gradient(circle at top left,#0a6ed129,transparent 45%),radial-gradient(circle at top right,#0854a01f,transparent 40%),var(--bg);min-width:320px;min-height:100vh;margin:0}#root{min-height:100vh}
