.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:linear-gradient(180deg,#1a1a1a,#0a0a0a);border-right:1px solid var(--gray-300);display:flex;flex-direction:column;z-index:100;box-shadow:4px 0 20px #00000080}.sidebar-header{padding:var(--spacing-xl);border-bottom:1px solid var(--gray-300);text-align:center}.sidebar-logo{width:60px;height:60px;margin:0 auto var(--spacing-md);filter:drop-shadow(0 0 15px rgba(149,193,31,.5))}.ironchip-logo{width:100%;height:100%;filter:brightness(0) invert(1)}.sidebar-title{font-size:1.5rem;margin:0;color:var(--white);font-weight:700;letter-spacing:1px}.sidebar-subtitle{display:block;font-size:.75rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:1px;margin-top:4px}.sidebar-nav{flex:1;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-xs);overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-md);padding:14px 18px;border-radius:var(--border-radius-sm);color:var(--white);text-decoration:none;font-weight:500;transition:all .3s ease;border:1px solid transparent;position:relative}.sidebar-link:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--ironchip-green);transition:height .3s ease;border-radius:0 2px 2px 0}.sidebar-link:hover{background:#95c11f1a;color:var(--white);border-color:#95c11f4d}.sidebar-link:hover:before{height:60%}.sidebar-link.active{background:linear-gradient(90deg,#95c11f33,#95c11f0d);color:var(--ironchip-green);border-color:var(--ironchip-green);box-shadow:0 0 20px #95c11f33}.sidebar-link.active:before{height:80%;box-shadow:0 0 10px var(--ironchip-green)}.sidebar-link svg{flex-shrink:0}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:var(--gray-100)}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--ironchip-green)}@media (max-width: 768px){.sidebar{width:240px;transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}}.topbar{position:fixed;top:0;left:280px;right:0;height:64px;background:var(--gray-200);border-bottom:1px solid var(--gray-300);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xl);z-index:100;box-shadow:0 2px 8px #0000004d}.topbar-left{flex:1}.topbar-title{font-size:1.25rem;font-weight:700;margin:0;background:linear-gradient(90deg,var(--white),var(--ironchip-green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.5px}.topbar-right{display:flex;align-items:center;gap:var(--spacing-md)}.topbar-user{position:relative}.topbar-user-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:6px 12px;background:transparent;border:1px solid var(--gray-400);border-radius:24px;cursor:pointer;transition:all .2s ease}.topbar-user-button:hover{background:var(--gray-300);border-color:var(--ironchip-green)}.topbar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--ironchip-green),var(--ironchip-green-glow));color:var(--ironchip-black);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}.topbar-user-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.topbar-user-name{font-size:.875rem;font-weight:600;color:#fff;line-height:1}.topbar-user-email{font-size:.75rem;color:#999;line-height:1}.topbar-chevron{color:#999;transition:transform .2s ease;flex-shrink:0}.topbar-chevron.rotate{transform:rotate(180deg)}.topbar-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:280px;background:var(--gray-200);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);padding:var(--spacing-sm);animation:dropdownSlideIn .2s ease}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.topbar-dropdown-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md)}.topbar-dropdown-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--ironchip-green),var(--ironchip-green-glow));color:var(--ironchip-black);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.topbar-dropdown-name{font-size:.875rem;font-weight:600;color:var(--white);margin-bottom:2px}.topbar-dropdown-email{font-size:.75rem;color:var(--white)}.topbar-dropdown-divider{height:1px;background:var(--gray-300);margin:var(--spacing-sm) 0}.topbar-dropdown-item{width:100%;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--border-radius-sm);color:var(--white);font-size:.875rem;cursor:pointer;transition:all .2s ease;text-align:left}.topbar-dropdown-item:hover{background:var(--gray-300);color:var(--white)}.topbar-dropdown-item:hover svg{color:var(--ironchip-green)}@media (max-width: 768px){.topbar{left:0;padding:0 var(--spacing-md)}.topbar-title{font-size:1rem}.topbar-user-info{display:none}.topbar-user-button{padding:6px}.topbar-dropdown{min-width:240px}}.dashboard-container{animation:fadeIn .5s ease-out}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg)}.loading-spinner{width:48px;height:48px;border:4px solid var(--gray-300);border-top-color:var(--ironchip-green);border-radius:50%;animation:spin .8s linear infinite}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl)}.dashboard-header h1{font-size:2.5rem;margin:0 0 var(--spacing-sm);background:linear-gradient(90deg,var(--white),var(--ironchip-green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.company-name{font-size:1.125rem;color:var(--gray-600);margin:0}.company-status{display:flex;align-items:center;gap:var(--spacing-sm);padding:12px 20px;border-radius:var(--border-radius-md);font-weight:600;border:1px solid}.company-status.active{background:#95c11f1a;border-color:var(--ironchip-green);color:var(--ironchip-green)}.company-status.inactive{background:#ef44441a;border-color:#ef4444;color:#ef4444}.license-overview{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.license-card{background:var(--gray-200);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-lg);transition:all .3s ease}.license-card:hover{border-color:var(--ironchip-green);box-shadow:0 0 30px #95c11f33}.license-card.primary{background:linear-gradient(135deg,var(--gray-200),var(--gray-100))}.license-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);color:var(--ironchip-green);font-size:1.125rem;font-weight:600}.license-body{display:flex;flex-direction:column;gap:var(--spacing-md)}.license-numbers{display:flex;align-items:baseline;gap:var(--spacing-sm);font-weight:700}.license-numbers .current{font-size:3.5rem;color:var(--ironchip-green);line-height:1}.license-numbers .separator{font-size:2rem;color:var(--gray-500)}.license-numbers .max{font-size:2rem;color:var(--gray-600)}.license-label{font-size:.875rem;color:var(--gray-600);text-transform:uppercase;letter-spacing:1px}.usage-bar{width:100%;height:12px;background:var(--gray-300);border-radius:6px;overflow:hidden;position:relative}.usage-fill{height:100%;transition:width .5s ease;position:relative}.usage-fill.low{background:linear-gradient(90deg,var(--ironchip-green),rgba(149,193,31,.7))}.usage-fill.medium{background:linear-gradient(90deg,#f59e0b,#f97316)}.usage-fill.high{background:linear-gradient(90deg,#ef4444,#dc2626)}.usage-text{font-size:.875rem;color:var(--gray-600);margin-top:4px}.license-stat{display:flex;align-items:center;gap:var(--spacing-lg)}.license-stat svg{color:var(--ironchip-green)}.stat-value{font-size:2.5rem;font-weight:700;color:var(--white);line-height:1}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.metric-card{background:var(--gray-200);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);display:flex;align-items:flex-start;gap:var(--spacing-lg);transition:all .3s ease;box-shadow:var(--shadow-md)}.metric-card:hover{border-color:var(--ironchip-green);box-shadow:0 0 25px #95c11f33;transform:translateY(-4px)}.metric-icon{width:60px;height:60px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid}.metric-icon.active{background:#95c11f26;border-color:var(--ironchip-green);color:var(--ironchip-green)}.metric-icon.warning{background:#f59e0b26;border-color:#f59e0b;color:#f59e0b}.metric-icon.danger{background:#ef444426;border-color:#ef4444;color:#ef4444}.metric-icon.blocked{background:#a855f726;border-color:#a855f7;color:#a855f7}.metric-content{flex:1}.metric-content h3{font-size:.875rem;color:var(--gray-600);margin:0 0 var(--spacing-sm);text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:2.25rem;font-weight:700;color:var(--white);margin:0 0 var(--spacing-sm);line-height:1}.metric-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.metric-badge.success{background:#95c11f33;color:var(--ironchip-green)}.metric-badge.warning{background:#f59e0b33;color:#f59e0b}.metric-badge.danger{background:#ef444433;color:#ef4444}.metric-badge.info{background:#a855f733;color:#a855f7}.keys-section{margin-bottom:var(--spacing-2xl)}.keys-section h2{font-size:1.75rem;margin:0 0 var(--spacing-lg);color:var(--white)}.keys-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg)}.key-stat-card{background:var(--gray-200);border:2px solid;border-radius:var(--border-radius-lg);padding:var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-xl);transition:all .3s ease;box-shadow:var(--shadow-lg)}.key-stat-card.available{border-color:var(--ironchip-green)}.key-stat-card.available:hover{box-shadow:0 0 30px #95c11f4d;transform:translateY(-4px)}.key-stat-card.used{border-color:var(--gray-400)}.key-stat-card.used:hover{box-shadow:0 0 30px #4a4a4a4d;transform:translateY(-4px)}.key-stat-icon{width:80px;height:80px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.key-stat-card.available .key-stat-icon{background:linear-gradient(135deg,#95c11f33,#95c11f1a);color:var(--ironchip-green)}.key-stat-card.used .key-stat-icon{background:linear-gradient(135deg,#4a4a4a4d,#4a4a4a1a);color:var(--gray-600)}.key-stat-content{flex:1}.key-stat-value{font-size:3rem;font-weight:700;color:var(--white);line-height:1;margin-bottom:var(--spacing-sm)}.key-stat-label{font-size:1rem;color:var(--gray-600);text-transform:uppercase;letter-spacing:1px}@media (max-width: 1024px){.license-overview{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:var(--spacing-lg)}.dashboard-header h1{font-size:2rem}.license-numbers .current{font-size:2.5rem}.license-numbers .max{font-size:1.5rem}.metrics-grid,.keys-stats{grid-template-columns:1fr}}.installations-container{animation:fadeIn .5s ease-out}.installations-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl)}.installations-header h1{font-size:2.5rem;margin:0 0 var(--spacing-sm);background:linear-gradient(90deg,var(--white),var(--ironchip-green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.installations-header p{color:var(--gray-600);margin:0}.installations-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card.inactive{border-color:#ef4444}.stat-card.inactive:hover{box-shadow:0 0 30px #ef44444d;transform:translateY(-4px)}.stat-card.inactive .stat-icon{background:linear-gradient(135deg,#ef444433,#ef44441a);color:#ef4444}.installations-table-container{background:var(--gray-200);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.installations-table{width:100%;border-collapse:collapse}.installations-table thead{background:linear-gradient(135deg,var(--gray-300),var(--gray-200));border-bottom:2px solid var(--ironchip-green)}.installations-table th{padding:var(--spacing-lg);text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gray-600)}.installations-table tbody tr{border-bottom:1px solid var(--gray-300);transition:all .3s ease}.installations-table tbody tr:hover{background:#95c11f0d}.installations-table td{padding:var(--spacing-lg);color:var(--gray-700)}.installation-id{background:var(--gray-300);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);font-family:Courier New,monospace;font-size:.85rem;color:var(--ironchip-green);border:1px solid var(--gray-400)}.device-info{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--gray-700)}.device-info svg{flex-shrink:0;color:var(--gray-500)}.user-email{color:var(--gray-700);font-weight:500}.date{color:var(--gray-600);font-size:.9em}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all var(--transition-fast)}.status-badge.active{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.status-badge.inactive{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.status-badge.suspended{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.status-badge.revoked{background:#6b728026;color:#6b7280;border:1px solid rgba(107,114,128,.3)}.btn-action{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:2px solid #ef4444;color:#ef4444;border-radius:var(--border-radius-md);font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:6px}.btn-action:hover{background:#ef4444;color:var(--white);box-shadow:0 0 20px #ef444466}.no-data{text-align:center!important;padding:var(--spacing-2xl)!important;color:var(--gray-600)}.no-data svg{opacity:.3;margin-bottom:var(--spacing-md)}.no-data p{font-size:1.1rem;margin:0}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md)}.loading-spinner{width:50px;height:50px;border:4px solid var(--gray-300);border-top-color:var(--ironchip-green);border-radius:50%;animation:spin 1s linear infinite}.keys-container{animation:fadeIn .5s ease-out}.keys-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl)}.keys-header h1{font-size:2.5rem;margin:0 0 var(--spacing-sm);background:linear-gradient(90deg,var(--white),var(--ironchip-green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.keys-header p{color:var(--gray-600);margin:0}.keys-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.stat-card{background:var(--gray-200);border:2px solid;border-radius:var(--border-radius-lg);padding:var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-lg);transition:all .3s ease;box-shadow:var(--shadow-md)}.stat-card.available{border-color:var(--ironchip-green)}.stat-card.available:hover{box-shadow:0 0 30px #95c11f4d;transform:translateY(-4px)}.stat-card.active{border-color:#10b981}.stat-card.active:hover{box-shadow:0 0 30px #10b9814d;transform:translateY(-4px)}.stat-icon{width:60px;height:60px;border-radius:var(--border-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card.available .stat-icon{background:linear-gradient(135deg,#95c11f33,#95c11f1a);color:var(--ironchip-green)}.stat-card.active .stat-icon{background:linear-gradient(135deg,#10b98133,#10b9811a);color:#10b981}.stat-content{flex:1}.stat-value{font-size:2.5rem;font-weight:700;color:var(--white);line-height:1;margin-bottom:var(--spacing-xs)}.stat-label{font-size:.875rem;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px}.keys-table-container{background:var(--gray-200);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.keys-table{width:100%;border-collapse:collapse}.keys-table thead{background:linear-gradient(135deg,var(--gray-300),var(--gray-200));border-bottom:2px solid var(--ironchip-green)}.keys-table th{padding:var(--spacing-lg);text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gray-600)}.keys-table tbody tr{border-bottom:1px solid var(--gray-300);transition:all .3s ease}.keys-table tbody tr:hover{background:#95c11f0d}.keys-table td{padding:var(--spacing-lg);color:var(--gray-700)}.no-data{text-align:center;padding:var(--spacing-2xl)!important;color:var(--gray-600)}.no-data svg{color:var(--gray-500);margin-bottom:var(--spacing-md)}.no-data p{font-size:1.125rem;margin:var(--spacing-md) 0 var(--spacing-lg)}.key-cell{display:flex;align-items:center;gap:var(--spacing-sm)}.key-code{font-family:Courier New,monospace;font-size:.875rem;background:var(--gray-100);padding:6px 12px;border-radius:var(--border-radius-sm);border:1px solid var(--gray-400);color:var(--ironchip-green);font-weight:600}.btn-copy{padding:6px;background:#95c11f1a;border:1px solid rgba(149,193,31,.3);border-radius:var(--border-radius-sm);color:var(--ironchip-green);cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.btn-copy:hover{background:#95c11f33;border-color:var(--ironchip-green);box-shadow:0 0 10px #95c11f4d}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#10b98133;color:#10b981}.status-badge.suspended{background:#f59e0b33;color:#f59e0b}.status-badge.revoked{background:#ef444433;color:#ef4444}.status-badge.unused{background:#3b82f633;color:#3b82f6}.status-badge.used{background:#10b98133;color:#10b981}.status-badge.expired{background:#6b728033;color:#6b7280}.status-badge.exhausted{background:#ef444433;color:#ef4444}.usage-cell{display:flex;flex-direction:column;gap:8px;min-width:150px}.usage-bar-container{width:100%;height:8px;background:var(--gray-300);border-radius:4px;overflow:hidden}.usage-bar{height:100%;border-radius:4px;transition:width .3s ease,background-color .3s ease;background:linear-gradient(90deg,var(--ironchip-green),#a0c838)}.usage-text{font-family:Courier New,monospace;font-size:.875rem;color:var(--gray-700);font-weight:600}.device-id,.ip-address,.date{font-family:Courier New,monospace;font-size:.875rem;color:var(--gray-600)}.btn-action{padding:8px;border-radius:var(--border-radius-sm);border:1px solid;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center}.btn-action.copy{background:#95c11f1a;border-color:#95c11f4d;color:var(--ironchip-green)}.btn-action.copy:hover{background:#95c11f33;border-color:var(--ironchip-green);box-shadow:0 0 10px #95c11f4d}.btn-action.revoke{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.btn-action.revoke:hover{background:#ef444433;border-color:#ef4444;box-shadow:0 0 15px #ef44444d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.modal-container{background:var(--gray-200);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);box-shadow:0 25px 50px -12px #00000080,0 0 40px #95c11f33;max-width:500px;width:90%;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--gray-300);background:linear-gradient(135deg,var(--gray-200),var(--gray-100))}.modal-header h2{font-size:1.5rem;margin:0;display:flex;align-items:center;gap:var(--spacing-md);color:var(--white)}.modal-header h2 svg{color:var(--ironchip-green)}.btn-close{width:36px;height:36px;border:1px solid var(--gray-400);background:var(--gray-300);border-radius:var(--border-radius-sm);font-size:1.5rem;color:var(--gray-600);cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.btn-close:hover:not(:disabled){background:var(--gray-400);border-color:var(--ironchip-green);color:var(--white)}.btn-close:disabled{opacity:.5;cursor:not-allowed}.modal-form{padding:var(--spacing-xl)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;font-weight:500;color:var(--gray-600);margin-bottom:var(--spacing-sm);text-transform:uppercase;letter-spacing:.5px}.form-group label svg{color:var(--ironchip-green)}.form-group input{width:100%;padding:12px 16px;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:var(--border-radius-sm);font-size:1rem;color:var(--white);transition:all .3s ease}.form-group input:focus{outline:none;border-color:var(--ironchip-green);box-shadow:0 0 0 3px #95c11f26;background:var(--gray-200)}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-hint{display:block;font-size:.75rem;color:var(--gray-500);margin-top:4px}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-lg);border-top:1px solid var(--gray-300)}.btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:12px 24px;border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-secondary{background:var(--gray-300);color:var(--gray-600);border:1px solid var(--gray-400)}.btn-secondary:hover:not(:disabled){background:var(--gray-400);color:var(--white)}.btn-primary{background:linear-gradient(135deg,var(--ironchip-green),rgba(149,193,31,.8));color:var(--gray-900);border:1px solid var(--ironchip-green);font-weight:600}.btn-primary:hover:not(:disabled){box-shadow:0 0 25px #95c11f80;transform:translateY(-2px)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid var(--gray-900);border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}@media (max-width: 768px){.keys-header{flex-direction:column;gap:var(--spacing-lg)}.keys-header h1{font-size:2rem}.keys-stats-grid{grid-template-columns:1fr}.keys-table-container{overflow-x:auto}.keys-table{min-width:800px}}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--gray-300);margin-top:var(--spacing-md)}.pagination-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-200);border:1px solid var(--gray-400);border-radius:var(--border-radius-sm);color:var(--gray-700);cursor:pointer;transition:all .3s ease;font-size:.875rem;font-weight:500;min-width:40px;height:36px}.pagination-btn:hover:not(:disabled){background:var(--gray-300);border-color:var(--ironchip-green);transform:translateY(-1px)}.pagination-btn.active{background:var(--ironchip-green);color:#fff;border-color:var(--ironchip-green);font-weight:600}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.page-numbers{display:flex;gap:4px}.page-info{color:#999;font-size:.875rem;margin-left:var(--spacing-md);font-weight:500}@media (max-width: 768px){.pagination-controls{flex-wrap:wrap;gap:var(--spacing-xs)}.page-info{flex-basis:100%;text-align:center;margin-left:0;margin-top:var(--spacing-xs)}}.metrics-container{animation:fadeIn .5s ease-out}.metrics-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl)}.metrics-header h1{font-size:2.5rem;margin:0 0 var(--spacing-sm);background:linear-gradient(90deg,var(--white),var(--ironchip-green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.metrics-header p{color:var(--gray-600);margin:0}.chart-card{background:var(--gray-200);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-lg);transition:all .3s ease}.chart-card:hover{box-shadow:0 0 30px #95c11f33;transform:translateY(-2px)}.chart-header{margin-bottom:var(--spacing-xl)}.chart-title{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.chart-title h2{font-size:1.5rem;margin:0;color:var(--white)}.chart-title svg{color:var(--ironchip-green)}.chart-subtitle{margin:0;color:var(--gray-600);font-size:.875rem}.chart-container{padding:var(--spacing-md) 0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.no-chart-data{display:flex;align-items:center;justify-content:center;height:300px;color:var(--gray-600);font-size:1rem}.domains-table-container{overflow-x:auto}.domains-table{width:100%;border-collapse:collapse}.domains-table thead{background:linear-gradient(135deg,var(--gray-300),var(--gray-200));border-bottom:2px solid var(--ironchip-green)}.domains-table th{padding:var(--spacing-lg);text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gray-600)}.domains-table tbody tr{border-bottom:1px solid var(--gray-300);transition:all .3s ease}.domains-table tbody tr:hover{background:#95c11f0d}.domains-table td{padding:var(--spacing-lg);color:var(--gray-700)}.domains-table td.rank{font-weight:700;color:var(--ironchip-green);font-size:1.125rem}.domains-table td.domain{font-family:Courier New,monospace;color:var(--white);font-size:.875rem}.domains-table td.count{font-weight:600;color:#ef4444;font-size:1.125rem}.percentage-bar{position:relative;width:100%;height:28px;background:var(--gray-100);border-radius:14px;overflow:hidden;border:1px solid var(--gray-400)}.percentage-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--ironchip-green),rgba(149,193,31,.6));border-radius:14px;transition:width .6s ease}.percentage-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:600;color:var(--white);text-shadow:0 1px 3px rgba(0,0,0,.5);z-index:1}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg)}.spinner{width:60px;height:60px;border:4px solid var(--gray-400);border-top-color:var(--ironchip-green);border-radius:50%;animation:spin .8s linear infinite}.loading p{color:var(--gray-600);font-size:1.125rem}.no-data{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg)}.no-data svg{color:var(--gray-500)}.no-data p{color:var(--gray-600);font-size:1.125rem}.recharts-cartesian-axis-tick-value{fill:#999;font-size:.75rem}.recharts-legend-item-text{color:#999!important}.recharts-tooltip-wrapper{outline:none}@media (max-width: 1024px){.metrics-grid{grid-template-columns:1fr}}@media (max-width: 768px){.metrics-header h1{font-size:2rem}.chart-card{padding:var(--spacing-lg)}.chart-title h2{font-size:1.25rem}.domains-table-container{overflow-x:auto}.domains-table{min-width:600px}.chart-container{overflow-x:auto}}.chart-actions{display:flex;gap:var(--spacing-sm)}.export-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--ironchip-green);color:var(--gray-100);border:none;border-radius:var(--border-radius-md);cursor:pointer;font-weight:500;transition:all .3s ease}.export-btn:hover:not(:disabled){background:#a8d42b;transform:translateY(-2px);box-shadow:0 4px 12px #95c11f4d}.export-btn:disabled{opacity:.5;cursor:not-allowed}.filters-container{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--gray-100);border-radius:var(--border-radius-md);border:1px solid var(--gray-300)}.filter-group{display:flex;align-items:center;gap:var(--spacing-xs);position:relative}.filter-group svg{color:var(--gray-600);flex-shrink:0}.filter-input,.filter-select{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-200);border:1px solid var(--gray-400);border-radius:var(--border-radius-sm);color:var(--white);font-size:.875rem;transition:all .3s ease}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--ironchip-green);box-shadow:0 0 0 3px #95c11f1a}.filter-select{cursor:pointer}.filter-select option{background:var(--gray-200);color:var(--white)}.reset-filters-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:var(--gray-600);border:1px solid var(--gray-400);border-radius:var(--border-radius-sm);cursor:pointer;font-size:.875rem;transition:all .3s ease;white-space:nowrap}.reset-filters-btn:hover{background:var(--gray-300);color:var(--white);border-color:var(--gray-500)}.history-table-container{overflow-x:auto;border-radius:var(--border-radius-md);border:1px solid var(--gray-300)}.history-table{width:100%;border-collapse:collapse;background:var(--gray-100)}.history-table thead{background:var(--gray-300);position:sticky;top:0;z-index:1}.history-table th{padding:var(--spacing-md);text-align:left;font-weight:600;color:var(--gray-700);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--gray-400)}.history-table tbody tr{border-bottom:1px solid var(--gray-300);transition:background .2s ease}.history-table tbody tr:hover{background:var(--gray-200)}.history-table td{padding:var(--spacing-md);color:var(--gray-700);font-size:.875rem}.date-cell{white-space:nowrap;color:var(--gray-600);font-family:Courier New,monospace}.url-cell{max-width:400px}.url-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ironchip-green);font-family:Courier New,monospace}.reason-cell{max-width:300px;color:var(--gray-600)}.type-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.type-badge.typosquatting{background:#ef444433;color:#ef4444;border:1px solid #ef4444}.type-badge.homoglyph{background:#f59e0b33;color:#f59e0b;border:1px solid #f59e0b}.type-badge.content_clone{background:#a855f733;color:#a855f7;border:1px solid #a855f7}.type-badge.phishingDatabase,.type-badge.phishing_database{background:#ec489933;color:#ec4899;border:1px solid #ec4899}.type-badge.ipdb{background:#8b5cf633;color:#8b5cf6;border:1px solid #8b5cf6}@media (max-width: 1024px){.filters-container{grid-template-columns:1fr}.history-table-container{overflow-x:scroll}.history-table{min-width:800px}}.settings-page{padding:2rem;max-width:900px;margin:0 auto}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;color:#1a1a1a;margin-bottom:.5rem}.subtitle{color:#666;font-size:.95rem}.settings-form{display:flex;flex-direction:column;gap:2rem}.settings-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;color:#2563eb}.section-header h2{font-size:1.25rem;color:#1a1a1a;margin:0}.section-description{color:#666;margin-bottom:1.5rem;font-size:.9rem}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#374151;margin-bottom:.5rem;font-size:.95rem}.form-group input[type=text],.form-group textarea{width:100%;padding:.75rem;border:1px solid #e5e7eb;border-radius:8px;font-size:.95rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;transition:all .2s}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input[type=text]:disabled,.form-group textarea:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.form-group textarea{resize:vertical;min-height:120px;font-family:Courier New,monospace;line-height:1.6}.form-hint{display:block;color:#6b7280;font-size:.85rem;margin-top:.5rem}.form-hint a{color:#2563eb;text-decoration:none}.form-hint a:hover{text-decoration:underline}.toggle-group{border:1px solid #e5e7eb;border-radius:8px;padding:1rem;background:#f9fafb}.toggle-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.toggle-header label{margin-bottom:0!important;font-weight:600}.toggle-switch{position:relative;width:50px;height:26px;display:inline-block}.toggle-switch input[type=checkbox]{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;z-index:2;margin:0}.toggle-switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.3s;border-radius:26px;z-index:1;pointer-events:none}.toggle-switch .slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.slider{background-color:#2563eb}.toggle-switch input:checked+.slider:before{transform:translate(24px)}.toggle-switch input:disabled+.slider{opacity:.5;cursor:not-allowed}.form-actions{display:flex;justify-content:flex-end;padding-top:1rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;animation:spin .8s linear infinite}.loading-container p{color:#6b7280;font-size:.95rem}@media (max-width: 768px){.settings-page{padding:1rem}.settings-section{padding:1.5rem}.page-header h1{font-size:1.5rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;width:500px;height:500px;top:-250px;left:-250px;background:radial-gradient(circle,var(--ironchip-green) 0%,transparent 70%);opacity:.1;animation:float 15s ease-in-out infinite}.login-container:after{content:"";position:absolute;width:400px;height:400px;bottom:-200px;right:-200px;background:radial-gradient(circle,var(--ironchip-green-glow) 0%,transparent 70%);opacity:.08;animation:float 20s ease-in-out infinite reverse}.login-card{width:100%;max-width:450px;background:var(--gray-200);border-radius:var(--border-radius-xl);padding:var(--spacing-2xl);box-shadow:var(--shadow-xl);border:1px solid var(--gray-300);position:relative;z-index:1;animation:slideInUp .6s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,var(--ironchip-green) 50%,transparent 100%);border-radius:var(--border-radius-xl) var(--border-radius-xl) 0 0;box-shadow:var(--glow-green)}.login-header{text-align:center;margin-bottom:var(--spacing-2xl)}.login-logo{width:120px;height:120px;margin:0 auto var(--spacing-lg);display:block;filter:brightness(0) invert(1) drop-shadow(0 0 20px rgba(149,193,31,.4));animation:pulse-glow 3s ease-in-out infinite}.login-header h1{font-size:2.5rem;margin-bottom:var(--spacing-sm);color:var(--white)}@keyframes pulse-glow{0%,to{filter:brightness(0) invert(1) drop-shadow(0 0 20px rgba(149,193,31,.3))}50%{filter:brightness(0) invert(1) drop-shadow(0 0 40px rgba(149,193,31,.5))}}.login-header p{color:var(--gray-400);font-size:.95rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin:0}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{color:var(--ironchip-green);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.form-group input{padding:14px 18px;background:var(--gray-300);border:2px solid var(--gray-400);border-radius:var(--border-radius-md);color:var(--gray-900);font-size:1rem;transition:all var(--transition-normal)}.form-group input:focus{border-color:var(--ironchip-green);background:var(--gray-200);box-shadow:0 0 0 4px #95c11f1a,0 0 30px #95c11f33}.form-group input::placeholder{color:var(--gray-600)}.btn-login{margin-top:var(--spacing-md);padding:16px;background:linear-gradient(135deg,var(--ironchip-green) 0%,var(--ironchip-green-glow) 100%);color:var(--ironchip-black);border:none;border-radius:var(--border-radius-md);font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;position:relative;overflow:hidden;transition:all var(--transition-normal);box-shadow:var(--shadow-md)}.btn-login:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-login:hover{transform:translateY(-3px);box-shadow:var(--glow-green-strong),var(--shadow-lg)}.btn-login:hover:before{width:300px;height:300px}.btn-login:active{transform:translateY(-1px)}.btn-login:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-login:disabled:hover{box-shadow:var(--shadow-md)}.login-card:after{content:"";position:absolute;top:20px;right:20px;width:100px;height:100px;background:radial-gradient(circle,var(--ironchip-green) 0%,transparent 70%);opacity:.05;border-radius:50%;animation:float-slow 10s ease-in-out infinite}@keyframes float-slow{0%,to{transform:translate(0)}50%{transform:translate(-10px,-10px)}}@media (max-width: 640px){.login-card{padding:var(--spacing-xl)}.login-header h1{font-size:2rem}}:root{--ironchip-black: #0a0a0a;--ironchip-dark-gray: #1a1a1a;--ironchip-medium-gray: #2a2a2a;--ironchip-green: #95c11f;--ironchip-green-glow: #a8d42d;--ironchip-green-dark: #7aa118;--white: #ffffff;--gray-100: #0a0a0a;--gray-200: #1a1a1a;--gray-300: #2a2a2a;--gray-400: #3a3a3a;--gray-500: #4a4a4a;--gray-600: #666666;--gray-700: #999999;--gray-800: #CCCCCC;--gray-900: #FFFFFF;--success: #00ff88;--success-glow: rgba(0, 255, 136, .3);--warning: #ffaa00;--warning-glow: rgba(255, 170, 0, .3);--danger: #ff3366;--danger-glow: rgba(255, 51, 102, .3);--info: #00d4ff;--info-glow: rgba(0, 212, 255, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--shadow-xl: 0 16px 64px rgba(0, 0, 0, .7);--glow-green: 0 0 20px rgba(149, 193, 31, .5), 0 0 40px rgba(149, 193, 31, .3), 0 0 60px rgba(149, 193, 31, .1);--glow-green-strong: 0 0 30px rgba(149, 193, 31, .7), 0 0 60px rgba(149, 193, 31, .5), 0 0 90px rgba(149, 193, 31, .3);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;background:linear-gradient(135deg,var(--ironchip-black) 0%,var(--ironchip-dark-gray) 100%);color:var(--gray-900);line-height:1.6;overflow-x:hidden;position:relative}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(var(--gray-300) 1px,transparent 1px),linear-gradient(90deg,var(--gray-300) 1px,transparent 1px);background-size:50px 50px;opacity:.05;z-index:-1;pointer-events:none}body:after{content:"";position:fixed;width:600px;height:600px;top:-300px;right:-300px;background:radial-gradient(circle,var(--ironchip-green) 0%,transparent 70%);opacity:.08;z-index:-1;pointer-events:none;animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-100px,100px) scale(1.1)}66%{transform:translate(50px,-50px) scale(.9)}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--gray-200);border-radius:var(--border-radius-sm)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--border-radius-sm);border:2px solid var(--gray-200);transition:var(--transition-normal)}::-webkit-scrollbar-thumb:hover{background:var(--ironchip-green);box-shadow:var(--glow-green)}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{margin-left:280px;margin-top:64px;flex:1;padding:var(--spacing-2xl);min-height:calc(100vh - 64px);width:calc(100% - 280px);transition:var(--transition-normal)}h1,h2,h3,h4,h5,h6{font-weight:700;letter-spacing:-.02em;color:var(--gray-900)}h1{font-size:2.5rem;margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#ffffff 0%,var(--ironchip-green) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}h2{font-size:2rem;margin-bottom:var(--spacing-md);color:#e0e0e0;font-weight:600}h3{font-size:1.5rem;margin-bottom:var(--spacing-sm)}p{color:var(--gray-700);margin-bottom:var(--spacing-md)}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all var(--transition-normal)}.btn-primary{background:linear-gradient(135deg,var(--ironchip-green) 0%,var(--ironchip-green-glow) 100%);color:var(--ironchip-black);padding:12px 28px;border-radius:var(--border-radius-md);font-weight:600;font-size:1rem;position:relative;overflow:hidden;box-shadow:var(--shadow-md)}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--glow-green-strong),var(--shadow-lg)}.btn-primary:hover:before{left:100%}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--gray-300);color:var(--ironchip-green);padding:12px 28px;border-radius:var(--border-radius-md);font-weight:600;border:1px solid var(--gray-400)}.btn-secondary:hover{background:var(--gray-400);border-color:var(--ironchip-green);box-shadow:0 0 20px #95c11f33}.btn-danger{background:linear-gradient(135deg,var(--danger) 0%,#ff5577 100%);color:#fff;padding:12px 28px;border-radius:var(--border-radius-md);font-weight:600}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 0 20px var(--danger-glow),var(--shadow-lg)}.card{background:var(--gray-200);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);border:1px solid var(--gray-300);box-shadow:var(--shadow-md);position:relative;overflow:hidden;transition:all var(--transition-normal)}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--ironchip-green) 50%,transparent 100%);transform:scaleX(0);transition:transform var(--transition-slow)}.card:hover{border-color:var(--gray-400);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card:hover:before{transform:scaleX(1)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl);color:var(--ironchip-green);font-size:1.2rem;gap:var(--spacing-md)}.loading:before{content:"";width:40px;height:40px;border:3px solid var(--gray-400);border-top-color:var(--ironchip-green);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.no-data{text-align:center;padding:var(--spacing-2xl);color:var(--gray-600);font-style:italic}table{width:100%;border-collapse:separate;border-spacing:0;background:var(--gray-200);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}thead{background:var(--gray-300)}thead th{padding:var(--spacing-md);text-align:left;font-weight:600;color:var(--ironchip-green);text-transform:uppercase;font-size:.85rem;letter-spacing:.05em;border-bottom:2px solid var(--ironchip-green)}tbody tr{border-bottom:1px solid var(--gray-300);transition:all var(--transition-fast)}tbody tr:hover{background:var(--gray-300);box-shadow:inset 0 0 20px #95c11f1a}tbody td{padding:var(--spacing-md);color:var(--gray-800)}tbody tr:last-child{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:6px 12px;border-radius:var(--border-radius-md);font-size:.85rem;font-weight:600;letter-spacing:.03em}.badge.success{background:#00ff8826;color:var(--success);border:1px solid var(--success);box-shadow:0 0 10px var(--success-glow)}.badge.warning{background:#ffaa0026;color:var(--warning);border:1px solid var(--warning);box-shadow:0 0 10px var(--warning-glow)}.badge.danger{background:#ff336626;color:var(--danger);border:1px solid var(--danger);box-shadow:0 0 10px var(--danger-glow)}.badge.info{background:#00d4ff26;color:var(--info);border:1px solid var(--info);box-shadow:0 0 10px var(--info-glow)}input,select,textarea{width:100%;padding:12px 16px;background:var(--gray-300);border:1px solid var(--gray-400);border-radius:var(--border-radius-md);color:var(--gray-900);font-family:inherit;font-size:1rem;transition:all var(--transition-normal)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ironchip-green);box-shadow:0 0 0 3px #95c11f1a,0 0 20px #95c11f33;background:var(--gray-200)}input::placeholder{color:var(--gray-600)}label{display:block;margin-bottom:var(--spacing-sm);color:var(--gray-800);font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}@media (max-width: 768px){.main-content{padding:var(--spacing-lg)}h1{font-size:2rem}h2{font-size:1.5rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .5s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.slide-in-right{animation:slideInRight .4s ease-out}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.pulse{animation:pulse 2s ease-in-out infinite}.app-layout{display:flex;min-height:100vh}@media (max-width: 768px){.main-content{margin-left:0;margin-top:64px;width:100%;padding:var(--spacing-lg)}}.dashboard-container,.installations-container{max-width:1400px;margin:0 auto}
