*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.auth-shell{display:flex;min-height:100vh;background-color:#f8fafc;color:#334155}.auth-left-panel{flex:1;background-color:#0f172a;color:#fff;display:flex;flex-direction:column;justify-content:center;padding:4rem}.auth-left-panel h1{font-size:3rem;margin-bottom:1rem}.auth-left-panel p{font-size:1.1rem;color:#94a3b8;line-height:1.6;max-width:80%}.auth-right-panel{flex:1;display:flex;align-items:center;justify-content:center;background-color:#fff;padding:2rem}.login-card{width:100%;max-width:400px;padding:2rem}.login-card h2{font-size:1.8rem;margin-bottom:.5rem;color:#0f172a}.login-card .subtitle{color:#64748b;margin-bottom:2rem;font-size:.95rem}.login-error{margin-bottom:1rem;padding:.75rem 1rem;border:1px solid #f5c2c7;border-radius:6px;background-color:#fff1f2;color:#9f1239;font-size:.95rem}.input-group{margin-bottom:1.5rem;position:relative}.input-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.9rem;color:#0f172a}.input-group input{width:100%;padding:.75rem 1rem;border:1px solid #cbd5e1;border-radius:6px;font-size:1rem;transition:border-color .3s,box-shadow .3s}.input-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.forgot-password{display:block;margin-top:.5rem;margin-left:auto;border:none;background:transparent;font-size:.85rem;color:#2563eb;cursor:pointer}.forgot-password:hover{text-decoration:underline}.btn-primary{width:100%;padding:.85rem;background-color:#2563eb;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:1rem;transition:background-color .3s,opacity .3s}.btn-primary:hover:not(:disabled){background-color:#1d4ed8}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.compliance-footer{margin-top:2rem;text-align:center;font-size:.75rem;color:#64748b;line-height:1.5}.compliance-footer a{color:#64748b;text-decoration:underline}.compliance-footer a:hover{color:#0f172a}@media (max-width: 768px){.auth-shell{flex-direction:column}.auth-left-panel{display:none}.auth-right-panel,.login-card{padding:1.5rem}.app-header-top{flex-direction:column;align-items:stretch}.app-header-actions{display:flex;flex-direction:column;align-items:stretch}.app-main{padding:1rem}}.app-shell{min-height:100vh;background:#f8fafc}.app-header{background:#0f172a;color:#fff;padding:1.5rem 2rem 1.25rem;box-shadow:0 10px 30px #0f172a29}.app-header-top{display:flex;justify-content:space-between;align-items:center;gap:1.5rem}.app-brand-block{display:grid;gap:.35rem}.app-brand{font-size:1.75rem;font-weight:700;line-height:1.1}.app-subtitle{margin-top:.35rem;color:#94a3b8;font-size:.95rem}.app-header-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.app-status-badge{padding:.55rem .85rem;border:1px solid rgba(148,163,184,.3);border-radius:999px;background:#94a3b814;color:#cbd5e1;font-size:.85rem;white-space:nowrap}.logout-button{padding:.7rem 1rem;border:none;border-radius:8px;background:#2563eb;color:#fff;font-weight:600;cursor:pointer;transition:background-color .25s ease}.logout-button:hover{background:#1d4ed8}.app-nav{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem}.app-nav-link{display:inline-flex;align-items:center;padding:.7rem 1rem;border-radius:10px;text-decoration:none;color:#cbd5e1;font-size:.95rem;font-weight:500;transition:background-color .25s ease,color .25s ease}.app-nav-link-text{display:inline-block;white-space:nowrap}.app-nav-link:hover{background:#ffffff14;color:#fff}.app-nav-link-active{background:#fff;color:#0f172a}.app-main{padding:2rem;min-width:0}.app-content{max-width:1440px;margin:0 auto}.page-shell{display:grid;gap:1.5rem}.page-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}.page-heading{display:grid;gap:.35rem}.page-eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#2563eb}.page-title{font-size:1.9rem;line-height:1.1;color:#0f172a}.page-description{color:#64748b;max-width:72ch}.page-grid-two{display:grid;grid-template-columns:minmax(320px,1fr) minmax(360px,1.2fr);gap:1.5rem}.surface-panel{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:1.5rem;box-shadow:0 10px 30px #0f172a0f}.surface-panel-soft{background:linear-gradient(180deg,#fff,#f8fafc)}.panel-title{font-size:1.25rem;font-weight:700;color:#0f172a;margin-bottom:.5rem}.panel-description{color:#64748b;margin-bottom:1.25rem}.message-success{margin-bottom:1rem;padding:.85rem 1rem;background:#dcfce7;color:#166534;border-radius:10px;border:1px solid #86efac}.message-error{margin-bottom:1rem;padding:.85rem 1rem;background:#fff1f2;color:#9f1239;border-radius:10px;border:1px solid #fecdd3}.dashboard-hero{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:1.5rem}.dashboard-highlight{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;border-radius:20px;padding:1.75rem;box-shadow:0 16px 40px #0f172a3d}.dashboard-highlight h2{font-size:1.75rem;margin-bottom:.75rem}.dashboard-highlight p{color:#cbd5e1;max-width:56ch;line-height:1.6}.dashboard-side-card{background:linear-gradient(180deg,#fff,#eff6ff);border:1px solid #dbeafe;border-radius:20px;padding:1.5rem}.dashboard-side-card h3{color:#0f172a;margin-bottom:.65rem}.dashboard-side-card p{color:#64748b;line-height:1.6}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:1.4rem;box-shadow:0 10px 30px #0f172a0d}.metric-label{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:.75rem}.metric-value{font-size:2rem;font-weight:800;line-height:1;color:#0f172a}.metric-accent-blue .metric-value{color:#2563eb}.metric-accent-green .metric-value{color:#059669}.metric-accent-violet .metric-value{color:#7c3aed}.metric-accent-teal .metric-value{color:#0f766e}.list-stack{display:grid;gap:.85rem}.empty-state{text-align:center;color:#64748b;padding:1.5rem;border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc}@media (max-width: 900px){.app-header{padding:1.25rem 1.25rem 1rem}.app-header-top{flex-direction:column;align-items:flex-start}.app-header-actions{width:100%;justify-content:space-between;flex-wrap:wrap}.app-main{padding:1.25rem}.page-header,.dashboard-hero,.metric-grid,.page-grid-two{grid-template-columns:1fr}}@media (max-width: 640px){.app-nav{display:grid;grid-template-columns:1fr 1fr}.app-status-badge,.logout-button{width:100%;text-align:center;justify-content:center}.app-header-actions{flex-direction:column;align-items:stretch}.page-title{font-size:1.6rem}.metric-grid{grid-template-columns:1fr}}
