.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:48px;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:32px;font-weight:700;color:#1a202c;margin-bottom:8px}.login-header p{font-size:14px;color:#718096}.login-form{display:flex;flex-direction:column;gap:24px}.form-group input{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:border-color .2s;background-color:#fff}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.form-group input::placeholder{color:#a0aec0}.error-message{padding:12px 16px;background-color:#fed7d7;border:1px solid #fc8181;border-radius:8px;color:#c53030;font-size:14px}.login-button{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s;margin-top:8px}.login-button:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.layout{min-height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5}.layout-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}.header-logo{text-decoration:none;color:inherit}.header-logo h1{font-size:24px;font-weight:700;color:#1a202c;margin:0}.header-nav{display:flex;gap:16px;flex:1}.nav-link{padding:8px 16px;text-decoration:none;color:#4a5568;font-weight:500;border-radius:6px;transition:background-color .2s,color .2s}.nav-link:hover{background-color:#f7fafc;color:#2d3748}.nav-link.active{background-color:#edf2f7;color:#2d3748}.header-user{display:flex;align-items:center;gap:16px}.header-server-time{font-size:14px;color:#475569;font-variant-numeric:tabular-nums;padding:4px 8px;background-color:#f1f5f9;border-radius:4px}.user-info{font-size:14px;color:#718096}.logout-button{padding:8px 16px;background-color:#e53e3e;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s}.logout-button:hover{background-color:#c53030}.layout-main{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:32px 24px}@media (max-width: 768px){.header-content{flex-direction:column;align-items:flex-start}.header-nav{width:100%;flex-direction:column}.header-user{width:100%;justify-content:space-between}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}.loading-spinner{border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.loading-small .loading-spinner{width:20px;height:20px;border-width:2px}.loading-medium .loading-spinner{width:40px;height:40px;border-width:3px}.loading-large .loading-spinner{width:60px;height:60px;border-width:4px}.loading-message{margin-top:12px;font-size:14px;color:#718096}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{padding:16px;background-color:#fed7d7;border:1px solid #fc8181;border-radius:8px;color:#c53030;margin-bottom:16px;display:flex;justify-content:space-between;align-items:flex-start}.error-conflict{background-color:#feebc8;border-color:#f6ad55;color:#c05621}.error-content{display:flex;gap:12px;flex:1}.error-icon{font-size:20px;flex-shrink:0}.error-text{flex:1}.error-title{font-weight:600;margin-bottom:4px;font-size:14px}.error-detail{font-size:14px;margin:0}.error-close{background:none;border:none;color:inherit;font-size:24px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7;transition:opacity .2s}.error-close:hover{opacity:1}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge-draft{background-color:#e2e8f0;color:#4a5568}.status-badge-scheduled{background-color:#bee3f8;color:#2c5282}.status-badge-running{background-color:#c6f6d5;color:#22543d}.status-badge-stopped{background-color:#fed7d7;color:#742a2a}.status-badge-completed{background-color:#c6f6d5;color:#22543d}.status-badge-failed{background-color:#fed7d7;color:#c53030}.status-badge-pending{background-color:#e2e8f0;color:#4a5568}.status-badge-sending{background-color:#bee3f8;color:#2c5282}.status-badge-success{background-color:#c6f6d5;color:#22543d}.status-badge-suppressed{background-color:#feebc8;color:#c05621}.progress-bar-container{margin-top:8px}.progress-bar-wrapper{width:100%;height:8px;background-color:#e2e8f0;border-radius:4px;overflow:hidden;position:relative}.progress-bar{height:100%;display:flex;transition:width .3s ease;position:relative}.progress-segment{height:100%;transition:width .3s ease}.progress-segment.success{background-color:#48bb78}.progress-segment.failed{background-color:#f56565}.progress-segment.suppressed{background-color:#ed8936}.progress-segment.sending{background-color:#4299e1;animation:pulse-bar 1.5s ease-in-out infinite}@keyframes pulse-bar{0%,to{opacity:1}50%{opacity:.7}}.progress-stats{display:flex;gap:16px;margin-top:8px;flex-wrap:wrap;font-size:12px}.stat-item{display:flex;align-items:center;gap:4px;color:#4a5568}.stat-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.stat-dot.success{background-color:#48bb78}.stat-dot.failed{background-color:#f56565}.stat-dot.suppressed{background-color:#ed8936}.stat-dot.sending{background-color:#4299e1;animation:pulse 1.5s ease-in-out infinite}.stat-dot.pending{background-color:#a0aec0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.dashboard-page{width:100%}.dashboard-header{margin-bottom:24px}.dashboard-header h1{font-size:28px;font-weight:600;color:#1a202c;margin:0}.delivery-stop-window-banner{background:#fef3c7;border:1px solid #f59e0b;color:#92400e;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-weight:600;text-align:center}.deliveries-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.deliveries-table{width:100%;border-collapse:collapse;font-size:14px}.deliveries-table thead{background-color:#f7fafc;border-bottom:2px solid #e2e8f0}.deliveries-table th{padding:12px 16px;text-align:left;font-weight:600;color:#2d3748;white-space:nowrap}.deliveries-table td{padding:12px 16px;border-bottom:1px solid #e2e8f0;color:#4a5568}.deliveries-table tbody tr:hover{background-color:#f7fafc}.delivery-id{font-family:monospace;font-size:12px;color:#718096}.delivery-subject{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-center{text-align:center}.count-link{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.count-link:hover{color:#764ba2}.eta{font-size:13px;color:#718096;white-space:nowrap}.actions{white-space:nowrap}.action-button{padding:6px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.action-button:disabled{opacity:.6;cursor:not-allowed}.action-button:not(:disabled):hover{opacity:.9;transform:translateY(-1px)}.action-start{background-color:#48bb78;color:#fff}.action-stop{background-color:#f56565;color:#fff}.action-resume{background-color:#4299e1;color:#fff}.action-delete{background-color:transparent;color:#c53030;border:1px solid #c53030;margin-left:4px}.action-delete:not(:disabled):hover{background-color:#c53030;color:#fff}.progress-row{background-color:#f7fafc}.progress-cell{padding:12px 16px!important;border-top:none!important}@media (max-width: 1200px){.deliveries-table-container{overflow-x:auto}.deliveries-table{min-width:1200px}}.delivery-detail-page{width:100%}.delivery-detail-header{margin-bottom:24px;display:flex;align-items:center;gap:16px}.delivery-detail-header h1{font-size:28px;font-weight:600;color:#1a202c;margin:0;flex:1}.delivery-info{display:flex;align-items:center;gap:12px}.delivery-subject{font-size:16px;color:#718096;margin:0}.filter-section{margin-bottom:24px}.status-filters{display:flex;gap:8px;flex-wrap:wrap}.filter-button{padding:8px 16px;background-color:#fff;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;font-weight:600;color:#4a5568;cursor:pointer;transition:all .2s}.filter-button:hover{border-color:#cbd5e0;background-color:#f7fafc}.filter-button.active{background-color:#667eea;border-color:#667eea;color:#fff}.empty-state p{font-size:16px;color:#718096;margin:0}.items-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto;margin-bottom:24px}.items-table{width:100%;border-collapse:collapse;font-size:14px}.items-table thead{background-color:#f7fafc;border-bottom:2px solid #e2e8f0}.items-table th{padding:12px 16px;text-align:left;font-weight:600;color:#2d3748;white-space:nowrap}.items-table td{padding:12px 16px;border-bottom:1px solid #e2e8f0;color:#4a5568}.items-table tbody tr:hover{background-color:#f7fafc}.error-cell,.suppression-cell{max-width:300px;word-break:break-word;font-size:13px;color:#718096}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:16px}.pagination-button{padding:8px 16px;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;font-weight:600;color:#4a5568;cursor:pointer;transition:all .2s}.pagination-button:hover:not(:disabled){background-color:#f7fafc;border-color:#cbd5e0}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:14px;color:#718096}.create-delivery-page{width:100%;max-width:800px}.create-delivery-header{margin-bottom:24px;display:flex;align-items:center;gap:16px}.create-delivery-header h1{font-size:28px;font-weight:600;color:#1a202c;margin:0}.create-delivery-form{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:32px;display:flex;flex-direction:column;gap:24px}.form-group select,.form-group input[type=file]{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:border-color .2s;background-color:#fff}.form-group select:focus,.form-group input[type=file]:focus{outline:none;border-color:#667eea}.form-group select:disabled,.form-group input[type=file]:disabled{background-color:#f7fafc;cursor:not-allowed}.form-help{font-size:13px;color:#718096;margin:0;line-height:1.5}.file-info{padding:12px;background-color:#edf2f7;border-radius:6px;font-size:14px;color:#4a5568}.templates-page{width:100%}.templates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.templates-header h1{font-size:28px;font-weight:600;color:#1a202c;margin:0}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px}.template-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:24px;display:flex;flex-direction:column}.template-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.template-name{font-size:20px;font-weight:600;color:#1a202c;margin:0;flex:1}.template-actions{display:flex;gap:8px}.edit-button,.delete-button{padding:6px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .2s}.edit-button{background-color:#4299e1;color:#fff}.edit-button:hover{opacity:.9}.delete-button{background-color:#e53e3e;color:#fff}.template-content{flex:1;display:flex;flex-direction:column;gap:12px}.template-field{display:flex;flex-direction:column;gap:4px}.template-field label{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px}.template-field p{font-size:14px;color:#2d3748;margin:0}.template-body-preview{color:#718096!important;line-height:1.6}.template-meta{margin-top:auto;padding-top:12px;border-top:1px solid #e2e8f0;font-size:12px;color:#a0aec0}@media (max-width: 768px){.templates-grid{grid-template-columns:1fr}}.template-form-page{width:100%;max-width:800px}.template-form-header{margin-bottom:24px;display:flex;align-items:center;gap:16px}.template-form-header h1{font-size:28px;font-weight:600;color:#1a202c;margin:0}.template-form{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:32px;display:flex;flex-direction:column;gap:24px}.form-group input[type=text],.form-group textarea{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:border-color .2s;background-color:#fff;font-family:inherit}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group input[type=text]:disabled,.form-group textarea:disabled{background-color:#f7fafc;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:200px}.form-help{font-size:13px;color:#718096;margin:0}.suppressions-page{width:100%}.suppressions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.suppressions-header h1{font-size:28px;font-weight:600;color:#1a202c;margin:0}.create-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.create-button:hover{opacity:.9;transform:translateY(-1px)}.empty-state{background:#fff;border-radius:8px;padding:48px;text-align:center;box-shadow:0 1px 3px #0000001a}.empty-state p{font-size:16px;color:#718096;margin-bottom:24px}.suppressions-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.suppressions-table{width:100%;border-collapse:collapse;font-size:14px}.suppressions-table thead{background-color:#f7fafc;border-bottom:2px solid #e2e8f0}.suppressions-table th{padding:12px 16px;text-align:left;font-weight:600;color:#2d3748;white-space:nowrap}.suppressions-table td{padding:12px 16px;border-bottom:1px solid #e2e8f0;color:#4a5568}.suppressions-table tbody tr:hover{background-color:#f7fafc}.email-cell{font-family:monospace;font-size:13px}.delete-button{padding:6px 12px;background-color:#e53e3e;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .2s}.delete-button:hover:not(:disabled){opacity:.9}.delete-button:disabled{opacity:.6;cursor:not-allowed}.create-suppression-page{width:100%;max-width:600px}.create-suppression-header{margin-bottom:24px;display:flex;align-items:center;gap:16px}.back-button{padding:8px 16px;background-color:#e2e8f0;color:#4a5568;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s}.back-button:hover{background-color:#cbd5e0}.create-suppression-header h1{font-size:28px;font-weight:600;color:#1a202c;margin:0}.create-suppression-form{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:32px;display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#2d3748}.required{color:#e53e3e}.form-group input[type=email],.form-group input[type=text]{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:border-color .2s;background-color:#fff}.form-group input[type=email]:focus,.form-group input[type=text]:focus{outline:none;border-color:#667eea}.form-group input[type=email]:disabled,.form-group input[type=text]:disabled{background-color:#f7fafc;cursor:not-allowed}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.cancel-button{padding:12px 24px;background-color:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;font-weight:600;color:#4a5568;cursor:pointer;transition:all .2s}.cancel-button:hover:not(:disabled){background-color:#f7fafc;border-color:#cbd5e0}.cancel-button:disabled{opacity:.6;cursor:not-allowed}.submit-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.submit-button:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.settings-page{max-width:560px;padding:24px 0}.settings-page h1{margin-bottom:24px;font-size:1.5rem}.settings-section{background:#f8fafc;border-radius:8px;padding:20px;margin-bottom:20px}.settings-section h2{font-size:1.1rem;margin-bottom:8px}.settings-description{color:#64748b;font-size:.9rem;margin-bottom:16px;line-height:1.5}.settings-timezone-note{color:#94a3b8;font-size:.85rem;margin-bottom:16px;line-height:1.5}.settings-timezone-note code{background:#e2e8f0;padding:2px 6px;border-radius:4px;font-size:.9em}.settings-form .form-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.settings-form label{display:flex;flex-direction:column;gap:4px;font-size:.9rem}.settings-form input[type=time]{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:1rem;min-width:120px}.form-sep{color:#64748b;margin-top:20px}.settings-message{margin-bottom:12px;font-size:.9rem}.settings-message.success{color:#059669}.settings-message.error{color:#dc2626}.settings-submit{padding:8px 20px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.95rem;cursor:pointer}.settings-submit:hover:not(:disabled){background:#1d4ed8}.settings-submit:disabled{opacity:.6;cursor:not-allowed}.settings-note{font-size:.85rem;color:#64748b;line-height:1.5}.app{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{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:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
