:root{--color-primary: #1E293B;--color-primary-dark: #0F172A;--color-accent: #3B82F6;--color-accent-hover: #2563EB;--color-accent-light: #DBEAFE;--color-success: #10B981;--color-success-light: #D1FAE5;--color-warning: #F59E0B;--color-warning-light: #FEF3C7;--color-error: #EF4444;--color-error-light: #FEE2E2;--color-info: #3B82F6;--color-info-light: #DBEAFE;--color-gray-50: #F8FAFC;--color-gray-100: #F1F5F9;--color-gray-200: #E2E8F0;--color-gray-300: #CBD5E1;--color-gray-400: #94A3B8;--color-gray-500: #64748B;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1E293B;--color-gray-900: #0F172A;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-100);background:linear-gradient(135deg,var(--color-gray-900) 0%,var(--color-gray-800) 100%);min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);font-size:var(--font-size-sm);font-weight:500;line-height:1;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-fast)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover)}.btn-secondary{background:var(--color-gray-700);color:var(--color-gray-100)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-600)}.btn-ghost{background:transparent;color:var(--color-gray-400)}.btn-ghost:hover:not(:disabled){background:var(--color-gray-700);color:var(--color-gray-100)}.btn-lg{padding:var(--spacing-4) var(--spacing-6);font-size:var(--font-size-base)}.btn-sm{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs)}.btn-full{width:100%}.form-group{margin-bottom:var(--spacing-5)}.form-label{display:block;margin-bottom:var(--spacing-2);font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-300)}.form-input{width:100%;padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);color:var(--color-gray-100);background:var(--color-gray-800);border:1px solid var(--color-gray-600);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f633}.form-input::placeholder{color:var(--color-gray-500)}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-error{font-size:var(--font-size-xs);color:var(--color-error);margin-top:var(--spacing-1)}.card{background:var(--color-gray-800);border:1px solid var(--color-gray-700);border-radius:var(--radius-xl);padding:var(--spacing-6)}.card-header{margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-gray-700)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-100)}.spinner{width:40px;height:40px;border:3px solid var(--color-gray-700);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}.spinner-sm{width:20px;height:20px;border-width:2px}.spinner-lg{width:60px;height:60px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;bottom:var(--spacing-6);right:var(--spacing-6);z-index:1000;display:flex;flex-direction:column;gap:var(--spacing-3)}.toast{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-5);background:var(--color-gray-800);border:1px solid var(--color-gray-700);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:slideIn .3s ease}.toast-success{border-left:4px solid var(--color-success)}.toast-error{border-left:4px solid var(--color-error)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-6)}.module-tile{background:var(--color-gray-800);border:1px solid var(--color-gray-700);border-radius:var(--radius-xl);padding:var(--spacing-6);cursor:pointer;transition:all var(--transition-normal);display:flex;flex-direction:column;gap:var(--spacing-4);position:relative;overflow:hidden}.module-tile:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--module-color);opacity:0;transition:opacity var(--transition-normal)}.module-tile:hover{border-color:var(--module-color);transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000004d}.module-tile:hover:before{opacity:1}.tile-header{display:flex;justify-content:space-between;align-items:flex-start}.tile-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.favorite-btn{background:none;border:none;padding:var(--spacing-2);cursor:pointer;color:var(--color-gray-500);transition:color var(--transition-fast)}.favorite-btn:hover,.favorite-btn.active{color:#f59e0b}.tile-body{flex:1}.tile-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-100);margin-bottom:var(--spacing-2)}.tile-description{font-size:var(--font-size-sm);color:var(--color-gray-400);line-height:1.5}.tile-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-4);border-top:1px solid var(--color-gray-700)}.tile-status{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-xs);color:var(--color-gray-500)}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.online{background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.status-dot.offline{background:var(--color-gray-500)}.status-dot.coming-soon{background:var(--color-warning)}.tile-action{font-size:var(--font-size-sm);font-weight:500;color:var(--module-color);opacity:0;transform:translate(-8px);transition:all var(--transition-normal)}.module-tile:hover .tile-action{opacity:1;transform:translate(0)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-6)}.login-container{width:100%;max-width:420px}.login-branding{text-align:center;margin-bottom:var(--spacing-8)}.login-branding .logo{width:80px;height:80px;margin:0 auto var(--spacing-4)}.login-branding .logo img{width:100%;height:100%}.login-branding h1{font-size:var(--font-size-2xl);color:var(--color-gray-100);margin-bottom:var(--spacing-2)}.login-branding p{color:var(--color-gray-400);font-size:var(--font-size-sm)}.login-card{background:var(--color-gray-800);border:1px solid var(--color-gray-700);border-radius:var(--radius-2xl);padding:var(--spacing-8)}.login-header{text-align:center;margin-bottom:var(--spacing-6)}.login-header h2{font-size:var(--font-size-xl);color:var(--color-gray-100);margin-bottom:var(--spacing-2)}.login-header p{color:var(--color-gray-400);font-size:var(--font-size-sm)}.login-error{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--radius-lg);color:var(--color-error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-5)}.login-footer{text-align:center;margin-top:var(--spacing-5);padding-top:var(--spacing-5);border-top:1px solid var(--color-gray-700)}.login-footer a{font-size:var(--font-size-sm);color:var(--color-gray-400)}.login-footer a:hover{color:var(--color-accent)}.login-help{text-align:center;margin-top:var(--spacing-6)}.login-help p{font-size:var(--font-size-sm);color:var(--color-gray-500)}.portal-layout{min-height:100vh;display:flex;flex-direction:column}.portal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-6);background:var(--color-gray-800);border-bottom:1px solid var(--color-gray-700)}.portal-logo{display:flex;align-items:center;gap:var(--spacing-3)}.portal-logo img{width:40px;height:40px}.portal-logo span{font-size:var(--font-size-xl);font-weight:600;color:var(--color-gray-100)}.portal-nav{display:flex;align-items:center;gap:var(--spacing-4)}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-gray-700);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:background var(--transition-fast)}.user-menu-trigger:hover{background:var(--color-gray-600)}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-accent);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600;color:#fff}.user-info{text-align:left}.user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-100)}.user-role{font-size:var(--font-size-xs);color:var(--color-gray-400)}.user-dropdown{position:absolute;top:100%;right:0;margin-top:var(--spacing-2);min-width:200px;background:var(--color-gray-800);border:1px solid var(--color-gray-700);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-gray-300);cursor:pointer;transition:background var(--transition-fast)}.dropdown-item:hover{background:var(--color-gray-700);color:var(--color-gray-100)}.dropdown-divider{height:1px;background:var(--color-gray-700);margin:var(--spacing-2) 0}.dropdown-item.danger{color:var(--color-error)}.portal-main{flex:1;padding:var(--spacing-8);max-width:1400px;margin:0 auto;width:100%}.dashboard{display:flex;flex-direction:column;gap:var(--spacing-8)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-6)}.welcome-section h1{font-size:var(--font-size-3xl);color:var(--color-gray-100);margin-bottom:var(--spacing-2)}.welcome-section p{color:var(--color-gray-400)}.quick-stats{display:flex;gap:var(--spacing-4)}.stat-card{background:var(--color-gray-800);border:1px solid var(--color-gray-700);border-radius:var(--radius-lg);padding:var(--spacing-4) var(--spacing-5);min-width:140px}.stat-value{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-gray-100)}.stat-label{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1)}.dashboard-content{display:grid;grid-template-columns:1fr 320px;gap:var(--spacing-8)}.modules-section{display:flex;flex-direction:column;gap:var(--spacing-8)}.module-group{display:flex;flex-direction:column;gap:var(--spacing-4)}.group-title{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-300)}.dashboard-sidebar{display:flex;flex-direction:column;gap:var(--spacing-6)}.announcements-card{background:var(--color-gray-800);border:1px solid var(--color-gray-700);border-radius:var(--radius-xl);overflow:hidden}.announcements-header{padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--color-gray-700);font-weight:600;color:var(--color-gray-100)}.announcement-item{padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--color-gray-700)}.announcement-item:last-child{border-bottom:none}.announcement-type{display:inline-block;padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-sm);margin-bottom:var(--spacing-2)}.announcement-type.info{background:var(--color-info-light);color:var(--color-info)}.announcement-type.warning{background:var(--color-warning-light);color:#b45309}.announcement-type.urgent{background:var(--color-error-light);color:var(--color-error)}.announcement-title{font-size:var(--font-size-sm);font-weight:500;color:var(--color-gray-100);margin-bottom:var(--spacing-1)}.announcement-date{font-size:var(--font-size-xs);color:var(--color-gray-500)}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-4)}.dashboard-loading p{color:var(--color-gray-400)}@media (max-width: 1024px){.dashboard-content{grid-template-columns:1fr}.dashboard-sidebar{order:-1}}@media (max-width: 768px){.dashboard-header{flex-direction:column}.quick-stats{width:100%;flex-wrap:wrap}.stat-card{flex:1;min-width:120px}.portal-header{padding:var(--spacing-3) var(--spacing-4)}.portal-main{padding:var(--spacing-4)}.module-grid{grid-template-columns:1fr}}
