/* ================================================================ */
/* ===    WORKSHOP AI: ADMIN DASHBOARD (Black & Orange)         === */
/* ===    Полностью адаптивный, компактный, без багов           === */
/* ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;600&display=swap');

/* ---------- Глобальная блокировка горизонтального скролла ---------- */
html, body {
    max-width: 100vw !important;
    overflow-x: hidden !important;
}

/* ================================================================ */
/* 1. ПЕРЕМЕННЫЕ И БАЗОВЫЙ КОНТЕЙНЕР                                */
/* ================================================================ */
#admin-view {
    /* Фон */
    --bg-main: #111212;
    --bg-panel: #141414;
    --bg-panel-hover: #1a1a1a;
    --bg-input: #1a1a1a;

    /* Рамки */
    --border-light: rgba(255, 255, 255, 0.08);
    --border-strong: rgba(255, 255, 255, 0.15);

    /* Акценты */
    --accent-brand: #FABF3C;
    --accent-brand-hover: #ff8533;
    --accent-green: #10b981;
    --accent-red: #ef4444;

    /* Совместимость с JS (neon-переменные) */
    --neon-main: #FABF3C;
    --neon-blue: #3b82f6;
    --neon-green: #10b981;
    --neon-red: #ef4444;
    --neon-secondary: #ff9d00;

    /* Текст */
    --text-main: #ffffff;
    --text-muted: #888888;
    --text-secondary: #888888;

    /* Шрифты и геометрия */
    --font-ui: 'Inter', sans-serif;
    --font-mono: 'JetBrains Mono', monospace;
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
    --shadow-card: 0 4px 20px rgba(0, 0, 0, 0.35);

    width: 100%;
    max-width: 100vw;
    overflow-x: hidden;
    background-color: var(--bg-main);
    color: var(--text-main);
    font-family: var(--font-ui);
    min-height: 100vh;
    box-sizing: border-box;
    padding: 0 16px 50px;
    font-size: 14px;
}

#admin-view * { box-sizing: border-box; }
#admin-view img { max-width: 100%; }

/* Утилиты (на случай если bootstrap отсутствует) */
#admin-view .text-success { color: var(--accent-green) !important; }
#admin-view .text-danger  { color: var(--accent-red) !important; }
#admin-view .text-warning { color: var(--accent-brand) !important; }
#admin-view .text-info    { color: var(--neon-blue) !important; }
#admin-view .text-secondary, #admin-view .text-muted { color: var(--text-muted) !important; }
#admin-view .text-white   { color: #fff !important; }
#admin-view .text-end     { text-align: right !important; }
#admin-view .text-center  { text-align: center !important; }
#admin-view .fw-bold, #admin-view .fw-600 { font-weight: 600 !important; }
#admin-view .fw-500 { font-weight: 500 !important; }
#admin-view .font-mono, #admin-view .font-monospace { font-family: var(--font-mono); }
#admin-view .text-main { color: var(--text-main); }
#admin-view .text-danger-dim { color: #fca5a5; }
#admin-view .w-100 { width: 100%; }
#admin-view .mb-2 { margin-bottom: 8px; }
#admin-view .mb-3 { margin-bottom: 16px; }
#admin-view .mb-4 { margin-bottom: 24px; }
#admin-view .mt-1 { margin-top: 4px; }
#admin-view .mt-2 { margin-top: 8px; }
#admin-view .mt-4 { margin-top: 24px; }
#admin-view .d-flex { display: flex; }
#admin-view .d-block { display: block; }
#admin-view .flex-column { flex-direction: column; }
#admin-view .align-items-center { align-items: center; }
#admin-view .justify-content-center { justify-content: center; }
#admin-view .justify-content-between { justify-content: space-between; }
#admin-view .justify-content-end { justify-content: flex-end; }
#admin-view .gap-2 { gap: 8px; }
#admin-view .gap-3 { gap: 12px; }
#admin-view .text-truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#admin-view .py-3 { padding: 16px 0; }
#admin-view .py-4 { padding: 24px 0; }
#admin-view .py-5 { padding: 40px 0; }
#admin-view .p-5 { padding: 40px; }
#admin-view .ms-1 { margin-left: 4px; }
#admin-view .ms-auto { margin-left: auto; }
#admin-view .me-2 { margin-right: 8px; }

/* Кастомный скроллбар */
#admin-view ::-webkit-scrollbar { width: 6px; height: 6px; }
#admin-view ::-webkit-scrollbar-track { background: transparent; }
#admin-view ::-webkit-scrollbar-thumb { background: #333; border-radius: 10px; }
#admin-view ::-webkit-scrollbar-thumb:hover { background: var(--accent-brand); }

/* Спиннеры (bootstrap fallback) */
#admin-view .spinner-border {
    display: inline-block; width: 2rem; height: 2rem;
    border: 0.25em solid currentColor; border-right-color: transparent;
    border-radius: 50%; animation: adminSpin 0.75s linear infinite;
    color: var(--accent-brand);
}
#admin-view .spinner-border-sm { width: 1rem; height: 1rem; border-width: 0.2em; }
@keyframes adminSpin { to { transform: rotate(360deg); } }
.fa-spin { animation: adminSpin 1s linear infinite; }

/* ================================================================ */
/* 2. СЕТКА, КАРТОЧКИ, ШАПКА                                        */
/* ================================================================ */

#admin-view .admin-grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}

#admin-view .admin-card {
    background: var(--bg-panel);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-lg);
    padding: 18px;
    display: flex;
    flex-direction: column;
    box-shadow: var(--shadow-card);
    transition: border-color 0.2s ease;
    min-width: 0;
    overflow: hidden;
}
#admin-view .admin-card:hover { border-color: var(--border-strong); }
#admin-view .admin-card.p-0 { padding: 0; }
#admin-view .mb-4.admin-card, #admin-view .admin-card.mb-4 { margin-bottom: 16px; }

#admin-view .list-header {
    font-family: var(--font-ui);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-main);
    padding-bottom: 10px;
    margin-bottom: 14px;
    border-bottom: 1px solid var(--border-light);
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
#admin-view .list-header.no-border { border: none; padding-bottom: 0; margin-bottom: 0; }
#admin-view .list-header i { color: var(--text-muted); flex-shrink: 0; }

