@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-primary:#4f46e5;--color-primary-hover:#4338ca;--color-primary-light:#eef2ff;--color-secondary:#10b981;--color-bg-base:#f9fafb;--color-bg-surface:#fff;--color-text-main:#111827;--color-text-muted:#6b7280;--color-border:#e5e7eb;--font-base:"Inter", system-ui, -apple-system, sans-serif;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-6:1.5rem;--spacing-8:2rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--transition-base:all .2s ease-in-out}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-base);background-color:var(--color-bg-base);color:var(--color-text-main);-webkit-font-smoothing:antialiased;line-height:1.5}h1,h2,h3,h4,h5,h6{color:var(--color-text-main);font-weight:600}a{color:var(--color-primary);transition:var(--transition-base);text-decoration:none}a:hover{color:var(--color-primary-hover)}button{font-family:var(--font-base)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-in{animation:.4s ease-out forwards fadeIn}.glass{-webkit-backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #ffffff2e}.app-layout{background-color:var(--color-bg-base);width:100vw;height:100vh;display:flex;overflow:hidden}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.content-area{padding:var(--spacing-6);flex:1;overflow-y:auto}.sidebar{background-color:var(--color-bg-surface);border-right:1px solid var(--color-border);width:260px;box-shadow:var(--shadow-sm);z-index:10;flex-direction:column;flex-shrink:0;display:flex}.sidebar-header{padding:var(--spacing-6);border-bottom:1px solid var(--color-border)}.logo-container{align-items:center;gap:var(--spacing-3);display:flex}.logo-icon{background-color:var(--color-primary-light);border-radius:var(--radius-md);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.logo-container h1{color:var(--color-text-main);letter-spacing:-.025em;font-size:1.25rem;font-weight:700}.sidebar-nav{padding:var(--spacing-4) var(--spacing-3);gap:var(--spacing-1);flex-direction:column;flex:1;display:flex}.nav-item{align-items:center;gap:var(--spacing-3);width:100%;padding:var(--spacing-3);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:var(--transition-base);text-align:left;background:0 0;border:none;font-size:.95rem;font-weight:500;display:flex}.nav-item:hover{background-color:var(--color-bg-base);color:var(--color-text-main)}.nav-item.active{background-color:var(--color-primary-light);color:var(--color-primary)}.nav-item.active .nav-icon{color:var(--color-primary)}.sidebar-footer{padding:var(--spacing-4);border-top:1px solid var(--color-border)}.user-profile{align-items:center;gap:var(--spacing-3);display:flex}.avatar{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;font-weight:600;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--color-text-main);font-size:.9rem;font-weight:600}.user-role{color:var(--color-text-muted);font-size:.8rem}.header{background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);height:70px;padding:0 var(--spacing-6);box-shadow:var(--shadow-sm);z-index:5;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.search-bar{background-color:var(--color-bg-base);border-radius:var(--radius-md);padding:var(--spacing-2) var(--spacing-4);border:1px solid var(--color-border);width:400px;transition:var(--transition-base);align-items:center;display:flex}.search-bar:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.search-input{width:100%;color:var(--color-text-main);font-size:.95rem;font-family:var(--font-base);background:0 0;border:none;outline:none}.search-input::placeholder{color:var(--color-text-muted)}.header-actions{align-items:center;gap:var(--spacing-4);display:flex}.icon-button{border:1px solid var(--color-border);border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-muted);cursor:pointer;transition:var(--transition-base);background:0 0;justify-content:center;align-items:center;display:flex;position:relative}.icon-button:hover{background-color:var(--color-bg-base);color:var(--color-text-main)}.notification-btn .badge{color:#fff;border:2px solid var(--color-bg-surface);background-color:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.dashboard{gap:var(--spacing-6);flex-direction:column;display:flex}.dashboard-header{justify-content:space-between;align-items:flex-end;display:flex}.dashboard-header h2{margin-bottom:var(--spacing-1);font-size:1.75rem}.subtitle{color:var(--color-text-muted);font-size:.95rem}.btn-primary{background-color:var(--color-primary);color:#fff;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-sm);transition:var(--transition-base);border:none;font-weight:500}.btn-primary:hover{background-color:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.stats-grid{gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.stat-card{background-color:var(--color-bg-surface);padding:var(--spacing-4);border-radius:var(--radius-lg);align-items:center;gap:var(--spacing-4);box-shadow:var(--shadow-sm);transition:var(--transition-base);display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon-wrapper{border-radius:var(--radius-md);justify-content:center;align-items:center;width:54px;height:54px;display:flex}.stat-info{flex-direction:column;display:flex}.stat-value{color:var(--color-text-main);font-size:1.5rem;font-weight:700;line-height:1.2}.stat-label{color:var(--color-text-muted);font-size:.85rem;font-weight:500}.dashboard-content{gap:var(--spacing-6);margin-top:var(--spacing-2);grid-template-columns:1fr 1fr;display:grid}.card{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-6);box-shadow:var(--shadow-sm);min-height:300px}.card h3{margin-bottom:var(--spacing-4);font-size:1.1rem}.empty-state{height:200px;color:var(--color-text-muted);justify-content:center;align-items:center;gap:var(--spacing-3);text-align:center;flex-direction:column;display:flex}.empty-state p{font-size:.95rem}.data-table-container{background:var(--color-bg-surface);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow-x:auto}.data-table-loading{padding:var(--spacing-8);text-align:center;color:var(--color-text-muted);background:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.data-table-empty{padding:var(--spacing-12);text-align:center;color:var(--color-text-muted);background:0 0}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th{background-color:var(--color-bg-base);padding:var(--spacing-3) var(--spacing-4);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border);z-index:1;font-size:.85rem;font-weight:600;position:sticky;top:0}.data-table td{padding:var(--spacing-4);border-bottom:1px solid var(--color-border);color:var(--color-text-main);font-size:.95rem}.data-table tbody tr{transition:var(--transition-base)}.data-table tbody tr.clickable-row{cursor:pointer}.data-table tbody tr.clickable-row:hover{background-color:var(--color-bg-base)}.data-table tbody tr:last-child td{border-bottom:none}.modal-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background-color:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.modal-content{background-color:var(--color-bg-surface);border-radius:var(--radius-lg);width:100%;max-width:450px;box-shadow:var(--shadow-lg);flex-direction:column;display:flex}.modal-header{padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-header h3{margin:0;font-size:1.2rem}.btn-close{cursor:pointer;color:var(--color-text-muted);transition:var(--transition-base);background:0 0;border:none;font-size:1.5rem}.btn-close:hover{color:var(--color-text-main)}.modal-body{padding:var(--spacing-6);gap:var(--spacing-4);flex-direction:column;display:flex}.modal-desc{color:var(--color-text-main);font-size:.95rem}.form-group{gap:var(--spacing-2);flex-direction:column;display:flex}.form-group label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.select-full{width:100%;padding:var(--spacing-3);border-radius:var(--radius-md);border:1px solid var(--color-border);font-family:var(--font-base);background-color:var(--color-bg-base);transition:var(--transition-base);outline:none;font-size:.95rem}.select-full:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.error-message{color:#ef4444;padding:var(--spacing-2);border-radius:var(--radius-md);background-color:#fef2f2;border:1px solid #fecaca;font-size:.85rem}.modal-actions{justify-content:flex-end;gap:var(--spacing-3);margin-top:var(--spacing-4);display:flex}.btn-secondary{background-color:var(--color-bg-base);color:var(--color-text-main);border:1px solid var(--color-border);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-base);font-weight:500}.companies-view{gap:var(--spacing-6);flex-direction:column;height:100%;display:flex}.view-header{justify-content:space-between;align-items:flex-end;display:flex}.view-header h2{margin-bottom:var(--spacing-1);font-size:1.75rem}.header-actions{gap:var(--spacing-4);align-items:center;display:flex}.filter-group{align-items:center;gap:var(--spacing-2);background-color:var(--color-bg-surface);border:1px solid var(--color-border);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);display:flex}.select-input{font-family:var(--font-base);color:var(--color-text-main);cursor:pointer;background:0 0;border:none;outline:none;font-size:.95rem}.table-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}.btn-text{font-family:var(--font-base);cursor:pointer;align-items:center;gap:var(--spacing-1);transition:var(--transition-base);background:0 0;border:none;font-size:.9rem;font-weight:500;display:flex}.btn-add{color:var(--color-primary)}.btn-add:hover{color:var(--color-primary-hover);transform:scale(1.05)}.search-view{flex-direction:column;gap:32px;height:100%;padding:32px;display:flex}.search-header-area{text-align:center;background:#fff;border-radius:16px;flex-direction:column;align-items:center;padding:40px;display:flex;box-shadow:0 4px 20px #0000000d}.search-header-area h1{color:var(--text-color);margin:0;font-size:32px;font-weight:700}.search-subtitle{color:#64748b;margin:12px 0 24px;font-size:16px}.search-bar-container{align-items:center;width:100%;max-width:600px;display:flex;position:relative}.search-icon{color:#94a3b8;font-size:20px;position:absolute;left:20px}.global-search-input{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;outline:none;width:100%;padding:18px 20px 18px 56px;font-size:18px;transition:all .2s}.global-search-input:focus{border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 4px #3b82f61a}.search-spinner{border:3px solid #3b82f64d;border-top-color:var(--primary-color);border-radius:50%;width:20px;height:20px;animation:1s ease-in-out infinite spin;position:absolute;right:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-results-area{background:#fff;border-radius:16px;flex-direction:column;flex:1;display:flex;overflow:hidden;box-shadow:0 4px 20px #0000000d}.no-results{text-align:center;color:#64748b;padding:40px;font-size:18px}.error-message{color:#ef4444;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin:20px;padding:20px}.profile-modal{width:100%;max-width:700px}.modal-header-title{color:var(--color-primary);align-items:center;gap:.5rem;display:flex}.profile-details-grid{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=640px){.profile-details-grid{grid-template-columns:1fr 1fr}.profile-section:first-child{grid-column:1/-1}}.profile-section{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem}.profile-section h3{color:var(--color-text);border-bottom:1px solid var(--color-border);margin-top:0;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.1rem}.detail-item{margin-bottom:.75rem;font-size:.95rem;display:flex}.detail-item:last-child{margin-bottom:0}.detail-label{width:120px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;font-size:.85rem;display:inline-block}.detail-value{color:var(--color-text)}.detail-icon{color:var(--color-primary);margin-top:.1rem;margin-right:.75rem}.font-bold{font-size:1.1rem;font-weight:600}.w-auto{width:auto}.mr-2{margin-right:.5rem}.link{color:var(--color-primary);text-decoration:none}.link:hover{text-decoration:underline}.individual-search-view{flex-direction:column;gap:1.5rem;display:flex}.search-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:0 4px 6px -1px #0000000d}.search-form{flex-wrap:wrap;align-items:flex-end;gap:1rem;display:flex}.table-select-group{min-width:250px}.search-input-group{flex:1;min-width:300px}.select-wrapper,.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--color-text-muted);position:absolute;left:.75rem}.table-select,.search-input{border:1px solid var(--color-border);background-color:var(--color-background);width:100%;color:var(--color-text);border-radius:var(--radius-md);padding:.625rem 1rem .625rem 2.5rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.table-select:focus,.search-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.search-btn{height:42px;padding:.625rem 1.5rem}.results-meta{color:var(--color-text-muted);font-size:.9rem}.btn-view-profile{color:var(--color-primary);font-weight:500}.btn-view-profile:hover{background-color:#2563eb0d;text-decoration:underline}.mt-6{margin-top:1.5rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.wizard-modal{width:100%;max-width:650px}.step-container{flex-direction:column;min-height:350px;display:flex}.wizard-step{flex-direction:column;flex:1;display:flex}.wizard-step h3{color:var(--color-text);margin-top:0;margin-bottom:.5rem;font-size:1.25rem}.wizard-step .subtitle{color:var(--color-text-muted);margin-bottom:2rem}.form-group{flex-direction:column;margin-bottom:1.5rem;display:flex}.form-group label{color:var(--color-text);margin-bottom:.5rem;font-size:.875rem;font-weight:500}.file-upload-area{text-align:center;background-color:#ffffff05;border:2px dashed #ffffff1a;border-radius:8px;padding:3rem;transition:all .2s}.file-upload-area:hover{border-color:var(--color-primary);background-color:#5e5ce60d}.wizard-actions{border-top:1px solid #ffffff0d;justify-content:flex-end;gap:1rem;margin-top:auto;padding-top:2rem;display:flex}.processing-step{text-align:center;justify-content:center;align-items:center}.loader-spinner{border:4px solid #ffffff1a;border-left-color:var(--color-primary);border-radius:50%;width:40px;height:40px;margin-bottom:1rem;animation:1s linear infinite spin}.summary-step{text-align:center;align-items:center}.success-icon{color:#30d158;background-color:#30d1581a;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:1rem;font-size:2rem;display:flex}.summary-card{background-color:var(--color-bg-secondary);border:1px solid #ffffff0d;border-radius:8px;width:100%;margin:1rem 0;padding:1.5rem}.summary-item{border-bottom:1px solid #ffffff0d;justify-content:space-between;padding:.75rem 0;display:flex}.summary-item:last-child{border-bottom:none}.summary-item span{color:var(--color-text-muted)}.summary-item strong{color:var(--color-primary);font-size:1.125rem}.campaigns-view{flex-direction:column;gap:1.5rem;display:flex}.campaigns-view .view-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.campaigns-view .view-header h2{color:var(--color-text);margin:0;font-size:1.5rem;font-weight:600}.campaigns-view .view-header .subtitle{color:var(--color-text-muted);margin-top:.25rem;font-size:.925rem}.campaigns-view .header-actions{gap:1rem;display:flex}.campaigns-view .table-wrapper{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);border-radius:12px;overflow:hidden}.status-badge{border-radius:20px;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-badge.completed{color:#2563eb;background-color:#eff6ff}.status-badge.paused{color:#d97706;background-color:#fffbeb}.status-badge.draft{color:#4b5563;background-color:#f3f4f6}.status-badge.ready-for-enrichment{color:#4338ca;background-color:#e0e7ff}.status-badge.in-progress{color:#b45309;background-color:#fef3c7}.status-badge.abandoned{color:#dc2626;background-color:#fef2f2}.manager-campaign-view,.manager-steps{flex-direction:column;gap:1.5rem;display:flex}.manager-step-card{background-color:var(--card-bg,#fff);border:1px solid var(--border-color,#e0e0e0);border-radius:8px;flex-direction:column;gap:1rem;padding:1.5rem;display:flex;box-shadow:0 2px 4px #0000000d}.manager-step-card h3{color:var(--text-color,#333);margin:0;font-size:1.25rem;font-weight:600}.manager-step-card p{color:var(--text-muted,#666);flex-grow:1;margin:0;font-size:.95rem;line-height:1.5}.manager-step-card button{align-self:flex-start}.assigned-users{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.user-badge{color:#1976d2;background-color:#e3f2fd;border-radius:12px;padding:.25rem .75rem;font-size:.85rem;font-weight:500}.stats-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.stat-box{background:var(--bg-color,#f8f9fa);border:1px solid var(--border-color,#e0e0e0);text-align:center;border-radius:6px;padding:1rem}.stat-box h4{text-transform:uppercase;color:var(--text-muted,#666);letter-spacing:.5px;margin:0 0 .5rem;font-size:.8rem}.stat-value{color:var(--primary-color,#007bff);font-size:1.5rem;font-weight:700}.btn-success{background-color:var(--success-color,#28a745);color:#fff;cursor:pointer;border:none;border-radius:4px;padding:.5rem 1rem;font-weight:500;transition:all .2s}.btn-success:hover{background-color:#218838}.btn-success:disabled{cursor:not-allowed;opacity:.65;background-color:#6c757d}.agent-enrichment-view{flex-direction:column;gap:1rem;height:calc(100vh - 120px);display:flex}.enrichment-header{background-color:var(--card-bg,#fff);border-radius:8px;align-items:center;gap:1.5rem;padding:1rem 1.5rem;display:flex;box-shadow:0 1px 3px #0000000d}.step-indicator{gap:.5rem;margin-left:auto;display:flex}.step-indicator span{color:#666;background-color:#e0e0e0;border-radius:16px;padding:.4rem 1rem;font-size:.85rem;font-weight:500;transition:all .3s}.step-indicator span.active{background-color:var(--primary-color,#007bff);color:#fff}.enrichment-workspace{flex:1;gap:1.5rem;display:flex;overflow:hidden}.left-pane{flex-direction:column;flex:0 0 70%;display:flex;overflow:hidden}.right-pane{flex:0 0 calc(30% - 1.5rem);overflow-y:auto}.step-container{flex-direction:column;height:100%;display:flex}.step-title{margin:0 0 1rem;padding:1.5rem 1.5rem 0;font-size:1.2rem}.iframe-wrapper{flex:1;padding:0 1.5rem 1.5rem;position:relative}.iframe-wrapper iframe{border:1px solid var(--border-color,#e0e0e0);background-color:#f8f9fa;border-radius:8px;width:100%;height:100%}.no-website{background:var(--bg-color,#f8f9fa);width:100%;height:100%;color:var(--text-muted,#666);border:1px dashed var(--border-color,#ccc);border-radius:8px;justify-content:center;align-items:center;display:flex}.validation-actions{border-top:1px solid var(--border-color,#e0e0e0);background-color:var(--bg-color,#fafafa);border-radius:0 0 8px 8px;flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.validation-row{border:1px solid var(--border-color,#eee);background:#fff;border-radius:6px;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.validation-row span{color:var(--text-color,#333);font-weight:500}.btn-group{gap:.5rem;display:flex}.btn-validate{cursor:pointer;background-color:var(--border-color,#e0e0e0);color:var(--text-color,#333);border:1px solid #0000;border-radius:4px;padding:.4rem 1rem;font-size:.85rem;font-weight:500;transition:all .2s}.btn-validate.validate.selected{background-color:var(--success-color,#28a745);color:#fff}.btn-validate.validate:hover:not(.selected){color:#155724;background-color:#d4edda}.btn-validate.invalidate.selected{background-color:var(--danger-color,#dc3545);color:#fff}.btn-validate.invalidate:hover:not(.selected){color:#721c24;background-color:#f8d7da}.step-flow-action{justify-content:flex-end;margin-top:1rem;display:flex}.step-flow-action button{padding:.75rem 2rem;font-size:1.1rem}.single-action-row{align-items:center;gap:1.5rem}.single-action-row h3{margin:0}.btn-group-large{gap:1rem;width:100%;display:flex}.btn-validate-large,.btn-invalidate-large{cursor:pointer;color:#fff;border:none;border-radius:8px;flex:1;padding:1rem;font-size:1.2rem;font-weight:700;transition:transform .1s}.btn-validate-large{background-color:var(--success-color,#28a745)}.btn-invalidate-large{background-color:var(--danger-color,#dc3545)}.btn-validate-large:hover,.btn-invalidate-large:hover{filter:brightness(.9)}.btn-validate-large:active,.btn-invalidate-large:active{transform:scale(.98)}.data-editor{padding:1.5rem}.data-editor h3{margin:0 0 .5rem}.help-text{color:var(--text-muted,#666);margin-top:0;margin-bottom:1.5rem;font-size:.8rem}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-color,#333);margin-bottom:.25rem;font-size:.85rem;font-weight:500;display:block}.form-group input{border:1px solid var(--border-color,#ccc);border-radius:4px;width:100%;padding:.6rem;font-family:inherit}.form-group input:focus{border-color:var(--primary-color,#007bff);outline:none;box-shadow:0 0 0 3px #007bff1a}.form-group.half{width:calc(50% - .5rem);display:inline-block}.form-group.half:nth-child(2n){margin-left:1rem}.divider{border:none;border-top:1px solid var(--border-color,#eee);margin:2rem 0 1.5rem}.contact-editor-card{border:1px solid var(--border-color,#eee);background:#fff;border-radius:6px;margin-bottom:1rem;padding:1rem;transition:border-color .3s,box-shadow .3s}.highlight-contact{border-color:var(--primary-color,#007bff);box-shadow:0 0 0 2px #007bff33}.contact-progress-bar{background-color:var(--border-color,#e0e0e0);border-radius:12px;justify-content:center;align-items:center;height:24px;margin:0 1.5rem 1rem;display:flex;position:relative;overflow:hidden}.contact-progress-bar .progress-fill{background-color:var(--primary-color,#007bff);z-index:1;height:100%;transition:width .3s;position:absolute;top:0;left:0}.contact-progress-bar span{z-index:2;color:#fff;text-shadow:0 1px 2px #0000004d;font-size:.85rem;font-weight:600;position:relative}.no-leads{justify-content:center;align-items:center}.react-flow{--xy-edge-stroke-default:#b1b1b7;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#555;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#ffffff80;--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:#f0f0f099;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#e2e2e2;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:transparent;--xy-background-pattern-dots-color-default:#91919a;--xy-background-pattern-lines-color-default:#eee;--xy-background-pattern-cross-color-default:#e2e2e2;background-color:var(--xy-background-color,var(--xy-background-color-default));--xy-node-color-default:inherit;--xy-node-border-default:1px solid #1a192b;--xy-node-background-color-default:#fff;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #00000014;--xy-node-boxshadow-selected-default:0 0 0 .5px #1a192b;--xy-node-border-radius-default:3px;--xy-handle-background-color-default:#1a192b;--xy-handle-border-color-default:#fff;--xy-selection-background-color-default:#0059dc14;--xy-selection-border-default:1px dotted #0059dccc;--xy-controls-button-background-color-default:#fefefe;--xy-controls-button-background-color-hover-default:#f4f4f4;--xy-controls-button-color-default:inherit;--xy-controls-button-color-hover-default:inherit;--xy-controls-button-border-color-default:#eee;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#fff;--xy-edge-label-color-default:inherit;--xy-resize-background-color-default:#3367d9;direction:ltr}.react-flow.dark{--xy-edge-stroke-default:#3e3e3e;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#727272;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#96969640;--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:#3c3c3c99;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#2b2b2b;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:#141414;--xy-background-pattern-dots-color-default:#777;--xy-background-pattern-lines-color-default:#777;--xy-background-pattern-cross-color-default:#777;--xy-node-color-default:#f8f8f8;--xy-node-border-default:1px solid #3c3c3c;--xy-node-background-color-default:#1e1e1e;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #ffffff14;--xy-node-boxshadow-selected-default:0 0 0 .5px #999;--xy-handle-background-color-default:#bebebe;--xy-handle-border-color-default:#1e1e1e;--xy-selection-background-color-default:#c8c8dc14;--xy-selection-border-default:1px dotted #c8c8dccc;--xy-controls-button-background-color-default:#2b2b2b;--xy-controls-button-background-color-hover-default:#3e3e3e;--xy-controls-button-color-default:#f8f8f8;--xy-controls-button-color-hover-default:#fff;--xy-controls-button-border-color-default:#5b5b5b;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#141414;--xy-edge-label-color-default:#f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props,var(--xy-background-color,var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width,var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke,var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width,var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{pointer-events:none;position:absolute;overflow:visible}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected,var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}svg.react-flow__connectionline{z-index:1001;position:absolute;overflow:visible}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default;position:absolute}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background-color:var(--xy-handle-background-color,var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color,var(--xy-handle-border-color-default));border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:0;left:50%;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px)translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px)translateY(-50%)}.react-flow__attribution{background:var(--xy-attribution-background-color,var(--xy-attribution-background-color-default));margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__viewport-portal{-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__minimap{background:var(--xy-minimap-background-color-props,var(--xy-minimap-background-color,var(--xy-minimap-background-color-default)))}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var(--xy-minimap-mask-background-color-props,var(--xy-minimap-mask-background-color,var(--xy-minimap-mask-background-color-default)));stroke:var(--xy-minimap-mask-stroke-color-props,var(--xy-minimap-mask-stroke-color,var(--xy-minimap-mask-stroke-color-default)));stroke-width:var(--xy-minimap-mask-stroke-width-props,var(--xy-minimap-mask-stroke-width,var(--xy-minimap-mask-stroke-width-default)))}.react-flow__minimap-node{fill:var(--xy-minimap-node-background-color-props,var(--xy-minimap-node-background-color,var(--xy-minimap-node-background-color-default)));stroke:var(--xy-minimap-node-stroke-color-props,var(--xy-minimap-node-stroke-color,var(--xy-minimap-node-stroke-color-default)));stroke-width:var(--xy-minimap-node-stroke-width-props,var(--xy-minimap-node-stroke-width,var(--xy-minimap-node-stroke-width-default)))}.react-flow__background-pattern.dots{fill:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-dots-color-default)))}.react-flow__background-pattern.lines{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-lines-color-default)))}.react-flow__background-pattern.cross{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-cross-color-default)))}.react-flow__controls{box-shadow:var(--xy-controls-box-shadow,var(--xy-controls-box-shadow-default));flex-direction:column;display:flex}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{background:var(--xy-controls-button-background-color,var(--xy-controls-button-background-color-default));border:none;border-bottom:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)));width:26px;height:26px;color:var(--xy-controls-button-color-props,var(--xy-controls-button-color,var(--xy-controls-button-color-default)));cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:4px;display:flex}.react-flow__controls-button svg{fill:currentColor;width:100%;max-width:12px;max-height:12px}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{border-radius:var(--xy-node-border-radius,var(--xy-node-border-radius-default));width:150px;color:var(--xy-node-color,var(--xy-node-color-default));text-align:center;border:var(--xy-node-border,var(--xy-node-border-default));background-color:var(--xy-node-background-color,var(--xy-node-background-color-default));padding:10px;font-size:12px}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover,var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected,var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color,var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color,var(--xy-selection-background-color-default));border:var(--xy-selection-border,var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var(--xy-controls-button-background-color-hover-props,var(--xy-controls-button-background-color-hover,var(--xy-controls-button-background-color-hover-default)));color:var(--xy-controls-button-color-hover-props,var(--xy-controls-button-color-hover,var(--xy-controls-button-color-hover-default)))}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)))}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border:1px solid #fff;border-radius:1px;width:5px;height:5px;translate:-50% -50%}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border-style:solid;border-width:0}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color,var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color,var(--xy-edge-label-color-default))}.db-browser-container{background-color:var(--color-background);border-radius:12px;flex-direction:column;height:100%;display:flex;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a}.db-header{border-bottom:1px solid var(--color-border);background-color:var(--color-surface);z-index:20;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.db-title-area{align-items:center;gap:.75rem;display:flex}.back-btn{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;padding:.5rem;transition:all .2s;display:flex}.back-btn:hover{background-color:var(--color-background);color:var(--color-text-primary)}.db-icon{color:var(--color-primary)}.db-title-area h2{color:var(--color-text-primary);font-size:1.25rem;font-weight:600}.db-content-area{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.schema-visualizer-wrapper{width:100%;height:100%;display:flex;position:relative;overflow:hidden}.react-flow-wrapper{flex:1;width:100%;height:100%;transition:width .3s}.react-flow-wrapper.panel-open{width:calc(100% - 350px)}.custom-table-node{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;min-width:200px;box-shadow:0 4px 6px -1px #0000001a}.node-header{background:var(--color-primary);color:#fff;border-top-left-radius:7px;border-top-right-radius:7px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;display:flex}.node-body{padding:.5rem;font-size:.8rem}.node-column{border-bottom:1px solid var(--color-background);color:var(--color-text-secondary);justify-content:space-between;align-items:center;padding:.25rem .5rem;display:flex}.node-column:last-child{border-bottom:none}.pk-icon{color:#fbbf24;margin-left:.5rem}.fk-text{color:#3b82f6;background-color:#3b82f61a;border-radius:4px;margin-left:.5rem;padding:2px 4px;font-size:.65rem}.more-text{justify-content:center;font-size:.75rem;font-style:italic}.schema-side-panel{background-color:var(--color-surface);border-left:1px solid var(--color-border);z-index:10;flex-direction:column;width:350px;height:100%;transition:right .3s;display:flex;position:absolute;top:0;right:-350px;box-shadow:-4px 0 15px #0000000d}.schema-side-panel.open{right:0}.panel-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.panel-body{flex:1;padding:1.5rem;overflow-y:auto}.view-data-btn{justify-content:center;align-items:center;gap:.5rem;width:100%;margin-bottom:2rem;padding:.75rem;font-size:1rem;display:flex}.columns-list h4{text-transform:uppercase;color:var(--color-text-secondary);letter-spacing:.05em;margin-bottom:1rem;font-size:.9rem}.column-info-item{border:1px solid var(--color-border);background-color:var(--color-background);border-radius:8px;margin-bottom:.75rem;padding:.75rem}.col-top-line{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.col-name{color:var(--color-text-primary);word-break:break-all;font-weight:500}.badge{border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:600}.badge-pk{color:#b45309;background-color:#fbbf2433}.badge-fk{color:#1d4ed8;background-color:#3b82f633}.col-details{color:var(--color-text-secondary);flex-direction:column;gap:.25rem;font-size:.8rem;display:flex}.col-type{font-family:monospace}.col-identity{color:#10b981}.fk-ref{color:var(--color-primary);border-top:1px dashed var(--color-border);margin-top:.25rem;padding-top:.25rem;font-style:italic}.db-controls{align-items:center;gap:1rem;display:flex}.search-bar{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:8px;align-items:center;width:250px;padding:.5rem .75rem;display:flex}.search-icon{color:var(--color-text-secondary);margin-right:.5rem}.search-bar input{width:100%;color:var(--color-text-primary);background:0 0;border:none;outline:none}.db-table-container{flex-direction:column;flex:1;height:100%;display:flex;position:relative;overflow:hidden}.table-responsive{height:100%;overflow:auto}.loading-state,.empty-state{height:100%;color:var(--color-text-secondary);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.db-table{border-collapse:collapse;white-space:nowrap;width:100%}.db-table th{background-color:var(--color-background);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:2px solid var(--color-border);z-index:10;padding:1rem;font-size:.85rem;font-weight:500;position:sticky;top:0}.db-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-primary);padding:.75rem 1rem;font-size:.9rem}.db-table tbody tr:hover{background-color:#00000005}.cell-content{text-overflow:ellipsis;max-width:250px;overflow:hidden}.null-val{color:var(--color-text-secondary);background-color:var(--color-background);border-radius:4px;padding:.1rem .4rem;font-size:.85rem;font-style:italic}.db-table .sticky-col{background-color:var(--color-surface);z-index:11;border-right:2px solid var(--color-border);position:sticky;left:0;box-shadow:2px 0 4px #00000005}.db-table th.sticky-col{z-index:12;background-color:var(--color-background)}.actions-cell{align-items:center;gap:.5rem;display:flex}.action-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.4rem;transition:all .2s;display:flex}.edit-btn{color:var(--color-primary);background-color:#3b82f61a}.edit-btn:hover{background-color:#3b82f633}.delete-btn{color:#ef4444;background-color:#ef44441a}.delete-btn:hover{background-color:#ef444433}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.edit-modal{background-color:var(--color-surface);border-radius:12px;flex-direction:column;width:90%;max-width:800px;max-height:90vh;display:flex;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.close-btn{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:.5rem}.close-btn:hover{background-color:var(--color-background)}.modal-body{padding:1.5rem;overflow-y:auto}.form-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--color-text-secondary);font-size:.85rem;font-weight:500}.form-control{border:1px solid var(--color-border);background-color:var(--color-background);color:var(--color-text-primary);border-radius:6px;padding:.75rem;font-family:inherit;transition:border-color .2s}.form-control:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #3b82f61a}.form-control:disabled{opacity:.7;cursor:not-allowed;background-color:#0000000d}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:1rem;padding:1.5rem;display:flex}.btn-primary,.btn-secondary{cursor:pointer;border-radius:8px;padding:.75rem 1.5rem;font-weight:500;transition:all .2s}.btn-secondary{background-color:var(--color-background);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-border)}.btn-primary{background-color:var(--color-primary);color:#fff;border:none}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.settings-view{flex-direction:column;height:100%;display:flex}.settings-header{margin-bottom:24px}.settings-layout{flex:1;gap:24px;display:flex}.settings-sidebar{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;width:250px;padding:16px}.settings-nav{flex-direction:column;gap:8px;display:flex}.settings-nav-item{text-align:left;cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:6px;padding:12px 16px;font-size:.95rem;font-weight:500;transition:all .2s}.settings-nav-item:hover{background-color:var(--color-surface-hover);color:var(--color-text)}.settings-nav-item.active{background-color:var(--color-primary-light);color:var(--color-primary)}.settings-content{background-color:#0000;border-radius:8px;flex:1;min-width:0}.settings-content .clients-view,.settings-content .users-roles-view{height:100%;animation:none}.users-roles-view{flex-direction:column;gap:24px;display:flex}.rbac-grid{grid-template-columns:1fr;align-items:flex-start;gap:24px;transition:all .3s;display:grid}@media (width>=1024px){.rbac-grid:has(.roles-panel){grid-template-columns:2fr 1fr}}.panel-card{border-radius:16px;padding:24px}.panel-header{border-bottom:1px solid var(--border-color);align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;display:flex}.panel-header svg{color:var(--color-primary)}.panel-header h3{color:var(--text-color);margin:0;font-size:1.25rem;font-weight:600}.user-identity{align-items:center;gap:16px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--color-primary) 0%, #a855f7 100%);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;font-weight:700;display:flex;box-shadow:0 4px 12px #6366f14d}.user-details{flex-direction:column;gap:4px;display:flex}.user-name{color:var(--text-color);font-weight:600}.user-email,.user-meta{color:var(--text-color-light);align-items:center;gap:6px;font-size:.85rem;display:flex}.roles-container{flex-wrap:wrap;gap:8px;display:flex}.role-pill{letter-spacing:.5px;text-transform:uppercase;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:600}.role-pill-admin{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.role-pill-manager{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b33}.role-pill-agent{color:#10b981;background:#10b9811a;border:1px solid #10b98133}.role-pill-default{color:#6366f1;background:#6366f11a;border:1px solid #6366f133}.no-roles{color:#ef4444;font-size:.85rem;font-style:italic}.role-toggles{flex-direction:column;gap:16px;display:flex}.role-toggle-card{background:var(--bg-surface-hover);border:1px solid var(--border-color);cursor:pointer;border-radius:12px;padding:16px;transition:all .2s}.role-toggle-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.role-toggle-card.active{background:#6366f10d;border-color:#6366f180}.role-toggle-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.role-title{align-items:center;gap:8px;display:flex}.role-title h4{color:var(--text-color);margin:0;font-weight:600}.status-dot{background:#cbd5e1;border-radius:50%;width:8px;height:8px;transition:background-color .3s}.status-dot.active{background:#10b981;box-shadow:0 0 8px #10b98199}.role-description{color:var(--text-color-light);margin:0;font-size:.85rem;line-height:1.4}.toggle-switch{background:#cbd5e1;border-radius:24px;width:44px;height:24px;transition:background-color .3s;position:relative}body.dark-mode .toggle-switch{background:#334155}.toggle-switch.on{background:var(--color-primary)}.toggle-thumb{background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .3s cubic-bezier(.4,0,.2,1);position:absolute;top:2px;left:2px;box-shadow:0 2px 4px #0003}.toggle-switch.on .toggle-thumb{transform:translate(20px)}.error-banner{color:#ef4444;background:#ef44441a;border-left:4px solid #ef4444;border-radius:8px;align-items:center;gap:12px;padding:16px;display:flex}.animate-slide-in{animation:.4s cubic-bezier(.16,1,.3,1) slideInRight}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.clients-view{flex-direction:column;gap:24px;display:flex}.clients-header{justify-content:space-between;align-items:flex-end;margin-bottom:8px;display:flex}.clients-header h2{background:linear-gradient(90deg, var(--text-main) 0%, var(--text-muted) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 4px;font-size:1.75rem;font-weight:700}.clients-header p{color:var(--text-muted);margin:0;font-size:.95rem}.status-badge{letter-spacing:.02em;text-transform:uppercase;border-radius:20px;align-items:center;padding:4px 10px;font-size:.8rem;font-weight:600;display:inline-flex}.status-badge.active{color:#10b981;background-color:#10b98126}.status-badge.inactive{color:#ef4444;background-color:#ef444426}.action-buttons{gap:8px;display:flex}.btn-icon{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-icon:hover{color:var(--text-main);background:#ffffff1a;transform:translateY(-2px)}.btn-icon.danger:hover{color:#ef4444;background:#ef444426}.client-modal{width:100%;max-width:480px}.checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;display:flex}.checkbox-label input{width:18px;height:18px;accent-color:var(--primary-color);cursor:pointer}.checkbox-label span{color:var(--text-main);font-size:.95rem}.ml-2{margin-left:8px}.mt-4{margin-top:16px}.login-container{background-color:var(--color-bg);background-image:radial-gradient(circle at 10% 20%,#38bdf80d 0%,#0000 40%),radial-gradient(circle at 90% 80%,#6366f10d 0%,#0000 40%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{flex-direction:column;align-items:center;width:100%;max-width:420px;padding:3rem 2rem;display:flex}.login-header{text-align:center;flex-direction:column;align-items:center;margin-bottom:2rem;display:flex}.login-header h1{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-top:1rem;margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.login-header p{color:var(--color-text-dim);font-size:.95rem}.login-form{flex-direction:column;gap:1.5rem;width:100%;display:flex}.login-form select{cursor:pointer}
