.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-background{background:linear-gradient(135deg,#667eea,#764ba2);z-index:-2}.background-pattern,.login-background{position:absolute;top:0;left:0;right:0;bottom:0}.background-pattern{background-image:radial-gradient(circle at 25% 25%,hsla(0,0%,100%,.1) 0,transparent 50%),radial-gradient(circle at 75% 75%,hsla(0,0%,100%,.1) 0,transparent 50%);animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(1deg)}}.login-container{width:100%;max-width:420px;padding:0 20px;z-index:1}.login-card{background:hsla(0,0%,100%,.95);backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.2);border-radius:24px;padding:40px;box-shadow:0 20px 40px rgba(0,0,0,.1),0 0 0 1px hsla(0,0%,100%,.05);animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.logo-section{flex-direction:column;gap:12px;margin-bottom:16px}.logo-icon,.logo-section{display:flex;align-items:center}.logo-icon{font-size:48px;width:80px;height:80px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:20px;justify-content:center;box-shadow:0 8px 25px rgba(59,130,246,.3);animation:pulse 2s ease-in-out infinite}.title{margin:0;font-size:28px}.login-form{display:flex;flex-direction:column;gap:20px}.form-input{background:hsla(0,0%,100%,.8);backdrop-filter:blur(10px);width:100%;box-sizing:border-box;height:48px}.form-input:focus{background:hsla(0,0%,100%,.95)}.password-input-wrapper{display:flex;align-items:center}.password-input{width:100%;box-sizing:border-box}.form-options{margin:8px 0}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:14px;color:#6b7280}.checkbox-input{display:none}.checkbox-custom{width:20px;height:20px;border:2px solid #d1d5db;border-radius:6px;position:relative;transition:all .2s ease;background:hsla(0,0%,100%,.8)}.checkbox-input:checked+.checkbox-custom{background:#3b82f6;border-color:#3b82f6}.checkbox-input:checked+.checkbox-custom:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.checkbox-text{-webkit-user-select:none;-moz-user-select:none;user-select:none}.login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px rgba(59,130,246,.3)}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(59,130,246,.4)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}@media (max-width:480px){.login-container{padding:0 16px}.login-card{padding:32px 24px}.logo-icon{width:60px;height:60px;font-size:36px}.title{font-size:24px}.subtitle{font-size:14px}}@media (max-height:600px){.login-page{align-items:flex-start;padding-top:20px}}.dashboard-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:24px}.dashboard-content{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stat-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px rgba(0,0,0,.08);border:1px solid #e5e7eb;display:flex;align-items:center;gap:16px;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.12)}.stat-icon{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px}.stat-icon.success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.stat-icon.failed{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.stat-icon.total{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.stat-icon.rate{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.stat-info{flex:1}.stat-number{font-size:32px;font-weight:700;color:#1f2937;line-height:1;margin-bottom:4px}.stat-label{font-size:14px;color:#6b7280;font-weight:500}.filters-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px rgba(0,0,0,.08);border:1px solid #e5e7eb;gap:20px;flex-wrap:wrap}.filter-group,.filters-section{display:flex;align-items:center}.filter-group{gap:8px}.filter-group label{font-weight:600;color:#374151;font-size:14px;white-space:nowrap}.filter-group input,.filter-group select{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;min-width:120px}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.refresh-btn{padding:8px 16px;border-radius:8px}.refresh-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px rgba(59,130,246,.3)}.clear-btn{gap:8px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;font-size:14px;font-weight:600}.clear-btn:hover{transform:translateY(-1px);box-shadow:0 4px 15px rgba(239,68,68,.3)}.results-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 20px rgba(0,0,0,.08);border:1px solid #e5e7eb}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{margin:0;font-size:20px;font-weight:700;color:#1f2937}.pagination-info{font-size:14px;color:#6b7280}.results-table{border-radius:12px;overflow:hidden;border:1px solid #e5e7eb}.table-header{display:grid;grid-template-columns:160px 180px 200px 1fr 100px 160px;background:#f9fafb;padding:16px;font-weight:600;color:#374151;font-size:13px;border-bottom:1px solid #e5e7eb;gap:8px}.table-header>div{display:flex;align-items:center;padding:0 4px;min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.table-body{max-height:600px;overflow-y:auto}.table-row{display:grid;grid-template-columns:160px 180px 200px 1fr 100px 160px;padding:16px;border-bottom:1px solid #f3f4f6;font-size:14px;transition:background-color .2s ease;gap:8px}.table-row:hover{background:#f9fafb}.table-row.success{border-left:4px solid #10b981}.table-row.failed{border-left:4px solid #ef4444}.table-row:last-child{border-bottom:none}.col-batch,.col-email-id,.col-recipient,.col-status,.col-subject,.col-time{display:flex;align-items:center;padding:0 4px;min-width:0;overflow:hidden}.col-batch,.col-recipient,.col-time{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-subject{word-break:break-word;line-height:1.4;max-height:2.8em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.col-status{justify-content:center}.col-email-id{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-badge{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;text-align:center}.status-badge.success{background:#dcfce7;color:#166534}.status-badge.failed{background:#fef2f2;color:#dc2626}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.page-btn{padding:8px 16px;border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s ease}.page-btn:hover:not(:disabled){background:#f9fafb;border-color:#3b82f6}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:14px;color:#6b7280}@media (max-width:1400px){.table-header,.table-row{grid-template-columns:140px 160px 180px 1fr 90px 140px}}@media (max-width:1200px){.table-header,.table-row{grid-template-columns:120px 140px 160px 1fr 80px 120px}.table-header{font-size:12px}.col-batch,.col-email-id,.col-recipient,.col-time{font-size:11px}}@media (max-width:768px){.dashboard-content{padding:0 16px}.stats-grid{grid-template-columns:1fr}.filters-section{flex-direction:column;align-items:stretch}.filter-group{justify-content:space-between}.table-header,.table-row{grid-template-columns:1fr;gap:8px}.col-time:before{content:"时间: ";font-weight:600}.col-batch:before{content:"批次: ";font-weight:600}.col-recipient:before{content:"收件人: ";font-weight:600}.col-subject:before{content:"主题: ";font-weight:600}.col-status:before{content:"状态: ";font-weight:600}.col-email-id:before{content:"邮件ID: ";font-weight:600}}.test-send-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:24px}.content-container{max-width:800px}.test-form{display:flex;flex-direction:column;gap:20px}.form-textarea{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;line-height:1.5;resize:vertical}.btn{min-width:140px}.result-section{animation:slideIn .3s ease}.result-card{border:2px solid}.result-card.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#10b981}.result-card.error{background:linear-gradient(135deg,#fef2f2,#fecaca);border-color:#ef4444}.result-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.result-icon{width:48px;height:48px;border-radius:12px;font-size:24px;background:#10b981;color:#fff}.result-card.error .result-icon{background:#ef4444}.result-text h4{margin:0 0 4px 0;font-size:18px;font-weight:600;color:#1f2937}.result-text p{margin:0;color:#6b7280;font-size:14px}.result-details{padding-top:16px;border-top:1px solid #e5e7eb}.detail-item{display:flex;align-items:center;gap:8px;margin-bottom:8px}.detail-label{font-weight:600;color:#374151;font-size:14px}.detail-value{background:#f3f4f6;padding:4px 8px;border-radius:6px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;color:#1f2937}@media (max-width:768px){.test-send-page{padding:16px}.header-content{flex-direction:column;text-align:center;gap:12px}.header-icon{width:60px;height:60px;font-size:36px}.title{font-size:24px}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn{width:100%}}input,textarea{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;outline:none;transition:border-color .2s}input:focus,textarea:focus{border-color:#3b82f6}.actions{margin-top:20px}button{transition:all .2s;font-size:15px}button:hover{background:#e5e7eb;border-color:#d1d5db}button.primary:hover{background:#2563eb;border-color:#2563eb}.message{font-size:14px;background:#ecf0f1;padding:8px 12px;border-radius:6px;display:inline-block}.list{margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.list-header h3{font-size:20px;color:#1f2937;margin:0;font-weight:700}.count{background:#f3f4f6;color:#6b7280;padding:4px 12px;border-radius:20px;font-size:14px;font-weight:500}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.template-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .3s ease;box-shadow:0 1px 3px rgba(0,0,0,.1)}.template-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.15);border-color:#3b82f6}.template-content{padding:20px;cursor:pointer;display:flex;align-items:flex-start;gap:12px}.template-icon{font-size:24px;width:40px;height:40px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.template-info{flex:1;min-width:0}.template-name{font-size:16px;font-weight:600;color:#1f2937;margin:0 0 6px 0;line-height:1.4}.template-subject{font-size:14px;color:#6b7280;margin:0 0 8px 0;line-height:1.4;font-weight:500}.template-preview{font-size:13px;color:#9ca3af;line-height:1.4;background:#f9fafb;padding:8px 10px;border-radius:6px;border-left:3px solid #e5e7eb}.template-actions{display:flex;gap:8px;padding:12px 20px;background:#f9fafb;border-top:1px solid #e5e7eb}.btn-apply{flex:1;background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-apply:hover{background:#2563eb;transform:translateY(-1px)}.btn-delete{background:#ef4444;color:#fff;border:none;padding:8px 12px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s ease;min-width:40px}.btn-delete:hover{background:#dc2626;transform:translateY(-1px)}@media (max-width:768px){.template-grid{grid-template-columns:1fr}.list-header{flex-direction:column;align-items:flex-start;gap:8px}.template-content{padding:16px}.template-actions{padding:10px 16px}}.domain-management-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:24px}.header-content{max-width:1200px}.header-text h1{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.content-container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.add-domain-card,.domains-list-card{background:#fff;border-radius:20px;padding:32px;box-shadow:0 8px 40px rgba(0,0,0,.1);border:1px solid #e5e7eb;position:relative;overflow:hidden}.add-domain-card:before,.domains-list-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#1d4ed8,#1e40af)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.card-header .header-text{flex:1}.card-icon{font-size:32px;width:60px;height:60px;background:linear-gradient(135deg,#10b981,#059669);border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(16,185,129,.3)}.card-header h2{margin:0 0 4px 0;font-size:20px}.card-header p{font-size:14px}.domain-form{display:flex;flex-direction:column;gap:20px}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.form-input[readonly]{background:#f3f4f6;color:#6b7280}.submit-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 4px 15px rgba(59,130,246,.3)}.submit-btn:hover:not(:disabled){box-shadow:0 6px 20px rgba(59,130,246,.4)}.refresh-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px rgba(59,130,246,.3);white-space:nowrap}.refresh-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,.4)}.refresh-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.refresh-btn .btn-icon{font-size:16px}.loading-state{text-align:center;padding:60px 20px;color:#6b7280}.loading-icon{font-size:48px;margin-bottom:16px;animation:spin 1s linear infinite}.loading-text{font-size:16px;font-weight:500;color:#374151}.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.empty-icon{font-size:64px;margin-bottom:16px}.empty-text{font-size:18px;font-weight:600;margin-bottom:8px;color:#374151}.empty-subtext{font-size:14px}.domains-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px}.domain-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:20px;transition:all .2s ease}.domain-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(0,0,0,.1);border-color:#3b82f6}.domain-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.domain-name{font-size:18px;font-weight:700;color:#1f2937}.domain-status{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.domain-status.verified{background:#dcfce7;color:#166534}.domain-status.pending{background:#fef3c7;color:#92400e}.domain-status.failed{background:#fecaca;color:#991b1b}.domain-status.unknown{background:#f3f4f6;color:#6b7280}.domain-info{margin-bottom:20px}.info-item{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px}.info-label{color:#6b7280;font-weight:500}.info-value{color:#1f2937;font-weight:600}.domain-actions{display:flex;gap:8px;flex-wrap:wrap}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;flex:1;min-width:0}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.info{background:#dbeafe;color:#1e40af}.action-btn.info:hover:not(:disabled){background:#bfdbfe}.action-btn.success{background:#dcfce7;color:#166534}.action-btn.success:hover:not(:disabled){background:#bbf7d0}.action-btn.warning{background:#fef3c7;color:#92400e}.action-btn.warning:hover:not(:disabled){background:#fde68a}.action-btn.danger{background:#fecaca;color:#991b1b}.action-btn.danger:hover:not(:disabled){background:#fca5a5}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #e5e7eb;margin-bottom:24px}.modal-header h3{margin:0;font-size:20px;font-weight:700;color:#1f2937}.close-btn{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:4px;border-radius:6px;transition:all .2s ease}.close-btn:hover{background:#f3f4f6;color:#374151}.modal-body{padding:0 24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid #e5e7eb;margin-top:24px}.btn{border-radius:8px}.btn.secondary{background:#f3f4f6;color:#374151}.btn.secondary:hover{background:#e5e7eb}.btn.primary{background:#3b82f6;color:#fff}.btn.primary:hover:not(:disabled){background:#2563eb}.btn.primary:disabled{opacity:.6;cursor:not-allowed}@media (max-width:768px){.domain-management-page{padding:16px}.header-content{padding:20px;flex-direction:column;text-align:center}.header-icon{width:60px;height:60px;font-size:36px}.header-text h1{font-size:24px}.add-domain-card,.domains-list-card{padding:24px}.card-header{flex-direction:column;align-items:stretch;gap:12px}.card-header .header-text{text-align:center}.refresh-btn{align-self:center;width:-moz-fit-content;width:fit-content}.domains-grid{grid-template-columns:1fr}.domain-actions{flex-direction:column}.action-btn{flex:none}}@media (max-width:480px){.header-content{padding:16px}.add-domain-card,.domains-list-card{padding:20px}.form-input{padding:12px 14px}.submit-btn{padding:14px 20px;font-size:14px}.modal-content{margin:10px}.modal-body,.modal-footer,.modal-header{padding:16px}}.settings{max-width:720px;margin:48px auto;padding:0 16px}.card{border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.06)}.title{margin:0 0 16px;font-size:20px;text-align:left}.form-row{margin-bottom:12px;display:flex;flex-direction:column}label{margin-bottom:6px;color:#374151;font-weight:500}input{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;outline:none;transition:border-color .2s}input:focus{border-color:#3b82f6}.form-help{margin-top:4px;color:#6b7280;font-size:12px}.actions{display:flex;gap:8px;margin-top:8px}button{padding:10px 14px;border-radius:8px;border:1px solid #d1d5db;background:#f3f4f6;cursor:pointer}button.primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.message{margin-top:12px;color:#2c3e50}.change-password-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:24px}.header-content{max-width:800px}.header-icon{box-shadow:0 8px 25px rgba(239,68,68,.3)}.header-icon,.header-text h1{background:linear-gradient(135deg,#ef4444,#dc2626)}.header-text h1{margin:0 0 8px 0;font-size:28px;font-weight:700;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-text p{margin:0;color:#6b7280;font-size:16px}.form-container{max-width:800px;margin:0 auto}.password-card{background:#fff;border-radius:20px;padding:32px;box-shadow:0 8px 40px rgba(0,0,0,.1);border:1px solid #e5e7eb;position:relative;overflow:hidden}.password-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ef4444,#dc2626,#b91c1c)}.card-header{text-align:center;margin-bottom:32px}.security-icon{font-size:48px;width:80px;height:80px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 8px 25px rgba(245,158,11,.3)}.card-header h2{margin:0 0 8px 0;font-size:24px;font-weight:700;color:#1f2937}.card-header p{margin:0;color:#6b7280;font-size:16px}.password-form{display:flex;flex-direction:column;gap:24px}.form-input{padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:14px;transition:all .2s ease;background:#f9fafb}.form-input:focus{outline:none;border-color:#ef4444;background:#fff;box-shadow:0 0 0 3px rgba(239,68,68,.1);transform:translateY(-1px)}.form-input.error{border-color:#ef4444;background:hsla(0,86%,97%,.8)}.form-input.error:focus{border-color:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.1)}.password-input-wrapper{position:relative}.password-input{padding-right:50px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:18px;padding:4px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.password-toggle:hover{background:rgba(0,0,0,.05)}.password-strength{margin-top:8px}.strength-bar{height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden;margin-bottom:4px}.strength-fill{height:100%;transition:all .3s ease;border-radius:2px}.strength-fill.weak{background:linear-gradient(90deg,#ef4444,#f87171)}.strength-fill.medium{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.strength-fill.strong{background:linear-gradient(90deg,#10b981,#34d399)}.strength-text{font-size:12px;font-weight:500;transition:color .3s ease}.strength-text.weak{color:#dc2626}.strength-text.medium{color:#d97706}.strength-text.strong{color:#059669}.submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 24px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px rgba(239,68,68,.3)}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(239,68,68,.4)}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-icon{font-size:18px}.btn-icon.loading{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.message{margin-top:20px;padding:16px;border-radius:12px;display:flex;align-items:center;gap:12px;animation:slideIn .3s ease}.message.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #10b981;color:#166534}.message.error{background:linear-gradient(135deg,#fef2f2,#fecaca);border:1px solid #ef4444;color:#dc2626}.message-icon{font-size:20px;flex-shrink:0}.message-text{font-size:14px;font-weight:500}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.change-password-page{padding:16px}.header-content{padding:20px;flex-direction:column;text-align:center}.header-icon{width:60px;height:60px;font-size:36px}.header-text h1{font-size:24px}.password-card{padding:24px}.security-icon{width:60px;height:60px;font-size:36px}.card-header h2{font-size:20px}}@media (max-width:480px){.header-content{padding:16px}.password-card{padding:20px}.form-input{padding:12px 14px}.submit-btn{padding:14px 20px;font-size:14px}}.batch-send-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:24px}.page-header{margin-bottom:32px}.header-content{gap:16px;background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 20px rgba(0,0,0,.08);border:1px solid #e5e7eb;max-width:1400px;margin:0 auto}.header-content,.header-icon{display:flex;align-items:center}.header-icon{font-size:48px;width:80px;height:80px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:20px;justify-content:center;box-shadow:0 8px 25px rgba(59,130,246,.3)}.header-text{flex:1}.title{margin:0 0 8px 0;font-size:32px;font-weight:700;color:#1f2937;background:linear-gradient(135deg,#3b82f6,#1d4ed8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{margin:0;color:#6b7280;font-size:16px;font-weight:500}.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1400px;margin:0 auto;align-items:start;grid-template-areas:"form status"}.form-section{grid-area:form}.status-section{grid-area:status}.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:24px;box-shadow:0 4px 20px rgba(0,0,0,.08);transition:all .3s ease;height:-moz-fit-content;height:fit-content}.card:hover{box-shadow:0 8px 30px rgba(0,0,0,.12);transform:translateY(-2px)}.card-header{margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #f3f4f6}.card-header h3{margin:0;font-size:20px;font-weight:600;color:#1f2937}.send-form{display:flex;flex-direction:column;gap:20px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{display:flex;align-items:center;gap:8px;font-weight:600;color:#374151;font-size:14px}.label-icon{font-size:16px}.recipient-count{background:#f3f4f6;color:#6b7280;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;margin-left:auto}.send-config-info{display:flex;gap:16px;margin-bottom:12px;padding:12px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #0ea5e9;border-radius:8px;font-size:13px}.config-item{display:flex;align-items:center;gap:6px}.config-label{color:#6b7280;font-weight:500}.config-value{color:#1f2937;font-weight:600;background:#fff;padding:2px 8px;border-radius:4px;border:1px solid #d1d5db}.sender-input-group{display:flex;align-items:center;gap:0;border:2px solid #e5e7eb;border-radius:16px;padding:6px;background:linear-gradient(135deg,#f8fafc,#fff);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px rgba(0,0,0,.04);position:relative;overflow:hidden}.sender-input-group:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#3b82f6,#1d4ed8);opacity:0;transition:opacity .3s ease;z-index:0}.sender-input-group:focus-within{border-color:#3b82f6;background:#fff;box-shadow:0 8px 25px rgba(59,130,246,.15),0 0 0 4px rgba(59,130,246,.1);transform:translateY(-1px)}.sender-input-group:focus-within:before{opacity:.05}.prefix-input{flex:1;border:none;background:transparent;padding:12px 16px;font-size:14px;font-weight:500;min-width:0;position:relative;z-index:1;color:#1f2937}.prefix-input:focus{outline:none;box-shadow:none}.prefix-input::-moz-placeholder{color:#9ca3af;font-weight:400}.prefix-input::placeholder{color:#9ca3af;font-weight:400}.at-symbol{font-size:18px;font-weight:700;color:#6b7280;padding:0 8px;position:relative;z-index:1;transition:all .3s ease}.sender-input-group:focus-within .at-symbol{color:#3b82f6;transform:scale(1.1)}.domain-select{flex:2;border:none;background:transparent;padding:12px 16px;font-size:14px;font-weight:500;min-width:0;position:relative;z-index:1;color:#1f2937;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px}.domain-select:focus{outline:none;box-shadow:none}.domain-select option{padding:8px 12px;font-weight:500}.domain-select option:disabled{color:#9ca3af;background:#f3f4f6}.sender-preview{display:flex;align-items:center;gap:12px;margin-top:12px;padding:12px 16px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #0ea5e9;border-radius:12px;font-size:13px;position:relative;overflow:hidden}.sender-preview:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#0ea5e9,#0284c7);opacity:.05}.preview-label{color:#0369a1;font-weight:600;position:relative;z-index:1;display:flex;align-items:center;gap:6px}.preview-label:before{content:"👁️";font-size:14px}.preview-email{color:#0c4a6e;font-weight:700;font-family:Monaco,Menlo,Ubuntu Mono,monospace;background:hsla(0,0%,100%,.8);padding:6px 12px;border-radius:8px;border:1px solid rgba(14,165,233,.2);position:relative;z-index:1;box-shadow:0 2px 4px rgba(0,0,0,.05);transition:all .2s ease}.preview-email:hover{background:hsla(0,0%,100%,.95);transform:translateY(-1px);box-shadow:0 4px 8px rgba(0,0,0,.1)}.domain-status-tip{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 12px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #0ea5e9;border-radius:8px;font-size:12px;color:#0369a1;animation:slideIn .3s ease}.domain-status-tip.warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b;color:#92400e}.tip-icon{flex-shrink:0}.tip-text{font-weight:500;line-height:1.4}.form-input,.form-select,.form-textarea{padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:14px;transition:all .2s ease;background:#fafafa}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.recipients-textarea{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;line-height:1.5}.import-section{margin-bottom:12px}.import-controls{display:flex;gap:8px;align-items:center;margin-bottom:8px}.file-input{display:none}.import-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px rgba(16,185,129,.3)}.import-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.4);background:linear-gradient(135deg,#059669,#047857)}.clear-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.clear-btn:hover:not(:disabled){background:#e5e7eb;color:#374151;transform:translateY(-1px)}.clear-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.import-tips{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280;background:#f9fafb;padding:6px 10px;border-radius:6px;border-left:3px solid #10b981}.tip-icon{font-size:14px}.form-actions{display:flex;gap:12px;margin-top:8px}.btn{display:flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:120px;justify-content:center}.btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;box-shadow:0 4px 15px rgba(59,130,246,.3)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(59,130,246,.4)}.btn-secondary{background:#f3f4f6;color:#374151;border:2px solid #e5e7eb}.btn-secondary:hover:not(:disabled){background:#e5e7eb;transform:translateY(-1px)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-icon{font-size:16px}.status-section{display:flex;flex-direction:column;gap:20px;height:-moz-fit-content;height:fit-content;min-height:0}.status-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #0ea5e9}.status-header{gap:16px}.status-header,.status-icon{display:flex;align-items:center}.status-icon{width:48px;height:48px;border-radius:12px;justify-content:center;font-size:24px;background:#0ea5e9;color:#fff}.status-icon.running{background:#f59e0b;animation:pulse 2s infinite}.status-icon.completed{background:#10b981}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.status-text h4{margin:0 0 4px 0;font-size:18px;font-weight:600;color:#1f2937}.status-text p{margin:0;color:#6b7280;font-size:14px}.progress-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.progress-info{display:flex;gap:12px;align-items:center}.thread-info{background:#3b82f6;color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600}.progress-header h4{margin:0;font-size:16px;font-weight:600;color:#1f2937}.progress-text{background:#f59e0b;color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.progress-bar{height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#d97706);border-radius:4px;transition:width .3s ease}.progress-indeterminate{width:100%!important;background:linear-gradient(90deg,#f59e0b,#d97706,#f59e0b);background-size:200% 100%;animation:progress-indeterminate 2s linear infinite}@keyframes progress-indeterminate{0%{background-position:200% 0}to{background-position:-200% 0}}.results-card{max-height:500px;overflow-y:auto}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #f3f4f6}.results-header h4{margin:0;font-size:16px;font-weight:600;color:#1f2937}.results-stats{display:flex;gap:12px}.stat{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600}.stat.success{background:#dcfce7;color:#166534}.stat.error{background:#fef2f2;color:#dc2626}.results-list{display:flex;flex-direction:column;gap:8px}.result-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.result-item.success{background:#f0fdf4;border-color:#bbf7d0}.result-item.error{background:#fef2f2;border-color:#fecaca}.result-item:hover{transform:translateX(4px);box-shadow:0 2px 8px rgba(0,0,0,.1)}.result-icon{font-size:16px;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.result-content{flex:1;min-width:0}.result-email{font-weight:600;color:#1f2937;font-size:14px;margin-bottom:2px}.result-details{font-size:12px;color:#6b7280}.result-id{background:#f3f4f6;padding:2px 6px;border-radius:4px;margin-right:8px}.result-error{color:#dc2626;font-weight:500}@media (max-width:1200px){.content-grid{grid-template-columns:1fr;grid-template-areas:"status" "form";align-items:stretch}.form-section{grid-area:form}.status-section{grid-area:status}}@media (max-width:768px){.batch-send-page{padding:16px}.header-content{flex-direction:column;text-align:center;gap:12px}.header-icon{width:60px;height:60px;font-size:36px}.title{font-size:24px}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn{width:100%}}#app{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-align:left;color:#1f2937;margin:0}#app,.layout{background:#f8fafc}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#1e293b,#0f172a);color:#e2e8f0;padding:0;box-shadow:4px 0 20px rgba(0,0,0,.1);position:relative;overflow-y:auto}.sidebar:before{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,transparent,hsla(0,0%,100%,.1) 50%,transparent)}.brand{padding:20px 16px;border-bottom:1px solid hsla(0,0%,100%,.1);gap:10px;background:hsla(0,0%,100%,.02)}.brand,.brand-icon{display:flex;align-items:center}.brand-icon{font-size:28px;width:40px;height:40px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:10px;justify-content:center;box-shadow:0 4px 15px rgba(59,130,246,.3);flex-shrink:0}.brand-text{flex:1;min-width:0}.brand-title{font-size:16px;font-weight:700;color:#fff;margin-bottom:2px}.brand-subtitle,.brand-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-subtitle{font-size:11px;color:#94a3b8;font-weight:500}.menu{padding:16px 0;display:flex;flex-direction:column;gap:4px}.menu-section{margin-bottom:16px}.menu-item{display:flex;align-items:center;gap:10px;padding:10px 16px;border:none;background:transparent;color:#cbd5e1;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;position:relative;width:100%;text-align:left;border-radius:8px;margin:2px 0}.menu-item:hover{background:hsla(0,0%,100%,.05);color:#fff;transform:translateX(4px)}.menu-item.active{background:linear-gradient(90deg,rgba(59,130,246,.2),rgba(59,130,246,.1));color:#60a5fa;border-right:3px solid #3b82f6}.menu-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,#3b82f6,#1d4ed8)}.item-icon{font-size:14px;width:18px;flex-shrink:0}.item-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expand-icon{font-size:9px;transition:transform .2s ease;color:#64748b;flex-shrink:0}.expand-icon.expanded{transform:rotate(180deg);color:#60a5fa}.submenu{display:flex;flex-direction:column;gap:2px;margin:4px 0 8px 12px;padding-left:16px;border-left:1px solid hsla(0,0%,100%,.1)}.submenu-item{display:flex;align-items:center;gap:8px;padding:6px 12px;border:none;background:transparent;color:#94a3b8;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease;border-radius:6px;margin:1px 0}.submenu-item:hover{background:hsla(0,0%,100%,.05);color:#e2e8f0;transform:translateX(2px)}.submenu-item.active{background:rgba(59,130,246,.15);color:#60a5fa}.submenu-icon{font-size:12px;width:14px;text-align:center;flex-shrink:0}.submenu-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.content{background:#f8fafc;display:flex;flex-direction:column;min-height:100vh}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px rgba(0,0,0,.05);position:sticky;top:0;z-index:100}.topbar-left{flex:1}.breadcrumb{display:flex;align-items:center;gap:8px}.breadcrumb-item{font-size:18px;font-weight:600;color:#1f2937}.topbar-right{display:flex;align-items:center}.user-info{position:relative}.user-avatar{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:12px;cursor:pointer;transition:all .2s ease;background:rgba(59,130,246,.05);border:1px solid rgba(59,130,246,.1)}.user-avatar:hover{background:rgba(59,130,246,.1);transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,.15)}.avatar-circle{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(59,130,246,.3)}.avatar-text{color:#fff;font-weight:600;font-size:16px}.user-details{display:flex;flex-direction:column;align-items:flex-start}.user-name{font-size:14px;font-weight:600;color:#1f2937;line-height:1.2}.user-role{font-size:12px;color:#6b7280;font-weight:500}.dropdown-arrow{font-size:10px;color:#6b7280;transition:transform .2s ease}.dropdown-arrow.expanded{transform:rotate(180deg);color:#3b82f6}.user-dropdown{position:absolute;right:0;top:100%;margin-top:8px;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.1);min-width:280px;overflow:hidden;z-index:1000;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:20px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);display:flex;align-items:center;gap:12px}.dropdown-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px rgba(59,130,246,.3)}.dropdown-avatar-text{color:#fff;font-weight:600;font-size:18px}.dropdown-user-info{flex:1}.dropdown-username{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:2px}.dropdown-email{font-size:13px;color:#6b7280}.dropdown-divider{height:1px;background:#e5e7eb;margin:0}.dropdown-menu{padding:8px 0}.dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 20px;border:none;background:transparent;color:#374151;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;width:100%;text-align:left}.dropdown-item:hover{background:#f9fafb;color:#1f2937}.dropdown-item.logout{color:#dc2626}.dropdown-item.logout:hover{background:#fef2f2;color:#b91c1c}.item-icon{font-size:16px;width:20px;text-align:center}.item-text{flex:1}.content-body{flex:1;padding:24px;overflow-y:auto}@media (max-width:1024px){.layout{grid-template-columns:220px 1fr}.sidebar{padding:0}.brand{padding:16px 12px}.brand-icon{width:36px;height:36px;font-size:24px}.brand-title{font-size:14px}.brand-subtitle{font-size:10px}.menu-item{padding:8px 12px;font-size:12px}.submenu{margin-left:12px;padding-left:12px}.submenu-item{padding:5px 10px;font-size:11px}}@media (max-width:768px){.layout{grid-template-columns:1fr}.sidebar{display:none}.topbar{padding:12px 16px}.content-body{padding:16px}.user-dropdown{min-width:240px}}