/* Шапка */
#admin-view .admin-header-row {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 20px; padding: 16px 0; border-bottom: 1px solid var(--border-light);
    flex-wrap: wrap; gap: 16px;
}
#admin-view .admin-title { font-size: 1.3rem; font-weight: 700; display: flex; align-items: center; gap: 10px; }
#admin-view .admin-title i { color: var(--accent-brand); }

/* Вкладки */
#admin-view .admin-tabs {
    display: flex; gap: 4px; background: var(--bg-panel);
    padding: 5px; border-radius: var(--radius-md); border: 1px solid var(--border-light);
    overflow-x: auto; flex: 1; max-width: 100%;
}
#admin-view .admin-tabs::-webkit-scrollbar { height: 0; }
#admin-view .admin-tab-btn {
    background: transparent; border: none; color: var(--text-muted);
    font-family: var(--font-ui); font-size: 0.8rem; font-weight: 500;
    padding: 8px 14px; border-radius: var(--radius-sm); cursor: pointer;
    transition: all 0.2s ease; display: flex; align-items: center; gap: 7px;
    white-space: nowrap;
}
#admin-view .admin-tab-btn:hover { color: var(--text-main); background: rgba(255,255,255,0.05); }
#admin-view .admin-tab-btn.active { background: rgba(250,191,60,0.12); color: var(--accent-brand); }

/* ================================================================ */
/* 3. ФОРМЫ                                                         */
/* ================================================================ */

#admin-view .cyber-input,
#admin-view .cyber-select,
#admin-view .cyber-textarea {
    width: 100%; background: var(--bg-input);
    border: 1px solid var(--border-strong); color: var(--text-main);
    font-family: var(--font-mono); padding: 9px 12px;
    font-size: 0.85rem; border-radius: var(--radius-sm);
    transition: border-color 0.2s ease;
}
#admin-view .cyber-input:focus,
#admin-view .cyber-textarea:focus,
#admin-view .cyber-select:focus { border-color: var(--accent-brand); outline: none; }
#admin-view .cyber-label { font-size: 0.72rem; color: var(--text-muted); margin-bottom: 5px; display: block; font-weight: 500; }
#admin-view select.cyber-input { appearance: none; cursor: pointer; }

/* Кнопки */
#admin-view .btn,
#admin-view .btn-primary {
    background: var(--bg-panel-hover); border: 1px solid var(--border-strong);
    color: var(--text-main); font-weight: 500; padding: 9px 18px;
    border-radius: var(--radius-sm); cursor: pointer; transition: all 0.2s ease;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    font-size: 0.85rem; font-family: var(--font-ui);
}
#admin-view .btn-primary:hover { background: var(--border-strong); color: var(--accent-brand); }
#admin-view .btn-sm { padding: 6px 12px; font-size: 0.78rem; }

#admin-view .btn-create {
    background: rgba(250,191,60,0.1); border: 1px solid rgba(250,191,60,0.25);
    color: var(--accent-brand); width: 100%; padding: 12px;
    border-radius: var(--radius-sm); font-weight: 600; cursor: pointer;
    transition: 0.2s; display: flex; align-items: center; justify-content: center; gap: 8px;
}
#admin-view .btn-create:hover { background: rgba(250,191,60,0.2); }

#admin-view .btn-broadcast {
    background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
    color: var(--text-main); width: 100%; padding: 12px;
    border-radius: var(--radius-sm); font-weight: 600; cursor: pointer; transition: 0.2s;
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
#admin-view .btn-broadcast:hover { background: rgba(255,255,255,0.1); border-color: var(--border-strong); }

#admin-view .btn-destruct {
    background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.25);
    color: var(--accent-red); width: 32px; height: 32px; border-radius: var(--radius-sm);
    display: inline-flex; align-items: center; justify-content: center; transition: 0.2s; cursor: pointer; flex-shrink: 0;
}
#admin-view .btn-destruct:hover { background: rgba(239,68,68,0.2); }

/* Outline кнопки (используются в JS) */
#admin-view .btn-outline-success { background: transparent; border: 1px solid rgba(16,185,129,0.4); color: var(--accent-green); }
#admin-view .btn-outline-success:hover { background: rgba(16,185,129,0.12); }
#admin-view .btn-outline-danger { background: transparent; border: 1px solid rgba(239,68,68,0.4); color: var(--accent-red); }
#admin-view .btn-outline-danger:hover { background: rgba(239,68,68,0.12); }
#admin-view .btn-outline-warning { background: transparent; border: 1px solid rgba(250,191,60,0.4); color: var(--accent-brand); }
#admin-view .btn-outline-warning:hover { background: rgba(250,191,60,0.12); }
#admin-view .btn-outline-info { background: transparent; border: 1px solid rgba(59,130,246,0.4); color: var(--neon-blue); }
#admin-view .btn-outline-info:hover { background: rgba(59,130,246,0.12); }
#admin-view .btn-outline-primary { background: transparent; border: 1px solid var(--border-strong); color: var(--text-main); }
#admin-view .btn-outline-primary:hover { background: var(--border-strong); }
#admin-view .btn-info { background: var(--neon-blue); border: none; color: #000; }
#admin-view .btn-dark { background: #0a0a0a; border: 1px solid var(--border-light); }
#admin-view .btn-success { background: var(--accent-green); border: none; color: #fff; }

/* Badge */
#admin-view .badge { display: inline-block; padding: 3px 7px; font-size: 0.65rem; border-radius: 4px; font-weight: 600; }
#admin-view .badge.bg-danger { background: var(--accent-red); color: #fff; }
#admin-view .badge.bg-success { background: var(--accent-green); color: #fff; }

/* Тумблеры */
#admin-view .cyber-toggle { position: relative; display: inline-block; width: 40px; height: 20px; margin: 0; flex-shrink: 0; }
#admin-view .cyber-toggle input { opacity: 0; width: 0; height: 0; }
#admin-view .cyber-slider { position: absolute; cursor: pointer; inset: 0; background-color: #333; border-radius: 20px; transition: .3s; }
#admin-view .cyber-slider:before { position: absolute; content: ""; height: 16px; width: 16px; left: 2px; bottom: 2px; background: #fff; border-radius: 50%; transition: .3s; }
#admin-view .cyber-toggle input:checked + .cyber-slider { background-color: var(--accent-green); }
#admin-view .cyber-toggle input:checked + .cyber-slider:before { transform: translateX(20px); }

