:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:#1a202c;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{font-size:16px;line-height:1.6}body{overflow-y:scroll;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#1a202c;font-size:1rem;min-width:1024px}a{color:#667eea;text-decoration:none;transition:color .2s ease}a:hover{color:#5a6fd8;text-decoration:underline}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:6px}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:6px;border:2px solid #f1f5f9}::-webkit-scrollbar-thumb:hover{background:#a0aec0}h1{font-size:2.25rem;font-weight:700;line-height:1.2;letter-spacing:-.025em}h2{font-size:1.875rem;font-weight:600;line-height:1.3;letter-spacing:-.025em}h3{font-size:1.5rem;font-weight:600;line-height:1.4}h4{font-size:1.25rem;font-weight:600;line-height:1.4}h5{font-size:1.125rem;font-weight:600;line-height:1.4}h6{font-size:1rem;font-weight:600;line-height:1.4}p{font-size:1rem;line-height:1.6;margin-bottom:1rem}button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:6px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s ease;text-decoration:none;letter-spacing:.025em;font-family:inherit;background-color:#667eea;color:#fff}.container{max-width:1400px;margin:0 auto;padding:0 2rem}.gap-8{gap:2rem}.logo-wrapper{display:flex;align-items:center;position:relative;gap:.5rem}.logo-image{display:block;object-fit:contain}.logo-fallback{font-weight:600;color:#333}.logo-text{font-weight:800;color:#333;white-space:nowrap}.logo-container.login{background-color:#fff;padding:.5rem 1rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.logo-container.dashboard{background-color:transparent;padding:0;border-radius:0}.logo-container.dashboard .logo-text{color:#1e293b}@media (max-width: 480px){.logo-container{gap:.375rem}.logo-container.login{padding:.375rem .75rem}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:40px}.login-card{background:#fff;padding:3rem 2.5rem;border-radius:12px;box-shadow:0 20px 40px #0000001a;width:100%;max-width:420px;min-width:380px;border:1px solid rgba(255,255,255,.2)}.login-header{text-align:center;margin-bottom:2.5rem}.login-title{display:flex;justify-content:center;margin-bottom:.75rem}.login-header h2{color:#333;margin-bottom:.75rem;font-size:2rem;font-weight:600;letter-spacing:-.025em}.login-header p{color:#666;margin:0;font-size:1.1rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{margin-bottom:.75rem;font-weight:600;color:#333;font-size:1rem;letter-spacing:.025em}.form-group input{padding:1rem 1.25rem;border:1px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:all .2s ease;background-color:#fafbfc;min-height:20px}.form-group input:focus{outline:none;border-color:#667eea;background-color:#fff;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f1f3f4;cursor:not-allowed;opacity:.7}.form-group input::placeholder{color:#9ca3af}.login-button{padding:1rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:1rem;letter-spacing:.025em;min-height:50px;text-align:center;display:flex;align-items:center;justify-content:center;position:relative;width:100%}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.error-message{background-color:#fef2f2;color:#dc2626;padding:1rem 1.25rem;border-radius:8px;border:1px solid #fecaca;margin-bottom:1rem;font-weight:500;border-left:4px solid #dc2626}.login-button:disabled:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite;display:none}@media (min-width: 1024px){.login-container{padding:40px}.login-card{max-width:480px;min-width:440px;padding:3.5rem 3rem}.login-header h2{font-size:2.25rem}.form-group input{padding:1.25rem 1.5rem;font-size:1.1rem}.login-button{padding:1.25rem 2rem;font-size:1.2rem}}@media (min-width: 1440px){.login-card{max-width:520px;min-width:480px;padding:4rem 3.5rem}}@media (max-width: 768px){.login-container{padding:20px}.login-card{padding:2rem;min-width:320px}}.settings-container{max-width:1200px;margin:0 auto}.settings-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.settings-header h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#1f2937}.settings-header p{margin:0;color:#6b7280;font-size:.95rem;line-height:1.5}.settings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.settings-loading .loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.settings-loading p{color:#6b7280;font-size:1rem;margin:0}.settings-message{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;border-radius:8px}.settings-message.error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.settings-message.success{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.settings-form{padding:0;background:transparent;box-shadow:none}.settings-card{padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;margin-bottom:1.5rem}.settings-card:last-child{margin-bottom:0}.company-stats-container{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding:15px;background:#fff;border-radius:8px;border:1px solid #e9ecef}.recalculate-btn{padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;white-space:nowrap}.recalculate-btn:hover:not(.disabled){background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea66}.recalculate-btn.disabled{background:#d1d5db;cursor:not-allowed;opacity:.6}.company-stats-text{font-size:14px;color:#374151;transition:opacity .3s}.company-stats-text.stale{opacity:.5;color:#6b7280}.info-tooltip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-left:8px;border-radius:50%;background:#e5e7eb;color:#6b7280;font-size:12px;font-weight:600;cursor:help;transition:background .2s}.info-tooltip:hover{background:#d1d5db}.tooltip-text{visibility:hidden;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);width:280px;padding:12px;background:#1f2937;color:#fff;font-size:13px;font-weight:400;line-height:1.4;border-radius:6px;box-shadow:0 4px 6px #0000001a;z-index:1000;opacity:0;transition:opacity .3s,visibility .3s}.tooltip-list{margin:0;padding:0 0 0 18px;list-style-type:disc}.tooltip-list li{margin-bottom:6px;margin-top:5px;color:#fff;text-align:left}.tooltip-list li:last-child{margin-bottom:0}.tooltip-list strong{font-weight:600}.tooltip-text:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1f2937}.info-tooltip:hover .tooltip-text{visibility:visible;opacity:1}.settings-section{margin-bottom:2.5rem}.settings-section:last-child{margin-bottom:0}.settings-section h3{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:#1f2937}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.form-row:last-child{margin-bottom:0}.settings-actions{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid #e5e7eb;margin-top:2rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s;text-decoration:none;min-height:44px}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea66}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.btn-global{background:#d1d5db;color:#111827;border:2px solid transparent}.btn-global:hover:not(:disabled){background:#9ca3af;color:#111827}.loading-spinner.inline{display:inline-block;width:14px;height:14px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;vertical-align:middle;margin-right:8px}.settings-help{background:#f8fafc;padding:2rem;border-top:1px solid #e5e7eb}.settings-help h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#1f2937}.settings-help ul{margin:0 0 1.5rem;padding-left:1.5rem;list-style-type:disc}.settings-help li{margin-bottom:.5rem;color:#374151;font-size:.9rem;line-height:1.5}.settings-help li strong{color:#1f2937}.help-note{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:1rem;margin:0;font-size:.9rem;line-height:1.5;color:#1e40af}.help-note strong{color:#1e3a8a}@media (max-width: 768px){.company-stats-container{flex-direction:column;align-items:stretch;gap:12px}.recalculate-btn{width:100%}.company-stats-text{text-align:center}.settings-card{padding:1.5rem}.settings-container{margin:0;border-radius:0}.settings-header{padding:1.5rem 1rem 1rem}.settings-header h2{font-size:1.25rem}.settings-form{padding:1.5rem 1rem}.form-row{grid-template-columns:1fr;gap:1rem}.settings-actions{flex-direction:column-reverse;gap:1rem;align-items:stretch}.btn{width:100%;justify-content:center}.settings-help{padding:1.5rem 1rem}}.keyword-filter{position:relative;width:100%}.keyword-filter .form-label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:#374151}.keyword-input-wrapper{position:relative}.keyword-input{display:block;width:100%;padding:.75rem 1rem!important;background:#fff!important;border:1px solid #d1d5db!important;border-radius:6px;font-size:.85rem!important;color:#6b7280;transition:all .15s ease;text-align:left}.keyword-input:hover{border-color:#9ca3af}.keyword-input:focus{outline:none;border-color:#3b82f6!important;color:#1f2937}.keyword-input.error{border-color:#ef4444}.keyword-input::placeholder{color:#6b7280}.keyword-add-icon{position:absolute;top:50%;right:1rem;transform:translateY(-50%);font-size:.875rem;color:#9ca3af;background:none;border:none;padding:0;cursor:pointer;transition:color .15s ease}.keyword-add-icon:hover{color:#6b7280}.dropdown-with-tags{position:relative;width:100%}.dropdown-with-tags .form-label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:#374151}.dropdown-with-tags .required{color:#ef4444;margin-left:.25rem}.selected-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;min-height:1.5rem}.tag{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background-color:#3b82f6;color:#fff;border-radius:6px;font-size:.875rem;font-weight:500;line-height:1}.tag-remove{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;background:#fff3;border:none;border-radius:3px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:background-color .15s ease;line-height:1}.tag-remove:hover{background:#ffffff4d}.dropdown-container{position:relative}.dropdown-button{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;color:#6b7280;cursor:pointer;transition:all .15s ease}.dropdown-button:hover{border-color:#9ca3af}.dropdown-button:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.dropdown-button.error{border-color:#ef4444}.dropdown-arrow{font-size:.75rem;transition:transform .15s ease;color:#9ca3af}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:.25rem;background:#fff;border-radius:6px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;max-height:16rem;overflow:hidden}.dropdown-search{display:flex;align-items:center;padding:0;border-bottom:1px solid #e5e7eb;position:relative}.search-input{flex:1;padding:.75rem 2.5rem .75rem .75rem;border:none;outline:none;font-size:.875rem;color:#1f2937;background:transparent}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.dropdown-close{position:absolute;right:.75rem;background:none;border:none;font-size:1.25rem;color:#6b7280;cursor:pointer;padding:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;line-height:1}.dropdown-close:hover{color:#374151}.dropdown-options{max-height:13.5rem;overflow-y:auto}.dropdown-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem;border:none;background:#fff;text-align:left;font-size:.875rem;color:#374151;cursor:pointer;transition:background-color .15s ease}.dropdown-option:hover:not(:disabled){background:#f3f4f6}.dropdown-option:disabled{color:#9ca3af;cursor:not-allowed;background:#f9fafb}.dropdown-option.selected{background:#eff6ff;color:#1d4ed8}.checkmark{color:#10b981;font-weight:700;font-size:.875rem}.dropdown-no-results{padding:.75rem 1rem;text-align:center;color:#6b7280;font-style:italic;font-size:.9rem}.form-description{margin-top:.5rem;font-size:.875rem;color:#6b7280;line-height:1.4}@media (max-width: 480px){.settings-header,.settings-form,.settings-help{padding:1rem}.btn{padding:.875rem 1rem;font-size:.875rem}.tag{font-size:.8125rem;padding:.25rem .5rem}.tag-remove{width:1rem;height:1rem;font-size:.875rem}}.check-dnc-container{max-width:1200px;margin:0 auto}.check-dnc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.check-dnc-header h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#1f2937}.check-dnc-header p{margin:0;color:#6b7280;font-size:.95rem;line-height:1.5}.check-dnc-message{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;border-radius:8px}.check-dnc-message.error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.check-dnc-form{padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.check-dnc-section{margin-bottom:2.5rem}.check-dnc-section:last-child{margin-bottom:0}.check-dnc-section h3{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:#1f2937}.section-description{margin:0 0 1.5rem;color:#6b7280;font-size:.9rem;line-height:1.5}.domain-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:600;color:#374151}.required{color:#ef4444;margin-left:.25rem}.input-with-button{display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap}.domain-input{flex:1;min-width:300px;max-width:400px;padding:.5rem 1rem!important;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;color:#374151;transition:all .15s ease;font-family:inherit;line-height:1.4}.domain-input:hover{border-color:#9ca3af}.domain-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.domain-input::placeholder{color:#9ca3af}.domain-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.domain-input:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.7}.field-error{margin-top:.5rem;font-size:.875rem;color:#ef4444}.result-notification{padding:.75rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;margin-bottom:.75rem;border:1px solid}.result-notification.customer{background-color:#fef2f2;border-color:#fecaca;color:#dc2626}.result-notification.not-customer{background-color:#f0fdf4;border-color:#bbf7d0;color:#166534}.inline-button{white-space:nowrap;align-self:flex-start}.loading-spinner.small{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.check-dnc-container{margin:0;border-radius:0}.check-dnc-header{padding:1.5rem 1rem 1rem}.check-dnc-header h2{font-size:1.25rem}.check-dnc-form{padding:1.5rem 1rem}.domain-input{min-width:250px;max-width:100%}.input-with-button{flex-direction:column;align-items:stretch}.inline-button{align-self:center;width:auto;min-width:200px;justify-content:center}}@media (max-width: 480px){.check-dnc-header,.check-dnc-form{padding:1rem}.inline-button{padding:.875rem 1rem;font-size:.875rem;min-width:180px}.domain-input{min-width:200px}}.draft-card{display:flex;gap:1rem;padding:1.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;transition:all .2s}.draft-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.draft-card.selected{border-color:#3b82f6;background:#f8faff}.draft-card.disapproved{border-left:4px solid #ef4444}.draft-card.approved{border-left:4px solid #10b981}.draft-select{display:flex;align-items:flex-start;padding-top:.25rem}.draft-checkbox{width:18px;height:18px;cursor:pointer}.draft-content{flex:1;display:flex;flex-direction:column;gap:1.25rem}.draft-info{display:flex;flex-direction:column;gap:1rem}.website-link{color:#3b82f6;text-decoration:none}.website-link:hover{text-decoration:underline}.email-preview{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px}.preview-toggle{display:flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;flex-shrink:0}.preview-toggle:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.preview-toggle:disabled{opacity:.6;cursor:not-allowed}.preview-toggle.save-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-weight:500;transition:all .2s}.preview-toggle.save-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.preview-toggle.save-button:disabled{background:#d1d5db;color:#9ca3af;transform:none;box-shadow:none;opacity:.6;cursor:not-allowed}.draft-controls{display:flex;flex-direction:column;gap:1rem;min-width:200px;padding-left:1rem;border-left:1px solid #e5e7eb}.approval-section{display:flex;flex-direction:column;gap:.75rem}.approval-checkbox{display:flex;align-items:center}.draft-card .checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem;font-weight:500;padding:.5rem .75rem;border-radius:6px;border:1px solid #e6e6e6;background:#fff;width:100%;justify-content:center}.draft-card .checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.draft-card .approval-text{font-weight:600}.draft-card .checkbox-label:has(input:checked){border-color:#10b981}.draft-card .checkbox-label:has(input:not(:checked)){border-color:#ef4444}.draft-card .approval-text.approved{color:#10b981}.draft-card .approval-text.disapproved{color:#ef4444}.draft-meta{display:flex;flex-direction:column;gap:.5rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.meta-value{color:#6b7280}.attempt-badge.attempt-1{background:#fef9e7;color:#7d6608;border-color:#d4af37}.attempt-badge.attempt-2{background:#f5f5f5;color:#555;border-color:#a8a8a8}.attempt-badge.attempt-3{background:#fdf4ed;color:#8b4513;border-color:#cd7f32}@media (max-width: 1024px){.draft-card{flex-direction:column;gap:1rem}.draft-select{order:-1;align-self:flex-start}.draft-controls{border-left:none;border-top:1px solid #e5e7eb;padding-left:0;padding-top:1rem;min-width:unset}.email-header{flex-direction:column;align-items:flex-start;gap:.75rem}.preview-toggle{align-self:flex-start}}@media (max-width: 768px){.draft-card{padding:1rem}.contact-name{font-size:1rem}.contact-meta{font-size:.8rem}.detail-item{flex-direction:column;align-items:flex-start;gap:.25rem}.detail-label{min-width:unset;font-size:.75rem}.detail-value{font-size:.8rem}.email-preview{padding:.75rem}.approval-section{flex-direction:row;align-items:center;justify-content:space-between;gap:1rem}}.email-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.email-actions{display:flex;gap:.5rem;align-items:center}.email-body-edit{display:flex;flex-direction:column;gap:1rem}.email-body-textarea{width:100%;min-height:200px;padding:.75rem 1rem;background:#fff;border:2px solid #e9ecef;border-radius:6px;font-size:.875rem;color:#374151;transition:all .2s ease;font-family:inherit;line-height:1.5;resize:vertical}.email-body-textarea:hover{border-color:#9ca3af}.email-body-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.email-body-textarea:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.7}.email-edit-info{margin-top:8px;padding:8px 12px;background:#f8f9fa;border-radius:4px;border-left:3px solid #007bff}.edit-hint{font-size:12px;color:#6c757d;font-style:italic;display:flex;align-items:center;gap:6px}.local-changes-indicator{font-size:12px;color:#f59e0b;font-weight:600;display:flex;align-items:center;gap:6px;margin-top:4px;padding:4px 8px;background:#fffbeb;border-radius:4px;border-left:3px solid #f59e0b}.email-edit-actions{display:flex;gap:.75rem;justify-content:flex-end;align-items:center;margin-top:1rem}.edit-button{color:#3b82f6!important;font-weight:500}.edit-button:hover{background-color:#eff6ff}.discard-button{color:#ef4444!important;font-weight:500}.discard-button:hover{background-color:#fef2f2}.accept-button{color:#10b981!important;font-weight:500}.accept-button:hover{background-color:#f0fdf4}.save-button{color:#10b981!important;font-weight:500}.save-button:hover{background-color:#f0fdf4}.save-button.has-changes{background-color:#10b981!important;color:#fff!important;font-weight:600}.save-button.has-changes:hover{background-color:#059669!important}@media (max-width: 480px){.draft-card{padding:.75rem}.email-body-content{padding:.75rem;font-size:.8rem}.email-actions{flex-direction:column;gap:.25rem;align-items:stretch}.email-edit-actions,.approval-section{flex-direction:column;align-items:stretch}.checkbox-label{font-size:.8rem}.meta-item{font-size:.7rem}}.drafts-container{max-width:1200px;margin:0 auto}.drafts-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.drafts-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.drafts-loading .loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.drafts-loading p{color:#6b7280;font-size:1rem;margin:0}.drafts-message{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;border-radius:8px}.drafts-message.error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.drafts-message.success{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.drafts-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.drafts-empty h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#374151}.drafts-empty p{margin:0 0 .5rem;color:#6b7280;font-size:.95rem;line-height:1.5;max-width:400px}.drafts-controls{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;margin-bottom:1rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.bulk-selection{display:flex;align-items:center;gap:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;color:#374151}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.bulk-actions{display:flex;align-items:center;gap:.75rem}.selection-count{font-size:.85rem;color:#6b7280;font-weight:500}.btn-small{padding:.375rem .75rem;font-size:.8rem}.btn-large{padding:.875rem 2rem;font-size:1rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary.disabled{background:#d1d5db;color:#9ca3af}.btn-success{background:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.drafts-stats{display:flex;align-items:center;gap:1rem}.stat{font-size:.85rem;color:#6b7280;font-weight:500}.stat.changes{color:#f59e0b;font-weight:600}.drafts-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.drafts-pagination{display:flex;justify-content:center;margin-bottom:2rem}.all-loaded-text{color:#9ca3af;font-size:.875rem;text-align:center;padding:.75rem}.drafts-save-area{margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;position:sticky;top:0;z-index:100;transition:all .2s ease-in-out}.drafts-save-area.is-sticky{box-shadow:0 2px 12px #00000026;border-bottom:1px solid #e0e0e0;background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:0;margin-bottom:0}.save-info{display:flex;flex-direction:column;gap:.25rem;transition:all .2s ease-in-out}.save-info.sticky-active{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:6px;padding:10px 16px;font-weight:500}.changes-indicator{color:#f59e0b;font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:8px}.no-changes{color:#9f9f9f;font-weight:500;font-size:.9rem;display:flex;align-items:center;gap:8px}.save-info.sticky-active .changes-indicator{color:#856404}.save-info.sticky-active .no-changes{color:#155724}.sticky-save-btn{box-shadow:0 2px 8px #007bff4d;transform:scale(1.02)}.changes-icon,.saved-icon{animation:pulseIcon 2s infinite}@keyframes pulseIcon{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.loading-spinner.small{width:16px;height:16px;border-width:2px}@media (max-width: 768px){.drafts-header{flex-direction:column;gap:1rem;align-items:stretch;padding:1.5rem}.header-actions{justify-content:center}.drafts-controls{flex-direction:column;gap:1rem;align-items:stretch;padding:1rem}.bulk-selection{justify-content:space-between}.bulk-actions{flex-wrap:wrap}.drafts-stats{justify-content:center;flex-wrap:wrap}.drafts-save-area{flex-direction:column;gap:1rem;align-items:stretch;padding:1.5rem 1rem}.drafts-save-area.is-sticky{padding:1rem;font-size:14px}.save-info.sticky-active{padding:8px 12px}.sticky-save-btn{padding:8px 16px;font-size:14px;transform:scale(1)}.save-info{text-align:center}}@media (max-width: 480px){.drafts-header{padding:1rem}.header-title h2{font-size:1.25rem}.btn{padding:.625rem 1rem;font-size:.8rem}.btn-large{padding:.75rem 1.5rem;font-size:.9rem}}.log-card{display:flex;gap:1rem;padding:1.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;transition:all .2s}.log-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.log-card.status-sent{border-left:4px solid #10b981}.log-card.status-failed{border-left:4px solid #ef4444}.log-card.status-queued{border-left:4px solid #3b82f6}.log-card.status-skipped{border-left:4px solid #8b5cf6}.log-card.status-not-approved{border-left:4px solid #64748b}.log-card.status-pending{border-left:4px solid #f59e0b}.log-card.status-unknown{border-left:4px solid #6b7280}.log-status{display:flex;align-items:flex-start;padding-top:.25rem}.status-icon{font-size:1.25rem}.log-content{flex:1;display:flex;flex-direction:column;gap:1.25rem}.log-info{display:flex;flex-direction:column;gap:1rem}.contact-header{display:flex;flex-direction:column;gap:.5rem}.contact-name{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937;line-height:1.4}.contact-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.9rem;color:#6b7280}.company-name{font-weight:500;color:#374151}.separator{color:#d1d5db}.job-function{font-style:italic}.contact-details{display:flex;flex-direction:column;gap:.5rem}.detail-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.detail-label{font-weight:500;color:#6b7280;min-width:100px;flex-shrink:0}.detail-value{color:#374151}.email-link{color:#3b82f6;text-decoration:none}.email-link:hover{text-decoration:underline}.email-content{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px}.email-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.email-subject{font-size:.9rem;color:#374151;flex:1}.email-subject strong{font-weight:600}.content-toggle{display:flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;flex-shrink:0}.content-toggle:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.content-toggle:disabled{opacity:.6;cursor:not-allowed}.email-body{margin-top:.5rem}.email-body-content{padding:1rem;background:#fff;border:1px solid #e5e7eb;border-radius:4px;font-size:.85rem;line-height:1.6;color:#374151;white-space:pre-wrap;word-wrap:break-word;max-height:300px;overflow-y:auto}.email-preview-snippet{font-size:.85rem;color:#6b7280;line-height:1.5;font-style:italic;margin-top:.25rem}.log-meta{display:flex;flex-direction:column;gap:1rem;min-width:200px;padding-left:1rem;border-left:1px solid #e5e7eb}.status-section{display:flex;flex-direction:column;gap:.75rem}.status-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;border:1px solid;text-align:center;width:100%}.status-badge.status-sent{background:#d1fae5;color:#065f46;border-color:#10b981}.status-badge.status-failed{background:#fee2e2;color:#991b1b;border-color:#ef4444}.status-badge.status-queued{background:#dbeafe;color:#1e40af;border-color:#3b82f6}.status-badge.status-skipped{background:#ede9fe;color:#6b21a8;border-color:#8b5cf6}.status-badge.status-not-approved{background:#fff;color:#333;border-color:#e6e6e6}.status-badge.status-pending{background:#fef3c7;color:#92400e;border-color:#f59e0b}.status-badge.status-unknown{background:#f3f4f6;color:#374151;border-color:#6b7280}.status-icon{display:flex;align-items:center;justify-content:center;font-size:1rem}.status-text{font-weight:600;white-space:nowrap}.failure-reason{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:4px}.failure-label{font-size:.75rem;font-weight:600;color:#991b1b;text-transform:uppercase;letter-spacing:.05em}.failure-text{max-width:min-content;font-size:.8rem;color:#dc2626;line-height:1.4}.timestamp-section{display:flex;flex-direction:column;gap:.5rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.meta-item{display:flex;justify-content:space-between;align-items:center;font-size:.75rem}.meta-label{color:#9ca3af;font-weight:500}.meta-value{color:#6b7280;text-align:right}.attempt-badge{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;border:1px solid;text-align:center;width:100%}.attempt-badge.attempt-1,.attempt-badge.attempt-2,.attempt-badge.attempt-3{background:#fff;color:#64748b;font-weight:600;border-color:#e6e6e6}@media (max-width: 1024px){.log-card{flex-direction:column;gap:1rem}.log-status{order:-1;align-self:flex-start}.log-meta{border-left:none;border-top:1px solid #e5e7eb;padding-left:0;padding-top:1rem;min-width:unset}.email-header{flex-direction:column;align-items:flex-start;gap:.75rem}.content-toggle{align-self:flex-start}.status-section{flex-direction:row;align-items:center;flex-wrap:wrap}.failure-reason{flex:1;min-width:250px}}@media (max-width: 768px){.log-card{padding:1rem}.contact-name{font-size:1rem}.contact-meta{font-size:.8rem}.detail-item{flex-direction:column;align-items:flex-start;gap:.25rem}.detail-label{min-width:unset;font-size:.75rem}.detail-value{font-size:.8rem}.email-content{padding:.75rem}.email-body-content{padding:.75rem;font-size:.8rem}.status-section{flex-direction:column;align-items:stretch}.timestamp-section{grid-template-columns:1fr}.meta-item{justify-content:flex-start;gap:.5rem}.meta-value{text-align:left}}@media (max-width: 480px){.log-card{padding:.75rem}.meta-item{font-size:.7rem}}.pagination-container{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0;border-top:1px solid #e5e7eb;background:#fff}.pagination-info{color:#6b7280;font-size:.9rem;text-align:center}.pagination-info.end-reached{font-style:italic;color:#9ca3af}.pagination{display:flex;align-items:center;gap:.5rem}.pagination-pages{display:flex;align-items:center;gap:.25rem}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:.5rem .75rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled):not(.disabled){background:#f9fafb;border-color:#9ca3af}.pagination-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.pagination-btn.disabled,.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:#f9fafb}.pagination-btn.ellipsis{cursor:default;background:transparent;border:none}.pagination-btn.ellipsis:hover{background:transparent;border:none}.load-more-section{display:flex;flex-direction:column;align-items:center;gap:1rem}.load-more-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 2rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#374151;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.load-more-btn:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-spinner.small{width:16px;height:16px;border:2px solid #e5e7eb;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.pagination-container{padding:1.5rem 0}.pagination{flex-wrap:wrap;justify-content:center}.pagination-btn{min-width:35px;height:35px;font-size:.8rem}.load-more-btn{padding:.625rem 1.5rem;font-size:.85rem}}@media (max-width: 480px){.pagination-pages{gap:.125rem}.pagination-btn{min-width:32px;height:32px;padding:.25rem .5rem;font-size:.75rem}}.log-container{max-width:1200px;margin:0 auto}.log-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.header-title h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#1f2937}.header-title p{margin:0;color:#6b7280;font-size:.95rem;line-height:1.5}.header-actions{display:flex;gap:.75rem}.log-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.log-loading .loading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.log-loading p{color:#6b7280;font-size:1rem;margin:0}.log-message{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;margin-bottom:1.5rem;font-size:.9rem;font-weight:500;border-radius:8px}.log-message.error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.message-icon{font-size:1.1rem}.log-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.log-empty h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#374151}.log-empty p{margin:0 0 .5rem;color:#6b7280;font-size:.95rem;line-height:1.5;max-width:400px}.log-controls{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;margin-bottom:1rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.log-filters{display:flex;align-items:center;gap:1.5rem}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-label{font-size:.9rem;font-weight:500;color:#374151}.filter-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:.85rem;cursor:pointer;transition:all .2s}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select:disabled{opacity:.6;cursor:not-allowed;background:#f9fafb}.log-stats{display:flex;align-items:center;gap:1rem}.stat{font-size:.85rem;font-weight:500;padding:.25rem .5rem;border-radius:4px}.stat{color:#6b7280;background:#f3f4f6}.stat.sent{color:#10b981;background:#d1fae5}.stat.failed{color:#ef4444;background:#fee2e2}.stat.pending{color:#f59e0b;background:#fef3c7}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.log-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.log-pagination{display:flex;justify-content:center;margin-bottom:2rem}.loading-spinner{width:20px;height:20px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.log-header{flex-direction:column;gap:1rem;align-items:stretch;padding:1.5rem}.header-actions{justify-content:center}.log-controls{flex-direction:column;gap:1rem;align-items:stretch;padding:1rem}.log-filters{justify-content:space-between;flex-wrap:wrap;gap:1rem}.log-stats{justify-content:center;flex-wrap:wrap}}@media (max-width: 480px){.log-header{padding:1rem}.header-title h2{font-size:1.25rem}.log-filters{flex-direction:column;align-items:stretch}.filter-group{justify-content:space-between}.filter-select{flex:1}}.dashboard{display:flex;flex-direction:column}.dashboard-header{background:#fff;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border-bottom:1px solid #e2e8f0}.header-content{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:.5rem}.app-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.user-info{display:flex;align-items:center;gap:1rem}.welcome-text{color:#64748b;font-size:.9rem}.api-status{display:flex;align-items:center;gap:.25rem;font-size:.8rem}.status-indicator{width:8px;height:8px;border-radius:50%;background-color:#94a3b8}.api-status.connected .status-indicator{background-color:#10b981}.api-status.disconnected .status-indicator{background-color:#ef4444}.api-status.checking .status-indicator{background-color:#f59e0b;animation:pulse 2s infinite}.status-text{color:#64748b}.sign-out-button{background:#ef4444;color:#fff;border:1px solid #ef4444;border-radius:8px;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:44px;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;line-height:1.4;letter-spacing:.025em}.sign-out-button:hover:not(:disabled){background:#dc2626;border-color:#dc2626;transform:translateY(-1px)}.sign-out-button:active:not(:disabled){transform:translateY(0)}.sign-out-button:disabled{background:#fee2e2;color:#6b7280;border-color:#fee2e2;opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.dashboard-nav{background:#fff;border-bottom:1px solid #e2e8f0}.nav-content{max-width:1200px;margin:0 auto;padding:0 2rem}.nav-tabs{display:flex;gap:10px;padding:10px 0}.nav-tab{background:none;border:none;padding:1rem 1.5rem;font-size:.9rem;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:.5rem}.nav-tab:hover{color:#1e293b;background-color:#f1f5f9}.tab-icon{font-size:1rem}.dashboard-main{flex:1;background-color:#f8fafc}.main-content{max-width:1200px;margin:0 auto;padding:2rem}.dashboard-footer{background:#fff;border-top:1px solid #e2e8f0;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;padding:1rem 2rem;text-align:center}.footer-content p{color:#64748b;font-size:.8rem;margin:0}@media (max-width: 768px){.header-content{padding:1rem;flex-direction:column;gap:1rem;align-items:stretch}.header-left{align-items:center;text-align:center;justify-content:center}.user-info{justify-content:center}.nav-content{padding:0 1rem}.nav-tabs{flex-direction:column}.nav-tab{justify-content:center;border-bottom:none;border-right:3px solid transparent}.nav-tab.active{border-right-color:#3b82f6;border-bottom-color:transparent}.main-content,.footer-content{padding:1rem}}@media (max-width: 480px){.app-title{font-size:1.25rem}.nav-tab{padding:.75rem 1rem;font-size:.8rem}.tab-icon{font-size:.9rem}}.not-found-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:40px}.not-found-content{background:#fff;padding:4rem 3rem;border-radius:12px;box-shadow:0 20px 40px #0000001a;width:100%;max-width:500px;text-align:center;border:1px solid rgba(255,255,255,.2)}.not-found-logo{display:flex;justify-content:center;margin-bottom:2rem}.not-found-title{font-size:4rem;font-weight:700;color:#667eea;margin:0 0 .5rem;letter-spacing:-.05em}.not-found-subtitle{font-size:1.5rem;font-weight:600;color:#333;margin:0 0 1rem;letter-spacing:-.025em}.not-found-message{color:#666;font-size:1.1rem;margin:0 0 2.5rem;line-height:1.5}.not-found-button{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.875rem 2rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:all .2s ease;border:none;cursor:pointer;letter-spacing:.025em}.not-found-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.not-found-button:active{transform:translateY(0)}@media (max-width: 480px){.not-found-container{padding:20px}.not-found-content{padding:2.5rem 2rem;max-width:100%}.not-found-title{font-size:3rem}.not-found-subtitle{font-size:1.25rem}.not-found-message{font-size:1rem}}:root{--color-primary: #3b82f6;--color-primary-light: #60a5fa;--color-primary-dark: #2563eb;--color-secondary: #6b7280;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-white: #ffffff;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, Courier, monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-base: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .15s ease-in-out;--transition-base: .2s ease-in-out;--transition-slow: .3s ease-in-out;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--z-toast: 1080}*,*:before,*:after{box-sizing:border-box}html{line-height:1.15;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{margin:0;padding:0;font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-800);background-color:var(--color-gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{margin:0 0 var(--spacing-md) 0;font-weight:600;line-height:1.3;color:var(--color-gray-900)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-base)}h6{font-size:var(--font-size-sm)}p{margin:0 0 var(--spacing-md) 0;line-height:1.6}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-base)}a:hover{color:var(--color-primary-dark);text-decoration:underline}input,textarea,select{font-family:inherit;font-size:inherit;line-height:inherit}button{font-family:inherit;font-size:inherit;line-height:inherit;margin:0;padding:0;border:none;background:none;cursor:pointer;color:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-light{font-weight:300}.font-normal{font-weight:400}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-800{color:var(--color-gray-800)}.text-gray-900{color:var(--color-gray-900)}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.bg-white{background-color:var(--color-white)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow{box-shadow:var(--shadow-base)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.flex-row{flex-direction:row}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.w-full{width:100%}.h-full{height:100%}.p-0{padding:0}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-4{padding:var(--spacing-md)}.p-6{padding:var(--spacing-lg)}.p-8{padding:var(--spacing-xl)}.m-0{margin:0}.m-1{margin:var(--spacing-xs)}.m-2{margin:var(--spacing-sm)}.m-4{margin:var(--spacing-md)}.m-6{margin:var(--spacing-lg)}.m-8{margin:var(--spacing-xl)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-4{margin-bottom:var(--spacing-md)}.mb-6{margin-bottom:var(--spacing-lg)}.mb-8{margin-bottom:var(--spacing-xl)}.mt-2{margin-top:var(--spacing-sm)}.mt-4{margin-top:var(--spacing-md)}.mt-6{margin-top:var(--spacing-lg)}.mt-8{margin-top:var(--spacing-xl)}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-4{gap:var(--spacing-md)}.gap-6{gap:var(--spacing-lg)}.gap-8{gap:var(--spacing-xl)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-fadeIn{animation:fadeIn .3s ease-in-out}.animate-fadeInUp{animation:fadeInUp .3s ease-in-out}.focus-ring:focus{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 3px #3b82f61a}@media (max-width: 640px){.container{padding:0 var(--spacing-sm)}.sm\:hidden{display:none}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:grid{display:grid}.sm\:text-sm{font-size:var(--font-size-sm)}.sm\:text-base{font-size:var(--font-size-base)}.sm\:p-2{padding:var(--spacing-sm)}.sm\:p-4{padding:var(--spacing-md)}.sm\:gap-2{gap:var(--spacing-sm)}.sm\:gap-4{gap:var(--spacing-md)}}@media (max-width: 768px){.md\:hidden{display:none}.md\:block{display:block}.md\:flex{display:flex}.md\:grid{display:grid}.md\:flex-col{flex-direction:column}.md\:items-stretch{align-items:stretch}.md\:text-sm{font-size:var(--font-size-sm)}.md\:text-base{font-size:var(--font-size-base)}.md\:p-3{padding:.75rem}.md\:p-4{padding:var(--spacing-md)}.md\:gap-3{gap:.75rem}.md\:gap-4{gap:var(--spacing-md)}}@media (max-width: 1024px){.lg\:hidden{display:none}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:grid{display:grid}}@media print{*{-webkit-print-color-adjust:exact;color-adjust:exact}body{background:#fff;font-size:12pt;line-height:1.4}.no-print{display:none!important}a[href]:after{content:" (" attr(href) ")";font-size:.8em;color:var(--color-gray-600)}h1,h2,h3,h4,h5,h6{page-break-after:avoid}pre,blockquote{page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;text-decoration:none;min-height:44px;font-family:inherit;line-height:1.4;letter-spacing:.025em}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{background:#d1d5db;color:#9ca3af}.btn-secondary{background:#fff;color:#374151;border:2px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px)}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-success{background:#10b981;color:#fff;border:1px solid #10b981}.btn-success:hover:not(:disabled){background:#059669;border-color:#059669;transform:translateY(-1px)}.btn-success:disabled{background:#d1fae5;color:#6b7280;border-color:#d1fae5}.btn-danger{background:#ef4444;color:#fff;border:1px solid #ef4444}.btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626;transform:translateY(-1px)}.btn-danger:disabled{background:#fee2e2;color:#6b7280;border-color:#fee2e2}.btn-small{padding:.375rem .75rem;font-size:.8rem;min-height:32px}.btn-large{padding:1rem 2rem;font-size:1rem;min-height:48px}.btn-full-width{width:100%}.btn-inline{white-space:nowrap;align-self:flex-start;width:auto}.btn-toggle{display:flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-toggle:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.btn-toggle:disabled{opacity:.6;cursor:not-allowed}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:0}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.form-label.required:after{content:" *";color:#ef4444}.form-input{width:100%;padding:.75rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;color:#374151;transition:all .15s ease;font-family:inherit;line-height:1.4}.form-input:hover{border-color:#9ca3af}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:#9ca3af}.form-input:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.7}.form-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-textarea{width:100%;min-height:120px;padding:.75rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;color:#374151;transition:all .15s ease;font-family:inherit;line-height:1.5;resize:vertical}.form-textarea:hover{border-color:#9ca3af}.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-textarea:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.7}.form-textarea.large{min-height:200px}.form-select{width:100%;padding:.75rem 1rem;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;color:#374151;transition:all .15s ease;font-family:inherit;line-height:1.4;cursor:pointer}.form-select:hover{border-color:#9ca3af}.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-select:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.7}.form-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;font-weight:500}.form-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#3b82f6}.field-error{margin-top:.5rem;font-size:.875rem;color:#ef4444;display:flex;align-items:center;gap:.25rem}.input-group{display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap}.input-group .form-input{flex:1;min-width:250px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;transition:all .2s ease}.card:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.card-small{padding:1rem}.card-medium{padding:1.5rem}.card-large{padding:2rem}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.card-title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#1f2937}.card-subtitle{margin:0;color:#6b7280;font-size:.95rem;line-height:1.5}.card-content{display:flex;flex-direction:column;gap:1rem}.card-actions{display:flex;gap:.75rem;justify-content:flex-end;align-items:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.card-elevated{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.card-border-left{border-left:4px solid #3b82f6}.card-border-success{border-left:4px solid #10b981}.card-border-warning{border-left:4px solid #f59e0b}.card-border-danger{border-left:4px solid #ef4444}.notification{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;font-size:.9rem;font-weight:500;border:1px solid;margin-bottom:1rem}.notification:last-child{margin-bottom:0}.notification-success{background-color:#f0fdf4;border-color:#bbf7d0;color:#166534}.notification-error{background-color:#fef2f2;border-color:#fecaca;color:#dc2626}.notification-warning{background-color:#fef3c7;border-color:#fcd34d;color:#92400e}.notification-info{background-color:#eff6ff;border-color:#bfdbfe;color:#1e40af}.notification-icon{font-size:1.1rem;flex-shrink:0}.notification-inline{padding:.5rem .75rem;font-size:.85rem;margin-bottom:.75rem}.status-badge{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;border:1px solid;text-align:center}.status-badge-success{background:#d1fae5;color:#065f46;border-color:#a7f3d0}.status-badge-error{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.status-badge-warning{background:#fef3c7;color:#92400e;border-color:#fcd34d}.status-badge-info{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.status-badge-neutral{background:#f3f4f6;color:#374151;border-color:#d1d5db}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem}.loading-spinner-small{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:1.25rem;color:#4a5568;font-weight:500;margin:0}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-900{color:#1f2937}@media (max-width: 768px){.card-header{flex-direction:column;align-items:flex-start;gap:1rem}.card-actions{flex-direction:column;align-items:stretch}.btn-full-width-mobile{width:100%}.input-group{flex-direction:column;align-items:stretch}.input-group .form-input{min-width:unset}}@media (max-width: 480px){.card-small,.card-medium,.card-large{padding:1rem}.btn{padding:.75rem 1rem;font-size:.875rem}.btn-small{padding:.5rem .75rem;font-size:.8rem}}#root{margin:0;min-height:100vh;background-color:#f8fafc}.app-container{min-height:100vh;background-color:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:100}.app-header h1{margin:0;color:#1a202c;font-size:1.875rem;font-weight:700;letter-spacing:-.025em}.user-info{display:flex;align-items:center;gap:1.5rem;font-size:1rem}.user-info span{color:#4a5568;font-weight:500}.logout-button{background:#e53e3e;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .2s ease;letter-spacing:.025em}.logout-button:hover{background:#c53030;transform:translateY(-1px);box-shadow:0 4px 12px #e53e3e4d}.logout-button:active{transform:translateY(0)}.app-main{padding:2rem;max-width:1400px;margin:0 auto;min-height:calc(100vh - 100px)}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background-color:#f8fafc;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{font-size:1.25rem;color:#4a5568;font-weight:500;margin:0}.content-wrapper{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:2rem;margin-bottom:2rem}.page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.page-title{font-size:1.75rem;font-weight:700;color:#1a202c;margin:0 0 .5rem;letter-spacing:-.025em}.page-description{color:#4a5568;font-size:1rem;margin:0}@media (min-width: 1024px){.app-main{padding:3rem}.app-header{padding:2rem 3rem}.content-wrapper{padding:3rem}}@media (min-width: 1440px){.app-main{max-width:1600px;padding:4rem}}@media (max-width: 768px){.app-container{font-size:.9rem}.app-header{padding:1rem;flex-direction:column;gap:1rem}.app-main{padding:1rem}.user-info{gap:1rem}}
