:root{--bg-primary:#fff;--bg-secondary:#f7f8fa;--bg-card:#fff;--bg-hover:#f0f2f5;--bg-input:#f7f8fa;--bg-overlay:#0f172a80;--text-primary:#0f1729;--text-secondary:#5a6275;--text-muted:#9ca3b0;--text-inverse:#fff;--accent:#2986cc;--accent-hover:#1565a7;--accent-light:#2986cc14;--accent-glow:#2986cc26;--brand-blue-light:#6cbae9;--brand-blue:#2986cc;--brand-blue-dark:#1565a7;--brand-orange:#f9c63d;--brand-orange-dark:#e8941a;--brand-green:#5ec33e;--brand-green-dark:#349822;--color-green:#4db648;--color-green-light:#4db6481a;--color-green-bg:#eefbe9;--color-pink:#ec4899;--color-pink-light:#ec48991a;--color-pink-bg:#fdf2f8;--color-purple:#8b5cf6;--color-purple-light:#8b5cf61a;--color-purple-bg:#f5f3ff;--color-blue:#4a90d9;--color-blue-light:#4a90d91a;--color-blue-bg:#ebf4fc;--color-orange:#f5a623;--color-orange-light:#f5a6231a;--color-orange-bg:#fef6e6;--color-yellow:#eab308;--color-yellow-light:#eab3081a;--color-yellow-bg:#fefce8;--color-red:#ef4444;--color-red-light:#ef44441a;--color-red-bg:#fef2f2;--color-teal:#14b8a6;--color-teal-light:#14b8a61a;--color-teal-bg:#f0fdfa;--accent-blue:var(--color-blue);--accent-green:var(--color-green);--accent-red:var(--color-red);--accent-orange:var(--color-orange);--accent-purple:var(--color-purple);--accent-yellow:var(--color-yellow);--accent-pink:var(--color-pink);--accent-1c:var(--color-yellow);--bg-dark:var(--bg-secondary);--bg-elevated:var(--bg-card);--shadow:var(--shadow-sm);--border:#e8ecf1;--border-hover:#d1d5db;--border-focus:var(--accent);--shadow-sm:0 1px 3px #0f172a0a;--shadow-md:0 4px 12px #0f172a0f;--shadow-lg:0 8px 24px #0f172a14;--shadow-xl:0 16px 40px #0f172a1a;--shadow-focus:0 0 0 3px var(--accent-glow);--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--transition:.2s ease;--transition-slow:.3s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-secondary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Onest,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;overflow-x:hidden}a{color:var(--accent);transition:color var(--transition);text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.navbar,.header{background:var(--bg-primary);border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;padding:14px 0;position:sticky;top:0}.navbar-content,.header-content{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:0 30px;display:flex}.navbar-brand{color:var(--text-primary);letter-spacing:-.02em;align-items:center;gap:10px;font-size:20px;font-weight:700;display:flex}.navbar-brand img{width:50px;height:50px}.navbar-right,.header-left,.header-title{align-items:center;gap:16px;display:flex}.header-right{align-items:center;gap:12px;display:flex}.page-title{color:var(--text-primary);letter-spacing:-.02em;font-size:22px;font-weight:700}.back-btn{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.back-btn:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.user-info{background:var(--bg-secondary);border-radius:var(--radius-full);border:1px solid var(--border);align-items:center;gap:10px;padding:6px 14px 6px 6px;display:flex}.user-avatar{background:var(--accent);width:32px;height:32px;color:var(--text-inverse);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.user-name{color:var(--text-primary);font-size:13px;font-weight:500}.user-role{color:var(--text-muted);font-size:11px}.btn-primary{background:var(--accent);border-radius:var(--radius-md);color:var(--text-inverse);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all var(--transition);align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:500;display:inline-flex}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}.btn-icon{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;justify-content:center;align-items:center;padding:8px;display:inline-flex}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-success{background:var(--color-green);border-radius:var(--radius-md);color:var(--text-inverse);cursor:pointer;transition:all var(--transition);border:none;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600}.btn-success:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 4px 12px #22c55e33}.btn-danger{background:var(--color-red);border-radius:var(--radius-md);color:var(--text-inverse);cursor:pointer;transition:all var(--transition);border:none;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600}.btn-danger:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 4px 12px #ef444433}.btn-logout{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500}.btn-logout:hover{border-color:var(--color-red);color:var(--color-red);background:var(--color-red-light)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition);padding:24px}.card:hover{box-shadow:var(--shadow-md)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px 24px 20px;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--accent);height:3px;position:absolute;top:0;left:0;right:0}.stat-card.stat-blue:before{background:var(--color-blue)}.stat-card.stat-green:before{background:var(--color-green)}.stat-card.stat-purple:before{background:var(--color-purple)}.stat-card.stat-orange:before{background:var(--color-orange)}.stat-card.stat-red:before{background:var(--color-red)}.stat-card.stat-teal:before{background:var(--color-teal)}.stat-card.stat-pink:before{background:var(--color-pink)}.stat-card.stat-yellow:before{background:var(--color-yellow)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600}.stat-value{color:var(--text-primary);letter-spacing:-.02em;font-size:28px;font-weight:700}.module-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm);padding:28px 24px 24px;position:relative;overflow:hidden}.module-card:before{content:"";background:var(--module-color,var(--accent));height:4px;position:absolute;top:0;left:0;right:0}.module-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.module-card.locked{opacity:.5;cursor:not-allowed}.module-card.locked:hover{border-color:var(--border);box-shadow:var(--shadow-sm);transform:none}.module-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:14px;font-size:22px;display:flex}.module-name{color:var(--text-primary);margin-bottom:4px;font-size:16px;font-weight:600}.module-description{color:var(--text-secondary);font-size:13px;line-height:1.5}.module-lock{color:var(--text-muted);font-size:16px;position:absolute;top:18px;right:18px}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.modules-section{margin-bottom:36px}.changelog-wrapper{width:100%;margin-top:32px}.section-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:16px;font-size:12px;font-weight:700}.dashboard{min-height:100vh}.dashboard-content{max-width:1400px;margin:0 auto;padding:32px 30px}.dashboard-header{margin-bottom:32px}.dashboard-title{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:4px;font-size:28px;font-weight:700}.dashboard-subtitle{color:var(--text-secondary);font-size:15px}.main-content{max-width:1400px;margin:0 auto;padding:28px 30px}.container{max-width:1400px;margin:0 auto;padding:0 30px}.form-group{margin-bottom:20px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition);padding:10px 14px;font-family:inherit;font-size:14px}.form-input:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);background:var(--bg-primary);outline:none}.form-select,.filter-select,.integration-select,select.form-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239CA3B0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding:10px 38px 10px 14px;font-family:inherit;font-size:14px}.form-select:focus,.filter-select:focus,.integration-select:focus,select.form-input:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);background-color:var(--bg-primary);outline:none}.form-select:hover,.filter-select:hover,.integration-select:hover,select.form-input:hover{border-color:var(--border-hover)}.form-select::-ms-expand{display:none}.filter-select::-ms-expand{display:none}.integration-select::-ms-expand{display:none}select.form-input::-ms-expand{display:none}.form-select:disabled,.filter-select:disabled,.integration-select:disabled,select.form-input:disabled{opacity:.5;cursor:not-allowed;background-color:var(--bg-secondary)}.form-select option,.filter-select option,.integration-select option,select.form-input option{background:var(--bg-primary);color:var(--text-primary);padding:8px 12px}.form-input::placeholder{color:var(--text-muted)}.form-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}textarea.form-input{resize:vertical;min-height:80px}.table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.table-container table,.data-table,.user-table,.history-table,table.table{border-collapse:collapse;width:100%}.table-container table thead,.data-table thead,.user-table thead,.history-table thead,table.table thead{background:var(--bg-secondary)}.table-container table th,.data-table th,.user-table th,.history-table th,table.table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:600}.table-container table td,.data-table td,.user-table td,.history-table td,table.table td{border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle;padding:12px 16px;font-size:14px}.table-container table tbody tr,.data-table tbody tr,.user-table tbody tr,.history-table tbody tr,table.table tbody tr{transition:background var(--transition)}.table-container table tbody tr:hover,.data-table tbody tr:hover,.user-table tbody tr:hover,.history-table tbody tr:hover,table.table tbody tr:hover{background:var(--bg-hover)}.table-container table tbody tr:last-child td,.data-table tbody tr:last-child td,.user-table tbody tr:last-child td,.history-table tbody tr:last-child td,table.table tbody tr:last-child td{border-bottom:none}.table-container{overflow-x:auto}.badge{border-radius:var(--radius-full);align-items:center;padding:3px 10px;font-size:12px;font-weight:600;line-height:1.4;display:inline-flex}.badge-success{background:var(--color-green-light);color:var(--color-green)}.badge-error,.badge-danger{background:var(--color-red-light);color:var(--color-red)}.badge-info{background:var(--color-blue-light);color:var(--color-blue)}.badge-warning{background:var(--color-orange-light);color:var(--color-orange)}.badge-purple{background:var(--color-purple-light);color:var(--color-purple)}.modal-overlay{background:var(--bg-overlay);z-index:1000;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-primary);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-xl);padding:24px;animation:.2s slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{font-size:18px;font-weight:700}.modal-close{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:6px;font-size:20px}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:0}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;display:flex}.alert{border-radius:var(--radius-md);align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.alert-success{background:var(--color-green-light);color:#15803d;border:1px solid #22c55e33}.alert-error{background:var(--color-red-light);color:#dc2626;border:1px solid #ef444433}.alert-info{background:var(--color-blue-light);color:#2563eb;border:1px solid #3b82f633}.alert-warning{background:var(--color-orange-light);color:#d97706;border:1px solid #f9731633}.error-message{background:var(--color-red-light);color:#dc2626;border-radius:var(--radius-md);border:1px solid #ef444433;margin-bottom:20px;padding:12px 16px;font-size:14px}.login-container{background:var(--bg-secondary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:48px 40px;position:relative;overflow:hidden}.login-card:before{content:"";background:linear-gradient(90deg, var(--brand-blue) 0%, var(--brand-blue-light) 30%, var(--brand-orange) 60%, var(--brand-green) 100%);height:3px;position:absolute;top:0;left:0;right:0}.login-logo{text-align:center;color:var(--text-primary);letter-spacing:-.02em;justify-content:center;align-items:center;gap:10px;margin-bottom:6px;font-size:24px;font-weight:700;display:flex}.login-logo img{width:65px;height:65px}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:14px}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;margin:0 auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{background:var(--bg-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.loading-text{color:var(--text-secondary);font-size:14px}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);min-width:200px;color:var(--text-primary);transition:all var(--transition);flex:1;padding:10px 14px;font-family:inherit;font-size:14px}.search-input:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:none}.search-input::placeholder{color:var(--text-muted)}.tabs{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);gap:2px;margin-bottom:24px;padding:3px;display:flex}.tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:500}.tab:hover{color:var(--text-primary);background:var(--bg-hover)}.tab.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-sm);font-weight:600}.empty-state-icon{opacity:.5;margin-bottom:16px;font-size:48px}.empty-state-text{color:var(--text-muted);font-size:14px}.pagination{justify-content:center;align-items:center;gap:6px;margin-top:20px;display:flex}.pagination-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);padding:8px 12px;font-family:inherit;font-size:13px}.pagination-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.pagination-btn.active{background:var(--accent);color:var(--text-inverse);border-color:var(--accent)}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);white-space:nowrap;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity var(--transition);padding:5px 9px;font-family:Onest,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px;font-weight:500;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.tooltip:hover:after{opacity:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.navbar-content,.header-content{padding:0 16px}.dashboard-content,.main-content{padding:20px 16px}.modules-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.user-info{display:none}.dashboard-title{font-size:24px}.toolbar{flex-direction:column}.search-input{width:100%}.modal{max-width:100%;margin:10px}.form-grid{grid-template-columns:1fr}.tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.login-card{padding:32px 24px}}.module-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:9999px;padding:6px 14px;font-size:12px;font-weight:700;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 6px #00000026}.module-badge-new{color:#16a34a;background:#dcfce7}.module-badge-beta{color:#d97706;background:#fef3c7}.module-badge-alpha{color:#dc2626;background:#fee2e2}.header-actions{gap:12px;display:flex}.action-buttons{gap:8px;display:flex}.action-buttons .btn-icon{font-size:16px}.search-box{margin-bottom:20px}.search-box input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);width:100%;color:var(--text-primary);transition:all var(--transition);padding:10px 16px;font-size:14px}.search-box input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #2986cc1a}.module-table{border-collapse:separate;border-spacing:0;width:100%}.module-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:2px solid var(--border);white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:600}.module-table tbody tr{transition:background var(--transition)}.module-table tbody tr:hover{background:var(--bg-secondary)}.module-table tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:14px 16px;font-size:14px}.module-table tbody tr:last-child td{border-bottom:none}.module-icon-preview{border-radius:var(--radius-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background:#ccc;border-radius:24px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;bottom:3px;left:3px;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background:var(--color-green,#22c55e)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.badge-new{color:#16a34a;background:#dcfce7}.badge-beta{color:#d97706;background:#fef3c7}.badge-alpha{color:#dc2626;background:#fee2e2}.badge-active{color:#16a34a;background:#dcfce7}.badge-inactive{color:#dc2626;background:#fee2e2}.alert{border-radius:var(--radius-md);margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500}.permission-list{flex-direction:column;gap:8px;max-height:400px;display:flex;overflow-y:auto}.permission-item{border:1px solid var(--border);border-radius:var(--radius-md);transition:background var(--transition);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.permission-item:hover{background:var(--bg-secondary)}.permission-user{align-items:center;gap:12px;display:flex}.permission-avatar{background:var(--color-accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.permission-name{font-size:14px;font-weight:600}.permission-email{color:var(--text-secondary);font-size:12px}.permission-actions{align-items:center;gap:8px;display:flex}.btn-grant{border:1px solid var(--color-green,#22c55e);color:var(--color-green,#22c55e);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:0 0;padding:6px 14px;font-size:13px;font-weight:500}.btn-grant:hover{background:var(--color-green,#22c55e);color:#fff}.btn-deny{border:1px solid var(--color-red,#ef4444);color:var(--color-red,#ef4444);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:0 0;padding:6px 14px;font-size:13px;font-weight:500}.btn-deny:hover{background:var(--color-red,#ef4444);color:#fff}.btn-reset{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);background:0 0;padding:6px 14px;font-size:13px}.btn-reset:hover{background:var(--bg-hover)}.icon-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:6px;max-height:180px;padding:4px;display:grid;overflow-y:auto}.icon-option{border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:40px;height:40px;color:var(--text-secondary);transition:all var(--transition);justify-content:center;align-items:center;font-size:16px;display:flex}.icon-option:hover{border-color:var(--color-accent);color:var(--color-accent);background:#2986cc0d}.icon-option.selected{border-color:var(--color-accent);color:var(--color-accent);background:#2986cc1a}.icon-option img{object-fit:contain;width:24px;height:24px}.icon-upload-zone{align-items:center;gap:12px;margin-bottom:12px;display:flex}.icon-upload-btn{border:1px dashed var(--border);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:all var(--transition);align-items:center;gap:8px;padding:8px 16px;font-size:13px;display:inline-flex}.icon-upload-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#2986cc0d}.icon-upload-hint{color:var(--text-secondary);font-size:12px}.custom-icons-section{margin-bottom:12px}.custom-icons-title{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.color-picker{align-items:center;gap:10px;display:flex}.color-preview{border-radius:var(--radius-sm);border:2px solid var(--border);flex-shrink:0;width:36px;height:36px}.form-select{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);width:100%;color:var(--text-primary);cursor:pointer;padding:10px 14px;font-size:14px}.form-select:focus{border-color:var(--color-accent);outline:none}.form-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:4px;display:grid}.btn-outline{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;padding:10px 20px;font-size:14px;font-weight:500}.btn-outline:hover{background:var(--bg-hover);border-color:var(--border-hover)}.btn-small{padding:4px 10px;font-size:14px;line-height:1.4}.toolbar{align-items:center;gap:12px;margin-bottom:16px;display:flex}.search-input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);flex:1;padding:10px 16px;font-size:14px}.search-input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #2986cc1a}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable:hover{color:var(--color-accent)}.sort-arrow{opacity:.3;margin-left:4px;font-size:10px}.sorted .sort-arrow{opacity:1;color:var(--color-accent)}.domain-link{color:var(--color-accent);font-weight:500;text-decoration:none}.domain-link:hover{text-decoration:underline}.sub-text{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:200px;margin-top:2px;font-size:11px;overflow:hidden}.paid-ok{border-radius:var(--radius-sm);color:#16a34a;background:#dcfce7;padding:3px 8px;font-size:12px;font-weight:500;display:inline-block}.paid-warning{border-radius:var(--radius-sm);color:#d97706;background:#fef3c7;padding:3px 8px;font-size:12px;font-weight:500;display:inline-block}.paid-danger{border-radius:var(--radius-sm);color:#dc2626;background:#fee2e2;padding:3px 8px;font-size:12px;font-weight:500;display:inline-block}.paid-unknown,.ssl-unknown{border-radius:var(--radius-sm);color:var(--text-secondary);background:var(--bg-secondary);padding:3px 8px;font-size:12px;display:inline-block}.ssl-danger{border-radius:var(--radius-sm);color:#dc2626;background:#fee2e2;padding:3px 8px;font-size:12px;font-weight:500;display:inline-block}.site-inactive{opacity:.5}.check-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);padding:4px 10px;font-size:11px;font-weight:600}.check-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.check-btn:disabled{opacity:.5;cursor:not-allowed}.tag{background:var(--bg-secondary);color:var(--text-secondary);border-radius:12px;margin:1px 2px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.tag-filter{border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border-radius:16px;margin-bottom:6px;margin-right:6px;padding:4px 12px;font-size:12px;display:inline-block}.tag-filter:hover,.tag-filter.active{border-color:var(--color-accent);color:var(--color-accent);background:#2986cc0d}.tags-input-wrap{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);cursor:text;flex-wrap:wrap;align-items:center;gap:6px;min-height:42px;padding:8px 12px;display:flex}.tags-input-wrap:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px #2986cc1a}.tags-input-wrap input{min-width:100px;color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:14px}.tag-chip{color:var(--color-accent);background:#2986cc1a;border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;display:inline-flex}.tag-chip button{color:var(--color-accent);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.empty-state{text-align:center;color:var(--text-secondary);padding:48px 24px}.empty-state-title{color:var(--text-primary);margin-bottom:8px;font-size:18px;font-weight:600}.empty-state-text{font-size:14px}.empty-state-icon{margin-bottom:12px;font-size:48px}.tg-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px 24px;display:flex}.tg-header-left{align-items:center;gap:14px;display:flex}.tg-logo{border-radius:var(--radius-md);color:#08c;background:#0088cc1a;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.tg-title{font-size:20px;font-weight:700}.tg-subtitle{color:var(--text-secondary);margin-top:2px;font-size:13px}.tg-header-right{align-items:center;gap:10px;display:flex}.tg-content{padding:0}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stats-grid .stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:left;padding:20px}.stats-grid .stat-card .stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:12px;font-size:20px;display:flex}.stats-grid .stat-card .stat-value{font-size:28px;font-weight:700;line-height:1.1}.stats-grid .stat-card .stat-label{text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);margin-top:4px;font-size:12px;font-weight:500}.tabs-container{border-bottom:2px solid var(--border);gap:4px;margin-bottom:20px;padding-bottom:0;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:14px;font-weight:500}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.sessions-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.session-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);padding:20px}.session-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.session-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.session-name{font-size:16px;font-weight:600}.session-meta{background:var(--bg-secondary);border-radius:var(--radius-md);flex-direction:column;gap:8px;margin-bottom:16px;padding:12px;display:flex}.session-meta-item{justify-content:space-between;align-items:center;display:flex}.session-meta-label{color:var(--text-secondary);font-size:12px;font-weight:500}.session-meta-value{font-size:13px;font-weight:500}.session-actions{flex-wrap:wrap;gap:8px;display:flex}.status-badge{border-radius:12px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.status-connected{color:#4db648;background:#4db6481a}.status-disconnected{color:#9ca3b0;background:#9ca3b01a}.status-awaiting_code,.status-awaiting_2fa{color:#d97706;background:#f5a6231a}.status-error{color:#ef4444;background:#ef44441a}.rules-table{border-collapse:separate;border-spacing:0;width:100%}.rules-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);border-bottom:2px solid var(--border);padding:10px 14px;font-size:12px;font-weight:600}.rules-table tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px;font-size:14px}.rules-table tbody tr:last-child td{border-bottom:none}.toggle{width:36px;height:20px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle .toggle-slider{cursor:pointer;background:#ccc;border-radius:20px;transition:all .3s;position:absolute;inset:0}.toggle .toggle-slider:before{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transition:all .3s;position:absolute;bottom:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--color-green,#22c55e)}.toggle input:checked+.toggle-slider:before{transform:translate(16px)}.log-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:12px 0;display:flex}.log-item:last-child{border-bottom:none}.log-direction{border-radius:var(--radius-sm);flex-shrink:0;margin-top:2px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.log-in{color:#3b82f6;background:#3b82f61a}.log-out{color:#22c55e;background:#22c55e1a}.log-text{color:var(--text-primary);word-break:break-word;font-size:13px}.log-meta{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;font-size:11px}.btn-sm{border-radius:var(--radius-sm);padding:6px 14px;font-size:13px}.btn-xs{border-radius:var(--radius-sm);padding:4px 10px;font-size:12px}.btn-success{color:#fff;cursor:pointer;transition:all var(--transition);background:#22c55e;border:none;font-weight:500}.btn-success:hover{background:#16a34a}.btn-danger{color:#fff;cursor:pointer;transition:all var(--transition);background:#ef4444;border:none;font-weight:500}.btn-danger:hover{background:#dc2626}.btn{border-radius:var(--radius-md)}.card-title{border-bottom:1px solid var(--border);align-items:center;margin-bottom:16px;padding-bottom:12px;font-size:16px;font-weight:600;display:flex}.alert-info{color:#2563eb;border-radius:var(--radius-md);background:#3b82f614;border:1px solid #3b82f633;margin-bottom:16px;padding:12px 16px;font-size:14px}.alert-warning{color:#d97706;border-radius:var(--radius-md);background:#f59e0b14;border:1px solid #f59e0b33;margin-bottom:16px;padding:12px 16px;font-size:14px}.alert-danger{color:#dc2626;border-radius:var(--radius-md);background:#ef444414;border:1px solid #ef444433;margin-bottom:16px;padding:12px 16px;font-size:14px}.form-hint{color:var(--text-secondary);margin-top:4px;font-size:12px}.chats-container{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);height:600px;display:flex;overflow:hidden}.chats-sidebar{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:300px;display:flex}.chats-search{border-bottom:1px solid var(--border);padding:12px}.chats-search input{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);width:100%;color:var(--text-primary);padding:8px 12px;font-size:13px}.chats-search input:focus{border-color:var(--color-accent);outline:none}.chats-list{flex:1;overflow-y:auto}.chats-loading{text-align:center;color:var(--text-secondary);padding:24px;font-size:14px}.chat-item{cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 16px;display:flex}.chat-item:hover{background:var(--bg-secondary)}.chat-item.active{border-left:3px solid var(--color-accent);background:#2986cc14}.chat-item.has-unread{background:#3b82f60a}.chat-item.has-unread .chat-name{color:var(--text-primary);font-weight:700}.chat-item.has-unread .chat-time{color:var(--color-accent);font-weight:600}.chat-avatar{background:var(--bg-secondary);width:40px;height:40px;color:var(--color-accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex}.chat-avatar-img{object-fit:cover;border-radius:50%;flex-shrink:0;width:40px;height:40px}.chat-info{flex:1;min-width:0}.chat-row-top{justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:3px;display:flex}.chat-row-bottom{justify-content:space-between;align-items:center;gap:8px;display:flex}.chat-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:14px;font-weight:500;overflow:hidden}.chat-time{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;font-size:11px}.chat-preview{flex:1;align-items:center;gap:6px;min-width:0;display:flex;overflow:hidden}.chat-last-msg{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.chat-item.has-unread .chat-last-msg{color:var(--text-primary)}.chat-type{color:var(--text-secondary);font-size:11px}.chat-unread{background:var(--color-accent);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:700;display:flex}.chats-main{flex-direction:column;flex:1;min-width:0;display:flex}.chats-empty{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.chats-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.chats-header-info{align-items:center;gap:10px;display:flex}.chats-header-icon{font-size:20px}.chats-header-photo{object-fit:cover;border-radius:50%;width:36px;height:36px}.chats-header-name{align-items:baseline;gap:8px;font-size:15px;font-weight:600;display:flex}.chats-header-username{color:var(--color-accent);font-size:12px;font-weight:400}.chats-header-phone,.chats-header-type{color:var(--text-secondary);font-size:12px}.chats-messages{background:var(--bg-secondary);flex-direction:column;flex:1;gap:8px;padding:16px 20px;display:flex;overflow-y:auto}.msg{flex-direction:column;max-width:70%;display:flex}.msg-in{align-self:flex-start}.msg-out{align-self:flex-end}.msg-sender{color:var(--color-accent);margin-bottom:2px;padding-left:12px;font-size:12px;font-weight:600}.msg-bubble{word-break:break-word;border-radius:16px;padding:8px 14px}.msg-in .msg-bubble{background:var(--bg-card);border:1px solid var(--border);border-bottom-left-radius:4px}.msg-out .msg-bubble{background:#2986cc1f;border:1px solid #2986cc33;border-bottom-right-radius:4px}.msg-text{white-space:pre-wrap;font-size:14px;line-height:1.4}.msg-media{color:var(--text-secondary);margin-bottom:4px;font-size:12px;font-style:italic}.msg-time{color:var(--text-secondary);text-align:right;margin-top:4px;font-size:10px}.chats-input{border-top:1px solid var(--border);background:var(--bg-card);gap:8px;padding:12px 16px;display:flex}.chats-input textarea{border:1px solid var(--border);border-radius:var(--radius-md);resize:none;background:var(--bg-secondary);color:var(--text-primary);flex:1;min-height:40px;max-height:120px;padding:10px 14px;font-family:inherit;font-size:14px}.chats-input textarea:focus{border-color:var(--color-accent);outline:none}.chats-input .btn{align-self:flex-end;padding:8px 16px;font-size:18px}.chat-client-badge{color:#3b82f6;background:#3b82f61a;border-radius:10px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-block}.chats-header-client{align-items:center;gap:6px;display:flex}.btn-link{color:var(--color-accent);cursor:pointer;background:0 0;border:none;margin-left:8px;padding:0;font-size:12px}.btn-link:hover{text-decoration:underline}.chats-assign{border-bottom:1px solid var(--border);background:#3b82f60a;align-items:center;gap:8px;padding:10px 20px;display:flex}.chats-assign .form-select{flex:1;padding:6px 10px;font-size:13px}.msg-media-placeholder{border-radius:var(--radius-sm);color:var(--color-accent);cursor:pointer;background:#0000000a;margin-bottom:4px;padding:8px 12px;font-size:13px}.msg-media-placeholder:hover{background:#2986cc14}.msg-media-content{margin-bottom:6px}.msg-media-content img{border-radius:var(--radius-md);cursor:pointer;max-width:300px;max-height:300px;display:block}.msg-media-content img:hover{opacity:.9}.msg-selected{border-radius:var(--radius-md);background:#2986cc14;margin:-4px -8px;padding:4px 8px}.msg-selected .msg-bubble{border-color:var(--color-accent)!important}.msg-checkbox{color:var(--color-accent);-webkit-user-select:none;user-select:none;margin-bottom:2px;font-size:18px}.chats-ticket-bar{border-top:2px solid var(--color-accent);background:#2986cc0a;align-items:center;gap:10px;padding:12px 16px;display:flex}.chats-ticket-bar span{color:var(--color-accent);font-size:13px;font-weight:600}.msg-media-link{color:var(--color-accent);font-size:13px;font-weight:500;text-decoration:none}.msg-media-link:hover{text-decoration:underline}@media (width<=768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.sessions-grid{grid-template-columns:1fr}.tg-header{flex-direction:column;align-items:flex-start;gap:12px;padding:16px}.tg-header-right{flex-wrap:wrap}.chats-container{flex-direction:column;height:auto}.chats-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;max-height:250px}.msg{max-width:85%}}