/* Сетки форм */
#admin-view .row-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
#admin-view .row-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }

/* Bootstrap row для модалок */
#admin-view .row.g-2 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 8px; }
#admin-view .col-md-4 { grid-column: span 4; }
#admin-view .col-md-8 { grid-column: span 8; }
@media (max-width: 700px) {
    #admin-view .col-md-4, #admin-view .col-md-8 { grid-column: span 12; }
}

/* ================================================================ */
/* 4. СТАТИСТИКА (ВЕРХНИЕ ПЛИТКИ)                                   */
/* ================================================================ */

#admin-view .admin-stats-row {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px; margin-bottom: 20px;
}
#admin-view .stat-item {
    background: var(--bg-panel); border: 1px solid var(--border-light);
    border-radius: var(--radius-md); padding: 14px 16px;
    display: flex; flex-direction: column; gap: 6px; box-shadow: var(--shadow-card);
    position: relative; overflow: hidden; min-width: 0;
}
#admin-view .stat-header { display: flex; justify-content: space-between; align-items: center; }
#admin-view .stat-label { font-size: 0.72rem; color: var(--text-muted); font-weight: 500; text-transform: uppercase; }
#admin-view .stat-value { font-family: var(--font-mono); font-size: 1.5rem; font-weight: 600; color: var(--text-main); word-break: break-word; }
#admin-view .stat-icon { font-size: 1.1rem; color: var(--border-strong); }
/* Глушим эффекты из JS, которые без CSS выглядят битыми */
#admin-view .stat-item-glow,
#admin-view .interference-overlay,
#admin-view .short-circuit-box { display: none !important; }

/* ================================================================ */
/* 5. ДОСЬЕ (ОНЛАЙН ПОЛЬЗОВАТЕЛИ)                                  */
/* ================================================================ */

#admin-view .online-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; margin-bottom: 24px; }
#admin-view .dossier-card {
    background: var(--bg-panel); border: 1px solid var(--border-light);
    border-radius: var(--radius-lg); padding: 14px; position: relative;
    transition: 0.2s ease; min-width: 0; overflow: hidden;
}
#admin-view .dossier-card:hover { border-color: var(--border-strong); }
#admin-view .glass-glare, #admin-view .chip-layer, #admin-view .scan-circle, #admin-view .scan-circle-inner { display: none; }
#admin-view .dossier-layout { display: flex; width: 100%; gap: 14px; align-items: flex-start; }

#admin-view .dossier-visual { flex-shrink: 0; display: flex; flex-direction: column; align-items: center; gap: 6px; }
#admin-view .avatar-scanner-container { position: relative; }
#admin-view .dossier-avatar { width: 46px; height: 46px; border-radius: 50%; border: 2px solid var(--border-strong); object-fit: cover; }
#admin-view .visual-status { font-size: 0.6rem; color: var(--accent-green); display: flex; align-items: center; gap: 4px; font-weight: 600; }
#admin-view .status-led { width: 6px; height: 6px; background: var(--accent-green); border-radius: 50%; box-shadow: 0 0 6px var(--accent-green); }

#admin-view .dossier-data { flex-grow: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
#admin-view .data-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
#admin-view .username-block { min-width: 0; }
#admin-view .username-block h4 { margin: 0; font-size: 0.95rem; color: var(--text-main); font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#admin-view .user-id-hash { font-family: var(--font-mono); font-size: 0.62rem; color: var(--text-muted); }
#admin-view .badge-pro, #admin-view .badge-pro-micro { background: var(--accent-brand); color: #000; font-size: 0.55rem; padding: 1px 5px; border-radius: 4px; font-weight: 700; vertical-align: middle; }

#admin-view .data-metrics { display: flex; gap: 16px; margin-top: 4px; }
#admin-view .metric-box { display: flex; flex-direction: column; }
#admin-view .metric-label { font-size: 0.6rem; color: var(--text-muted); text-transform: uppercase; }
#admin-view .metric-val { font-size: 0.85rem; font-weight: 600; font-family: var(--font-mono); }
#admin-view .metric-val.credits { color: var(--accent-brand); }
#admin-view .device-grid { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 8px; }
#admin-view .tech-badge { background: rgba(255,255,255,0.05); color: var(--text-muted); font-size: 0.58rem; padding: 2px 6px; border-radius: 4px; }
#admin-view .tech-badge.warning { color: var(--accent-brand); background: rgba(250,191,60,0.08); }

#admin-view .dossier-actions { display: flex; gap: 6px; margin-top: 12px; flex-wrap: wrap; }
#admin-view .dossier-action-btn {
    background: var(--bg-input); border: 1px solid var(--border-strong); color: var(--text-muted);
    font-size: 0.68rem; padding: 6px 10px; border-radius: var(--radius-sm); cursor: pointer;
    transition: 0.2s; display: flex; align-items: center; gap: 5px; flex: 1; justify-content: center;
}
#admin-view .dossier-action-btn:hover { background: var(--border-strong); color: var(--text-main); }

/* ================================================================ */
/* 6. ГРАФИКИ (ANALYTICS / REVENUE)                                */
/* ================================================================ */

#admin-view .revenue-full-width { grid-column: 1 / -1; }
#admin-view .analytics-hub-card { display: flex; flex-direction: column; }
#admin-view .analytics-header-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; flex-wrap: wrap; gap: 10px; }
#admin-view .analytics-switcher { display: flex; background: var(--bg-input); border-radius: var(--radius-sm); padding: 4px; border: 1px solid var(--border-light); }
#admin-view .switcher-btn { background: transparent; border: none; color: var(--text-muted); font-size: 0.72rem; font-weight: 500; padding: 6px 12px; border-radius: 4px; cursor: pointer; transition: 0.2s; }
#admin-view .switcher-btn.active { background: rgba(250,191,60,0.12); color: var(--accent-brand); }

#admin-view .analytics-charts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
#admin-view .chart-container-cyber { background: var(--bg-input); border: 1px solid var(--border-light); border-radius: var(--radius-md); padding: 14px; min-width: 0; }
#admin-view .chart-title { font-size: 0.72rem; color: var(--text-muted); margin-bottom: 12px; font-weight: 500; text-transform: uppercase; }
#admin-view .chart-canvas-wrapper { height: 240px; width: 100%; position: relative; }

