@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--primary:#0d9488;--primary-light:#14b8a6;--primary-dark:#0f766e;--primary-pale:#f0fdfa;--accent:#d97706;--accent-light:#f59e0b;--bg-page:#f8fafc;--bg-card:#fff;--bg-surface:#f1f5f9;--bg-elevated:#e2e8f0;--bg-hover:#f8fafc;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border:#e2e8f0;--border-active:#0d9488;--success:#16a34a;--success-bg:#f0fdf4;--success-text:#15803d;--warning:#d97706;--warning-bg:#fffbeb;--warning-text:#b45309;--danger:#dc2626;--danger-bg:#fef2f2;--danger-text:#b91c1c;--info:#2563eb;--info-bg:#eff6ff;--info-text:#1d4ed8;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 8px 24px #0000001a, 0 4px 8px #0000000f;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg-page);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-family:Outfit,sans-serif;font-weight:600;line-height:1.2}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:Inter,sans-serif}input,select,textarea{outline:none;font-family:Inter,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base), border-color var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-fade-in{animation:.5s forwards fadeIn}.animate-slide-left{animation:.5s forwards slideInLeft}.animate-slide-right{animation:.5s forwards slideInRight}.animate-scale-in{animation:.4s forwards scaleIn}.login-page{background:var(--bg-page);justify-content:center;align-items:center;width:100vw;min-height:100vh;padding:24px;display:flex;position:relative}.login-container{border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid var(--border);width:1040px;max-width:100%;min-height:600px;box-shadow:var(--shadow-lg);animation:.5s scaleIn;display:flex;overflow:hidden}.login-branding{background:var(--primary-pale);border-right:1px solid var(--border);flex-direction:column;flex:1;justify-content:space-between;padding:48px;display:flex;position:relative;overflow:hidden}.login-branding:before{content:"";pointer-events:none;background:#0d94880f;border-radius:50%;width:300px;height:300px;position:absolute;bottom:-80px;right:-80px}.branding-content{z-index:1;position:relative}.login-logo{align-items:baseline;gap:4px;margin-bottom:48px;display:flex}.logo-brand-cma{color:var(--primary);letter-spacing:.04em;font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:800;line-height:1}.logo-brand-platform{color:var(--text-primary);letter-spacing:-.01em;font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:300;line-height:1}.branding-headline{color:var(--text-primary);margin-bottom:20px;font-size:2.2rem;font-weight:700;line-height:1.2}.branding-headline .text-accent{color:var(--primary)}.branding-description{color:var(--text-secondary);max-width:380px;margin-bottom:32px;font-size:.92rem;line-height:1.7}.branding-features{flex-wrap:wrap;gap:12px;margin-bottom:40px;display:flex}.feature-badge{border-radius:var(--radius-full);color:var(--primary-dark);background:#0d948814;border:1px solid #0d948826;align-items:center;gap:6px;padding:5px 12px;font-size:.75rem;font-weight:500;display:flex}.branding-stats{align-items:center;gap:24px;display:flex}.brand-stat{flex-direction:column;display:flex}.brand-stat-value{color:var(--text-primary);font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700}.brand-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.brand-stat-divider{background:var(--border);width:1px;height:36px}.branding-footer{z-index:1;color:var(--text-muted);flex-direction:column;gap:2px;font-size:.72rem;display:flex;position:relative}.login-form-panel{background:var(--bg-card);flex-direction:column;flex:0 0 420px;justify-content:center;padding:48px;display:flex}.login-form-wrapper{width:100%;max-width:340px;margin:0 auto}.login-form-header{margin-bottom:32px}.login-form-header h2{color:var(--text-primary);margin-bottom:6px;font-size:1.5rem;font-weight:700}.login-form-header p{color:var(--text-secondary);font-size:.85rem}.login-form{flex-direction:column;gap:18px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.01em;justify-content:space-between;align-items:center;font-size:.78rem;font-weight:500;display:flex}.forgot-link{color:var(--primary);transition:color var(--transition-fast);font-size:.78rem;font-weight:400}.forgot-link:hover{color:var(--primary-dark)}.form-group input[type=email],.form-group input[type=password],.form-group input[type=text]{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:11px 14px;font-size:.9rem}.form-group input:focus{background:var(--bg-card);border-color:var(--border-active);box-shadow:0 0 0 3px #0d94881a}.password-field{position:relative}.password-field input{width:100%;padding-right:48px}.password-toggle{color:var(--text-muted);transition:color var(--transition-fast);background:0 0;padding:4px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.password-toggle:hover{color:var(--text-primary)}.form-options{align-items:center;display:flex}.checkbox-label{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:.82rem;display:flex}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.login-btn{background:var(--primary);color:#fff;border-radius:var(--radius-md);width:100%;transition:all var(--transition-base);justify-content:center;align-items:center;gap:8px;padding:13px 24px;font-size:.92rem;font-weight:600;display:flex}.login-btn:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px #0d948840}.login-btn:active{transform:translateY(0)}.login-btn.loading{pointer-events:none;opacity:.8}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-alt{text-align:center;position:relative}.login-alt:before{content:"";background:var(--border);z-index:0;height:1px;position:absolute;top:50%;left:0;right:0}.divider-text{color:var(--text-muted);z-index:1;background:var(--bg-card);padding:0 14px;font-size:.75rem;position:relative}.sso-btn{background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-base);justify-content:center;align-items:center;gap:8px;padding:11px 24px;font-size:.85rem;font-weight:500;display:flex}.sso-btn:hover{background:var(--bg-surface);border-color:var(--border-active);color:var(--text-primary)}.login-disclaimer{color:var(--text-muted);text-align:center;margin-top:24px;font-size:.7rem;line-height:1.5}@media (width<=900px){.login-page{align-items:flex-start;padding:0}.login-container{min-height:100vh;box-shadow:none;border:none;border-radius:0;flex-direction:column}.login-branding{border-right:none;border-bottom:1px solid var(--border);padding:32px 24px}.branding-headline{font-size:1.8rem}.login-form-panel{flex:none;padding:32px 24px}}.layout{background:var(--bg-page);min-height:100vh;display:flex}.sidebar{background:var(--bg-card);border-right:1px solid var(--border);z-index:100;width:260px;height:100vh;transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-collapsed .sidebar{width:72px}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;min-height:68px;padding:20px 16px;display:flex}.sidebar-logo{align-items:center;gap:12px;display:flex;overflow:hidden}.sidebar-logo-text{white-space:nowrap;flex-direction:column;display:flex}.logo-cma{color:var(--primary);letter-spacing:.04em;font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:800;line-height:1}.logo-platform{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-top:3px;font-family:Outfit,sans-serif;font-size:.72rem;font-weight:500}.sidebar-logo-mono{color:var(--primary);letter-spacing:.04em;font-family:Outfit,sans-serif;font-size:1rem;font-weight:800;display:none}.sidebar-collapsed .sidebar-logo-mono,.sidebar-collapsed .sidebar-logo-text{display:none}.sidebar-collapsed .sidebar-header{justify-content:center;padding:20px 0}.sidebar-toggle{background:var(--bg-surface);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.sidebar-toggle:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{flex-direction:column;gap:2px;display:flex}.nav-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:8px 12px;font-size:.65rem;font-weight:600}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:12px;padding:9px 12px;font-size:.85rem;font-weight:500;display:flex;position:relative}.sidebar-collapsed .nav-item{justify-content:center;padding:10px}.nav-item:hover{background:var(--bg-surface);color:var(--text-primary)}.nav-item.active{background:var(--primary-pale);color:var(--primary)}.nav-item.active:before{content:"";background:var(--primary);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-footer{border-top:1px solid var(--border);padding:12px}.sidebar-user{border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);align-items:center;gap:10px;padding:8px;display:flex}.sidebar-collapsed .sidebar-user{justify-content:center}.sidebar-user:hover{background:var(--bg-surface)}.sidebar-avatar,.topbar-avatar{background:var(--primary-pale);border-radius:var(--radius-sm);width:34px;min-width:34px;height:34px;color:var(--primary);letter-spacing:.02em;border:1px solid #0d948833;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex}.sidebar-user-info{flex-direction:column;flex:1;display:flex;overflow:hidden}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;overflow:hidden}.sidebar-chevron{color:var(--text-muted);transition:transform var(--transition-fast)}.sidebar-chevron.open{transform:rotate(180deg)}.sidebar-user-menu{flex-direction:column;gap:2px;padding:8px 0 0;animation:.2s fadeIn;display:flex}.user-menu-item{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;align-items:center;gap:8px;padding:8px 10px;font-size:.8rem;display:flex}.user-menu-item:hover{background:var(--bg-surface);color:var(--text-primary)}.user-menu-item.danger:hover{background:var(--danger-bg);color:var(--danger)}.main-wrapper{min-height:100vh;transition:margin-left var(--transition-base);flex-direction:column;flex:1;margin-left:260px;display:flex}.sidebar-collapsed .main-wrapper{margin-left:72px}.topbar{z-index:50;background:var(--bg-card);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:68px;padding:0 28px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:16px;display:flex}.page-title{color:var(--text-primary);font-size:1.15rem;font-weight:700}.topbar-right{align-items:center;gap:10px;display:flex}.topbar-search{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-muted);transition:all var(--transition-fast);align-items:center;gap:8px;padding:8px 14px;display:flex}.topbar-search:focus-within{border-color:var(--border-active);background:var(--bg-card);box-shadow:0 0 0 3px #0d948814}.topbar-search input{color:var(--text-primary);background:0 0;border:none;width:180px;font-size:.82rem}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-icon-btn{background:var(--bg-surface);border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.topbar-icon-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.notification-dot{background:var(--danger);border:2px solid var(--bg-card);border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:6px}.topbar-user-mini{margin-left:4px}.topbar-avatar{width:32px;height:32px;font-size:.65rem}.main-content{background:var(--bg-page);flex:1;padding:28px}.mobile-only,.mobile-overlay{display:none}.mobile-menu-btn{color:var(--text-primary);background:0 0}@media (width<=900px){.desktop-only{display:none}.mobile-only{display:flex}.sidebar{transition:transform var(--transition-base);transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.sidebar-collapsed .sidebar{width:260px}.main-wrapper{margin-left:0!important}.mobile-overlay{z-index:99;background:#0000004d;display:block;position:fixed;inset:0}.main-content{padding:16px}.topbar{padding:0 16px}.topbar-search{display:none}}.topbar-dropdown-wrap{position:relative}.topbar-icon-btn.active{background:var(--bg-elevated);color:var(--text-primary)}.topbar-user-mini{cursor:pointer;margin-left:4px}.topbar-user-mini.active .topbar-avatar{box-shadow:0 0 0 2px var(--primary)}.topbar-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);z-index:200;animation:.15s fadeIn;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 8px 24px #0000001a}.notif-dropdown{width:360px}.dropdown-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.dropdown-title{color:var(--text-primary);font-size:.875rem;font-weight:700}.dropdown-action-link{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-size:.75rem}.dropdown-action-link:hover{text-decoration:underline}.notif-list{max-height:320px;overflow-y:auto}.notif-item{cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--transition-fast);align-items:flex-start;gap:10px;padding:12px 16px;display:flex;position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-surface)}.notif-item.unread{background:var(--primary-pale)}.notif-item.unread:hover{background:#0d948814}.notif-icon-wrap{flex-shrink:0;margin-top:2px}.notif-type-icon{display:block}.notif-type-icon.alert{color:var(--danger)}.notif-type-icon.success{color:#22c55e}.notif-type-icon.warning{color:var(--warning,#f59e0b)}.notif-type-icon.info{color:var(--primary)}.notif-body{flex:1;min-width:0}.notif-title{color:var(--text-primary);margin-bottom:2px;font-size:.8rem;font-weight:600}.notif-message{color:var(--text-secondary);margin-bottom:4px;font-size:.75rem;line-height:1.4}.notif-time{color:var(--text-muted);font-size:.68rem}.notif-unread-dot{background:var(--primary);border-radius:50%;width:7px;min-width:7px;height:7px;margin-top:5px}.profile-dropdown{width:260px;padding:8px 0}.profile-dropdown-header{align-items:center;gap:12px;padding:10px 16px 14px;display:flex}.profile-dropdown-avatar{background:var(--primary-pale);border-radius:var(--radius-sm);width:40px;min-width:40px;height:40px;color:var(--primary);letter-spacing:.02em;border:1px solid #0d948833;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:flex}.profile-dropdown-info{flex-direction:column;display:flex;overflow:hidden}.profile-dropdown-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:700;overflow:hidden}.profile-dropdown-role{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.profile-dropdown-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.68rem;overflow:hidden}.dropdown-divider{background:var(--border);height:1px;margin:4px 0}.profile-menu-item{width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:9px 16px;font-size:.82rem;display:flex}.profile-menu-item:hover{background:var(--bg-surface);color:var(--text-primary)}.profile-menu-item.danger{color:var(--danger)}.profile-menu-item.danger:hover{background:var(--danger-bg,#ef44440f);color:var(--danger)}.dashboard{flex-direction:column;gap:24px;animation:.5s fadeIn;display:flex}.stat-cards{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.stat-card{opacity:0;padding:22px;animation:.5s forwards fadeIn}.stat-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:42px;height:42px;display:flex}.stat-change{border-radius:var(--radius-full);align-items:center;gap:3px;padding:3px 8px;font-size:.72rem;font-weight:600;display:flex}.stat-change.up{color:var(--success-text);background:var(--success-bg)}.stat-change.down{color:var(--danger-text);background:var(--danger-bg)}.stat-value{color:var(--text-primary);margin-bottom:4px;font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:700;line-height:1}.stat-unit{color:var(--text-muted);font-size:.75rem;font-weight:500}.stat-label{color:var(--text-secondary);font-size:.78rem}.mini-stats{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.mini-stat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:center;gap:10px;padding:14px 18px;display:flex}.mini-stat-icon{color:var(--text-muted)}.mini-stat-value{color:var(--text-primary);font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700}.mini-stat-label{color:var(--text-muted);font-size:.75rem}.charts-row,.bottom-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.chart-card{padding:24px}.chart-card.compact{padding:20px}.chart-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.chart-header h3{color:var(--text-primary);margin-bottom:2px;font-size:1rem;font-weight:600}.chart-header p{color:var(--text-muted);font-size:.75rem}.chart-legend-custom{color:var(--text-muted);align-items:center;gap:6px;font-size:.72rem;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px;margin-left:8px;display:inline-block}.chart-tooltip{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:10px 14px}.chart-tooltip-label{color:var(--text-muted);margin-bottom:4px;font-size:.72rem}.chart-tooltip-value{font-size:.8rem;font-weight:600}.pie-body{align-items:center;gap:16px;display:flex}.pie-legend{flex-direction:column;flex:1;gap:6px;display:flex}.pie-legend-item{align-items:center;gap:8px;font-size:.72rem;display:flex}.pie-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.pie-legend-label{color:var(--text-secondary);flex:1}.pie-legend-value{color:var(--text-primary);font-weight:600}.activity-list{flex-direction:column;gap:2px;max-height:380px;display:flex;overflow-y:auto}.activity-item{border-radius:var(--radius-sm);transition:background var(--transition-fast);align-items:flex-start;gap:12px;padding:10px 8px;display:flex}.activity-item:hover{background:var(--bg-surface)}.activity-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:30px;min-width:30px;height:30px;display:flex}.activity-icon.success{background:var(--success-bg);color:var(--success)}.activity-icon.warning{background:var(--warning-bg);color:var(--warning)}.activity-icon.info{background:var(--info-bg);color:var(--info)}.activity-content{flex-direction:column;flex:1;min-width:0;display:flex}.activity-action{color:var(--text-primary);font-size:.8rem;font-weight:600}.activity-detail{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.activity-time{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:.68rem}.view-all-btn{color:var(--primary);transition:color var(--transition-fast);background:0 0;align-items:center;gap:4px;font-size:.78rem;font-weight:500;display:flex}.view-all-btn:hover{color:var(--primary-dark)}@media (width<=1200px){.stat-cards{grid-template-columns:repeat(2,1fr)}.charts-row,.bottom-row{grid-template-columns:1fr}}@media (width<=600px){.stat-cards,.mini-stats{grid-template-columns:1fr}.pie-body{flex-direction:column}}.modal-overlay{z-index:1000;background:#00000059;justify-content:center;align-items:center;padding:24px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg,12px);flex-direction:column;width:100%;max-height:90vh;animation:.18s slideUp;display:flex;box-shadow:0 20px 60px #00000026}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.modal-title{color:var(--text-primary);font-size:.95rem;font-weight:700}.modal-close{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.modal-body{flex-direction:column;display:flex;overflow-y:auto}.modal-fields{flex-direction:column;gap:16px;padding:20px 22px;display:flex}.modal-field{flex-direction:column;gap:6px;display:flex}.modal-field-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.modal-label{color:var(--text-secondary);font-size:.78rem;font-weight:600}.modal-required{color:var(--danger)}.modal-input,.modal-select,.modal-textarea{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);width:100%;padding:9px 12px;font-family:inherit;font-size:.82rem}.modal-input:focus,.modal-select:focus,.modal-textarea:focus{border-color:var(--primary);background:var(--bg-card);outline:none;box-shadow:0 0 0 3px #0d94881a}.modal-input::placeholder,.modal-textarea::placeholder{color:var(--text-muted)}.modal-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.modal-textarea{resize:vertical;min-height:72px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 22px 18px;display:flex}.modal-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:-6px;font-size:.7rem;font-weight:700}.modal-info-box{background:var(--primary-pale);border-radius:var(--radius-sm);color:var(--text-secondary);border:1px solid #0d948833;padding:10px 14px;font-size:.78rem;line-height:1.5}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.page-header-left h2{color:var(--text-secondary);margin-top:2px;font-size:.85rem;font-weight:400}.page-actions{align-items:center;gap:8px;display:flex}.btn{border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:6px;padding:9px 18px;font-size:.82rem;font-weight:500;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #0d948840}.btn-secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--bg-elevated)}.tabs{background:var(--bg-surface);border-radius:var(--radius-md);border:1px solid var(--border);gap:2px;width:fit-content;margin-bottom:20px;padding:3px;display:flex}.tab{border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition-fast);background:0 0;padding:8px 20px;font-size:.8rem;font-weight:500}.tab:hover{color:var(--text-secondary);background:var(--bg-card)}.tab.active{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-sm)}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.filter-select{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;appearance:none;transition:border-color var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding:8px 30px 8px 14px;font-size:.8rem}.filter-select:focus{border-color:var(--border-active);box-shadow:0 0 0 3px #0d948814}.filter-search{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);max-width:300px;transition:border-color var(--transition-fast);flex:1;align-items:center;gap:8px;padding:8px 14px;display:flex}.filter-search:focus-within{border-color:var(--border-active);box-shadow:0 0 0 3px #0d948814}.filter-search input{color:var(--text-primary);background:0 0;border:none;width:100%;font-size:.8rem}.filter-search input::placeholder{color:var(--text-muted)}.data-table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);box-shadow:var(--shadow-sm);overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-surface);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 16px;font-size:.7rem;font-weight:600}.data-table td{color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 16px;font-size:.82rem}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-surface)}.data-table .id-cell{color:var(--text-muted);font-family:JetBrains Mono,monospace,Inter,sans-serif;font-size:.75rem}.status-badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:5px;padding:3px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.status-badge:before{content:"";border-radius:50%;width:5px;height:5px}.status-badge.active,.status-badge.approved,.status-badge.compliant,.status-badge.confirmed,.status-badge.paid,.status-badge.healthy,.status-badge.running{background:var(--success-bg);color:var(--success-text)}.status-badge.active:before,.status-badge.approved:before,.status-badge.compliant:before,.status-badge.confirmed:before,.status-badge.paid:before,.status-badge.healthy:before,.status-badge.running:before{background:var(--success)}.status-badge.partial,.status-badge.pending,.status-badge.in-progress,.status-badge.warning,.status-badge.under-review,.status-badge.idle,.status-badge.awaiting{background:var(--warning-bg);color:var(--warning-text)}.status-badge.partial:before,.status-badge.pending:before,.status-badge.in-progress:before,.status-badge.warning:before,.status-badge.under-review:before,.status-badge.idle:before,.status-badge.awaiting:before{background:var(--warning)}.status-badge.non-compliant,.status-badge.overdue,.status-badge.maintenance,.status-badge.error{background:var(--danger-bg);color:var(--danger-text)}.status-badge.non-compliant:before,.status-badge.overdue:before,.status-badge.maintenance:before,.status-badge.error:before{background:var(--danger)}.status-badge.draft,.status-badge.not-started{background:var(--bg-surface);color:var(--text-muted)}.status-badge.draft:before,.status-badge.not-started:before{background:var(--text-muted)}.type-badge{border-radius:var(--radius-full);align-items:center;gap:5px;padding:3px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.type-badge.maritime{background:var(--info-bg);color:var(--info-text)}.type-badge.aviation{color:#6d28d9;background:#f5f3ff}.type-badge.issuance{background:var(--success-bg);color:var(--success-text)}.type-badge.transfer{background:var(--info-bg);color:var(--info-text)}.type-badge.retirement{background:var(--bg-surface);color:var(--text-secondary)}.type-badge.cancellation{background:var(--danger-bg);color:var(--danger-text)}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:24px;display:grid}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:center;gap:14px;padding:18px;display:flex}.summary-card-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.summary-card-info{flex-direction:column;display:flex}.summary-card-value{color:var(--text-primary);font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:700;line-height:1}.summary-card-label{color:var(--text-muted);margin-top:2px;font-size:.72rem}.page-content{animation:.4s fadeIn}@media (width<=900px){.page-header{flex-direction:column;align-items:flex-start}.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.summary-cards{grid-template-columns:1fr}}.mrv-cards{flex-direction:column;gap:16px;display:flex}.mrv-card{padding:24px}.mrv-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.mrv-card-id{color:var(--text-muted);font-family:monospace;font-size:.7rem}.mrv-card-project{color:var(--text-primary);margin-top:2px;font-size:1rem;font-weight:600}.mrv-progress{align-items:flex-start;gap:0;margin-bottom:20px;padding:16px 0;display:flex}.mrv-step{flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.mrv-step-dot{background:var(--bg-surface);border:2px solid var(--border);width:28px;height:28px;color:var(--text-muted);z-index:1;transition:all var(--transition-base);border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;font-weight:600;display:flex;position:relative}.mrv-step.completed .mrv-step-dot{background:var(--primary-pale);border-color:var(--primary-light);color:var(--primary)}.mrv-step.current .mrv-step-dot{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px #0d94881f}.mrv-step-label{color:var(--text-muted);text-align:center;max-width:80px;margin-top:8px;font-size:.65rem;line-height:1.3}.mrv-step.completed .mrv-step-label,.mrv-step.current .mrv-step-label{color:var(--text-primary)}.mrv-step-line{background:var(--border);z-index:0;width:100%;height:2px;position:absolute;top:14px;left:50%}.mrv-step.completed .mrv-step-line{background:var(--primary-light)}.mrv-card-details{border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;padding:16px 0;display:grid}.mrv-detail{flex-direction:column;gap:2px;display:flex}.mrv-detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.68rem}.mrv-detail-value{color:var(--text-primary);font-size:.82rem;font-weight:500}.mrv-card-action{align-self:flex-end;margin-left:auto;display:flex}@media (width<=768px){.mrv-card-details{grid-template-columns:repeat(2,1fr)}.mrv-progress{padding-bottom:8px;overflow-x:auto}.mrv-step-label{font-size:.6rem}}.dp-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.dp-section{padding:22px}.dp-section-header{color:var(--text-primary);align-items:center;gap:10px;margin-bottom:18px;display:flex}.dp-section-header h3{flex:1;font-size:1rem}.dp-count{color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);padding:3px 10px;font-size:.72rem}.dp-list{flex-direction:column;gap:4px;display:flex}.dp-item{border-radius:var(--radius-sm);transition:background var(--transition-fast);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.dp-item:hover{background:var(--bg-surface)}.dp-item-info{flex-direction:column;gap:2px;min-width:0;display:flex}.dp-item-name{color:var(--text-primary);font-size:.82rem;font-weight:500}.dp-item-meta{color:var(--text-muted);align-items:center;gap:6px;font-size:.7rem;display:flex}.dp-item-type{background:var(--bg-surface);border-radius:var(--radius-sm);color:var(--text-muted);padding:1px 6px;font-size:.65rem;font-weight:500}.dp-item-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.dp-item-sync{color:var(--text-muted);white-space:nowrap;font-size:.68rem}.arch-card{padding:28px}.arch-card h3{color:var(--text-primary);margin-bottom:24px;font-size:1rem}.arch-diagram{flex-direction:column;align-items:center;gap:8px;display:flex}.arch-layer{flex-direction:column;align-items:center;gap:10px;width:100%;display:flex}.arch-layer-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.72rem;font-weight:600}.arch-nodes{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.arch-node{border-radius:var(--radius-md);transition:all var(--transition-base);border:1px solid;padding:8px 18px;font-size:.78rem;font-weight:500}.arch-node:hover{transform:translateY(-2px)}.arch-node.ingestion{color:#92400e;background:#fffbeb;border-color:#fde68a}.arch-node.bronze{color:#92400e;background:#fdf4ec;border-color:#f5c89a}.arch-node.silver{background:var(--bg-surface);border-color:var(--border);color:var(--text-secondary)}.arch-node.gold{color:#713f12;background:#fefce8;border-color:#fef08a}.arch-node.app{background:var(--primary-pale);color:var(--primary-dark);border-color:#0d948833}.arch-arrow{color:var(--text-muted);opacity:.5;font-size:1.2rem}@media (width<=900px){.dp-grid{grid-template-columns:1fr}}.reports-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.report-card{opacity:0;flex-direction:column;padding:24px;animation:.5s forwards fadeIn;display:flex}.report-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.report-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:46px;height:46px;display:flex}.report-type{border-radius:var(--radius-full);padding:3px 10px;font-size:.68rem;font-weight:600}.report-title{color:var(--text-primary);margin-bottom:6px;font-size:1rem;font-weight:600}.report-desc{color:var(--text-muted);flex:1;margin-bottom:18px;font-size:.78rem;line-height:1.5}.report-meta{border-top:1px solid var(--border);border-bottom:1px solid var(--border);gap:20px;margin-bottom:16px;padding:14px 0;display:flex}.report-meta-item{flex-direction:column;gap:1px;display:flex}.report-meta-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.65rem}.report-meta-value{color:var(--text-primary);font-size:.78rem;font-weight:500}.report-actions{gap:8px;display:flex}.btn-sm{padding:6px 14px;font-size:.75rem}#root{width:100%;min-height:100vh}
