.App{min-height:100vh}.spinner{border:3px solid rgba(0,217,255,.1);border-top:3px solid var(--color-primary);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:20px auto}[data-theme=dark] .spinner{box-shadow:0 0 20px #00d9ff4d}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s;display:inline-flex;align-items:center;gap:8px}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9}.btn-success{background-color:#27ae60;color:#fff}.btn-success:hover{background-color:#229954}.btn-danger{background-color:#f36;color:#fff}.btn-danger:hover{background-color:#e62958;transform:translateY(-1px);box-shadow:0 4px 12px #ff33664d}[data-theme=dark] .btn-danger{background:linear-gradient(135deg,#f36,#cc2952)}[data-theme=dark] .btn-danger:hover{box-shadow:0 6px 20px #ff336680}.card{background:var(--color-card);border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;border:1px solid var(--color-border)}.form-label{display:block;margin-bottom:5px;font-weight:600;color:var(--color-text)}.form-input{width:100%;padding:10px;border:1px solid var(--color-border);border-radius:4px;font-size:14px;background:var(--color-bg-alt);color:var(--color-text)}.form-input:focus{outline:none;border-color:var(--color-primary)}.form-error{color:#e74c3c;font-size:12px;margin-top:5px}.table{width:100%;background:var(--color-card)}.table th,.table td{padding:12px;text-align:left;border-bottom:1px solid var(--color-border);color:var(--color-text)}.table th{background-color:var(--color-bg-alt);font-weight:600}.table tr:hover{background-color:var(--color-bg-alt)}.table tr:hover{background-color:#f8f9fa}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;border-radius:12px;padding:40px;width:100%;max-width:450px;box-shadow:0 10px 40px #0003}.auth-header{text-align:center;margin-bottom:30px}.auth-header h1{font-size:28px;color:#333;margin-bottom:8px}.auth-header p{color:#666;font-size:14px}.auth-form{margin-bottom:20px}.form-group-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.checkbox-label{display:flex;align-items:center;font-size:14px;color:#666;cursor:pointer}.checkbox-label input{margin-right:8px}.btn-block{width:100%;margin-top:10px}.link{color:#3498db;text-decoration:none;font-size:14px;transition:color .3s}.link:hover{color:#2980b9;text-decoration:underline}.auth-footer{text-align:center;padding-top:20px;border-top:1px solid #eee}.auth-footer p{color:#666;font-size:14px;margin:0}.dashboard-layout{display:flex;min-height:100vh;background-color:var(--color-bg);transition:background-color .3s;position:relative}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media(max-width:768px){.sidebar-backdrop{display:block}}.sidebar{width:250px;background:var(--color-sidebar);color:var(--color-sidebar-text);display:flex;flex-direction:column;transition:width .3s,background .3s;position:fixed;height:100vh;overflow-y:auto;z-index:1000;border-right:1px solid var(--color-border)}.sidebar.closed{width:60px}.sidebar-header{padding:20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--color-border)}.sidebar-header h2{font-size:20px;margin:0;white-space:nowrap}.sidebar.closed .sidebar-header h2{display:none}.toggle-btn{background:none;border:none;color:var(--color-sidebar-text);cursor:pointer;padding:5px;display:flex;align-items:center;justify-content:center;transition:color .3s}.sidebar-nav{flex:1;padding:20px 0}.nav-item{display:flex;align-items:center;gap:15px;padding:12px 20px;color:var(--color-sidebar-text);text-decoration:none;transition:all .3s;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-size:14px;opacity:.8;position:relative;border-left:3px solid transparent}.nav-item:hover{background-color:#00d9ff1a;opacity:1;color:var(--color-primary)}[data-theme=dark] .nav-item:hover{box-shadow:inset var(--glow-cyan)}.nav-item.active{background-color:#00d9ff26;color:var(--color-primary);border-left:3px solid var(--color-primary);opacity:1;font-weight:600}[data-theme=dark] .nav-item.active{box-shadow:inset var(--glow-cyan)}.sidebar.closed .nav-item{justify-content:center;padding:12px}.sidebar.closed .nav-item span{display:none}.sidebar-footer{padding:20px 0;border-top:1px solid var(--color-border)}.logout-btn{color:#f36;font-weight:500}.logout-btn:hover{background-color:#ff336626;color:#f36}[data-theme=dark] .logout-btn{color:#f36}[data-theme=dark] .logout-btn:hover{background-color:#f363;box-shadow:inset 0 0 10px #ff33664d}.main-content{flex:1;margin-left:250px;transition:margin-left .3s;display:flex;flex-direction:column}.sidebar.closed~.main-content{margin-left:60px}.top-header{background:var(--color-header);padding:15px 30px;box-shadow:0 2px 8px #00000026;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--color-border);transition:background .3s,border-color .3s}[data-theme=dark] .top-header{box-shadow:0 2px 12px #00d9ff1a}.mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:5px}.header-actions{display:flex;align-items:center;gap:20px}.user-menu{display:flex;align-items:center;gap:10px}.user-info{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-weight:600;font-size:14px;color:var(--color-header-text)}.user-role{font-size:12px;color:var(--color-text);opacity:.7;text-transform:capitalize}.page-content{flex:1;overflow-y:auto}@media(max-width:768px){.sidebar{transform:translate(-100%);width:250px!important}.sidebar.open{transform:translate(0);box-shadow:2px 0 10px #0000004d}.main-content{margin-left:0!important}.mobile-toggle{display:flex;color:var(--color-header-text)}.header-actions .btn{padding:8px 12px;font-size:13px}.header-actions .btn span,.user-info{display:none}}} .dashboard-container{padding:20px}.dashboard-header{margin-bottom:30px}.dashboard-header h1{font-size:28px;color:#333;margin-bottom:5px}.dashboard-header p{color:#666;font-size:14px}.stat-card{background:#fff;border-radius:8px;padding:20px;display:flex;align-items:center;gap:15px;box-shadow:0 2px 4px #0000001a;border-left:4px solid}.stat-icon{font-size:40px}.stat-content h3{font-size:32px;margin:0;color:#333}.stat-content p{margin:5px 0 0;color:#666;font-size:14px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.empty-state{text-align:center;color:#999;padding:40px 20px}.quick-actions{display:flex;flex-direction:column;gap:10px;padding:10px 0}.quick-actions .btn{width:100%}.bots-list{display:flex;flex-direction:column;gap:10px;padding:10px 0}.bot-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#f8f9fa;border-radius:6px;cursor:pointer;transition:all .2s ease}.bot-item:hover{background:#e9ecef;transform:translate(5px)}.bot-item strong{display:block;color:#333;font-size:15px}.bot-username{color:#666;font-size:13px;margin-left:8px}.badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize}.badge-success{background:#d4edda;color:#155724}.badge-secondary{background:#e2e3e5;color:#383d41}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-content.details-modal{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:24px;color:#333}.close-btn{background:none;border:none;cursor:pointer;padding:5px;color:#666;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.close-btn:hover{background:#f0f0f0;color:#333}.modal-form,.modal-body{padding:20px}.form-hint{display:block;margin-top:5px;color:#999;font-size:12px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover{background:#d0d0d0}.details-section{margin-bottom:25px}.details-section:last-child{margin-bottom:0}.details-section h3{font-size:16px;margin:0 0 15px;color:#333;font-weight:600}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-label{font-size:12px;color:#999;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:14px;color:#333}.token-display{display:flex;align-items:center;gap:10px;padding:12px;background:#f8f9fa;border-radius:6px;margin-bottom:10px}.token-display code{flex:1;font-family:Courier New,monospace;font-size:13px;color:#333;word-break:break-all}.token-actions{display:flex;gap:5px}.btn-icon{background:#fff;border:1px solid #ddd;padding:6px 10px;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#e9ecef;border-color:#bbb}.warning-text{display:block;color:#e67e22;font-size:12px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}.stat-box{text-align:center;padding:15px;background:#f8f9fa;border-radius:8px}.stat-number{display:block;font-size:24px;font-weight:700;color:#3498db;margin-bottom:5px}.stat-label{display:block;font-size:12px;color:#666}.webhook-info{padding:12px;background:#f8f9fa;border-radius:6px}.webhook-url{display:block;margin-top:5px;font-family:Courier New,monospace;font-size:12px;color:#3498db;word-break:break-all}.modal-footer{padding:20px;border-top:1px solid #eee;display:flex;justify-content:flex-end}@media(max-width:768px){.modal-content{max-width:100%;margin:0}.details-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}.page-container{padding:20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{font-size:28px;margin:0 0 5px;color:#333}.page-header p{margin:0;color:#666;font-size:14px}.page-header .btn{display:flex;align-items:center;gap:8px}.bots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.bot-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.bot-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.bot-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid #eee}.bot-info h3{margin:0 0 5px;font-size:18px;color:#333}.bot-username{color:#666;font-size:14px}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;color:#fff;text-transform:capitalize}.bot-card-body{margin-bottom:15px}.bot-description{color:#666;font-size:14px;margin-bottom:15px;line-height:1.5}.bot-stats{display:flex;gap:20px;margin-bottom:15px}.stat-item{display:flex;flex-direction:column}.stat-label{font-size:12px;color:#999;margin-bottom:2px}.stat-value{font-size:20px;font-weight:600;color:#333}.bot-meta{font-size:12px;color:#999}.bot-card-actions{display:flex;gap:8px;padding-top:15px;border-top:1px solid #eee}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:8px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s;color:#666}.action-btn:hover{background:#e9ecef;color:#333}.action-btn.delete{color:#e74c3c}.action-btn.delete:hover{background:#fee;border-color:#e74c3c}.empty-state h3{font-size:20px;margin-bottom:10px;color:#333}.empty-state .btn{display:inline-flex;align-items:center;gap:8px}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:15px}.bots-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.5rem;color:#333}.close-btn{background:none;border:none;cursor:pointer;color:#666;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background-color:#f5f5f5;color:#333}.modal-form{padding:20px}.form-label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-input{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-input:focus{outline:none;border-color:#667eea}.form-error{display:block;color:#e74c3c;font-size:12px;margin-top:4px}.form-hint{display:block;color:#666;font-size:12px;margin-top:4px;line-height:1.4}.form-hint code{background:#f0f0f0;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:11px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:20px;border-top:1px solid #e0e0e0;margin-top:20px}.btn{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background-color:#5568d3}.btn-secondary{background-color:#f5f5f5;color:#333;border:1px solid #ddd}.btn-secondary:hover:not(:disabled){background-color:#e0e0e0}.filter-tabs{display:flex;gap:12px;margin-bottom:24px;padding:8px;background:var(--color-bg-alt);border-radius:12px;border:1px solid var(--color-border)}.filter-tabs button{flex:1;padding:12px 24px;background:transparent;border:none;border-radius:8px;color:var(--color-text);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.filter-tabs button:hover{background:var(--color-card)}.filter-tabs button.active{background:var(--color-primary);color:#fff}[data-theme=dark] .filter-tabs button.active{background:linear-gradient(135deg,#00d9ff,#00a3cc);box-shadow:0 4px 12px #00d9ff4d}.channels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.channel-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:24px;transition:all .3s}.channel-card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}[data-theme=dark] .channel-card:hover{box-shadow:0 8px 24px #00d9ff33}.channel-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}.channel-info{display:flex;gap:12px;align-items:center}.channel-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);border-radius:12px;color:#fff}[data-theme=dark] .channel-icon{background:linear-gradient(135deg,#00d9ff,#00a3cc);box-shadow:0 4px 12px #00d9ff4d}.channel-info h3{margin:0;font-size:18px;color:var(--color-text)}.channel-username{font-size:14px;color:var(--color-text);opacity:.7}.channel-card-body{margin-bottom:16px}.channel-type-badge{display:inline-block;padding:4px 12px;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:16px;font-size:12px;font-weight:600;margin-bottom:12px;color:var(--color-text)}[data-theme=dark] .channel-type-badge{background:#00d9ff1a;border-color:#00d9ff4d;color:#00d9ff}.channel-description{font-size:14px;color:var(--color-text);opacity:.8;margin-bottom:16px;line-height:1.5}.channel-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.stat-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--color-bg-alt);border-radius:8px;border:1px solid var(--color-border)}.stat-label{font-size:12px;color:var(--color-text);opacity:.6;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:18px;font-weight:700;color:var(--color-primary)}[data-theme=dark] .stat-value{color:#00d9ff}.channel-bot{padding:8px 12px;background:var(--color-bg-alt);border-radius:8px;border-left:3px solid var(--color-primary);margin-bottom:12px}.channel-bot span{font-size:13px;color:var(--color-text)}.channel-meta{font-size:12px;color:var(--color-text);opacity:.5}.channel-card-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--color-border)}.action-btn{padding:8px 12px;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;color:var(--color-text);transition:all .3s;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff;transform:scale(1.05)}[data-theme=dark] .action-btn:hover{background:#00d9ff;box-shadow:0 0 12px #00d9ff66}.action-btn.delete:hover{background:var(--color-danger);border-color:var(--color-danger)}[data-theme=dark] .action-btn.delete:hover{background:#f36;box-shadow:0 0 12px #f366}@media(max-width:768px){.channels-grid{grid-template-columns:1fr}.filter-tabs{flex-direction:column}.channel-stats{grid-template-columns:1fr}}.filters-bar{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap}.search-box{flex:1;min-width:250px;display:flex;align-items:center;gap:10px;padding:10px 15px;background:#fff;border:1px solid #ddd;border-radius:8px}.search-box input{flex:1;border:none;outline:none;font-size:14px}.filter-select{padding:10px 15px;border:1px solid #ddd;border-radius:8px;background:#fff;font-size:14px;cursor:pointer;outline:none}.filter-select:focus{border-color:#3498db}.user-cell{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.user-info{display:flex;flex-direction:column}.user-name{font-weight:500;color:#333}.user-username{font-size:12px;color:#666}.bot-badge{padding:4px 12px;background:#e3f2fd;color:#1976d2;border-radius:12px;font-size:12px;font-weight:500}.table-actions{display:flex;gap:8px}.table-actions .action-btn.success{color:#27ae60}.table-actions .action-btn.success:hover{background:#e8f5e9;border-color:#27ae60}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:20px;padding:20px;background:#fff;border-radius:8px}.page-info{color:#666;font-size:14px}@media(max-width:768px){.filters-bar{flex-direction:column}.search-box{min-width:100%}.table{font-size:12px}.user-avatar{width:32px;height:32px;font-size:14px}}.tabs{display:flex;gap:10px;margin-bottom:20px}.tab{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;color:#666;transition:all .3s}.tab:hover{border-color:#3498db;color:#3498db}.tab.active{background:#3498db;color:#fff;border-color:#3498db}.broadcast-form{max-width:800px}.form-actions{display:flex;gap:10px;margin-top:20px}.broadcast-list{display:flex;flex-direction:column;gap:15px}.broadcast-item{padding:20px;border:1px solid #eee;border-radius:8px;background:#fafafa}.broadcast-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.broadcast-header h4{margin:0 0 5px;font-size:16px;color:#333}.broadcast-date{font-size:12px;color:#999}.broadcast-message{padding:15px;background:#fff;border-radius:6px;margin-bottom:15px;line-height:1.6;color:#333;white-space:pre-wrap}.broadcast-stats{display:flex;gap:30px}.broadcast-stats .stat{display:flex;gap:8px;font-size:14px}.broadcast-stats .stat-label{color:#999}.broadcast-stats .stat-value{color:#333;font-weight:600}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content.large{width:100%;max-width:900px;max-height:90vh;overflow-y:auto;background:var(--color-card);border-radius:12px;box-shadow:0 20px 60px #0000004d}[data-theme=dark] .modal-content.large{box-shadow:0 20px 60px #00d9ff33;border:1px solid rgba(0,217,255,.2)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0;font-size:24px;color:var(--color-text)}.close-btn{background:none;border:none;cursor:pointer;color:var(--color-text);padding:8px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .3s}.close-btn:hover{background:var(--color-bg-alt)}.pattern-form{padding:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.form-group{margin-bottom:20px}.form-group label{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-weight:500;color:var(--color-text);font-size:14px}.char-count{font-size:12px;opacity:.7;font-weight:400}.char-count.error{color:var(--color-danger);font-weight:600}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px;border:1px solid var(--color-border);border-radius:6px;font-size:14px;background:var(--color-bg-alt);color:var(--color-text);transition:all .3s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary)}[data-theme=dark] .form-group input:focus,[data-theme=dark] .form-group textarea:focus,[data-theme=dark] .form-group select:focus{box-shadow:0 0 0 3px #00d9ff1a}.form-group textarea{resize:vertical;font-family:Courier New,monospace;line-height:1.6}.help-text{display:block;margin-top:6px;font-size:12px;color:var(--color-text);opacity:.6}.validation-errors{margin-top:12px;padding:12px;background:#e74c3c1a;border:1px solid var(--color-danger);border-radius:6px}.error-item{display:flex;align-items:center;gap:8px;color:var(--color-danger);font-size:13px;margin-bottom:6px}.error-item:last-child{margin-bottom:0}.validation-success{margin-top:12px;padding:12px;background:#27ae601a;border:1px solid var(--color-success);border-radius:6px;display:flex;align-items:center;gap:8px;color:var(--color-success);font-size:13px}[data-theme=dark] .validation-success{background:#00ff881a;border-color:#0f8;color:#0f8}.form-checkbox{margin-bottom:20px}.form-checkbox label{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:14px;color:var(--color-text)}.form-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-section{margin-bottom:24px;padding:20px;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:8px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{margin:0;font-size:16px;color:var(--color-text)}.btn-sm{padding:6px 12px;font-size:13px;display:flex;align-items:center;gap:6px}.variable-row,.button-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:12px;margin-bottom:12px}.variable-row:last-child,.button-row:last-child{margin-bottom:0}.variable-row input,.button-row input{padding:10px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;background:var(--color-card);color:var(--color-text)}.variable-row button,.button-row button{padding:10px;background:none;border:1px solid var(--color-danger);color:var(--color-danger);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}.variable-row button:hover,.button-row button:hover{background:var(--color-danger);color:#fff}.preview-section{margin-top:32px;padding:24px;background:var(--color-bg-alt);border-radius:8px;border:1px solid var(--color-border)}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.preview-header h3{margin:0;font-size:18px;color:var(--color-text)}.preview-content{display:flex;flex-direction:column;gap:24px}.preview-variables{padding:16px;background:var(--color-card);border-radius:8px;border:1px solid var(--color-border)}.preview-variables h4{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--color-text);opacity:.8;text-transform:uppercase;letter-spacing:.5px}.variables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.preview-variable-input{display:flex;flex-direction:column;gap:6px}.preview-variable-input label{font-size:12px;font-weight:500;color:var(--color-text);opacity:.9}.preview-variable-input input{padding:8px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text);font-size:14px;transition:all .3s}.preview-variable-input input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #007bff1a}.preview-message{padding:16px;background:var(--color-card);border-radius:8px;border:1px solid var(--color-border)}.preview-message h4{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--color-text);opacity:.8;text-transform:uppercase;letter-spacing:.5px}.message-bubble{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:16px;max-width:500px;box-shadow:0 2px 8px #0000001a}[data-theme=dark] .message-bubble{background:#1a1a1a;box-shadow:0 2px 8px #00d9ff1a}.message-text{color:var(--color-text);line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.message-text strong{font-weight:700}.message-text em{font-style:italic}.message-text code{background:#0000001a;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:.9em}[data-theme=dark] .message-text code{background:#ffffff1a}.preview-buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.preview-button{padding:8px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:default;transition:all .3s}.preview-button:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.preview-info{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border);font-size:13px;color:var(--color-text);opacity:.7}.preview-info strong{color:var(--color-primary);font-weight:600}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid var(--color-border)}@media(max-width:768px){.modal-content.large{max-width:100%;max-height:100vh;border-radius:0}.form-row,.variable-row,.button-row{grid-template-columns:1fr}.variable-row button,.button-row button{width:100%}}.message-patterns-page{padding:24px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.page-header h1{font-size:28px;margin-bottom:8px;color:var(--color-text)}.page-header p{color:var(--color-text);opacity:.7}.patterns-toolbar{display:flex;gap:16px;margin-bottom:24px}.search-box{flex:1;display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px}.search-box input{flex:1;border:none;background:none;font-size:14px;color:var(--color-text)}.search-box input:focus{outline:none}.category-filter{padding:12px 16px;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:14px;cursor:pointer;min-width:180px}.patterns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.pattern-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:20px;transition:all .3s}.pattern-card:hover{transform:translateY(-4px)}[data-theme=dark] .pattern-card:hover{box-shadow:0 8px 24px #00d9ff26;border-color:#00d9ff4d}.pattern-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.pattern-title{display:flex;align-items:center;gap:12px;flex:1}.pattern-title h3{font-size:18px;margin:0;color:var(--color-text)}.pattern-status .active{color:var(--color-success)}.pattern-status .inactive{color:var(--color-danger)}.pattern-description{font-size:13px;color:var(--color-text);opacity:.7;margin-bottom:16px;line-height:1.5}.pattern-content{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:6px;padding:12px;margin-bottom:16px;max-height:120px;overflow:hidden}.pattern-content code{font-family:Courier New,monospace;font-size:12px;color:var(--color-text);line-height:1.6;white-space:pre-wrap;word-break:break-word}[data-theme=dark] .pattern-content{background:#00d9ff0d}.pattern-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.meta-item{display:flex;flex-direction:column;gap:4px}.meta-item .label{font-size:11px;color:var(--color-text);opacity:.6;text-transform:uppercase;letter-spacing:.5px}.meta-item .value{font-size:13px;color:var(--color-text);font-weight:500}.pattern-stats{font-size:13px;color:var(--color-text);opacity:.6;margin-bottom:16px;padding-top:12px;border-top:1px solid var(--color-border)}.pattern-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--color-border)}.btn-icon{padding:8px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:all .3s;color:var(--color-text)}.btn-icon:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}[data-theme=dark] .btn-icon:hover{box-shadow:0 0 10px #00d9ff80}.btn-icon.btn-danger:hover{background:var(--color-danger);border-color:var(--color-danger)}.badge{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge.welcome{background:#3498db1a;color:#3498db}.badge.help{background:#9b59b61a;color:#9b59b6}.badge.promo{background:#f1c40f1a;color:#f1c40f}.badge.notification{background:#2ecc711a;color:#2ecc71}.badge.custom{background:#95a5a61a;color:#95a5a6}[data-theme=dark] .badge{border:1px solid currentColor}.empty-state{text-align:center;padding:80px 20px;color:var(--color-text);opacity:.6}.empty-state p{font-size:16px;margin-bottom:24px}@media(max-width:768px){.patterns-grid{grid-template-columns:1fr}.page-header{flex-direction:column;gap:16px}.patterns-toolbar{flex-direction:column}.category-filter{width:100%}}.send-message-page{padding:24px}.send-message-layout{display:grid;grid-template-columns:1fr 400px;gap:24px}.message-composer h2,.message-history h2{display:flex;align-items:center;gap:12px;margin-bottom:24px;font-size:20px;color:var(--color-text)}.recipient-type-tabs{display:flex;gap:12px;margin-top:8px}.recipient-type-tabs label{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--color-bg-alt);border:2px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .3s}.recipient-type-tabs input[type=radio]{display:none}.recipient-type-tabs label:hover{border-color:var(--color-primary);background:#3498db0d}.recipient-type-tabs label.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}[data-theme=dark] .recipient-type-tabs label.active{background:linear-gradient(135deg,#00d9ff,#00a3cc);box-shadow:0 4px 12px #00d9ff4d}.formatting-toolbar{display:flex;gap:8px;margin-bottom:12px;padding:8px;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:6px}.formatting-toolbar button{padding:6px 12px;background:var(--color-card);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;color:var(--color-text);transition:all .3s}.formatting-toolbar button:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}[data-theme=dark] .formatting-toolbar button:hover{box-shadow:0 0 8px #00d9ff66}#message-input{font-family:Courier New,monospace;line-height:1.6;resize:vertical}.btn-block{width:100%;justify-content:center}.search-box{position:relative;margin-bottom:12px}.search-box svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text);opacity:.5;pointer-events:none}.search-box input{width:100%;padding:10px 12px 10px 40px;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:14px;transition:all .3s}.search-box input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3498db1a}[data-theme=dark] .search-box input:focus{border-color:#00d9ff;box-shadow:0 0 0 3px #00d9ff26}.subscriber-list{max-height:400px;overflow-y:auto;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-alt)}.subscriber-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--color-border);transition:all .3s}.subscriber-item:last-child{border-bottom:none}.subscriber-item:hover{background:var(--color-card)}[data-theme=dark] .subscriber-item:hover{background:#00d9ff0d}.subscriber-item.select-all{font-weight:600;background:var(--color-card);border-bottom:2px solid var(--color-primary)}[data-theme=dark] .subscriber-item.select-all{background:#00d9ff14;border-bottom-color:#00d9ff}.subscriber-item svg{color:var(--color-text);opacity:.5;flex-shrink:0;transition:all .3s}.subscriber-item svg.checked{color:var(--color-primary);opacity:1}[data-theme=dark] .subscriber-item svg.checked{color:#00d9ff}.subscriber-info{flex:1;display:flex;flex-direction:column;gap:4px}.subscriber-info strong{color:var(--color-text);font-size:14px}.subscriber-info small{color:var(--color-text);opacity:.6;font-size:12px}.selected-count{margin-left:8px;padding:2px 8px;background:var(--color-primary);color:#fff;border-radius:12px;font-size:12px;font-weight:600}[data-theme=dark] .selected-count{background:#00d9ff;color:#0a0e27}.message-history{position:sticky;top:90px;max-height:calc(100vh - 140px);overflow-y:auto}.history-list{display:flex;flex-direction:column;gap:16px}.history-item{padding:16px;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:8px;transition:all .3s}.history-item:hover{border-color:var(--color-primary)}[data-theme=dark] .history-item:hover{box-shadow:0 4px 12px #00d9ff26}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.bot-badge{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#3498db1a;border-radius:12px;font-size:12px;font-weight:600;color:var(--color-primary)}[data-theme=dark] .bot-badge{background:#00d9ff26;color:#00d9ff}.status-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.sent{background:#27ae601a;color:var(--color-success);border:1px solid var(--color-success)}.status-badge.failed{background:#e74c3c1a;color:var(--color-danger);border:1px solid var(--color-danger)}[data-theme=dark] .status-badge.sent{background:#00ff8826;color:#0f8;border-color:#0f8}.history-recipient{font-size:13px;color:var(--color-text);opacity:.8;margin-bottom:8px}.history-message{font-size:13px;color:var(--color-text);line-height:1.5;margin-bottom:8px;padding:8px;background:var(--color-card);border-radius:4px;border-left:3px solid var(--color-primary)}.history-time{font-size:11px;color:var(--color-text);opacity:.5;text-align:right}.empty-state{text-align:center;padding:40px 20px;color:var(--color-text);opacity:.6}@media(max-width:1200px){.send-message-layout{grid-template-columns:1fr}.message-history{position:relative;top:0;max-height:500px}}@media(max-width:768px){.recipient-type-tabs{flex-direction:column}.formatting-toolbar{flex-wrap:wrap}}.help-text{display:block;margin-top:8px;padding:12px;font-size:13px;color:#555;line-height:1.8;background:#f8f9fa;border-left:3px solid var(--color-primary);border-radius:4px}[data-theme=dark] .help-text{background:#00d9ff1a;color:#bbb}.help-text strong{color:var(--color-primary);display:block;margin-bottom:6px;font-size:14px}.help-text code{background:#e9ecef;padding:2px 6px;border-radius:3px;font-size:12px;color:#e74c3c;word-break:break-all;font-family:Courier New,monospace}[data-theme=dark] .help-text code{background:#ffffff1a;color:#00d9ff}.help-text br{line-height:2}.send-channel-form{max-width:900px;margin:0 auto}.channel-info{background:#f8f9fa;border-radius:8px;padding:20px;margin-bottom:20px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px}.info-item{display:flex;flex-direction:column;gap:5px}.info-label{font-size:12px;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:14px;color:#333;font-weight:500}.verification-section{border-top:1px solid #e0e0e0;padding-top:15px}.verification-result{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-hint code{background:#f0f0f0;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:12px}.btn-large{padding:12px 30px;font-size:16px}.empty-state{text-align:center;padding:60px 20px}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{margin-bottom:10px;color:#333}.empty-state p{color:#666;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:#fff;border-radius:12px;padding:20px;display:flex;gap:15px;box-shadow:0 2px 8px #0000000d;transition:transform .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.stat-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.stat-content{flex:1}.stat-content h3{margin:0 0 8px;font-size:14px;color:#999;font-weight:500}.stat-value{margin:0 0 5px;font-size:28px;font-weight:700;color:#333}.stat-change{font-size:12px;color:#999}.stat-change.positive{color:#2ecc71}.stat-change.negative{color:#e74c3c}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:20px;margin-bottom:20px}.chart-title{margin:0 0 20px;font-size:18px;color:#333;font-weight:600}.activity-list{display:flex;flex-direction:column;gap:15px}.activity-item{display:flex;gap:15px;align-items:flex-start}.activity-dot{width:10px;height:10px;border-radius:50%;margin-top:5px;flex-shrink:0}.activity-content{flex:1}.activity-text{margin:0 0 5px;color:#333;font-size:14px}.activity-time{font-size:12px;color:#999}@media(max-width:768px){.charts-grid,.stats-grid{grid-template-columns:1fr}}.settings-layout{display:grid;grid-template-columns:250px 1fr;gap:20px}.settings-sidebar{display:flex;flex-direction:column;gap:8px}.settings-tab{padding:12px 20px;background:#fff;border:1px solid #ddd;border-radius:8px;text-align:left;cursor:pointer;font-size:14px;transition:all .3s;color:#666}.settings-tab:hover{border-color:#3498db;color:#3498db}.settings-tab.active{background:#3498db;color:#fff;border-color:#3498db}.settings-content{min-height:400px}.settings-content .card h2{margin:0 0 20px;font-size:20px;color:#333}.settings-form{max-width:500px}.settings-form .btn{display:inline-flex;align-items:center;gap:8px;margin-top:10px}.checkbox-group{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.checkbox-group .checkbox-label{display:flex;align-items:center;gap:10px;font-size:14px;color:#333;cursor:pointer}.checkbox-group .checkbox-label input{cursor:pointer}@media(max-width:768px){.settings-layout{grid-template-columns:1fr}.settings-sidebar{flex-direction:row;overflow-x:auto}.settings-tab{white-space:nowrap}}*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #f5f5f5;--color-bg-alt: #fff;--color-text: #222;--color-primary: #3498db;--color-primary-dark: #2980b9;--color-success: #27ae60;--color-danger: #e74c3c;--color-border: #e0e0e0;--color-card: #fff;--color-sidebar: #222c36;--color-sidebar-text: #fff;--color-sidebar-active: #3498db;--color-header: #fff;--color-header-text: #222;--transition: .3s}[data-theme=dark]{--color-bg: #0a0e27;--color-bg-alt: #0f1729;--color-text: #e0e7ff;--color-primary: #00d9ff;--color-primary-dark: #00a3cc;--color-success: #00ff88;--color-danger: #ff3366;--color-border: #1a2332;--color-card: #0f1729;--color-sidebar: #06080f;--color-sidebar-text: #e0e7ff;--color-sidebar-active: #00d9ff;--color-header: #0f1729;--color-header-text: #e0e7ff;--shadow-cyber: 0 0 20px rgba(0, 217, 255, .15);--glow-cyan: 0 0 10px rgba(0, 217, 255, .5)}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:var(--color-bg);color:var(--color-text);transition:background var(--transition),color var(--transition)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.card{background:var(--color-card);border-radius:12px;box-shadow:0 2px 8px #0000000a;padding:24px;margin-bottom:24px;border:1px solid var(--color-border);transition:background var(--transition),border var(--transition),box-shadow var(--transition)}[data-theme=dark] .card{box-shadow:0 4px 16px #00d9ff14,inset 0 0 0 1px #00d9ff1a}[data-theme=dark] .card:hover{box-shadow:0 6px 20px #00d9ff1f,inset 0 0 0 1px #00d9ff33}[data-theme=dark] .btn-primary{background:linear-gradient(135deg,#00d9ff,#00a3cc);box-shadow:0 4px 12px #00d9ff4d}[data-theme=dark] .btn-primary:hover{box-shadow:0 6px 20px #00d9ff80;transform:translateY(-2px)}[data-theme=dark] .btn-secondary{background:#00d9ff1a;border:1px solid rgba(0,217,255,.3);color:#00d9ff}[data-theme=dark] .btn-secondary:hover{background:#00d9ff33;box-shadow:0 0 15px #00d9ff4d}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select{background:#0f1729cc;border:1px solid rgba(0,217,255,.2);color:#e0e7ff}[data-theme=dark] input:focus,[data-theme=dark] textarea:focus,[data-theme=dark] select:focus{border-color:#00d9ff;box-shadow:0 0 10px #00d9ff4d;outline:none}[data-theme=dark] table{background:var(--color-card);border:1px solid rgba(0,217,255,.1)}[data-theme=dark] th{background:#00d9ff0d;border-bottom:2px solid rgba(0,217,255,.3)}[data-theme=dark] tr:hover{background:#00d9ff0d}[data-theme=dark] td{border-bottom:1px solid rgba(0,217,255,.1)}[data-theme=dark] .badge{background:#00d9ff26;border:1px solid rgba(0,217,255,.3);color:#00d9ff;text-shadow:0 0 5px rgba(0,217,255,.5)}[data-theme=dark] .badge.success{background:#00ff8826;border-color:#00ff884d;color:#0f8;text-shadow:0 0 5px rgba(0,255,136,.5)}[data-theme=dark] .badge.danger{background:#ff336626;border-color:#ff33664d;color:#f36;text-shadow:0 0 5px rgba(255,51,102,.5)}*{transition:background .3s,color .3s,border-color .3s}