/* Revenue stream */
#admin-view #revenue-stream-chart { height: 280px !important; }
#admin-view #rev-total-30d { color: #fff; }

/* ================================================================ */
/* 7. МОНИТОР API (CYBER MONITOR)                                  */
/* ================================================================ */

#admin-view .cyber-monitor { display: flex; flex-direction: column; min-height: 300px; padding: 20px; position: relative; }
#admin-view .cyber-vignette { display: none; }
#admin-view .cyber-monitor-header { text-align: center; margin-bottom: 20px; }
#admin-view .cyber-title-main { font-family: var(--font-mono); font-size: 2.2rem; font-weight: 700; color: var(--accent-brand); }
#admin-view .cyber-title-sub { font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 2px; }

#admin-view .cyber-services-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important; gap: 12px !important; }
#admin-view .cyber-service-row {
    display: flex; flex-direction: column; gap: 8px; padding: 11px;
    background: rgba(255,255,255,0.02); border-radius: var(--radius-sm);
    border: 1px solid var(--border-light); cursor: pointer; transition: 0.2s; min-width: 0;
}
#admin-view .cyber-service-row:hover { background: rgba(255,255,255,0.05); border-color: var(--border-strong); }
#admin-view .cyber-service-info { display: flex; justify-content: space-between; align-items: center; font-size: 0.78rem; gap: 8px; }
#admin-view .service-name { color: var(--text-main); font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
#admin-view .service-status { font-family: var(--font-mono); font-size: 0.7rem; flex-shrink: 0; }

#admin-view .cyber-track { display: flex; gap: 3px; height: 6px; width: 100%; }
#admin-view .cyber-seg { flex: 1; background: var(--border-strong); border-radius: 2px; transition: 0.2s; }
#admin-view .cyber-seg.active { background: var(--accent-green); }
#admin-view .cyber-seg.failed { background: var(--accent-red); }
#admin-view .cyber-seg.filtered { background: var(--accent-brand); }
@keyframes cyberPulse { 0%,100% { opacity: 0.5; background: var(--text-muted); } 50% { opacity: 1; background: var(--text-main); } }
#admin-view .cyber-seg.scanning { animation: cyberPulse 1.5s infinite ease-in-out; }

/* Эффекты переключения экранов из JS */
#admin-view .screen-off { opacity: 0; transition: opacity 0.2s; }
#admin-view .screen-on { animation: screenFlick 0.3s; }
@keyframes screenFlick { 0% { opacity: 0; } 100% { opacity: 1; } }

/* ================================================================ */
/* 8. ДЕТАЛИЗАЦИЯ ЛОГА (TASK ANALYTICS)                            */
/* ================================================================ */

@keyframes fade-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
#admin-view .cyber-detail-panel { display: flex; flex-direction: column; gap: 14px; animation: fade-in 0.2s ease; padding: 4px; }
#admin-view .cyber-detail-header { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--border-light); padding-bottom: 12px; }
#admin-view .header-title { color: var(--text-main); font-weight: 600; display: flex; gap: 8px; align-items: center; }
#admin-view .task-id-badge { background: var(--border-light); padding: 4px 8px; font-size: 0.68rem; border-radius: var(--radius-sm); font-family: var(--font-mono); color: var(--text-muted); }

#admin-view .cyber-user-plate { display: flex; align-items: center; gap: 14px; padding: 12px; background: var(--bg-input); border-radius: var(--radius-sm); border: 1px solid var(--border-light); cursor: pointer; transition: 0.2s; }
#admin-view .cyber-user-plate:hover { border-color: var(--border-strong); }
#admin-view .user-avatar-scan img { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
#admin-view .user-info-tech { display: flex; flex-direction: column; flex-grow: 1; min-width: 0; }
#admin-view .user-info-tech .user-name { color: var(--text-main); font-weight: 600; font-size: 0.9rem; }
#admin-view .user-info-tech .user-role { color: var(--text-muted); font-size: 0.65rem; }
#admin-view .user-link-icon { color: var(--text-muted); }

#admin-view .cyber-metrics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
#admin-view .cyber-metric-box { background: var(--bg-input); border: 1px solid var(--border-light); padding: 10px; border-radius: var(--radius-sm); min-width: 0; }
#admin-view .cyber-metric-box .metric-label { font-size: 0.62rem; color: var(--text-muted); text-transform: uppercase; margin-bottom: 4px; }
#admin-view .cyber-metric-box .metric-value { font-size: 0.85rem; color: var(--text-main); font-weight: 600; overflow: hidden; text-overflow: ellipsis; }
#admin-view .metric-value.cost-value { color: var(--accent-brand); font-family: var(--font-mono); }
#admin-view .metric-value.mono-font { font-family: var(--font-mono); }

#admin-view .cyber-status-box { padding: 10px; text-align: center; font-weight: 600; border-radius: var(--radius-sm); font-size: 0.82rem; border: 1px solid transparent; }

#admin-view .cyber-error-log { padding: 12px; border-radius: var(--radius-sm); margin-top: 4px; border-left: 3px solid var(--accent-red); background: rgba(239,68,68,0.05); }
#admin-view .error-header { font-weight: 600; font-size: 0.82rem; margin-bottom: 6px; display: flex; gap: 6px; align-items: center; }
#admin-view .error-body { color: #fca5a5; font-size: 0.78rem; font-family: var(--font-mono); word-break: break-word; }

#admin-view .cyber-terminal-section { margin-top: auto; }
#admin-view .terminal-toggle-btn { background: var(--bg-input); border: 1px solid var(--border-light); color: var(--text-muted); width: 100%; padding: 10px; border-radius: var(--radius-sm); font-size: 0.78rem; cursor: pointer; display: flex; justify-content: space-between; align-items: center; transition: 0.2s; }
#admin-view .terminal-toggle-btn:hover { color: var(--text-main); border-color: var(--border-strong); }
#admin-view .terminal-toggle-btn .toggle-icon { transition: transform 0.3s; }
#admin-view .terminal-toggle-btn.active .toggle-icon { transform: rotate(180deg); }
#admin-view .cyber-terminal-window { height: 0; overflow: hidden; transition: height 0.3s; background: #000; border-radius: var(--radius-sm); margin-top: 8px; }
#admin-view .cyber-terminal-window.open { height: 120px; overflow-y: auto; border: 1px solid var(--border-strong); }
#admin-view .terminal-content { padding: 12px; color: var(--text-muted); font-family: var(--font-mono); font-size: 0.78rem; white-space: pre-wrap; word-break: break-word; }

