@import"https://fonts.googleapis.com/css2?family=Poppins:wght@600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--color-primary: #02152F;--color-primary-light: #03214a;--color-primary-dark: #010d1a;--color-gray-900: #111827;--color-gray-800: #1F2937;--color-gray-700: #374151;--color-gray-600: #4B5563;--color-gray-500: #6B7280;--color-gray-400: #9CA3AF;--color-gray-300: #D1D5DB;--color-gray-200: #E5E7EB;--color-gray-100: #F3F4F6;--color-gray-50: #F9FAFB;--color-success: #10B981;--color-success-light: #D1FAE5;--color-warning: #F59E0B;--color-warning-light: #FEF3C7;--color-danger: #EF4444;--color-danger-light: #FEE2E2;--color-bg: #FFFFFF;--color-bg-light: #F9FAFB;--color-border: #E5E7EB;--color-text: #111827;--color-text-secondary: #6B7280;--color-text-tertiary: #9CA3AF;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 20px;--font-size-3xl: 24px;--font-size-4xl: 32px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .04);--shadow-sm: 0 2px 4px 0 rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px 0 rgba(0, 0, 0, .1);--shadow-lg: 0 12px 24px 0 rgba(0, 0, 0, .12);--shadow-xl: 0 20px 40px 0 rgba(0, 0, 0, .15)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--color-bg-light);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:Poppins,sans-serif;font-weight:700;line-height:1.2;letter-spacing:-.5px}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-dark)}input,textarea,select{font-family:Inter,sans-serif;font-size:var(--font-size-md);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:10px 12px;background-color:var(--color-bg);color:var(--color-text);transition:all .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #02152f1a}input::placeholder{color:var(--color-text-tertiary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-light)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.screen{display:flex;flex-direction:column;height:100vh;background-color:var(--color-bg)}.screen-content{flex:1;overflow-y:auto;background-color:var(--color-bg-light);padding-bottom:80px}.screen-inner{max-width:1200px;margin:0 auto;padding:var(--spacing-xl);width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.mt-lg{margin-top:var(--spacing-lg)}.mb-lg{margin-bottom:var(--spacing-lg)}@media (max-width: 768px){.screen-inner{padding:var(--spacing-lg)}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}}#root{width:100%;height:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-family:Inter,sans-serif;font-weight:700;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;white-space:nowrap;text-decoration:none}.btn--sm{font-size:13px;padding:10px 16px;height:38px;font-weight:600}.btn--md{font-size:15px;padding:14px 24px;height:48px;font-weight:700}.btn--lg{font-size:16px;padding:16px 32px;height:56px;font-weight:700}.btn--primary{background:linear-gradient(135deg,#02152f,#03214a);color:#fff;box-shadow:0 4px 12px #02152f4d;padding:10px}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #02152f66}.btn--primary:active:not(:disabled){transform:translateY(0)}.btn--secondary{background-color:var(--color-gray-100);color:#02152f;border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background-color:var(--color-gray-200);border-color:#02152f}.btn--ghost{background-color:transparent;color:#02152f;border:1px solid #02152F}.btn--ghost:hover:not(:disabled){background-color:#02152f0d}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--full{width:100%}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.error-alert{background:#ffebee;border:1px solid #ef5350;border-radius:8px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.error-content{display:flex;align-items:center;gap:12px;flex:1}.error-icon{font-size:18px;color:#e24b4a}.error-message{font-size:13px;color:#c62828;margin:0}.error-dismiss{background:none;border:none;color:#e24b4a;cursor:pointer;font-size:16px;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.error-dismiss:active{opacity:.7}.login-screen{flex:1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f9fb,#fff);padding:var(--spacing-lg);min-height:100vh}.login-container{width:100%;max-width:360px}.login-header{text-align:center;margin-bottom:40px}.login-logo{display:flex;justify-content:center;align-items:center;width:100%;margin-bottom:16px}.login-logo img{max-width:180px;height:auto}.logo-hexagon:before{content:"";position:absolute;width:100%;height:100%;background:linear-gradient(135deg,#02152f,#03214a);clip-path:polygon(50% 0%,93.3% 25%,93.3% 75%,50% 100%,6.7% 75%,6.7% 25%)}.logo-inner{position:relative;z-index:1;display:flex;gap:6px}.logo-inner:before,.logo-inner:after,.logo-inner{content:"";width:20px;height:20px;background:#02152f4d;clip-path:polygon(50% 0%,93.3% 25%,93.3% 75%,50% 100%,6.7% 75%,6.7% 25%)}.login-title{font-size:32px;font-weight:700;color:var(--color-text);margin-bottom:8px}.login-subtitle{font-size:13px;color:var(--color-text-secondary);margin:0}.login-form{margin-bottom:24px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--color-text);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}input[type=text],input[type=password],input[type=url]{width:100%;padding:12px 14px;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-md);transition:all .2s;background-color:var(--color-bg)}input[type=text]:focus,input[type=password]:focus,input[type=url]:focus{outline:none;border-color:#02152f;box-shadow:0 0 0 3px #02152f1a}input[type=text]:disabled,input[type=password]:disabled,input[type=url]:disabled{background-color:var(--color-bg-light);opacity:.6;cursor:not-allowed}.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;font-family:inherit}.button:disabled{opacity:.6;cursor:not-allowed}.button.primary{background:linear-gradient(135deg,#02152f,#03214a);color:#fff;box-shadow:0 4px 12px #02152f4d}.button.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #02152f66}.button.primary:active:not(:disabled){transform:translateY(0)}.button.secondary{background:var(--color-bg-light);color:var(--color-text);border:1px solid var(--color-border)}.button.secondary:hover:not(:disabled){background:var(--color-bg);border-color:#02152f}.button.ghost{background:transparent;color:#02152f;border:1px solid #02152F}.button.ghost:hover:not(:disabled){background:#02152f0d}.button.small{padding:.5rem 1rem;font-size:var(--font-size-sm)}.button.large{padding:1rem 2rem;font-size:var(--font-size-lg);width:100%}.button.fullWidth{width:100%}.login-footer{text-align:center}.login-footer-logo{width:100%;height:auto;margin:0 auto 16px;display:flex;justify-content:center}.login-footer-logo img{width:200px;height:auto;object-fit:contain}.login-footer-text{font-size:11px;color:var(--color-text-tertiary);margin:0;line-height:1.5}.text-primary{color:#02152f;font-weight:600}@media (max-width: 480px){.login-container{max-width:100%}.login-header{margin-bottom:32px}.login-title{font-size:28px}.login-logo{width:100px;height:100px}.button.large{padding:.875rem 1.5rem;font-size:var(--font-size-md)}.login-footer-logo img{width:160px}}.header{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#02152f,#03214a);color:#fff;padding:var(--spacing-md) var(--spacing-lg);box-shadow:0 4px 16px #02152f33;height:64px;z-index:50;position:relative}.header-left{display:flex;align-items:center;gap:var(--spacing-md);flex:1;min-width:0}.header-right{display:flex;align-items:center;gap:var(--spacing-lg)}.header-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;width:40px;height:40px;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-btn:hover{background:#ffffff40;border-color:#fff6;transform:translateY(-1px)}.header-btn:active{transform:translateY(0)}.header-menu-btn{margin-right:var(--spacing-sm)}.header-title{font-size:var(--font-size-lg);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-logo{display:flex;align-items:center;gap:var(--spacing-md);padding-right:var(--spacing-lg);border-right:1px solid rgba(255,255,255,.2)}.header-logo-img{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.header-logo-text{display:flex;flex-direction:column;gap:2px}.logo-brand{font-weight:700;font-size:var(--font-size-lg);line-height:1;font-family:Poppins,sans-serif;letter-spacing:-.5px}.logo-subtitle{font-size:var(--font-size-xs);opacity:.85;font-weight:400}.header-logout{background:#fff3;padding:6px 14px;font-size:var(--font-size-sm)}.notification-bell{position:relative}.bell-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;width:40px;height:40px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;position:relative}.bell-btn:hover{background:#ffffff40;border-color:#fff6;transform:translateY(-1px)}.notification-badge{position:absolute;top:-6px;right:-6px;background-color:#ef4444;color:#fff;font-size:10px;font-weight:700;width:20px;height:20px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;border:2px solid #02152F;animation:pulse 2s infinite}@media (max-width: 480px){.header{padding:var(--spacing-md);gap:var(--spacing-sm)}.header-logo-text{display:none}.header-logo-img{width:36px;height:36px}.header-title,.logo-brand{font-size:var(--font-size-md)}.header-logout{display:none}}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:99;animation:fadeIn .2s ease}.sidebar{position:fixed;left:0;top:0;height:100vh;width:280px;background:#fff;box-shadow:2px 0 8px #0000001a;transform:translate(-100%);transition:transform .3s ease;z-index:999;display:flex;flex-direction:column}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,#02152f,#03214a);color:#fff}.sidebar-title{font-family:Poppins,sans-serif;font-weight:700;font-size:var(--font-size-xl)}.sidebar-close{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sidebar-close:hover{background:#ffffff4d}.sidebar-profile{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--color-gray-100)}.profile-avatar{width:48px;height:48px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#02152f,#03214a);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-lg);flex-shrink:0}.profile-info{flex:1;min-width:0}.profile-name{font-size:var(--font-size-md);font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-role{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.sidebar-menu{flex:1;padding:var(--spacing-lg) 0;display:flex;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto}.sidebar-menu-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;color:var(--color-text-secondary);font-weight:500;font-size:var(--font-size-md);cursor:pointer;transition:all .2s ease;text-align:left}.sidebar-menu-item:hover{background-color:var(--color-bg-light);color:var(--color-primary)}.sidebar-menu-item:active{transform:translate(4px)}.sidebar-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-gray-100);margin-top:auto;flex-shrink:0}.sidebar-logout{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-lg);background-color:#fee2e2;border:none;color:#dc2626;font-weight:600;font-size:var(--font-size-md);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.sidebar-logout:hover{background-color:#dc2626;color:#fff}.card{background-color:var(--color-bg);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:none;box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1);animation:fadeIn .3s ease}.card:hover:not(.card--stat){box-shadow:var(--shadow-md);transform:translateY(-2px)}.card--interactive{cursor:pointer}.card--interactive:active{transform:translateY(0)}.card--stat{padding:var(--spacing-xl);text-align:center;background:linear-gradient(135deg,#0052cc05,#0052cc03);border:none;box-shadow:var(--shadow-xs)}.card--stat:hover{box-shadow:var(--shadow-md);background:linear-gradient(135deg,#0052cc0d,#0052cc05)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:40;animation:fadeIn .2s ease}.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background-color:#fff;box-shadow:0 10px 40px #00000026;z-index:50;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);background:linear-gradient(135deg,#02152f,#03214a);color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-title{font-size:var(--font-size-lg);font-weight:700;font-family:Poppins,sans-serif;letter-spacing:-.5px}.sidebar-close{background:transparent;border:none;color:#fff;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .2s ease}.sidebar-close:hover{background:#fff3}.sidebar-profile{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.profile-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:linear-gradient(135deg,#02152f,#03214a);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-lg);flex-shrink:0}.profile-info{display:flex;flex-direction:column;gap:2px;min-width:0}.profile-name{font-weight:600;color:var(--color-text);font-size:var(--font-size-md);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-role{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.sidebar-menu{flex:1;overflow-y:auto;padding:var(--spacing-md) 0}.sidebar-menu-item{width:100%;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:transparent;border:none;color:var(--color-text);cursor:pointer;font-size:var(--font-size-md);font-weight:500;transition:all .2s ease}.sidebar-menu-item:hover{background-color:var(--color-bg-light);color:#02152f}.sidebar-menu-item:active{background-color:#02152f0d;color:#02152f}.sidebar-menu-item svg{flex-shrink:0;width:20px;height:20px}.sidebar-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.sidebar-logout{width:100%;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:#fee2e2;border:none;border-radius:var(--radius-lg);color:#991b1b;cursor:pointer;font-size:var(--font-size-md);font-weight:600;transition:all .2s ease}.sidebar-logout:hover{background:#fecaca}.sidebar-logout:active{transform:scale(.98)}.sidebar-logout svg{flex-shrink:0;width:20px;height:20px}@media (max-width: 768px){.sidebar{width:240px}.sidebar-profile{padding:var(--spacing-md)}.profile-avatar{width:44px;height:44px}}@media (max-width: 480px){.sidebar{width:100%}.sidebar-header{padding:var(--spacing-md)}.sidebar-menu-item{padding:var(--spacing-sm) var(--spacing-md)}}.avatar{display:flex;align-items:center;justify-content:center;clip-path:polygon(30% 0%,70% 0%,100% 30%,100% 70%,70% 100%,30% 100%,0% 70%,0% 30%);color:#fff;font-weight:600;flex-shrink:0;-webkit-user-select:none;user-select:none}.avatar--sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar--md{width:44px;height:44px;font-size:var(--font-size-sm)}.avatar--lg{width:64px;height:64px;font-size:var(--font-size-lg)}.avatar-text{letter-spacing:.5px}.badge{display:inline-flex;align-items:center;gap:4px;border-radius:var(--radius-full);font-weight:500;white-space:nowrap;transition:all .2s ease}.badge--sm{font-size:var(--font-size-xs);padding:4px 8px}.badge--md{font-size:var(--font-size-sm);padding:6px 12px}.badge--success{background-color:var(--color-success-light);color:#047857}.badge--warning{background-color:var(--color-warning-light);color:#b45309}.badge--danger{background-color:var(--color-danger-light);color:#991b1b}.badge--info{background-color:#0052cc1a;color:var(--color-primary)}.badge--neutral{background-color:var(--color-gray-100);color:var(--color-gray-700)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid #e5e5e5;border-top:3px solid #0066ff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{font-size:14px;color:#666;margin:0}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background-color:var(--color-bg);border-top:1px solid var(--color-border);display:flex;justify-content:space-around;align-items:flex-start;padding:var(--spacing-sm) 0;z-index:100;box-shadow:0 -2px 12px #00000014;max-width:100%}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--spacing-md) var(--spacing-sm);background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:var(--font-size-xs);font-weight:500;transition:all .2s ease;flex:1;border-radius:var(--radius-lg)}.bottom-nav-item:hover{color:#02152f;background-color:#02152f0d}.bottom-nav-item.active{color:#02152f;background-color:#02152f1a;font-weight:600}.bottom-nav-label{line-height:1.2;text-align:center}@media (max-width: 480px){.bottom-nav-label{font-size:10px;max-width:50px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}.dashboard-greeting{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg)}.greeting-title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm);color:var(--color-text)}.greeting-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-md)}.date-filter{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.date-filter label{font-weight:600;color:var(--color-text);white-space:nowrap}.date-select{padding:8px 12px!important;border-radius:var(--radius-lg)!important;font-size:var(--font-size-md)!important;border:1px solid var(--color-border)!important;background-color:var(--color-bg)!important;flex:1;min-width:200px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.section{margin-bottom:var(--spacing-2xl)}.section-title{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-lg);color:var(--color-text)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.section-link{display:flex;align-items:center;gap:var(--spacing-sm);background:none;border:none;color:var(--color-primary);font-weight:600;cursor:pointer;font-size:var(--font-size-sm);transition:all .2s ease;padding:4px 8px;border-radius:var(--radius-md)}.section-link:hover{background-color:#0052cc14;transform:translate(2px)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--spacing-md)}.quick-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-lg)!important;min-height:110px;text-align:center;font-weight:600;font-size:var(--font-size-sm);cursor:pointer;transition:all .2s ease}.quick-action-btn:active{transform:scale(.98)}.charts-section{margin-bottom:var(--spacing-2xl)}.chart-card{padding:var(--spacing-xl)!important}.chart-title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xl);color:var(--color-text);font-weight:600}.invoice-status{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.status-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);text-align:center}.status-badge{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-lg);color:#fff;font-weight:700;font-size:var(--font-size-xl);box-shadow:var(--shadow-md)}.status-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:600}.status-percent{font-size:var(--font-size-lg);color:var(--color-text);font-weight:700}.recent-items{display:flex;flex-direction:column;gap:var(--spacing-md)}.recent-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg)!important}.recent-left{display:flex;align-items:center;gap:var(--spacing-md);flex:1;min-width:0}.recent-info{flex:1;min-width:0}.recent-name{font-size:var(--font-size-md);font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-detail{font-size:var(--font-size-sm);color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-sm)}.recent-amount{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);font-family:JetBrains Mono,monospace}.empty-message{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);color:var(--color-text-tertiary);font-size:var(--font-size-md)}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.invoice-status{grid-template-columns:1fr}.date-filter{flex-direction:column;align-items:flex-start}.date-select{width:100%}}@media (max-width: 480px){.greeting-title{font-size:var(--font-size-2xl)}.stats-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2,1fr)}}.condominios-search{position:relative;margin-bottom:20px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none;display:flex;align-items:center;justify-content:center;width:20px;height:20px}.search-input{width:100%;padding:12px 12px 12px 40px;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-md);background-color:var(--color-bg);height:44px;display:flex;align-items:center}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #02152f1a}.condominios-filters{display:flex;gap:8px;margin-bottom:20px;overflow-x:auto;padding-bottom:8px}.filter-btn{padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;font-weight:500;background:transparent;color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;transition:all .2s;display:flex;align-items:center;gap:6px}.filter-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.filter-count{font-weight:600;background:#ffffff4d;padding:2px 6px;border-radius:4px;font-size:11px}.filter-btn.active .filter-count{background:#fff6}.condominios-table-container{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg)}.condominios-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.condominios-table thead{background-color:var(--color-bg-light);border-bottom:1px solid var(--color-border)}.condominios-table th{padding:12px;text-align:left;font-weight:600;color:var(--color-text);white-space:nowrap}.condominios-table tbody tr{border-bottom:1px solid var(--color-border);cursor:pointer;transition:all .2s ease}.condominios-table tbody tr:hover{background-color:var(--color-bg-light)}.condominios-table tbody tr.table-row:last-child{border-bottom:none}.condominios-table td{padding:12px;color:var(--color-text)}.cell-name{font-weight:500}.cell-content{display:flex;align-items:center;gap:10px}.cell-info{display:flex;flex-direction:column;gap:2px}.cell-info .name{font-weight:600;color:var(--color-text);font-size:13px}.cell-info .email{font-size:11px;color:var(--color-text-tertiary)}.cell-services{text-align:center}.service-count{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background-color:var(--color-primary);color:#fff;border-radius:var(--radius-full);font-weight:600;font-size:12px}.cell-status{text-align:left}.table-empty{text-align:center;padding:40px 20px!important}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--color-text-secondary)}.empty-state p{font-size:14px;margin:0}@media (max-width: 768px){.condominios-filters{margin-bottom:16px}.condominios-table{font-size:11px}.condominios-table th,.condominios-table td{padding:8px}.cell-content{gap:8px}.service-count{width:24px;height:24px;font-size:11px}}.condominios-header{margin-bottom:24px}.condominios-title{font-size:24px;font-weight:700;color:var(--color-text);margin:0 0 8px}.condominios-subtitle{font-size:14px;color:var(--color-text-secondary);margin:0}.detail-profile{padding:var(--spacing-xl)!important;margin-bottom:var(--spacing-xl)}.profile-header{display:flex;align-items:flex-start;gap:var(--spacing-lg);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-xl)}.profile-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.profile-name{font-size:var(--font-size-2xl);color:var(--color-text)}.profile-details{display:flex;flex-direction:column;gap:var(--spacing-lg)}.detail-row{display:flex;gap:var(--spacing-md);align-items:flex-start}.detail-icon{color:var(--color-primary);flex-shrink:0;margin-top:2px}.detail-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500;margin-bottom:4px}.detail-value{font-size:var(--font-size-md);color:var(--color-text);font-weight:500}.section-title{font-size:var(--font-size-xl);margin-bottom:var(--spacing-lg);color:var(--color-text)}.invoices-filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);overflow-x:auto;padding-bottom:var(--spacing-sm)}.invoice-card{padding:var(--spacing-lg)!important}.invoice-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.invoice-num{font-size:var(--font-size-md);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-sm)}.invoice-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.invoice-amount{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-sm)}.amount{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);font-family:JetBrains Mono,monospace}.invoice-description{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:var(--spacing-md);font-style:italic}.empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg);color:var(--color-text-tertiary)}@media (max-width: 480px){.profile-header,.invoice-header{flex-direction:column}.invoice-amount{align-items:flex-start}}.invoices-summary{padding:var(--spacing-xl)!important;margin-bottom:var(--spacing-xl)}.summary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.summary-item{display:flex;flex-direction:column;gap:var(--spacing-sm);text-align:center}.summary-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.summary-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text);font-family:JetBrains Mono,monospace}.summary-value.success{color:var(--color-success)}.summary-value.warning{color:var(--color-warning)}.invoices-filters{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);overflow-x:auto;padding-bottom:var(--spacing-sm)}.filter-btn{display:flex;align-items:center;justify-content:center;padding:8px 16px;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-weight:500;font-size:var(--font-size-sm);cursor:pointer;white-space:nowrap;transition:all .2s ease}.filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-btn.active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.invoices-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.invoice-item{padding:var(--spacing-lg)!important}.invoice-content{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.invoice-left{flex:1;min-width:0}.invoice-number{font-size:var(--font-size-md);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-sm)}.invoice-client{font-size:var(--font-size-md);color:var(--color-text);font-weight:500;margin-bottom:4px}.invoice-date,.invoice-duedate{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:4px}.invoice-notes{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-top:var(--spacing-sm);font-style:italic}.invoice-right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-sm);white-space:nowrap}.invoice-total{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);font-family:JetBrains Mono,monospace}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-lg);text-align:center;color:var(--color-text-tertiary)}.empty-state p{margin-top:var(--spacing-lg);font-size:var(--font-size-md)}@media (max-width: 480px){.summary-row{grid-template-columns:1fr}.invoice-content{flex-direction:column}.invoice-right{width:100%;align-items:flex-start}}.department-selector{display:flex;gap:8px;overflow-x:auto;padding:12px 0;margin-bottom:16px;scroll-behavior:smooth;scrollbar-width:none}.department-selector::-webkit-scrollbar{display:none}.dept-btn{flex-shrink:0;padding:8px 16px;border:1px solid #E5E7EB;border-radius:20px;background:#fff;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.dept-btn:hover{border-color:#d1d5db;background:#f9fafb}.dept-btn.active{background:var(--primary-color, #02152F);color:#fff;border-color:var(--primary-color, #02152F)}.tickets-summary{margin-bottom:16px}.summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media (max-width: 640px){.summary-row{grid-template-columns:repeat(2,1fr)}}.summary-item{display:flex;flex-direction:column;align-items:center;gap:6px}.summary-label{font-size:12px;color:#6b7280;font-weight:500}.summary-value{font-size:24px;font-weight:700;color:var(--primary-color, #02152F)}.tickets-filters{display:flex;gap:8px;overflow-x:auto;padding:12px 0;margin-bottom:16px;scroll-behavior:smooth;scrollbar-width:none}.tickets-filters::-webkit-scrollbar{display:none}.filter-btn{flex-shrink:0;padding:8px 14px;border:1px solid #E5E7EB;border-radius:16px;background:#fff;color:#6b7280;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.filter-btn:hover{border-color:#d1d5db;background:#f9fafb}.filter-btn.active{background:var(--primary-color, #02152F);color:#fff;border-color:var(--primary-color, #02152F)}.tickets-list{display:flex;flex-direction:column;gap:12px}.ticket-item{transition:all .2s}.ticket-item:active{background-color:#f3f4f6}.ticket-content{display:flex;justify-content:space-between;gap:12px}.ticket-left{flex:1;display:flex;flex-direction:column;gap:4px}.ticket-id{font-size:14px;font-weight:700;color:var(--primary-color, #02152F);margin:0}.ticket-subject{font-size:14px;font-weight:600;color:#1f2937;margin:0;line-height:1.4}.ticket-client{font-size:13px;color:#6b7280;margin:0}.ticket-date{font-size:12px;color:#9ca3af;margin:0}.ticket-lastreply{font-size:12px;color:#9ca3af;margin:0;font-weight:500}.ticket-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start;gap:8px}.ticket-badges{display:flex;flex-direction:column;gap:4px;align-items:flex-end}.ticket-dept{font-size:11px;color:#9ca3af;margin:0;text-align:right}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 20px;text-align:center}.empty-state p{font-size:14px;color:#6b7280;margin:0}.ticket-header-card{margin-bottom:20px}.ticket-header{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #E5E7EB}.ticket-title{font-size:18px;font-weight:700;color:var(--primary-color, #02152F);margin:0 0 8px;line-height:1.4}.ticket-client-info{font-size:13px;color:#6b7280;margin:0}.ticket-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media (max-width: 640px){.ticket-info-grid{grid-template-columns:1fr}}.info-item{display:flex;flex-direction:column;gap:4px}.info-label{font-size:11px;color:#9ca3af;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:13px;color:#1f2937;font-weight:500}.section-title{font-size:14px;font-weight:700;color:#1f2937;margin:24px 0 12px;padding-top:8px;border-top:1px solid #E5E7EB}.notes-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.note-card{display:flex;flex-direction:column;gap:12px}.note-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:8px;border-bottom:1px solid #E5E7EB;gap:12px}.note-author{display:flex;flex-direction:column;gap:2px}.note-author strong{font-size:13px;color:var(--primary-color, #02152F);font-weight:600}.note-email{font-size:11px;color:#9ca3af}.note-date{font-size:11px;color:#9ca3af;white-space:nowrap}.note-message{font-size:13px;color:#374151;line-height:1.6}.note-message p{margin:0;white-space:pre-wrap;word-break:break-word}.note-attachments{display:flex;flex-direction:column;gap:8px;padding:8px 12px;background:#f9fafb;border-radius:6px;border-left:3px solid #D1D5DB}.attachments-title{font-size:12px;font-weight:600;color:#6b7280;margin:0;display:flex;align-items:center;gap:6px}.attachment-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#fff;border-radius:4px;cursor:pointer;transition:all .2s}.attachment-item:hover{background:#f3f4f6}.attachment-item svg{color:#9ca3af;flex-shrink:0}.attachment-name{font-size:12px;color:#374151;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-notes{text-align:center;padding:30px 20px}.empty-notes p{font-size:13px;color:#6b7280;margin:0}.phase-2-note{margin-top:16px;background:#fef3c7;border-left:3px solid #FCD34D;padding:12px 14px}.phase-2-note p{margin:0;font-size:12px;color:#78350f}.error-message{text-align:center;padding:30px 20px}.error-message p{font-size:14px;margin:8px 0 0}.error-message p:first-child{color:#1f2937;font-weight:600}.error-message .text-secondary{font-size:12px;color:#9ca3af}
