/* ==========================================================================
   БАЗА ТЕМЫ (цвета, шрифты, фон)
   ========================================================================== */
/* Стилизация скроллбаров */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}
::-webkit-scrollbar-track {
    background: transparent;
}
::-webkit-scrollbar-thumb {
    background: rgba(128, 128, 128, 0.2);
    border-radius: 20px;
    border: 2px solid transparent;
    background-clip: content-box;
}
::-webkit-scrollbar-thumb:hover {
    background: rgba(128, 128, 128, 0.3);
    border: 2px solid transparent;
    background-clip: content-box;
}

/* Firefox */
* {
    scrollbar-width: thin;
    scrollbar-color: var(--card-2) var(--bg);
}

:root{
    /* Dark Theme (Default) */
    --bg: #03050a;
    --card: rgba(255, 255, 255, 0.03);
    --card-2: rgba(255, 255, 255, 0.06);
    --text: #f0f2ff;
    --muted: #8c98d9;
    --accent: #5B8FF9;
    --accent-glow: rgba(91, 143, 249, 0.3);
    --accent-2: #61DDAA;
    --danger: #ff6b6b;
    --ok: #61DDAA;
    --shadow: 0 12px 40px rgba(0,0,0,0.5);
    --glass: rgba(255, 255, 255, 0.02);
    --glass-border: rgba(255, 255, 255, 0.12);
    --br: 14px;
    --br-card: 24px;
    --focus: 0 0 0 4px rgba(91,143,249,0.25);
    --header-bg: rgba(255, 255, 255, 0.03);
    --modal-bg: rgba(0,0,0,0.4);
    --input-bg: rgba(255,255,255,0.04);
    --input-hover: rgba(255,255,255,0.07);
    --input-focus: rgba(255,255,255,0.08);
    --title-gradient: linear-gradient(135deg, #fff 0%, #aeb7e6 100%);
    --flash-bg: rgba(141, 199, 255, 0.35);
    --flash-glow: rgba(141, 199, 255, 0.4);
}

body.light-theme {
    --bg: #f3f5fa;
    --card: rgba(255, 255, 255, 0.45);
    --card-2: rgba(255, 255, 255, 0.8);
    --text: #1e293b;
    --muted: #64748b;
    --accent: #3b82f6;
    --accent-glow: rgba(59, 130, 246, 0.15);
    --accent-2: #10b981;
    --danger: #ef4444;
    --ok: #10b981;
    --shadow: 0 10px 40px rgba(0, 30, 80, 0.06);
    --glass: rgba(255, 255, 255, 0.3);
    --glass-border: rgba(15, 23, 42, 0.08); /* Тёмная граница для контраста в светлой теме */
    --focus: 0 0 0 4px rgba(59, 130, 246, 0.12);
    --header-bg: rgba(255, 255, 255, 0.5);
    --modal-bg: rgba(15, 23, 42, 0.25);
    --input-bg: rgba(255, 255, 255, 0.6);
    --input-hover: rgba(255, 255, 255, 0.9);
    --input-focus: #ffffff;
    --title-gradient: linear-gradient(135deg, #0f172a 0%, #334155 100%);
    --flash-bg: rgba(59, 130, 246, 0.15);
    --flash-glow: rgba(59, 130, 246, 0.25);
}

html, body { min-height: 100%; overflow-x: hidden; }
body{
    background: 
        radial-gradient(circle at 10% 20%, rgba(91, 143, 249, 0.1) 0%, transparent 40%),
        radial-gradient(circle at 90% 80%, rgba(97, 221, 170, 0.06) 0%, transparent 40%),
        radial-gradient(circle at 50% 50%, rgba(20, 25, 55, 0.3) 0%, var(--bg) 100%),
        var(--bg);
    background-attachment: fixed;
    background-size: cover;
    background-repeat: no-repeat;
    color: var(--text);
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    margin: 0;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    transition: background-color 0.3s ease, color 0.3s ease;
}

body.light-theme {
    background: 
        radial-gradient(circle at 5% 5%, rgba(59, 130, 246, 0.08) 0%, transparent 45%),
        radial-gradient(circle at 95% 95%, rgba(16, 185, 129, 0.08) 0%, transparent 45%),
        radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.5) 0%, #f3f5fa 100%),
        #f3f5fa;
}

/* Контейнер страницы */
.page{
    padding: 32px;
    max-width: 1600px;
    margin: 0 auto;
    min-height: 100vh;
    transform: translateZ(0); /* Fix for ghost artifacts on sub-pixel rendering */
}

/* Заголовок и шапка раздела */
.header{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom: 32px; }
.title h1{ margin:0; font-size:32px; font-weight:800; letter-spacing: -0.5px; background: var(--title-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.title p{ margin:8px 0 0; color:var(--muted); font-size: 15px; }

/* ==========================================================================
   СЕТКА И КАРТОЧКИ
   ========================================================================== */
.grid{ display:grid; grid-template-columns: repeat(12, 1fr); gap: 24px; margin-bottom: 24px; width: 100%; }
.g-col-3{ grid-column: span 3; }
.g-col-4{ grid-column: span 4; }
.g-col-6{ grid-column: span 6; }
.g-col-8{ grid-column: span 8; }
.g-col-9{ grid-column: span 9; }
.g-col-12{ grid-column: span 12; }

@media (max-width: 1200px){
    .g-col-3, .g-col-4, .g-col-6, .g-col-8, .g-col-9 { grid-column: span 12; }
}

.card{
    background: var(--card);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid var(--glass-border);
    border-radius: var(--br-card);
    box-shadow: var(--shadow);
    transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.card:hover {
    box-shadow: 0 16px 64px rgba(0,0,0,0.5);
    border-color: rgba(255,255,255,0.18);
}
body.light-theme .card {
    background: rgba(255, 255, 255, 0.7);
    border-color: rgba(15, 23, 42, 0.08);
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.03);
}
body.light-theme .card-header {
    border-bottom-color: rgba(15, 23, 42, 0.05);
}
.card-header{ padding:20px 24px; border-bottom: 1px solid var(--glass-border); display:flex; align-items:center; gap:12px; }
.card-header h3{ margin:0; font-size:18px; font-weight:700; color: var(--text); }
.card-header-row{ justify-content:space-between; }
.card-body{ padding:24px; }

/* ==========================================================================
   ТЕКСТ, ЧИПСЫ, ЛЕЙБЛЫ
   ========================================================================== */
.muted{ color: var(--muted); font-size: 13px; }
.chips{ display:flex; gap:14px; flex-wrap:wrap; }
.chip{
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid var(--glass-border);
    border-radius: var(--br-card); 
    padding: 20px 24px; 
    box-shadow: var(--shadow); 
    min-width: 160px;
    transition: background 0.2s ease, border-color 0.2s ease;
}
.chip:hover { 
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255,255,255,0.2);
    box-shadow: 0 12px 32px rgba(0,0,0,0.4);
}
body.light-theme .chip {
    background: #ffffff;
    border-color: rgba(15, 23, 42, 0.08);
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
}
body.light-theme .chip:hover {
    background: #ffffff;
    border-color: var(--accent);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}
.chip-title{ color: var(--muted); font-size:13px; }
.chip-value{ font-size:22px; font-weight:700; margin-top:4px; }
.mini-stats{ margin-top: 12px; }
.mini-row{
    display:grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
}
.mini-item{
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    padding: 12px;
    transition: all 0.2s ease;
}
.mini-item:hover {
    background: rgba(255,255,255,0.06);
    border-color: rgba(255,255,255,0.15);
}
body.light-theme .mini-item {
    background: #ffffff;
    border-color: rgba(15, 23, 42, 0.08);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
}
body.light-theme .mini-item:hover {
    background: #ffffff;
    border-color: var(--accent);
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.06);
}
body.light-theme .mini-val {
    color: #0f172a;
}
.mini-title{ color: var(--muted); font-size: 12px; margin-bottom: 4px; }
.mini-val{ color: var(--text); font-weight: 700; font-size: 14px; line-height: 1.2; }
.mini-delta{ margin-left: 6px; font-weight: 700; font-size: 12px; padding: 2px 6px; border-radius: 8px; }
.mini-delta.up{ background: rgba(97,221,170,.18); color: #6de3b8; }
.mini-delta.down{ background: rgba(246,99,22,.18); color: #ffb08a; }
.mini-delta.zero{ background: rgba(255,255,255,.10); color: var(--muted); }

body.light-theme .mini-delta.up { background: rgba(16, 185, 129, 0.1); color: #059669; }
body.light-theme .mini-delta.down { background: rgba(239, 68, 68, 0.1); color: #dc2626; }
body.light-theme .mini-delta.zero { background: rgba(100, 116, 139, 0.1); color: var(--muted); }

@media (max-width: 1200px){
    .mini-row{ grid-template-columns: repeat(2, 1fr); }
}

/* ==========================================================================
   ФОРМЫ И ЭЛЕМЕНТЫ ВВОДА
   ========================================================================== */
.form-block{ display:flex; flex-direction:column; gap:8px; margin-bottom: 12px; }
.form-row{
    display: grid;
    grid-template-columns: minmax(0, 1fr) 140px auto; /* ссылка гибкая, число узкое, кнопка по содержимому */
    gap: 12px;
    align-items: end;
    margin-bottom: 8px;
}
.form-col label{ display:block; font-size:12px; color: var(--muted); margin-bottom:6px; }
#followCount{
    box-sizing: border-box;
    width: 100%;
    max-width: 140px; /* достаточно для «10000» */
    text-align: right;
}

.form-col-btn .btn-primary{
    white-space: nowrap;
    min-width: 110px;
}
@media (max-width: 900px){
    .form-row{
        grid-template-columns: 1fr;   /* одна колонка */
    }
    .form-col-btn{
        justify-self: stretch;        /* кнопка на всю ширину строки */
    }
    .form-col-btn .btn-primary{
        width: 100%;
    }
}



.monospace{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace; }
.textarea{
    box-sizing: border-box;
    width: 100%;
    min-height: 160px;
    padding: 16px;
    border-radius: var(--br);
    border: 1px solid var(--glass-border);
    background: var(--input-bg);
    color: var(--text);
    resize: vertical;
    outline: none;
    transition: all 0.2s ease;
    font-size: 14px;
    font-family: inherit;
}
.textarea:hover{ background: var(--input-hover); border-color: rgba(255,255,255,0.2); }
.textarea:focus{
    background: var(--input-focus);
    border-color: var(--accent);
    box-shadow: var(--focus);
}

.field-error{
    border-color: rgba(246,144,61,0.7) !important;
    box-shadow: 0 0 0 3px rgba(246,144,61,0.25) !important;
    background: rgba(246,144,61,0.08) !important;
}

.help-row{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.help-text{ color: var(--muted); font-size: 12px; }
.help-text.err{ color: #ffb08a; }

.toolbar-row{ display:flex; align-items:center; gap:12px; }

/* Поля ввода/кнопки (общие) */
input[type="text"], input[type="url"], input[type="number"], select, textarea, .textarea{
    box-sizing: border-box;
    width: 100%;
    padding: 12px 16px;
    border-radius: var(--br);
    border: 1px solid var(--glass-border);
    background: var(--input-bg);
    color: var(--text);
    outline: none;
    transition: all 0.2s ease;
    font-size: 14px;
}
select {
    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='%238c98d9' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 40px !important;
}
.select-xs, .auto-refresh select, .auto-refresh-targets select {
    background-position: right 8px center;
    background-size: 12px;
    padding-right: 28px !important;
}
body.light-theme select {
    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='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
}
select option {
    background-color: #1a1d23; /* Более темный непрозрачный фон для выпадающего списка в темной теме */
    color: #f0f2ff;
}
body.light-theme select option {
    background-color: #ffffff;
    color: #1e293b;
}
input[type="text"]:hover, input[type="url"]:hover, input[type="number"]:hover, select:hover, textarea:hover, .textarea:hover{
    background: var(--input-hover);
    border-color: var(--accent-glow);
}
input[type="text"]:focus, input[type="url"]:focus, input[type="number"]:focus, select:focus, textarea:focus, .textarea:focus{
    background: var(--input-focus);
    border-color: var(--accent);
    box-shadow: var(--focus);
}

body.light-theme input[type="text"], 
body.light-theme input[type="url"], 
body.light-theme input[type="number"], 
body.light-theme select,
body.light-theme textarea,
body.light-theme .textarea {
    background: #ffffff;
    border-color: rgba(15, 23, 42, 0.12);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.02);
}
body.light-theme input:focus,
body.light-theme select:focus,
body.light-theme textarea:focus,
body.light-theme .textarea:focus {
    border-color: var(--accent);
    background: #ffffff;
}

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
input[type="number"]{ -moz-appearance: textfield; appearance: textfield; }

/* Кнопки */
.btn-primary, .btn-secondary{
    border: none; border-radius: var(--br); padding: 12px 20px; cursor: pointer; font-weight: 700; font-size: 14px;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    min-width: 0; 
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.btn-primary{ 
    background: linear-gradient(135deg, var(--accent) 0%, #4a7be0 100%); 
    color: #ffffff; 
    box-shadow: 0 4px 14px 0 var(--accent-glow); 
}
body.light-theme .btn-primary {
    color: #ffffff;
    background: linear-gradient(135deg, var(--accent) 0%, #2563eb 100%);
}
.btn-primary:hover{ 
    transform: translateY(-1px);
    box-shadow: 0 6px 20px 0 var(--accent-glow);
    filter: brightness(1.1);
}
.btn-primary:active{ transform: translateY(0); }
.btn-primary:disabled{ opacity: .5; cursor: not-allowed; box-shadow: none; transform: none; }

.btn-secondary{
    background: rgba(255,255,255,0.05); 
    color: var(--text); 
    border: 1px solid var(--glass-border);
}
.btn-secondary:hover{ 
    background: rgba(255,255,255,0.1); 
    border-color: rgba(255,255,255,0.2);
    transform: translateY(-1px);
}

.timeouts-toolbar{
    display:flex; 
    align-items:center; 
    justify-content: space-between; 
    gap:10px; 
    flex-wrap: wrap;
    margin-bottom: 14px;
    padding-bottom: 2px;

}
@media (max-width: 640px){
    .timeouts-toolbar{
        flex-wrap: wrap;
        margin-bottom: 12px;
    }
}


.timeouts-toolbar h4{ 
    margin: 0;
    font-size: 15px;      /* немного крупнее, чтобы казался «повыше» */
    line-height: 1.25;    /* компактнее по вертикали */
    font-weight: 700;
}
.timeouts-toolbar .btn-secondary{
    flex: 0 1 auto;
    max-width: 100%;
}

/* Сообщения */
.login-msg{
    margin-top: 0; padding: 10px 12px; border-radius: var(--br); font-size: 14px;
    background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14);
}
.login-msg.ok{ border-color: rgba(97,221,170,0.5); }
.login-msg.err{ border-color: rgba(246,144,61,0.6); }

/* Разделители */
.hr-soft{ border: none; height: 1px; background: rgba(255,255,255,0.12); margin: 18px 0; }

/* ==========================================================================
   ТАБЛИЦЫ
   ========================================================================== */
.table-wrap{
    overflow:auto;                     
    max-width: 100%;    
    border-radius: var(--br);
    background: transparent;
}

/* Добавим запас для выпадающих меню действий, если они есть в таблице */
.table-wrap:has(.actions-dropdown) {
    padding-bottom: 100px;
}

.table{
    width:100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size:13.5px;
    color: var(--text);
    table-layout: fixed;           
}

.table thead th{
    text-align:left; color: var(--muted); font-weight:700; padding:12px 8px;
    background: var(--header-bg);
    text-transform: uppercase;
    font-size: 10px;
    letter-spacing: 0.5px;
    position: sticky; top: 0; backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--glass-border);
}
.table thead th.text-center{ text-align: center; }
.table tbody td.text-center{ text-align: center; }
.numeric { 
    font-variant-numeric: tabular-nums; 
    letter-spacing: -0.01em; 
    white-space: nowrap;
}

/* Actions Dropdown */
.actions-dropdown {
    position: relative;
    display: flex;
    justify-content: center;
}

.btn-actions-trigger {
    background: var(--card-2);
    border: 1px solid var(--glass-border);
    color: var(--text);
    border-radius: 8px;
    padding: 6px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.btn-actions-trigger:hover {
    background: var(--accent);
    border-color: var(--accent);
    color: white;
}

.btn-actions-trigger.copied {
    background: rgba(97, 221, 170, 0.2);
    color: var(--ok);
    border-color: var(--ok);
}

.actions-menu {
    display: none;
    position: absolute;
    right: 0;
    top: 100%;
    background: #1a1d26; /* Fixed solid bg for better visibility */
    border: 1px solid var(--glass-border);
    border-radius: var(--br);
    box-shadow: var(--shadow);
    z-index: 1000;
    min-width: 190px;
    margin-top: 5px;
    padding: 6px 0;
}

.actions-menu::before {
    content: "";
    position: absolute;
    top: -10px;
    left: 0;
    right: 0;
    height: 10px;
}

body.light-theme .actions-menu {
    background: #ffffff;
}

.actions-dropdown:hover .actions-menu {
    display: block;
    animation: fadeInScale 0.15s ease-out;
}

.actions-menu button {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    padding: 10px 16px;
    border: none;
    background: transparent;
    color: var(--text);
    text-align: left;
    cursor: pointer;
    font-size: 13.5px;
    transition: background 0.15s;
}

.actions-menu button:hover {
    background: var(--input-hover);
}

.actions-menu button.btn-danger-text {
    color: var(--danger);
}

.actions-menu button svg {
    opacity: 0.8;
}

@keyframes fadeInScale {
    from { opacity: 0; transform: scale(0.95) translateY(-5px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}


.table tbody td{
    padding:12px 8px; 
    border-bottom: 1px solid rgba(255,255,255,0.04);
    color: var(--text);
    background: transparent;
}
.table thead th, .table tbody td{
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.table tbody tr{ background: transparent; }
.table tbody tr:hover td{ 
    background: var(--card-2); 
}
.table tbody tr:active td{
    background: rgba(128,128,128,0.15);
}

/* Remove old striping */
.table tbody tr:nth-child(odd){ background: transparent; }
.table tbody tr:nth-child(even){ background: transparent; }

/* ================= Boost: Targets table layout helpers ================= */
#targetsTable, #zd-projects-table { table-layout: fixed; }
#targetsTable th, #targetsTable td, #zd-projects-table th, #zd-projects-table td { 
    overflow: visible; /* Чтобы выпадающее меню не обрезалось */
}

#targetsTable th:nth-child(1),
#targetsTable td:nth-child(1) { width: 45px; }

/* Аккаунт - оптимизируем ширину */
#targetsTable th:nth-child(2),
#targetsTable td:nth-child(2) { 
    width: 130px; 
}

/* Колонки - настраиваем ширину и предотвращаем сжатие */
#targetsTable th:nth-child(3), #targetsTable td:nth-child(3) { width: 60px; }
#targetsTable th:nth-child(4), #targetsTable td:nth-child(4) { width: 70px; }
#targetsTable th:nth-child(5), #targetsTable td:nth-child(5) { width: 80px; }
#targetsTable th:nth-child(6), #targetsTable td:nth-child(6) { width: 80px; }
#targetsTable th:nth-child(7), #targetsTable td:nth-child(7) { width: 95px; }
#targetsTable th:nth-child(8), #targetsTable td:nth-child(8) { width: 85px; }
#targetsTable th:nth-child(9), #targetsTable td:nth-child(9) { width: 140px; }
#targetsTable th:nth-child(10), #targetsTable td:nth-child(10) { width: 95px; }
#targetsTable th:nth-child(11), #targetsTable td:nth-child(11) { width: 140px; }
#targetsTable th:nth-child(12), #targetsTable td:nth-child(12) { width: 90px; }

/* Колонка действий - уменьшаем, так как там теперь компактная кнопка */
#targetsTable th:last-child,
#targetsTable td:last-child { width: 60px; }
#targetsTable td .actions-group{ display:flex; align-items:center; gap:6px; }

/* Control cell specific layout */
.control-cell-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 12px;
}
.control-toggle-side {
    display: flex;
    justify-content: flex-start;
}
.control-value-side {
    display: flex;
    align-items: center;
    gap: 6px;
    justify-content: flex-end;
}
.check-count-val {
    display: flex;
    align-items: center;
    gap: 4px;
    font-weight: 700;
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 6px;
    background: var(--card-2);
    border: 1px solid transparent;
    transition: all 0.2s;
}
.check-count-val:hover {
    background: var(--card);
    border-color: var(--accent-glow);
}

/* links highlight in targets table */
.link-bright{ color:#8fb8ff; text-decoration: underline; }
.link-bright:hover{ color:#c9dbff; }

/* Soft updates for targets table */
#targetsTable tbody tr.row-enter{ animation: rowFadeIn .22s ease-out; }
#targetsTable tbody tr.row-exit{ animation: rowFadeOut .22s ease-in forwards; }
@keyframes rowFadeIn{ from{ opacity:0; transform: translateY(2px);} to{ opacity:1; transform: translateY(0);} }
@keyframes rowFadeOut{ from{ opacity:1; height:auto;} to{ opacity:0; height:0;} }

/* Compact icon buttons for actions */
.btn-icon{
    display:inline-flex; align-items:center; justify-content:center;
    width:34px; height:34px; padding:0; line-height:1;
    border-radius:10px;
    background: var(--input-bg);
    border: 1px solid var(--glass-border);
    color: var(--muted);
    cursor:pointer;
    transition: all 0.2s ease;
}
.btn-icon:hover{ 
    background: var(--input-hover); 
    color: var(--text);
    border-color: var(--accent-glow);
    transform: scale(1.05);
}
.btn-icon:active{ transform: scale(0.95); }

/* Modern switches (toggle sliders) */
.switch { position: relative; display: inline-block; width: 44px; height: 24px; }
.switch input { opacity:0; width:0; height:0; }
.switch .slider { position:absolute; cursor:pointer; inset:0; background: var(--card-2); transition:.3s; border-radius: 999px; border: 1px solid var(--glass-border); }
.switch .slider:before { content:""; position:absolute; height:16px; width:16px; left:3px; top:3px; background:var(--muted); border-radius:50%; transition:.3s; }
.switch input:checked + .slider { background: var(--accent); border-color: transparent; }
.switch.switch-warning input:checked + .slider { background: #192a56; box-shadow: 0 0 10px rgba(25, 42, 86, 0.35); }
.switch.switch-warning input:checked + .slider:before { background: #fff; }
.switch input:checked + .slider:before { transform: translateX(20px); background: #0b1024; }
.switch input:disabled + .slider { opacity:.6; cursor:not-allowed; }

/* Modal form grids for Boost */
.form-row-1col{ display:grid; grid-template-columns: 1fr; gap:12px; margin-bottom:8px; }
.form-row-2col{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; margin-bottom:8px; }
@media (max-width: 900px){ .form-row-2col{ grid-template-columns: 1fr; } }

/* Logs modal tabs */
.tabs { display:flex; gap:12px; border-bottom:1px solid rgba(255,255,255,0.12); padding:12px 16px 10px; margin-top:4px; }
.tabs .tab { 
    appearance:none; background:rgba(255,255,255,0.03); color:var(--muted); border:1px solid var(--glass-border); 
    padding:12px 18px; border-radius:12px; cursor:pointer; font-size:13px; font-weight:700; transition: all 0.2s;
}
.tabs .tab:hover { background: rgba(255,255,255,0.07); color: var(--text); }
.tabs .tab.active { background: var(--accent); color:#ffffff; border-color: transparent; box-shadow: 0 4px 12px var(--accent-glow); }
.logs-content { padding: 12px 16px; }
.logs-content .table { font-size: 13px; }

/* Targets auto-refresh controls */
.auto-refresh-targets { display:flex; align-items:center; gap:8px; }
.auto-refresh-targets select { background: var(--card-2); color: var(--text); border:1px solid rgba(255,255,255,0.15); border-radius:8px; padding:4px 8px; font-size:12px; min-width:64px; }
.auto-refresh-targets .countdown { color: var(--muted); font-size:12px; padding:2px 8px; border-radius:8px; background: rgba(255,255,255,0.08); white-space: nowrap; min-width: 60px; text-align: right; }

/* Wider logs modal and scrollable content */
#logsModal .modal-dialog, #docsModal .modal-dialog{ max-width: 1100px; width: calc(100% - 40px); }
#logsModal .logs-content{ max-height: 70vh; overflow: auto; }

/* Doc Viewer specific styles */
#docsModal .modal-card { width: 100%; }
#docsModal .markdown-body { position: relative; }

/* Copy button for code blocks */
.code-copy-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: 8px;
    color: var(--text);
    cursor: pointer;
    transition: all 0.2s;
    opacity: 0;
    z-index: 10;
}
.markdown-body div:hover .code-copy-btn { opacity: 1; }
.code-copy-btn:hover { background: rgba(255,255,255,0.12); border-color: var(--accent); }
.code-copy-btn.copied { background: rgba(97,221,170,0.2); color: var(--ok); border-color: var(--ok); opacity: 1 !important; }

/* Logs modal fixed toolbar/header and footer pager */
#logsModal .logs-toolbar{ 
    display:flex; align-items:center; gap:12px; padding: 10px 16px 8px; flex-wrap: nowrap; 
    position: sticky; top: 0; z-index: 2; 
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--glass-border); 
}
#logsModal .logs-toolbar .title{ font-weight:700; margin-right:6px; }
#logsModal .logs-footer{ 
    position: sticky; bottom: 0; 
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-top: 1px solid var(--glass-border); 
    padding: 8px 16px; 
}
#logsModal .logs-footer .pager{ justify-content: center; }

/* Logs modal controls */
.logs-toolbar .spacer{ flex:1 1 auto; }
.input-xs{ box-sizing:border-box; padding:6px 8px; border-radius:8px; border:1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.06); color: var(--text); }
.logs-toolbar .input-xs{ flex:1 1 auto; min-width: 240px; }
.select-xs{ background: var(--card-2); color: var(--text); border:1px solid rgba(255,255,255,0.15); border-radius:8px; padding:4px 8px; font-size:12px; }
#logsModal .logs-toolbar .select-xs{ min-width: 160px; }
.pager{ display:flex; align-items:center; gap:8px; }
.pager .btn{ appearance:none; border:1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.06); color: var(--text); padding:4px 8px; border-radius:8px; cursor:pointer; }
.pager .btn:disabled{ opacity:.5; cursor:not-allowed; }

/* Inline field: label + select on one line */
.inline-field{ display:inline-flex; align-items:center; gap:8px; }
.inline-field > label{ margin:0; white-space: nowrap; }
#logsModal .logs-toolbar .inline-field{ margin-left: 12px; }

/* Wider assignment column in delivery logs */
#paneDelivery .table{ table-layout: auto; }
#paneDelivery .table th:nth-child(2),
#paneDelivery .table td:nth-child(2){ min-width: 360px; word-break: break-all; }

#timeoutsTable .link-cell span,
#activeTasksTable td:first-child span{
    display: inline-block;
    max-width: 100%;
    word-break: break-all;              /* переносим очень длинные URL */
}

.tbl-timeout{
    box-sizing: border-box;
    width: 100%;
    max-width: 110px;
    text-align: right;
}


/* ==========================================================================
   МОДАЛКИ
   ========================================================================== */
/* Блокировка фона при открытых модалках */
body.modal-open{ overflow: hidden; }

.modal{
    position: fixed; inset: 0; background: rgba(0,0,0,0.0);
    display: none; align-items:center; justify-content:center;
    z-index: 1060; opacity: 0; pointer-events: none;
    transition: all .3s cubic-bezier(0.4, 0, 0.2, 1);
    backdrop-filter: blur(0px);
}
.modal.show{ 
    display: flex !important; 
    background: var(--modal-bg); 
    opacity: 1; 
    pointer-events: auto; 
    backdrop-filter: blur(14px); 
    -webkit-backdrop-filter: blur(14px); 
}
.modal-dialog{ 
    max-width: 480px; 
    width: calc(100% - 32px); 
    margin: 0 auto !important;
    display: flex;
    align-items: center;
    min-height: calc(100% - 3.5rem);
}
.modal-card{
    background: var(--card); 
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border); 
    border-radius: var(--br-card); 
    overflow: hidden;
    transform: translateY(20px) scale(0.95); 
    opacity: 0;
    transition: all .3s cubic-bezier(0.34, 1.56, 0.64, 1);
    box-shadow: 0 32px 80px rgba(0,0,0,0.7);
}
.modal.show .modal-card{ transform: translateY(0) scale(1); opacity: 1; }
.modal-header{ padding: 20px 24px; border-bottom: 1px solid var(--glass-border); display:flex; align-items:center; justify-content:space-between; }
.modal-header h3{ margin:0; font-size: 20px; font-weight: 700; color: var(--text); }
.modal-close{ appearance:none; background:transparent; color: var(--muted); border:none; font-size:24px; cursor:pointer; transition: color 0.2s; }
.modal-close:hover { color: var(--text); }
.modal-body{ padding: 24px; }
.modal-footer{ padding: 16px 24px; display:flex; gap: 12px; justify-content:flex-end; border-top: 1px solid var(--glass-border); background: transparent; }

/* Поле ввода в попапах (пример) */
#timeoutInput{
    box-sizing: border-box; width: 160px; max-width: 100%; padding: 10px 12px;
    border-radius: var(--br); border: 1px solid rgba(255,255,255,0.18);
    background: rgba(255,255,255,0.06); color: var(--text);
    text-align: right; outline: none; transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
#timeoutInput:hover{ background: rgba(255,255,255,0.08); }
#timeoutInput:focus{ border-color: rgba(91,143,249,0.6); box-shadow: var(--focus); }

/* ==========================================================================
   АВТООБНОВЛЕНИЕ (селекты + таймер)
   ========================================================================== */
.auto-refresh{
    display:flex; align-items:center; gap:10px;
    margin-left:auto;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.10);
    padding: 8px 10px; border-radius: var(--br);
    flex-wrap: wrap;
}
.auto-refresh label{ color: var(--muted); font-size:12px; }
.auto-refresh select{
    background: var(--card-2); color: var(--text);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 8px; padding: 4px 8px; font-size:12px; /* было 6px 10px — ужали */
    width: auto; min-width: 64px;       /* не растягиваться на всю ширину */
}

.auto-refresh .countdown{
    color: var(--muted);
    font-size:12px;
    padding: 2px 8px;
    border-radius: 8px;
    background: rgba(255,255,255,0.08);
    display: inline-flex; align-items: center; white-space: nowrap; line-height: 1; height: auto; vertical-align: middle;
}


.auto-refresh .group { display:flex; align-items:center; gap:8px; flex-wrap: nowrap; }
.auto-refresh .group.stack-countdown { flex-wrap: wrap; }
.auto-refresh .group.stack-countdown .countdown { flex-basis: 100%; margin-top: 6px; text-align: right; }

/* ==========================================================================
   ВКЛАДКИ АДМИНКИ (навигация)
   ========================================================================== */
.admin-tabs { 
    width: 100%; 
    background: var(--header-bg);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border-bottom: 1px solid var(--glass-border); 
    position: sticky; 
    top: 0; 
    z-index: 100; 
    box-shadow: 0 4px 20px rgba(0,0,0,0.2);
    clip-path: inset(0px 0px -30px 0px);
    transform: translateZ(0); /* GPU acceleration to fix artifacts */
}
body.light-theme .admin-tabs {
    box-shadow: 0 4px 20px rgba(30, 41, 59, 0.05);
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}
.admin-tabs .tabs-container {
    max-width: 1600px; margin: 0 auto; padding: 0 32px; display: flex; gap: 8px; overflow-x: auto;
}
.admin-tab {
    display: inline-flex; align-items: center; gap: 8px; padding: 16px 20px;
    color: var(--muted); text-decoration: none; border-bottom: 3px solid transparent; transition: all .2s ease; white-space: nowrap;
    font-weight: 600;
    font-size: 14px;
}
.admin-tab:hover { color: var(--text); background: rgba(255,255,255,0.04); }
body.light-theme .admin-tab:hover { background: rgba(0,0,0,0.03); }
.admin-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.admin-tab .badge {
    background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.18); color: var(--text);
    font-size: 11px; padding: 2px 6px; border-radius: 8px;
}
.tabs-tools{ margin-left: auto; display: inline-flex; align-items: center; gap: 10px; }
.tabs-tools .user-name{ color: var(--muted); font-size: 13px; white-space: nowrap; }
.tabs-tools .btn-logout{
    background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.18); color: var(--text);
    padding: 8px 12px; border-radius: 10px; cursor: pointer; font-size: 12px; transition: all .15s ease;
}
.tabs-tools .btn-logout:hover{
    background: var(--accent); color: #ffffff; box-shadow: 0 6px 18px rgba(91,143,249,.35); border-color: transparent;
}
body.light-theme .tabs-tools .btn-logout:hover {
    box-shadow: 0 6px 18px rgba(59, 130, 246, 0.2);
}

/* ==========================================================================
   КОМПОНЕНТЫ ГРАФИКОВ И ЛЕГЕНД (если используются на других страницах)
   ========================================================================== */
.chart-container{ position: relative; width: 100%; }
.h-420{ height: 340px; }
@media (max-width: 1200px){ .h-420{ height: 220px; } }

.legend-grid{ margin-top: 14px; max-height: 260px; overflow: auto; display: grid; grid-template-columns: 1fr 1fr; gap: 12px 18px; }
@media (max-width: 1200px){ .legend-grid{ grid-template-columns: 1fr; } }
.legend-item{
    display:flex; align-items:flex-start; gap:12px; padding:10px 12px;
    background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius:12px;
}
.legend-item .dot{ width:10px; height:10px; border-radius:50%; margin-top:6px; flex: 0 0 10px; }
.legend-text{ display:flex; flex-direction:column; gap:6px; min-width:0; }
.legend-item .label{ color: var(--text); font-weight: 650; line-height: 1.25; white-space: normal; word-break: break-word; }
.legend-item .value{ color: var(--muted); font-size: 12px; line-height: 1.25; }

/* ==========================================================================
   АДАПТИВ
   ========================================================================== */
@media (max-width: 900px){
    /* форма подписчиков — перенос, кнопка на всю ширину, чтобы не выезжала */
    .form-row{ display: grid; grid-template-columns: 1fr; gap: 10px; }
    .form-col-btn .btn-primary{ width: 100%; }
}

@media (max-width: 640px) {
    .page { padding: 20px; } /* чуть меньше отступы, чтобы влезало */
    .header { display: flex; flex-direction: column; gap: 12px; }
    .chips { display: flex; flex-wrap: wrap; gap: 8px; width: 100%; }
    .grid { grid-template-columns: 1fr; gap: 12px; }
    .g-col-6, .g-col-12 { grid-column: auto; }
    .legend-grid.legend-list { grid-template-columns: 1fr; }

    /* тулбар таймаутов — кнопка на отдельной строке */
    .timeouts-toolbar .btn-secondary{ width: 100%; order: 2; }

    /* автообновление — селект ещё компактнее */
    .auto-refresh select{ min-width: 56px; padding: 4px 6px; }

    /* таблицы — меньше паддинги ячеек, чтобы не «толкались» за край */
    .table thead th, .table tbody td{ padding: 10px; }

}

/* ========================================================================== */
/* БЛОК: Subscribers (левая/правая части с разделителем) */
/* ========================================================================== */
.subscribers-grid{
    display: grid;
    grid-template-columns: minmax(0,1fr) 1px minmax(0,1fr); /* левая | разделитель | правая */
    column-gap: 24px;
    row-gap: 0;
    align-items: start;
}
.subs-divider{
    background: rgba(255,255,255,0.08);
    width: 1px;
    align-self: stretch; /* на всю высоту контента */
}
.subs-left, .subs-right{
    min-width: 0; /* чтобы длинные таблицы/ссылки не растягивали колонки */
}

/* На узких экранах — в одну колонку, разделитель убираем */
@media (max-width: 1200px){
    .subscribers-grid{
        grid-template-columns: 1fr;
        column-gap: 0;
        row-gap: 16px;
    }
    .subs-divider{ display: none; }
}

/* Стилизация темы (Light/Dark Switcher) */
.theme-switch-wrapper {
    display: flex;
    align-items: center;
    margin-right: 15px;
}
.theme-switch {
    display: inline-block;
    height: 24px;
    position: relative;
    width: 48px;
}
.theme-switch input {
    display: none;
}
.theme-slider {
    background-color: rgba(255,255,255,0.1);
    bottom: 0;
    cursor: pointer;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    transition: .4s;
    border-radius: 34px;
    border: 1px solid var(--glass-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 5px;
}
.theme-slider:before {
    background-color: var(--muted);
    bottom: 3px;
    content: "";
    height: 16px;
    left: 3px;
    position: absolute;
    transition: .4s;
    width: 16px;
    border-radius: 50%;
    z-index: 2;
}
input:checked + .theme-slider:before {
    transform: translateX(24px);
    background-color: #0b1024;
}
input:checked + .theme-slider {
    background-color: var(--accent);
}
.theme-slider svg {
    width: 12px;
    height: 12px;
    color: var(--muted);
}
input:checked + .theme-slider svg.sun {
    color: #0b1024;
}
input:not(:checked) + .theme-slider svg.moon {
    color: var(--muted);
}
.toolbar{
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.segmented{
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 12px;
}
/* маленькие кнопки */
.btn.btn-xs{
    padding: 6px 10px;
    font-size: 12px;
    border-radius: 10px;
}
/* кнопки внутри segmented */
.segmented .btn{
    background: transparent;
    border: none;
    color: var(--text);
    border-radius: 10px;
    padding: 6px 12px;
    font-size: 12px;
    cursor: pointer;
    transition: all .15s ease;
}
.segmented .btn:hover{
    background: rgba(255,255,255,0.10);
}
.segmented .btn.active{
    background: var(--accent);
    color: #ffffff;
    box-shadow: 0 6px 18px var(--accent-glow);
}

/* Адаптив: на узких экранах не даём блоку расползаться */
@media (max-width: 640px){
    .toolbar.segmented{
        display: inline-flex;
        flex-wrap: nowrap;
    }
}

/* ==========================================================================
   СВЕТЛАЯ ТЕМА: КОРРЕКТИРОВКИ
   ========================================================================== */
body.light-theme .legend-item {
    background: #ffffff;
    border-color: rgba(15, 23, 42, 0.08);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
}
body.light-theme .tabs .tab {
    background: rgba(255, 255, 255, 0.4);
    border-color: var(--glass-border);
    color: var(--text);
}
body.light-theme .tabs .tab:hover {
    background: rgba(255, 255, 255, 0.8);
}
body.light-theme .tabs .tab.active {
    background: var(--accent);
    color: #ffffff;
    border-color: transparent;
}
body.light-theme .login-msg {
    background: rgba(255, 255, 255, 0.6);
    border-color: var(--glass-border);
    color: var(--text);
}
body.light-theme .login-msg.ok { border-color: rgba(16, 185, 129, 0.4); background: rgba(16, 185, 129, 0.05); }
body.light-theme .login-msg.err { border-color: rgba(239, 68, 68, 0.4); background: rgba(239, 68, 68, 0.05); }

body.light-theme .auto-refresh, 
body.light-theme .auto-refresh-targets {
    background: rgba(255, 255, 255, 0.4);
    border-color: var(--glass-border);
}
body.light-theme .auto-refresh .countdown,
body.light-theme .auto-refresh-targets .countdown {
    background: rgba(255, 255, 255, 0.8);
    color: var(--text);
    border: 1px solid var(--glass-border);
}
body.light-theme .btn-secondary {
    background: rgba(255, 255, 255, 0.7);
    color: var(--text);
    border-color: var(--glass-border);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
}
body.light-theme .btn-secondary:hover {
    background: #ffffff;
    border-color: var(--accent);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
}
body.light-theme .btn-icon {
    background: rgba(255, 255, 255, 0.5);
    border-color: var(--glass-border);
}
body.light-theme .btn-icon:hover {
    background: rgba(255, 255, 255, 0.9);
    border-color: var(--accent);
}
body.light-theme .switch .slider {
    background: rgba(0, 0, 0, 0.05);
    border-color: rgba(0, 0, 0, 0.1);
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.03);
}
body.light-theme .switch .slider:before {
    background: #ffffff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}
body.light-theme .switch input:checked + .slider {
    background: var(--accent);
    border-color: transparent;
    box-shadow: 0 2px 8px var(--accent-glow);
}
body.light-theme .switch input:checked + .slider:before {
    background: #ffffff;
}
body.light-theme .hr-soft {
    background: rgba(0, 0, 0, 0.06);
}
body.light-theme .table thead th {
    background: rgba(255, 255, 255, 0.6);
}
body.light-theme .table tbody td {
    border-bottom-color: rgba(0, 0, 0, 0.03);
}
body.light-theme .modal {
    background: rgba(15, 23, 42, 0.1);
}
body.light-theme .modal-card {
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.1);
    background: rgba(255, 255, 255, 0.85);
}
/* ==========================================================================
   СИСТЕМНОЕ УПРАВЛЕНИЕ (System Page)
   ========================================================================== */
.system-info-list { display: flex; flex-direction: column; }
.info-row { 
    display: flex; 
    justify-content: space-between; 
    align-items: center;
    width: 100%; 
    border-bottom: 1px solid var(--glass-border); 
    padding: 12px 0; 
}
.info-row:last-child { border-bottom: none; }
.info-label { color: var(--muted); font-weight: 500; font-size: 14px; }
.info-value { font-weight: 600; color: var(--text); font-size: 14px; text-align: right; }

.btn-danger {
    background: #ff4d4f;
    color: #ffffff;
    border: none !important;
    border-radius: var(--br);
    padding: 12px 20px;
    cursor: pointer;
    font-weight: 700;
    font-size: 14px;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-danger:hover { background: #ff7875 !important; box-shadow: 0 4px 12px rgba(255, 77, 79, 0.3); }

.btn-danger-text { color: var(--danger) !important; }
.btn-danger-text:hover { opacity: 0.8; }
/* System page actions layout */
.system-actions { display: flex; flex-direction: column; gap: 20px; }
.action-item + .action-item { border-top: 1px solid var(--glass-border); padding-top: 20px; }
.sys-note { margin-bottom: 10px; color: var(--muted); }

/* ZennoDroid Manager Styles */
.alert-info-glass {
    background: rgba(91, 143, 249, 0.1);
    border: 1px solid rgba(91, 143, 249, 0.2);
    color: var(--accent);
    border-radius: var(--br);
}
.bg-primary-glass {
    background: rgba(91, 143, 249, 0.15);
}
.bg-secondary-glass {
    background: rgba(255, 255, 255, 0.05);
}
.border-primary-40 {
    border-color: rgba(91, 143, 249, 0.4) !important;
}
.white-10 {
    border-color: rgba(255, 255, 255, 0.1) !important;
}
.bg-white-5 {
    background: rgba(255, 255, 255, 0.05);
}
.btn-primary-glass {
    background: var(--accent);
    color: #fff;
    border: none;
}
.btn-primary-glass:hover {
    background: #4a7ee6;
    color: #fff;
    box-shadow: 0 0 15px var(--accent-glow);
}
.opacity-50 {
    opacity: 0.5;
}

/* Стили для загрузки обновлений (Drag and Drop) */
.upload-drop-zone {
    border: 2px dashed var(--glass-border);
    border-radius: var(--br);
    padding: 32px 20px;
    text-align: center;
    background: var(--card);
    transition: all 0.2s ease-in-out;
    cursor: pointer;
    margin-top: 15px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    position: relative;
    overflow: hidden;
}

.upload-drop-zone:hover {
    background: var(--card-2);
    border-color: var(--muted);
}

.upload-drop-zone.dragover {
    border-color: var(--accent);
    background: var(--accent-glow);
    box-shadow: 0 0 20px var(--accent-glow);
}

.upload-drop-zone svg {
    color: var(--accent);
    margin-bottom: 5px;
    transition: transform 0.2s ease;
}

.upload-drop-zone.dragover svg {
    transform: translateY(-5px);
}

.upload-drop-zone p {
    margin: 0;
    font-size: 0.9rem;
    color: var(--muted);
    pointer-events: none;
}

.upload-drop-zone .drop-title {
    font-weight: 600;
    color: var(--text);
    font-size: 1rem;
}

.upload-status-badge {
    margin-top: 10px;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 500;
    display: none;
}

/* Progress Bar */
.progress-container {
    width: 100%;
    height: 8px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 10px;
    overflow: hidden;
    margin-top: 15px;
    display: none;
}
body.light-theme .progress-container {
    background: rgba(0, 0, 0, 0.05);
}
.progress-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--accent), var(--accent-2));
    width: 0%;
    transition: width 0.2s ease;
    box-shadow: 0 0 10px var(--accent-glow);
}

/* Loading/Restart Overlay */
.sys-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(0px);
    -webkit-backdrop-filter: blur(0px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    opacity: 0;
    pointer-events: none;
    transition: all 0.3s ease;
}
.sys-overlay.show {
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    opacity: 1;
    pointer-events: auto;
}
.sys-overlay-card {
    background: var(--card);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    border-radius: var(--br-card);
    padding: 40px;
    text-align: center;
    max-width: 400px;
    width: calc(100% - 40px);
    box-shadow: 0 32px 80px rgba(0,0,0,0.5);
    transform: translateY(20px);
    transition: transform 0.3s ease;
}
.sys-overlay.show .sys-overlay-card {
    transform: translateY(0);
}
.spinner {
    width: 50px;
    height: 50px;
    border: 4px solid rgba(255,255,255,0.1);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto 24px;
}
@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Ratio Inputs */
.ratio-inputs {
    display: flex;
    align-items: center;
    gap: 12px;
    background: rgba(255, 255, 255, 0.03);
    padding: 12px;
    border-radius: var(--br);
    border: 1px solid var(--glass-border);
}
.ratio-field {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
}
.ratio-field input {
    width: 70px !important;
    padding: 8px !important;
    text-align: center;
}
.ratio-label {
    font-size: 13px;
    color: var(--muted);
    white-space: nowrap;
}
.ratio-separator {
    font-weight: 700;
    color: var(--accent);
    opacity: 0.8;
}
body.light-theme .ratio-inputs {
    background: rgba(0, 0, 0, 0.02);
}

/* ==========================================================================
   CUSTOM TOOLTIPS (Bootstrap override)
   ========================================================================== */
.tooltip {
    --bs-tooltip-bg: rgba(15, 23, 42, 0.9);
    --bs-tooltip-color: #f0f2ff;
    --bs-tooltip-opacity: 1;
    --bs-tooltip-padding-x: 12px;
    --bs-tooltip-padding-y: 8px;
    --bs-tooltip-border-radius: 10px;
    font-size: 13px;
    z-index: 2100;
    pointer-events: none;
    background: transparent !important;
    border: 0 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    backface-visibility: hidden;
}
/* Анимация появления/пропадания */
.tooltip.fade {
    transition: opacity 0.15s ease-out;
}
.tooltip.show {
    opacity: 1 !important;
    transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.tooltip-inner {
    background-color: var(--bs-tooltip-bg) !important;
    color: var(--bs-tooltip-color) !important;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--bs-tooltip-border-radius) !important;
    box-shadow: 0 12px 32px rgba(0,0,0,0.4);
    padding: var(--bs-tooltip-padding-y) var(--bs-tooltip-padding-x) !important;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    overflow: hidden;
    background-clip: padding-box;
    backface-visibility: hidden;
}
.tooltip.bs-tooltip-top .tooltip-arrow::before { border-top-color: var(--bs-tooltip-bg) !important; }
.tooltip.bs-tooltip-bottom .tooltip-arrow::before { border-bottom-color: var(--bs-tooltip-bg) !important; }
.tooltip.bs-tooltip-start .tooltip-arrow::before { border-left-color: var(--bs-tooltip-bg) !important; }
.tooltip.bs-tooltip-end .tooltip-arrow::before { border-right-color: var(--bs-tooltip-bg) !important; }

body.light-theme .tooltip {
    --bs-tooltip-bg: rgba(255, 255, 255, 0.95);
    --bs-tooltip-color: #1e293b;
}
body.light-theme .tooltip-inner {
    border: 1px solid rgba(15, 23, 42, 0.1);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}
body.light-theme .tooltip.bs-tooltip-top .tooltip-arrow::before { border-top-color: rgba(255, 255, 255, 0.95) !important; }
body.light-theme .tooltip.bs-tooltip-bottom .tooltip-arrow::before { border-bottom-color: rgba(255, 255, 255, 0.95) !important; }


/* ===================== Sidebar Layout ===================== */
.content-with-sidebar { margin-left: 260px; transition: margin-left .2s ease; }
.sidebar { position: fixed; top: 0; left: 0; bottom: 0; width: 240px; background: var(--card); border-right: 1px solid var(--glass-border); padding: 14px; z-index: 100; backdrop-filter: blur(6px); display:flex; flex-direction:column; overflow: hidden; }
.sidebar .sidebar-header{ display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.sidebar .brand{ display:flex; align-items:center; gap:8px; font-weight:700; letter-spacing: .02em; }
.sidebar .sidebar-toggle{ background: transparent; border:none; color: var(--text); border-radius: 10px; padding: 6px 10px; cursor: pointer; }
.sidebar .sidebar-toggle:hover{ background: var(--card-2); filter: brightness(1.05);}
.sidebar .menu-group{ margin-top: 14px; margin-bottom: 6px; font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; padding: 0 6px; }
.sidebar .item{ display:block; padding: 8px 10px; border-radius: var(--br); color: var(--text); text-decoration: none; margin: 3px 0; }
.sidebar .item:hover, .sidebar .item.active{ background: var(--card-2); box-shadow: inset 0 0 0 1px var(--glass-border); }
.sidebar .sidebar-footer{ margin-top:auto; padding-top: 10px; border-top: 1px dashed var(--glass-border); display:flex; flex-direction: column; gap:10px; background: var(--card); }
.sidebar .sidebar-footer .user{ font-size: 13px; color: var(--muted); margin-bottom: 8px; }

/* collapsed */
body.sidebar-collapsed .sidebar{ width: 64px; padding-left: 8px; padding-right: 8px; }
body.sidebar-collapsed .sidebar .menu-group{ display:none; }
body.sidebar-collapsed .sidebar .item{ text-align: center; padding-left: 0; padding-right: 0; justify-content: center; }
body.sidebar-collapsed .sidebar .item .label{ display:none; }
body.sidebar-collapsed .sidebar .item .icon{ color: var(--text); }
body.sidebar-collapsed .content-with-sidebar { margin-left: 88px; }

/* Sidebar extras */
.sidebar .brand .brand-text{ background: linear-gradient(135deg, #7dd3fc 0%, #a78bfa 50%, #60a5fa 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; font-weight: 800; letter-spacing: .2px; }
.sidebar .item{ display:flex; align-items:center; gap:10px; }
.sidebar .item .icon{ width: 24px; height: 24px; display:inline-flex; align-items:center; justify-content:center; color: var(--muted); }
.sidebar .item.active .icon, .sidebar .item:hover .icon{ color: var(--accent); }
.sidebar .sidebar-footer .userbox{ display:flex; align-items:center; gap:10px; }
.sidebar .sidebar-footer .avatar{ width:34px; height:34px; border-radius:50%; background-color: var(--card-2); background-size: cover; background-position: center; display:flex; align-items:center; justify-content:center; font-weight:700; color: var(--accent); box-shadow: inset 0 0 0 1px var(--glass-border); }
.sidebar .sidebar-footer .meta .name{ font-weight:600; line-height:1.2; }
.sidebar .sidebar-footer .meta .level{ font-size:12px; color: var(--muted); }
.sidebar .sidebar-footer .btn-logout{ background: transparent; color: var(--danger); border: 1px solid var(--glass-border); border-radius: var(--br); padding: 6px 10px; cursor: pointer; }
.sidebar .sidebar-footer .btn-logout:hover{ background: rgba(255,255,255,0.04); filter: none; box-shadow: none; }
body.sidebar-collapsed .sidebar .brand-text{ display:none; }
body.sidebar-collapsed .sidebar .sidebar-footer .meta{ display:none; }
body.sidebar-collapsed .sidebar .sidebar-footer{ align-items: center; }
body.sidebar-collapsed .sidebar .sidebar-footer .avatar{ width:36px; height:36px; }

/* ===================== Buttons ===================== */
.btn{ background: var(--accent); color: #fff; border: 0; border-radius: var(--br); padding: 8px 14px; cursor: pointer; box-shadow: var(--shadow); }
.btn:hover{ filter: brightness(1.05); box-shadow: 0 0 0 3px var(--accent-glow); }
.btn:disabled{ opacity: .7; cursor: not-allowed; }
.btn-outline{ background: transparent; border: 1px solid var(--glass-border); color: var(--text); box-shadow: none; }
.btn-sm{ padding: 4px 10px; font-size: .9rem; border-radius: var(--br); background: var(--card-2); color: var(--text); border:1px solid var(--glass-border); box-shadow: none; }
.btn-success{ background: var(--ok); color: #0f2f23; }
.btn-danger{ background: var(--danger); color: #fff; }

/* ===================== Tables header rounding fix ===================== */
.table{ border-collapse: separate; border-spacing: 0; width: 100%; }
.table thead th{ background: var(--card-2); }
.table thead th:first-child{ border-top-left-radius: var(--br); }
.table thead th:last-child{ border-top-right-radius: var(--br); }
.table tbody tr:last-child td:first-child{ border-bottom-left-radius: var(--br); }
.table tbody tr:last-child td:last-child{ border-bottom-right-radius: var(--br); }
.table-wrap{ overflow: hidden; border-radius: var(--br-card); border: 1px solid var(--glass-border); }


/* Sidebar layout tweaks overrides */
.sidebar-menu { flex: 1 1 auto; overflow-y: auto; }
.sidebar .brand svg { display:block; }
.sidebar .sidebar-footer .btn-logout { width: 100%; display:flex; align-items:center; justify-content:center; gap:8px; }


/* ======================================================================
   SCOPES PICKER (API Keys)
   ====================================================================== */
.scopes-picker{
    display:flex; flex-wrap:wrap; gap:8px; padding:10px; border-radius: var(--br);
    background: var(--card-2); border:1px solid var(--glass-border);
}
.scope-item{ display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border-radius:10px; background: var(--card); border:1px solid var(--glass-border); color: var(--text); cursor: pointer; transition: all .15s ease; }
.scope-item:hover{ background: var(--input-hover); border-color: var(--accent-glow); }
.scope-item input{ accent-color: var(--accent); }

/* Subtle table hover/enter animations (generic) */
.table tbody tr{ transition: background-color .18s ease, transform .18s ease; }
.table tbody tr:hover{ background: rgba(255,255,255,0.03); }