#admin-view .btn-cyber-back { width: 100%; background: var(--bg-input); border: 1px solid var(--border-strong); color: var(--text-main); padding: 12px; border-radius: var(--radius-sm); cursor: pointer; transition: 0.2s; margin-top: 8px; }
#admin-view .btn-cyber-back:hover { background: var(--border-strong); }

/* ================================================================ */
/* 9. КОМАНДНЫЙ ЦЕНТР (ОПЛАТЫ / РЕГИСТРАЦИИ)                       */
/* ================================================================ */

#admin-view .command-center {
    display: grid; grid-template-columns: 2fr 1fr; gap: 20px;
    background: var(--bg-panel); border: 1px solid var(--border-light);
    border-radius: var(--radius-lg); padding: 18px; margin-bottom: 24px;
}
#admin-view .cc-section { display: flex; flex-direction: column; height: 320px; min-width: 0; }
#admin-view .cc-section[style*="border-left"] { border-left: 1px solid var(--border-light) !important; padding-left: 18px; }
#admin-view .cc-header { font-size: 0.88rem; font-weight: 600; color: var(--text-main); border-bottom: 1px solid var(--border-light); padding-bottom: 10px; margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
#admin-view .cc-header i { color: var(--text-muted); }
#admin-view .cc-list-container { overflow-y: auto; flex-grow: 1; padding-right: 5px; }

#admin-view .pay-item, #admin-view .new-user-item {
    display: flex; align-items: center; gap: 12px; padding: 9px;
    border-bottom: 1px solid var(--border-light); transition: 0.2s; border-radius: var(--radius-sm);
}
#admin-view .pay-item:hover, #admin-view .new-user-item:hover { background: rgba(255,255,255,0.02); }
#admin-view .user-mini-avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
#admin-view .pay-user, #admin-view .nu-name { font-weight: 500; font-size: 0.85rem; color: var(--text-main); }
#admin-view .pay-amount { font-family: var(--font-mono); color: var(--accent-green); font-weight: 600; font-size: 0.85rem; }
#admin-view .nu-time { color: var(--text-muted); font-size: 0.72rem; }

/* ================================================================ */
/* 10. СТАТУСЫ СЕРВИСОВ (DASHBOARD SWITCHES)                       */
/* ================================================================ */

#admin-view .status-widget-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; }
#admin-view .status-mini-card {
    background: rgba(255,255,255,0.02); border: 1px solid var(--border-light);
    border-radius: var(--radius-sm); padding: 11px 13px;
    display: flex; justify-content: space-between; align-items: center; gap: 8px; min-width: 0;
}
#admin-view .status-label-mini { font-size: 0.72rem; color: var(--text-muted); font-weight: 500; display: flex; align-items: center; gap: 7px; min-width: 0; overflow: hidden; }
#admin-view .status-label-mini i { color: var(--accent-brand); flex-shrink: 0; }

/* ================================================================ */
/* 11. ОПАСНАЯ ЗОНА (МУЛЬТИАККАУНТЫ)                               */
/* ================================================================ */

#admin-view .danger-zone-container {
    margin-top: 24px; background: rgba(239,68,68,0.04);
    border: 1px solid rgba(239,68,68,0.2); border-radius: var(--radius-lg); padding: 18px;
    position: relative; overflow: hidden;
}
#admin-view .crack-overlay, #admin-view .flicker-overlay, #admin-view .spark { display: none; }
#admin-view .danger-header { display: flex; align-items: center; justify-content: center; gap: 10px; color: var(--accent-red); font-weight: 600; font-size: 0.95rem; border-bottom: 1px solid rgba(239,68,68,0.2); padding-bottom: 12px; margin-bottom: 14px; }
#admin-view .wanted-table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: 0.8rem; }
#admin-view .wanted-table th { text-align: left; color: var(--text-muted); padding: 9px; border-bottom: 1px solid var(--border-strong); font-weight: 500; }
#admin-view .wanted-table td { padding: 11px 9px; color: var(--text-main); border-bottom: 1px solid var(--border-light); }
#admin-view .wanted-ip { color: var(--accent-red); font-weight: 600; }
#admin-view .wanted-count-box { background: rgba(239,68,68,0.1); color: var(--accent-red); padding: 2px 8px; border-radius: 4px; font-weight: bold; }
#admin-view .wanted-names { color: var(--text-muted); }

#admin-view .alert-dark { background: var(--bg-panel); border: 1px dashed var(--border-strong); padding: 16px; border-radius: var(--radius-md); }

/* ================================================================ */
/* 12. ТАБЛИЦЫ (УНИВЕРСАЛЬНЫЕ + ПРОМО + WHALE)                     */
/* ================================================================ */

#admin-view .table-wrapper { overflow-x: auto; -webkit-overflow-scrolling: touch; width: 100%; max-width: 100%; }

#admin-view .modern-table, #admin-view .whale-table {
    width: 100%; border-collapse: collapse; text-align: left;
}
#admin-view .modern-table thead th, #admin-view .whale-table thead th {
    color: var(--text-muted); font-size: 0.72rem; font-weight: 500;
    text-transform: uppercase; letter-spacing: 0.5px; padding: 0 14px 11px 14px;
    border-bottom: 1px solid var(--border-strong); white-space: nowrap;
}
#admin-view .modern-row, #admin-view .whale-row { transition: background 0.2s ease; }
#admin-view .modern-row:hover, #admin-view .whale-row:hover { background: rgba(255,255,255,0.04); }
#admin-view .modern-row td, #admin-view .whale-row td {
    padding: 13px 14px; border-bottom: 1px solid var(--border-light);
    vertical-align: middle; font-size: 0.85rem;
}

