.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0ba4a9,#088f93);padding:20px}.login-box{background:#fff;border-radius:16px;padding:48px;box-shadow:0 20px 60px #0003;max-width:420px;width:100%;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:32px}.login-icon{font-size:64px;color:#0ba4a9;margin-bottom:16px}.login-header h1{font-size:32px;color:#333;margin:0 0 8px;font-weight:700}.login-header p{color:#666;margin:0;font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.input-group{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:16px;color:#0ba4a9;font-size:18px}.input-group input{width:100%;padding:14px 16px 14px 48px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:all .3s;box-sizing:border-box}.input-group input:focus{outline:none;border-color:#0ba4a9;box-shadow:0 0 0 3px #0ba4a91a}.input-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fff0f0;color:#d32f2f;padding:12px;border-radius:8px;font-size:14px;border-left:4px solid #d32f2f}.login-button{background:linear-gradient(135deg,#ff7900,#ff6000);color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #ff79004d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center}.login-footer small{color:#999;font-size:12px}.send-message{max-width:900px}.card{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 12px #00000014}.card-header{margin-bottom:24px}.card-header h2{margin:0 0 8px;color:#333;font-size:24px}.card-header p{margin:0;color:#666;font-size:14px}.mode-selector{display:flex;gap:12px;margin-bottom:32px;padding:12px;background:#f9f9f9;border-radius:8px}.mode-button{flex:1;padding:16px;border:2px solid transparent;background:#fff;border-radius:8px;font-size:15px;font-weight:600;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s}.mode-button:hover{border-color:#0ba4a9;color:#0ba4a9}.mode-button.active{background:linear-gradient(135deg,#0ba4a9,#088f93);color:#fff;border-color:#0ba4a9}.message-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-group input,.form-group textarea{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;transition:all .3s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#0ba4a9;box-shadow:0 0 0 3px #0ba4a91a}.form-group input:disabled,.form-group textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group small{color:#999;font-size:12px}.csv-info{background:#f0f9fa;border-left:4px solid #0BA4A9;padding:16px;border-radius:8px;margin:8px 0}.csv-info h4{margin:0 0 12px;color:#0ba4a9;font-size:14px}.csv-info pre{background:#fff;padding:12px;border-radius:6px;overflow-x:auto;font-size:12px;margin:12px 0;border:1px solid #e0e0e0}.csv-info p{margin:8px 0 0;font-size:13px;color:#666}.delay-group{display:grid;grid-template-columns:1fr 1fr;gap:16px}.submit-button{background:linear-gradient(135deg,#ff7900,#ff6000);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s;margin-top:8px}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #ff79004d}.submit-button:disabled{opacity:.6;cursor:not-allowed}.alert{padding:16px;border-radius:8px;margin-top:20px;font-size:14px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-success{background-color:#e8f5e9;color:#2e7d32;border-left:4px solid #4caf50}.alert-error{background-color:#ffebee;color:#c62828;border-left:4px solid #f44336}.alert code{background:#0000001a;padding:2px 6px;border-radius:4px;font-size:11px}.csv-preview{background:#f9f9f9;border-radius:8px;padding:20px;margin:20px 0}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.preview-header h3{margin:0;color:#333;font-size:18px}.btn-cancel{background:#f44336;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.btn-cancel:hover:not(:disabled){background:#d32f2f}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.preview-stats{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.stat-item{background:#fff;padding:12px 20px;border-radius:8px;border-left:4px solid #0BA4A9;flex:1;min-width:120px}.stat-item.valid{border-left-color:#4caf50}.stat-item.invalid{border-left-color:#f44336}.stat-item strong{color:#666;font-size:13px;display:block;margin-bottom:4px}.preview-errors{background:#fff3cd;border-left:4px solid #ff9800;padding:16px;border-radius:8px;margin-bottom:20px}.preview-errors h4{margin:0 0 12px;color:#f57c00;font-size:14px}.preview-errors ul{margin:0;padding-left:20px}.preview-errors li{margin-bottom:8px;font-size:13px;color:#666}.preview-table{background:#fff;border-radius:8px;padding:16px;overflow-x:auto}.preview-table h4{margin:0 0 12px;color:#333;font-size:14px}.preview-table table{width:100%;border-collapse:collapse;font-size:13px}.preview-table th{background:#f5f5f5;padding:10px;text-align:left;font-weight:600;color:#666;border-bottom:2px solid #e0e0e0}.preview-table td{padding:10px;border-bottom:1px solid #f0f0f0;color:#333}.preview-table .msg-preview{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-table .valid-row{background:#fff}.preview-table .invalid-row{background:#ffebee}.preview-table .invalid-row td{color:#999;text-decoration:line-through}@media (max-width: 768px){.card{padding:20px}.mode-selector{flex-direction:column}.delay-group{grid-template-columns:1fr}.preview-stats{flex-direction:column}.stat-item{min-width:auto}.preview-table{overflow-x:auto}.preview-table table{min-width:600px}}.batch-status{max-width:900px}.search-form{margin-bottom:24px}.search-group{display:flex;gap:12px}.search-group input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:all .3s}.search-group input:focus{outline:none;border-color:#0ba4a9;box-shadow:0 0 0 3px #0ba4a91a}.search-group button{background:linear-gradient(135deg,#0ba4a9,#088f93);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s;white-space:nowrap}.search-group button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #0ba4a94d}.search-group button:disabled{opacity:.6;cursor:not-allowed}.batch-result{margin-top:24px;animation:fadeIn .3s ease-in}.batch-header{margin-bottom:24px}.batch-status-badge{display:inline-flex;align-items:center;gap:12px;padding:12px 20px;background:#f9f9f9;border-radius:8px;font-size:16px;font-weight:600}.status-icon{font-size:24px}.status-icon.success{color:#4caf50}.status-icon.error{color:#f44336}.status-icon.processing{color:#ff7900}.status-icon.pending{color:#9e9e9e}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.batch-error{margin-top:12px;padding:12px;background:#ffebee;border-left:4px solid #f44336;border-radius:8px;color:#c62828;font-size:14px}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:24px}.progress-fill{height:100%;background:linear-gradient(90deg,#0ba4a9,#088f93);transition:width .5s ease}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}.stat-card{background:#f9f9f9;padding:20px;border-radius:8px;text-align:center;border-left:4px solid #0BA4A9}.stat-card.success{border-left-color:#4caf50}.stat-card.error{border-left-color:#f44336}.stat-card.pending{border-left-color:#9e9e9e}.stat-value{font-size:32px;font-weight:700;color:#333;margin-bottom:8px}.stat-label{font-size:14px;color:#666;font-weight:600}.recent-messages{margin-top:32px}.recent-messages h3{margin:0 0 16px;font-size:18px;color:#333}.messages-table{display:flex;flex-direction:column;gap:8px}.message-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f9f9f9;border-radius:8px;font-size:14px}.message-number{font-weight:600;color:#333}.message-status{font-weight:600;font-size:12px}.message-status.sent{color:#4caf50}.message-status.failed{color:#f44336}@media (max-width: 768px){.search-group{flex-direction:column}.stats-grid{grid-template-columns:repeat(2,1fr)}.message-row{flex-direction:column;align-items:flex-start;gap:8px}}.history{max-width:900px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.stats-summary{display:flex;gap:12px}.stat-chip{padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600}.stat-chip.success{background:#e8f5e9;color:#2e7d32}.stat-chip.error{background:#ffebee;color:#c62828}.filter-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #e0e0e0;padding-bottom:0}.filter-tab{background:transparent;border:none;padding:12px 20px;font-size:14px;font-weight:600;color:#666;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s;position:relative;top:2px}.filter-tab:hover{color:#0ba4a9}.filter-tab.active{color:#0ba4a9;border-bottom-color:#ff7900}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{display:flex;gap:16px;padding:16px;background:#f9f9f9;border-radius:8px;transition:all .3s;animation:fadeIn .3s ease-in}.history-item:hover{background:#f0f0f0;transform:translate(4px)}.history-status{display:flex;align-items:flex-start;padding-top:4px}.history-content{flex:1}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:8px}.history-number{color:#333;font-size:14px}.history-date{color:#999;font-size:12px}.history-message{color:#666;font-size:14px;line-height:1.5;margin-bottom:8px;word-break:break-word}.history-footer{display:flex;gap:8px;flex-wrap:wrap}.batch-badge,.error-badge{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600}.batch-badge{background:#e3f2fd;color:#1976d2}.error-badge{background:#ffebee;color:#c62828}.empty-state{text-align:center;padding:60px 20px;color:#999}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.3}.empty-state p{margin:0;font-size:16px}.history-footer{margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0;text-align:center;color:#999}.info-card{margin-top:24px;background:linear-gradient(135deg,#fff7ed,#fff3e6);border-left:4px solid #FF7900;padding:20px;border-radius:8px}.info-card h3{margin:0 0 12px;color:#ff7900;font-size:16px}.info-card p{margin:0;color:#666;font-size:14px;line-height:1.6}@media (max-width: 768px){.card-header{flex-direction:column;align-items:flex-start}.filter-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.filter-tab{white-space:nowrap}.history-item{flex-direction:column}.history-header{flex-direction:column;align-items:flex-start}}.dashboard{min-height:100vh;background-color:#f9f9f9}.dashboard-header{background:linear-gradient(135deg,#dbdfe2,#fff);color:#333;padding:20px 40px;box-shadow:0 2px 8px #0000001a}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:20px}.header-logo{height:60px;width:auto;object-fit:contain}.header-info{display:flex;flex-direction:column;gap:4px}.dashboard-header h1{margin:0;font-size:28px;font-weight:700;color:#333}.header-subtitle{margin:0;font-size:13px;color:#666;font-weight:400}.status-indicator{margin-top:4px;font-size:14px}.status-online{color:#4caf50;font-weight:600}.status-offline{color:#ff5252;font-weight:600}.logout-button{background:#f0f0f0;color:#333;border:1px solid #e0e0e0;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .3s}.logout-button:hover{background:#f0f0f0;transform:translateY(-2px)}.dashboard-container{max-width:1400px;margin:0 auto;padding:32px 40px}.dashboard-nav{display:flex;gap:12px;margin-bottom:32px;border-bottom:2px solid #e0e0e0;padding-bottom:0}.nav-button{background:transparent;border:none;padding:16px 24px;font-size:16px;font-weight:600;color:#666;cursor:pointer;display:flex;align-items:center;gap:8px;border-bottom:3px solid transparent;transition:all .3s;position:relative;top:2px}.nav-button:hover{color:#0ba4a9;background:#0ba4a90d}.nav-button.active{color:#0ba4a9;border-bottom-color:#ff7900}.dashboard-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.dashboard-header{padding:16px 20px}.header-content{flex-direction:column;gap:16px}.header-left{flex-direction:column;text-align:center;gap:12px}.header-logo{height:50px}.header-subtitle{font-size:12px}.dashboard-container{padding:20px}.dashboard-nav{flex-direction:column;border-bottom:none}.nav-button{border-bottom:none;border-left:3px solid transparent;justify-content:flex-start}.nav-button.active{border-bottom:none;border-left-color:#ff7900}}*{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:#f9f9f9}.app{min-height:100vh}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0ba4a9,#088f93)}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#0ba4a9;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#088f93}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