/* Промокоды */
#admin-view .promo-code-badge { display: inline-block; background: var(--bg-input); border: 1px solid var(--border-strong); color: var(--text-main); padding: 4px 10px; border-radius: var(--radius-sm); font-family: var(--font-mono); font-size: 0.82rem; font-weight: 600; }
#admin-view .promo-val { color: var(--accent-brand); font-weight: 600; font-family: var(--font-mono); }
#admin-view .usage-track { width: 100%; height: 6px; background: var(--bg-input); border-radius: 3px; overflow: hidden; }
#admin-view .usage-fill { height: 100%; background: var(--accent-brand); border-radius: 3px; transition: 0.3s; }
#admin-view .usage-fill.full { background: var(--accent-red); }
#admin-view .usage-text { font-size: 0.7rem; color: var(--text-muted); font-family: var(--font-mono); }

/* Whale (Топ донатеров) */
#admin-view .rank-cell { font-weight: 600; color: var(--text-muted); text-align: center; width: 50px; font-family: var(--font-mono); }
#admin-view .rank-1 { color: var(--accent-brand); font-size: 1.1rem; }
#admin-view .rank-2 { color: #e2e8f0; font-size: 1.1rem; }
#admin-view .rank-3 { color: #d97706; font-size: 1.1rem; }
#admin-view .user-cell-content { display: flex; align-items: center; gap: 12px; min-width: 0; }
#admin-view .user-avatar-hex { width: 36px; height: 36px; border-radius: 50%; overflow: hidden; border: 1px solid var(--border-strong); flex-shrink: 0; }
#admin-view .user-avatar-hex img { width: 100%; height: 100%; object-fit: cover; }
#admin-view .user-text-info { display: flex; flex-direction: column; min-width: 0; }
#admin-view .u-name { font-weight: 600; color: var(--text-main); font-size: 0.85rem; }
#admin-view .u-id { color: var(--text-muted); font-size: 0.7rem; font-family: var(--font-mono); }
#admin-view .ltv-val { color: var(--accent-green); font-family: var(--font-mono); font-weight: 600; }
#admin-view .last-pay { color: var(--text-muted); font-size: 0.68rem; display: block; margin-top: 2px; }
#admin-view .tx-badge { background: var(--bg-input); border: 1px solid var(--border-strong); color: var(--text-muted); padding: 2px 6px; border-radius: var(--radius-sm); font-family: var(--font-mono); font-size: 0.72rem; }
#admin-view .balance-val { color: var(--text-main); font-family: var(--font-mono); font-weight: 600; }
#admin-view .ctrl-btn { width: 32px; height: 32px; border-radius: var(--radius-sm); border: 1px solid var(--border-strong); background: transparent; color: var(--text-muted); display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: 0.2s; }
#admin-view .ctrl-btn:hover { background: var(--border-strong); color: var(--accent-brand); }
#admin-view .ctrl-btn.add:hover { color: var(--accent-green); border-color: var(--accent-green); }

/* Поиск пользователей */
#admin-view .user-search-hud { background: var(--bg-panel); border: 1px solid var(--border-light); border-radius: var(--radius-md); padding: 14px; }
#admin-view .search-input-group { position: relative; flex-grow: 1; }
#admin-view .search-icon-deco { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--text-muted); }
#admin-view .search-input-group .cyber-input { padding-left: 40px; height: 44px; }

/* ================================================================ */
/* 13. ЭКОНОМИКА (UNIT CARDS)                                      */
/* ================================================================ */

#admin-view .eco-layout-grid { display: grid; grid-template-columns: 300px 1fr; gap: 20px; align-items: start; }
#admin-view #prices-gen-combined-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 14px; }

#admin-view .unit-card { background: rgba(255,255,255,0.02); border: 1px solid var(--border-light); border-radius: var(--radius-md); padding: 14px; transition: 0.2s; min-width: 0; }
#admin-view .unit-card:hover { border-color: var(--border-strong); }
#admin-view .unit-header { display: flex; align-items: center; gap: 9px; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--border-light); }
#admin-view .unit-icon { color: var(--accent-brand); }
#admin-view .unit-name { font-weight: 600; font-size: 0.85rem; color: var(--text-main); }
#admin-view .unit-inputs-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; }
#admin-view .input-group-vertical { display: flex; flex-direction: column; min-width: 0; }
#admin-view .input-label-small { font-size: 0.65rem; color: var(--text-muted); margin-bottom: 5px; font-weight: 500; }
#admin-view .no-icon { padding-left: 12px !important; }

#admin-view .profit-meter-container { background: var(--bg-input); height: 28px; border-radius: var(--radius-sm); position: relative; overflow: hidden; display: flex; align-items: center; padding: 0 12px; border: 1px solid var(--border-light); }
#admin-view .profit-bar { position: absolute; inset: 0 auto 0 0; background: rgba(16,185,129,0.12); border-right: 2px solid var(--accent-green); transition: 0.4s; z-index: 1; }
#admin-view .profit-text { position: relative; z-index: 2; font-family: var(--font-mono); font-size: 0.72rem; font-weight: 600; color: var(--text-main); width: 100%; display: flex; justify-content: space-between; }
#admin-view .unit-card.profit-negative .profit-bar { background: rgba(239,68,68,0.12); border-color: var(--accent-red); }
#admin-view .unit-card.profit-negative .val-profit { color: var(--accent-red); }
#admin-view .unit-card.profit-positive .val-profit { color: var(--accent-green); }

/* Фиксированная кнопка сохранения */
#admin-view .fixed-bottom { position: fixed; left: 0; right: 0; bottom: 0; z-index: 100; }

/* ================================================================ */
/* 14. ЛОГИ (ТЕРМИНАЛ)                                             */
/* ================================================================ */

#admin-view .log-viewer-card { background: #0a0a0a; border: 1px solid var(--border-strong); border-radius: var(--radius-md); overflow: hidden; display: flex; flex-direction: column; }
#admin-view .log-toolbar { background: var(--bg-panel); padding: 12px 14px; border-bottom: 1px solid var(--border-strong); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
#admin-view .log-select { background: var(--bg-input); border: 1px solid var(--border-strong); color: var(--text-main); padding: 8px 12px; border-radius: var(--radius-sm); font-family: var(--font-mono); font-size: 0.8rem; cursor: pointer; }
#admin-view .log-switch-wrapper { display: flex; align-items: center; }
#admin-view .btn-log-action { padding: 7px 14px; font-size: 0.78rem; }
#admin-view .log-terminal-area { padding: 14px; color: var(--text-muted); font-family: var(--font-mono); font-size: 0.78rem; height: 500px; overflow-y: auto; line-height: 1.5; word-break: break-word; white-space: pre-wrap; }
#admin-view .log-date { color: var(--neon-blue); }
#admin-view .log-error { color: var(--accent-red); font-weight: 600; }
#admin-view .log-warning { color: var(--accent-brand); }
#admin-view .log-info { color: var(--accent-green); }

/* Bootstrap form-switch fallback */
#admin-view .form-check-input { width: 36px; height: 18px; appearance: none; background: #333; border-radius: 20px; position: relative; cursor: pointer; transition: 0.3s; border: none; }
#admin-view .form-check-input:checked { background: var(--accent-green); }
#admin-view .form-check-input::before { content: ''; position: absolute; width: 14px; height: 14px; background: #fff; border-radius: 50%; top: 2px; left: 2px; transition: 0.3s; }
#admin-view .form-check-input:checked::before { transform: translateX(18px); }
#admin-view .form-check { display: flex; align-items: center; gap: 8px; }
#admin-view .form-check-label { color: var(--text-muted); font-size: 0.78rem; }

/* ================================================================ */
/* 15. ДЕРЕВО РЕФЕРАЛОВ                                            */
/* ================================================================ */

#admin-view .cyber-tree-container { overflow-x: auto; padding: 16px; }
#admin-view .custom-scrollbar { scrollbar-width: thin; }

/* ================================================================ */
/* 16. ТАБЛИЦА ТРАНЗАКЦИЙ (REF-STYLE МОДАЛКА)                      */
/* ================================================================ */

#admin-view .ref-tabs-wrapper, .ref-tabs-wrapper { display: inline-flex; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); overflow: hidden; flex-wrap: wrap; }
.ref-tab-btn { background: transparent; border: none; color: var(--text-muted); padding: 8px 16px; font-size: 0.82rem; font-weight: 500; border-right: 1px solid var(--border-strong); cursor: pointer; transition: 0.2s; }
.ref-tab-btn:last-child { border-right: none; }
.ref-tab-btn:hover { background: rgba(255,255,255,0.05); color: var(--text-main); }
.ref-tab-btn.active { color: var(--accent-brand); background: rgba(250,191,60,0.1); }

.ref-table { width: 100%; border-collapse: collapse; text-align: left; }
.ref-table thead th { color: var(--text-main); font-size: 0.85rem; font-weight: 600; padding: 12px 0; border-bottom: 1px solid var(--border-strong); }
.ref-table tbody tr { transition: background 0.2s ease; }
.ref-table tbody tr:hover { background: rgba(255,255,255,0.02); }
.ref-table tbody td { padding: 14px 0; border-bottom: 1px solid #222; font-size: 0.85rem; vertical-align: middle; }

.ref-pagination { margin-top: 18px; display: flex; justify-content: center; align-items: center; gap: 6px; flex-wrap: wrap; }
.ref-pagination button { background: transparent; border: none; color: var(--text-muted); font-size: 0.82rem; font-weight: 600; padding: 5px 9px; cursor: pointer; transition: 0.2s; border-radius: 4px; }
.ref-pagination button:hover:not(:disabled) { color: var(--text-main); background: rgba(255,255,255,0.05); }
.ref-pagination button.active { color: var(--accent-brand); background: rgba(250,191,60,0.1); }
.ref-pagination button:disabled { opacity: 0.3; cursor: not-allowed; }
.pag-dots { color: var(--text-muted); font-size: 0.82rem; }

/* ================================================================ */
/* 17. ФИНАНСОВЫЙ ОТЧЕТ (P&L)                                      */
/* ================================================================ */

#admin-view .btn-icon-back { background: var(--bg-panel); border: 1px solid var(--border-strong); color: var(--text-muted); width: 36px; height: 36px; border-radius: var(--radius-sm); display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: 0.2s; }
#admin-view .btn-icon-back:hover { background: var(--border-strong); color: var(--accent-brand); }

#admin-view .editable-expense-cell { display: inline-flex; align-items: center; justify-content: space-between; gap: 10px; min-width: 120px; background: var(--bg-input); border: 1px solid var(--border-strong); padding: 6px 12px; border-radius: var(--radius-sm); cursor: pointer; transition: 0.2s; }
#admin-view .editable-expense-cell:hover { border-color: var(--accent-brand); background: rgba(250,191,60,0.08); }
#admin-view .editable-expense-cell .edit-icon { font-size: 0.7rem; color: var(--text-muted); transition: color 0.2s; }
#admin-view .editable-expense-cell:hover .edit-icon { color: var(--accent-brand); }

#admin-view .tx-grid-row { display: flex; align-items: center; }

/* ================================================================ */
/* 18. ТЕНЕВАЯ ГАЛЕРЕЯ                                             */
/* ================================================================ */

#admin-view .shadow-gallery-item { position: relative; border-radius: var(--radius-sm); overflow: hidden; }

/* ================================================================ */
/* 19. ЖИВАЯ ЛЕНТА                                                */
/* ================================================================ */

#admin-view #live-feed-list .admin-card { border-radius: var(--radius-sm) !important; flex-direction: row !important; }

/* ================================================================ */
/* 20. МОДАЛЬНЫЕ ОКНА (Bootstrap fallback / стилизация)            */
/* ================================================================ */

.modal-content { background: var(--bg-panel, #141414); color: #fff; }
#chestLootModal .cyber-input, #grantItemModal .cyber-input,
#chestLootModal .modern-table, #grantItemModal .modern-table { font-size: 0.85rem; }
.shop-buy-btn { background: var(--accent-brand, #FABF3C); color: #000; border: none; padding: 10px; width: 100%; border-radius: var(--radius-sm); font-weight: 700; cursor: pointer; transition: 0.2s; display: flex; align-items: center; justify-content: center; gap: 8px; }
.shop-buy-btn:hover { background: #ff8533; }

/* ================================================================ */
/* 21. ЗАГРУЗЧИК                                                   */
/* ================================================================ */

#admin-view .fa-circle-notch { color: var(--accent-brand); }

/* ================================================================ */
/* 22. АДАПТИВ: ПЛАНШЕТЫ (≤ 1100px)                                */
/* ================================================================ */

@media (max-width: 1100px) {
    #admin-view .admin-header-row { flex-direction: column; align-items: stretch; }
    #admin-view .admin-grid-container { grid-template-columns: 1fr; gap: 14px; }
    #admin-view .analytics-charts-grid { grid-template-columns: 1fr; }
    #admin-view .command-center { grid-template-columns: 1fr; gap: 16px; }
    #admin-view .cc-section { height: auto; min-height: 220px; }
    #admin-view .cc-section[style*="border-left"] { border-left: none !important; padding-left: 0; border-top: 1px solid var(--border-light); padding-top: 16px; }
    #admin-view .eco-layout-grid { grid-template-columns: 1fr; }
    #admin-view .cyber-services-list { grid-template-columns: 1fr !important; }
    #admin-view .modern-table, #admin-view .whale-table { min-width: 600px; }
}

/* ================================================================ */
/* 23. АДАПТИВ: СМАРТФОНЫ (≤ 768px)                                */
/* ================================================================ */

@media (max-width: 768px) {
    #admin-view { padding: 0 10px 30px; font-size: 13px; }

    /* Карточки и формы */
    #admin-view .admin-card { padding: 12px; border-radius: var(--radius-md); overflow: hidden; }
    #admin-view .row-grid-2, #admin-view .row-grid-3, #admin-view .unit-inputs-row {
        display: flex !important; flex-direction: column !important; gap: 10px !important;
    }

    /* Плашка с тумблером (перепродажа и т.п.) */
    #admin-view .admin-card .d-flex.align-items-center.gap-3 {
        flex-wrap: wrap;
    }

    /* Таблицы — изолируем скролл внутри обёртки */
    #admin-view .table-wrapper { width: 100%; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 8px; border-radius: var(--radius-sm); }
    #admin-view .modern-table { min-width: 720px; }
    #admin-view .whale-table { min-width: 560px; }
    #admin-view .ref-table { min-width: 520px; }
    #admin-view .wanted-table { min-width: 480px; }

    /* Сжимаем шрифты таблиц */
    #admin-view .modern-row td, #admin-view .whale-row td { padding: 10px 8px; font-size: 0.78rem; }
    #admin-view .modern-table thead th, #admin-view .whale-table thead th { padding: 0 8px 8px; font-size: 0.65rem; }
}

/* ================================================================ */
/* 24. АДАПТИВ: КОМПАКТ (≤ 600px)                                  */
/* ================================================================ */

@media (max-width: 600px) {
    #admin-view .admin-header-row { padding: 12px 0; margin-bottom: 14px; gap: 10px; }
    #admin-view .admin-title { font-size: 1.1rem; }

    /* Вкладки — только иконки */
    #admin-view .admin-tabs { width: 100%; padding: 4px; }
    #admin-view .admin-tab-btn { padding: 8px 11px; gap: 0; }
    #admin-view .admin-tab-btn span { display: none; }
    #admin-view .admin-tab-btn i { font-size: 1.05rem; }
    #admin-view .admin-actions { width: 100%; }
    #admin-view .admin-actions .btn { width: 100%; }

    /* Статистика */
    #admin-view .admin-stats-row { grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 14px; }
    #admin-view .stat-item { padding: 10px 12px; gap: 4px; }
    #admin-view .stat-label { font-size: 0.58rem; }
    #admin-view .stat-value { font-size: 1.2rem; }
    #admin-view .stat-icon { font-size: 0.9rem; }

    #admin-view .list-header { font-size: 0.8rem; margin-bottom: 10px; padding-bottom: 8px; }

    /* Монитор */
    #admin-view .cyber-monitor { padding: 12px; }
    #admin-view .cyber-title-main { font-size: 1.6rem; }
    #admin-view .cyber-title-sub { font-size: 0.6rem; letter-spacing: 1px; }
    #admin-view .cyber-service-info { font-size: 0.7rem; }

    /* Досье — вертикально */
    #admin-view .online-grid { gap: 10px; }
    #admin-view .dossier-card { padding: 12px; }
    #admin-view .dossier-avatar { width: 40px; height: 40px; }
    #admin-view .username-block h4 { font-size: 0.85rem; }
    #admin-view .data-metrics { gap: 12px; }
    #admin-view .metric-val { font-size: 0.78rem; }
    #admin-view .dossier-action-btn { font-size: 0.62rem; padding: 6px 4px; }

    /* Командный центр */
    #admin-view .pay-user, #admin-view .nu-name { font-size: 0.8rem; }

    /* Аналитика */
    #admin-view .chart-canvas-wrapper { height: 200px; }
    #admin-view #revenue-stream-chart { height: 220px !important; }
    #admin-view .analytics-switcher { overflow-x: auto; }
    #admin-view .switcher-btn { flex-shrink: 0; font-size: 0.68rem; padding: 5px 9px; }

    /* Формы */
    #admin-view .cyber-input, #admin-view .cyber-textarea, #admin-view .cyber-select { padding: 8px 10px; font-size: 0.8rem; }
    #admin-view .btn, #admin-view .btn-primary, #admin-view .btn-create, #admin-view .btn-broadcast { padding: 9px; font-size: 0.8rem; }

    /* Лог-терминал */
    #admin-view .log-terminal-area { height: 400px; font-size: 0.72rem; }
    #admin-view .log-toolbar { padding: 10px; }

    /* P&L */
    #admin-view .editable-expense-cell { min-width: auto; padding: 5px 8px; font-size: 0.78rem; }
    #admin-view .btn-icon-back { width: 30px; height: 30px; font-size: 0.8rem; }

    /* Модалки на весь экран удобнее */
    .modal-dialog { margin: 8px; }

    /* Эко-форма в один столбец */
    #admin-view #prices-gen-combined-form { grid-template-columns: 1fr; }
}

/* ================================================================ */
/* 25. АДАПТИВ: УЗКИЕ ЭКРАНЫ (≤ 380px)                             */
/* ================================================================ */

@media (max-width: 380px) {
    #admin-view .admin-stats-row { grid-template-columns: 1fr; }
    #admin-view .stat-value { font-size: 1.4rem; }
    #admin-view .dossier-layout { flex-direction: column; align-items: stretch; }
    #admin-view .dossier-visual { flex-direction: row; justify-content: flex-start; gap: 10px; }
    #admin-view .status-widget-grid { grid-template-columns: 1fr; }
}