/* ══════════════════════════════════════
   OmniSolver Code — Chat Interface Styles
   Тёмная тема, код-эстетика, звёзды
   ══════════════════════════════════════ */

/* Text-selection floating action menu */
#text-sel-menu.sel-menu {
    z-index: 9999;
    padding: 4px;
    display: flex;
    gap: 2px;
    background: var(--bg-card, #1a1f2e);
    border: 1px solid var(--border, rgba(255,255,255,0.08));
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.35), 0 2px 6px rgba(0,0,0,0.2);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    animation: sel-menu-in 140ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes sel-menu-in {
    from { opacity: 0; transform: translateY(4px) scale(0.96); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
#text-sel-menu .sel-menu-btn {
    position: relative;
    background: transparent;
    border: none;
    cursor: pointer;
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 7px;
    color: var(--text, #e4e7f0);
    transition: background 120ms ease, color 120ms ease, transform 120ms ease;
}
#text-sel-menu .sel-menu-btn:hover {
    transform: translateY(-1px);
}
#text-sel-menu .sel-menu-btn svg {
    display: block;
    transition: transform 200ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
#text-sel-menu .sel-menu-btn:active svg {
    transform: scale(0.88);
}
#text-sel-menu .sel-menu-copy:hover {
    background: linear-gradient(135deg, rgba(99,102,241,0.18), rgba(139,92,246,0.18));
    color: #a5b4fc;
}
#text-sel-menu .sel-menu-explain:hover {
    background: linear-gradient(135deg, rgba(250,204,21,0.18), rgba(249,115,22,0.18));
    color: #fde68a;
}
#text-sel-menu .sel-menu-simplify:hover {
    background: linear-gradient(135deg, rgba(16,185,129,0.18), rgba(14,165,233,0.18));
    color: #6ee7b7;
}
#text-sel-menu .sel-menu-explain:hover svg {
    transform: rotate(-8deg) scale(1.08);
}
#text-sel-menu .sel-menu-simplify:hover svg {
    transform: rotate(12deg) scale(1.1);
}
body.light-theme #text-sel-menu.sel-menu {
    background: #ffffff;
    border-color: rgba(15,23,42,0.1);
    box-shadow: 0 8px 24px rgba(15,23,42,0.12), 0 2px 6px rgba(15,23,42,0.06);
}
body.light-theme #text-sel-menu .sel-menu-btn {
    color: #334155;
}
body.light-theme #text-sel-menu .sel-menu-copy:hover    { color: #4f46e5; }
body.light-theme #text-sel-menu .sel-menu-explain:hover { color: #b45309; }
body.light-theme #text-sel-menu .sel-menu-simplify:hover{ color: #047857; }

*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --bg: #06070c;
    --bg-card: #0c0d17;
    --bg-hover: #13152a;
    --bg-input: #090a13;
    --border: #191b30;
    --border-light: #262842;

    --text: #e8e8f4;
    --text-secondary: #9294b8;
    --text-muted: #8587ad;

    --primary: #6c5ce7;
    --primary-light: #a29bfe;
    --primary-dark: #5541d9;
    --primary-glow: rgba(108, 92, 231, 0.25);

    --accent: #00cec9;
    --accent-light: #55efc4;

    --gradient: linear-gradient(135deg, #6c5ce7, #00cec9);
    --gradient-text: linear-gradient(135deg, #a29bfe, #55efc4);

    --code-bg: #080914;
    --code-border: #191b30;

    --msg-user: #0e0f1c;
    --msg-ai: #0a0b16;

    --sidebar-w: 280px;

    --success: #00b894;
    --warning: #fdcb6e;
    --danger: #ff7675;

    --radius: 14px;
    --radius-lg: 18px;
    --shadow: 0 4px 24px rgba(0, 0, 0, 0.5);
    --transition: 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);

    --bg-secondary: #111225;

    --font-code: 'JetBrains Mono', 'Fira Code', monospace;
}

html, body {
    height: 100%;
    overflow: hidden;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
}

/* iOS: фикс высоты при повороте/появлении адресной строки */
@supports (height: 100dvh) {
    html, body { height: 100dvh; }
}

body {
    font-family: 'Inter', 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    background: var(--bg);
    background-image: radial-gradient(circle at 0% 0%, rgba(108, 92, 231, 0.03) 0%, transparent 50%),
                      radial-gradient(circle at 100% 100%, rgba(0, 206, 201, 0.02) 0%, transparent 50%);
    color: var(--text);
    line-height: 1.5;
    font-feature-settings: 'cv02', 'cv03', 'cv04', 'cv11';
    text-rendering: optimizeLegibility;
}

body.osc-booting .auth-screen,
body.osc-booting .chat-screen {
    visibility: hidden;
}

.osc-boot-overlay {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(circle at 50% 35%, rgba(108, 92, 231, 0.14), transparent 34%),
        linear-gradient(180deg, #070812 0%, #05060b 100%);
    opacity: 1;
    transition: opacity 260ms ease, visibility 260ms ease;
}

.osc-boot-overlay.is-hiding {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.osc-boot-card {
    width: min(260px, calc(100vw - 48px));
    min-height: 150px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    border: 1px solid rgba(162, 155, 254, 0.18);
    border-radius: 18px;
    background: rgba(12, 13, 23, 0.82);
    box-shadow: 0 24px 90px rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.osc-boot-card img {
    border-radius: 10px;
    box-shadow: 0 0 28px rgba(108, 92, 231, 0.22);
}

.osc-boot-title {
    color: var(--text);
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0;
}

.osc-boot-line {
    width: 132px;
    height: 3px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
}

.osc-boot-line span {
    display: block;
    width: 46%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--primary-light), var(--accent-light));
    animation: oscBootLine 1.05s ease-in-out infinite;
}

@keyframes oscBootLine {
    0% { transform: translateX(-110%); }
    55%, 100% { transform: translateX(250%); }
}

@media (prefers-reduced-motion: reduce) {
    .osc-boot-overlay { transition: none; }
    .osc-boot-line span { animation: none; width: 100%; opacity: 0.65; }
}

a { color: var(--primary-light); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ══════════════════════════════════════
   Auth Screen
   ══════════════════════════════════════ */

.auth-screen {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    min-height: 100dvh;
    padding: 24px;
    padding-top: max(24px, env(safe-area-inset-top));
    padding-bottom: max(24px, env(safe-area-inset-bottom));
    position: relative;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.auth-particles {
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(108, 92, 231, 0.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 70%, rgba(0, 206, 201, 0.07) 0%, transparent 50%),
        radial-gradient(circle at 50% 50%, rgba(162, 155, 254, 0.04) 0%, transparent 70%);
}

.auth-container {
    width: 100%;
    max-width: 400px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 36px;
    position: relative;
    z-index: 2;
    box-shadow: var(--shadow);
}

.auth-logo {
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: center;
    margin-bottom: 8px;
}

.auth-logo h1 {
    font-family: 'Sora', sans-serif;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.auth-logo .accent {
    background: var(--gradient-text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.auth-subtitle {
    text-align: center;
    color: var(--text-secondary);
    font-size: 14px;
    margin-bottom: 22px;
}

.auth-choice-head {
    margin-bottom: 18px;
    text-align: left;
}

.auth-choice-kicker {
    display: inline-flex;
    align-items: center;
    margin-bottom: 12px;
    color: var(--text-muted);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.auth-choice-head h2 {
    margin: 0 0 8px;
    color: var(--text);
    font-family: 'Sora', sans-serif;
    font-size: 28px;
    font-weight: 750;
    letter-spacing: -0.04em;
    line-height: 1.12;
}

.auth-choice-head p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 13.5px;
    line-height: 1.55;
}

/* Auth tabs */
.auth-tabs {
    display: flex;
    gap: 4px;
    background: var(--bg);
    border-radius: 10px;
    padding: 3px;
    margin-bottom: 24px;
}

.auth-tab {
    flex: 1;
    padding: 8px;
    border: none;
    background: none;
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    border-radius: 8px;
    font-family: inherit;
    transition: var(--transition);
}

.auth-tab.active {
    background: var(--primary);
    color: #fff;
}

/* Forms */
.auth-form { display: flex; flex-direction: column; gap: 16px; }

.input-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.input-group label {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
}

.input-group input {
    padding: 10px 14px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
    outline: none;
    transition: var(--transition);
}

.input-group input:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(108, 92, 231, 0.15);
}

.auth-error {
    color: #f87171;
    font-size: 13px;
    display: none;
}

.auth-error.show {
    display: block;
}

.auth-footer {
    text-align: center;
    margin-top: 20px;
}

.auth-footer a {
    font-size: 13px;
    color: var(--text-muted);
}

/* Auth buttons */
.auth-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 13px 16px;
    font-size: 14px;
    font-weight: 600;
    border: 1px solid var(--border);
    border-radius: 12px;
    cursor: pointer;
    width: 100%;
    box-sizing: border-box;
    transition: all 0.2s;
    font-family: inherit;
    color: var(--text);
    background: var(--bg);
}
.auth-btn:hover { border-color: var(--primary); background: rgba(99,102,241,0.06); }
.auth-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.auth-btn-google {
    justify-content: flex-start;
    min-height: 54px;
    margin-bottom: 10px;
    padding: 14px 16px;
    color: var(--text);
    background: rgba(255,255,255,0.035);
    border-color: var(--border);
    text-decoration: none !important;
}
.auth-btn-google span,
.auth-btn-tg-oauth span {
    flex: 1;
    text-align: left;
}
.auth-btn-google:hover {
    background: rgba(255,255,255,0.065);
    border-color: rgba(162, 155, 254, 0.45);
}

.auth-btn-primary {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}
.auth-btn-primary:hover { background: #5a5fe0; border-color: #5a5fe0; }

.auth-btn-telegram {
    background: #2AABEE;
    color: #fff;
    border-color: #2AABEE;
}
.auth-btn-telegram:hover { background: #229ED9; border-color: #229ED9; }

.auth-btn-phone {
    background: var(--bg);
    color: var(--text);
}

.auth-btn-ghost {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 13px;
    padding: 10px;
}
.auth-btn-ghost:hover { color: var(--primary-light); }

.auth-btn-sm {
    padding: 8px 16px;
    font-size: 13px;
    width: auto;
    min-width: 100px;
}

.auth-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 16px 0;
}

/* Telegram OAuth кнопка — стилизована под официальный виджет, мгновенный рендер */
.auth-btn-tg-oauth {
    justify-content: flex-start;
    background: linear-gradient(180deg, #54a9eb 0%, #2f8cd1 100%);
    color: #fff;
    border: none;
    box-shadow: 0 2px 8px rgba(42, 171, 238, 0.25);
    font-weight: 600;
    letter-spacing: 0.2px;
    min-height: 54px;
    cursor: pointer;
    transition: transform 0.1s ease, box-shadow 0.2s ease, filter 0.15s ease;
}
.auth-btn-tg-oauth:hover {
    background: linear-gradient(180deg, #5fb1ef 0%, #3596d8 100%);
    box-shadow: 0 4px 14px rgba(42, 171, 238, 0.35);
    filter: brightness(1.05);
}
.auth-btn-tg-oauth:active { transform: translateY(1px); }
.auth-btn-tg-oauth:disabled { opacity: 0.6; cursor: wait; }
.auth-tg-hint {
    font-size: 11px;
    color: var(--text-muted);
    text-align: center;
    margin: 4px 0 6px;
    opacity: 0.85;
}
.auth-divider::before, .auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}
.auth-divider span {
    font-size: 12px;
    color: var(--text-secondary);
}

.auth-register-hint {
    font-size: 13px;
    color: var(--text-secondary);
    text-align: center;
    margin-bottom: 28px;
    line-height: 1.5;
}

/* Отодвигаем кнопку "Отправить SMS-код" от инпута телефона */
#reg-step-phone #btn-reg-send-code {
    margin-top: 16px;
}

/* Hint под Email-формой */
.auth-login-hint {
    font-size: 12px;
    color: var(--text-muted);
    text-align: center;
    margin: 8px 0 14px;
    line-height: 1.5;
    opacity: 0.85;
}

/* Phone input */
.phone-input-wrap {
    display: flex;
    align-items: center;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
    transition: border-color 0.2s;
}
.phone-input-wrap:focus-within {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(99,102,241,0.15);
}
.phone-prefix {
    padding: 10px 8px 10px 14px;
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    background: rgba(99,102,241,0.06);
    border-right: 1px solid var(--border);
    user-select: none;
}
.phone-input-wrap input {
    flex: 1;
    padding: 10px 14px;
    background: transparent;
    border: none;
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
    outline: none;
}

/* SMS code input */
.sms-code-input {
    text-align: center;
    font-size: 24px !important;
    font-weight: 700;
    letter-spacing: 8px;
    font-family: 'JetBrains Mono', monospace;
}

.sms-code-info {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: rgba(99,102,241,0.08);
    border-radius: 10px;
    font-size: 13px;
    color: var(--text);
    margin-bottom: 4px;
}

/* Phone exists error */
.auth-phone-exists {
    text-align: center;
    padding: 20px 0;
}
.phone-exists-icon { font-size: 36px; margin-bottom: 12px; }
.phone-exists-title { font-size: 16px; font-weight: 700; margin-bottom: 8px; }
.phone-exists-text { font-size: 13px; color: var(--text-secondary); margin-bottom: 12px; }
.phone-exists-email {
    display: inline-block;
    padding: 8px 16px;
    background: rgba(99,102,241,0.1);
    border-radius: 8px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
    font-weight: 600;
    color: var(--primary-light);  /* a11y: --primary 4.14:1 FAIL → --primary-light 8.3:1 */
    margin-bottom: 16px;
}

/* ═══ Account Linking Modal ═══ */
.link-account-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0,0,0,0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    backdrop-filter: blur(8px);
}

.link-account-box {
    position: relative;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 32px;
    max-width: 440px;
    width: 100%;
    box-shadow: 0 24px 64px rgba(0,0,0,0.5);
    text-align: center;
}

.link-account-icon { font-size: 48px; margin-bottom: 12px; }
.link-account-title { font-size: 20px; font-weight: 700; margin-bottom: 8px; }
.link-account-desc { font-size: 14px; color: var(--text-secondary); margin-bottom: 24px; line-height: 1.5; }

.link-account-steps {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 16px;
}

.link-step {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 14px;
    text-align: left;
}
.link-step.done {
    border-color: #22c55e;
    background: rgba(34,197,94,0.06);
}

.link-step-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.link-step-info { flex: 1; }
.link-step-name { font-size: 14px; font-weight: 600; }
.link-step-status { font-size: 12px; color: var(--text-muted); }
.link-step.done .link-step-status { color: #22c55e; }

.link-email-form {
    padding: 16px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 14px;
}

.auth-box {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.link-account-note {
    font-size: 12px;
    color: var(--text-muted);
    margin-top: 16px;
    line-height: 1.4;
}

/* ══════════════════════════════════════
   Buttons (shared)
   ══════════════════════════════════════ */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 24px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    border: none;
    font-family: inherit;
}

.btn-primary {
    background: var(--gradient);
    color: #fff;
}

.btn-primary:hover {
    box-shadow: 0 4px 20px rgba(115, 100, 245, 0.35);
    transform: translateY(-1px);
    filter: brightness(1.1);
}

.btn-block { width: 100%; }

/* ══════════════════════════════════════
   Chat Layout
   ══════════════════════════════════════ */

.chat-screen {
    display: flex;
    height: 100vh;
    height: 100dvh;
}

/* ── Sidebar ── */
.sidebar {
    width: var(--sidebar-w);
    min-width: var(--sidebar-w);
    height: 100vh;
    height: 100dvh;
    background: var(--bg-card);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    transition: var(--transition);
    overflow: hidden;
    position: relative;
}

.sidebar.collapsed {
    width: 0;
    min-width: 0;
    border-right: none;
}

/* Resize-grip: тонкая полоса на правой границе sidebar.
   Drag = меняет --sidebar-w. Сохраняется в localStorage. */
.sidebar-resize-grip {
    position: absolute;
    top: 0;
    right: -3px;
    width: 6px;
    height: 100%;
    cursor: col-resize;
    z-index: 50;
    background: transparent;
    transition: background 0.15s ease;
}
.sidebar-resize-grip:hover,
.sidebar-resize-grip.dragging {
    background: linear-gradient(90deg, transparent, rgba(139, 92, 246, 0.5), transparent);
}
.sidebar-resize-grip::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 2px;
    height: 32px;
    background: rgba(139, 92, 246, 0);
    border-radius: 1px;
    transition: background 0.15s ease;
}
.sidebar-resize-grip:hover::after,
.sidebar-resize-grip.dragging::after {
    background: rgba(139, 92, 246, 0.7);
}
.sidebar.collapsed .sidebar-resize-grip { display: none; }
body.sidebar-resizing {
    cursor: col-resize !important;
    user-select: none;
}
body.sidebar-resizing * { user-select: none !important; }
@media (max-width: 768px) {
    .sidebar-resize-grip { display: none; }
}

.sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
}

.sidebar-logo {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: 'Sora', sans-serif;
    font-weight: 700;
    font-size: 15px;
    letter-spacing: -0.02em;
}

.sidebar-toggle {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 4px;
    border-radius: 6px;
    transition: var(--transition);
}

.sidebar-toggle:hover {
    color: var(--text);
    background: var(--bg-hover);
}

/* New chat button */
.btn-new-chat {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 12px 12px 0;
    padding: 10px 14px;
    background: rgba(115, 100, 245, 0.1);
    border: 1px dashed rgba(115, 100, 245, 0.3);
    border-radius: 10px;
    color: var(--primary-light);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: var(--transition);
}

.btn-new-chat:hover {
    background: rgba(115, 100, 245, 0.18);
    border-color: var(--primary);
}

/* Chat list */
.sidebar-section {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: 12px;
}

.sidebar-section-title {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 4px 4px 8px;
}

.chat-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.chat-list-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text-secondary);
    transition: var(--transition);
    position: relative;
    user-select: none;
    -webkit-user-select: none;
    -webkit-touch-callout: none;
    /* На touch разрешаем только вертикальный скролл — иначе горизонтальные жесты могут
       интерпретироваться как drag и блокировать тап */
    touch-action: pan-y;
}

/* Визуальный сигнал что drag «вооружён» — без grab-курсора, только подсветка */
.chat-list-item.drag-armed {
    transform: scale(1.04) !important;
    box-shadow: 0 0 0 2px var(--primary), 0 6px 20px rgba(108, 92, 231, 0.45) !important;
    background: rgba(108, 92, 231, 0.14) !important;
    z-index: 10 !important;
    transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease !important;
}

/* Принудительно pointer на чате — даже когда draggable=true браузер не должен показывать "move" */
.chat-list-item,
.chat-list-item[draggable="true"],
.chat-list-item.drag-armed {
    cursor: pointer !important;
}

.chat-list-item:hover {
    background: var(--bg-hover);
    color: var(--text);
}

.chat-list-item.active {
    background: rgba(115, 100, 245, 0.12);
    color: var(--text);
}
.chat-list-item:active { cursor: grabbing; }
body.dragging-chat .chat-main { outline: 2px dashed var(--accent); outline-offset: -4px; }
body.dragging-chat .chat-main::after {
    content: '⊞ Перетащите сюда для split-view';
    position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
    background: rgba(99,102,241,0.9); color: #fff; padding: 12px 24px; border-radius: 12px;
    font-size: 14px; font-weight: 600; z-index: 100; pointer-events: none;
}
#dual-chat-pane.drag-over { outline: 2px solid var(--accent); outline-offset: -2px; }

.chat-list-item .chat-item-icon {
    font-size: 16px;
    flex-shrink: 0;
}

.chat-list-item .chat-item-title {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-list-item .chat-item-delete {
    opacity: 0;
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 2px;
    border-radius: 4px;
    transition: var(--transition);
}

.chat-list-item .chat-item-restore {
    flex-shrink: 0;
    background: rgba(99, 102, 241, 0.1);
    border: 1px solid rgba(99, 102, 241, 0.2);
    color: var(--primary-light, #818cf8);
    cursor: pointer;
    width: 24px;
    height: 24px;
    padding: 0;
    border-radius: 7px;
    transition: var(--transition);
}

.chat-list-item .chat-item-restore:hover {
    color: #fff;
    background: var(--primary, #6366f1);
}

.chat-list-item .chat-item-tokens {
    flex-shrink: 0;
    font-size: 10px;
    font-weight: 600;
    padding: 1px 6px;
    border-radius: 6px;
    color: var(--primary-light, #7c89f6);
    background: rgba(124, 137, 246, 0.12);
    border: 1px solid rgba(124, 137, 246, 0.2);
    font-variant-numeric: tabular-nums;
    line-height: 1.4;
    transition: var(--transition);
}

.chat-list-item:hover .chat-item-tokens {
    opacity: 0;
    pointer-events: none;
}

.chat-list-item:hover .chat-item-delete {
    opacity: 1;
}

.chat-list-item .chat-item-delete:hover {
    color: #f87171;
}

/* Draggable sidebar divider */
.sidebar-divider {
    height: 6px;
    cursor: row-resize;
    background: transparent;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
    transition: background 0.15s;
}
.sidebar-divider::after {
    content: '';
    position: absolute;
    left: 25%;
    right: 25%;
    top: 50%;
    height: 3px;
    border-radius: 2px;
    background: var(--border);
    transform: translateY(-50%);
    transition: background 0.15s;
}
.sidebar-divider:hover::after,
.sidebar-divider.dragging::after {
    background: var(--primary);
}
.sidebar-divider.dragging {
    background: rgba(108, 92, 231, 0.08);
}

/* Settings toggles */
.sidebar-bottom {
    border-top: none;
    padding: 12px;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
}

.sidebar-footer {
    flex-shrink: 0;
    border-top: 1px solid var(--border);
    padding: 12px;
    background: var(--bg-card);
}

.sidebar-settings {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 12px;
}

/* AI Toggles smooth expand/collapse */
#ai-toggles-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
    overflow: hidden;
    transition: max-height 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity 0.3s ease, margin 0.3s ease;
}
#ai-toggles-list.ai-toggles-collapsed {
    max-height: 0;
    opacity: 0;
    margin-top: 0;
}
#ai-toggles-list.ai-toggles-expanded {
    max-height: 500px;
    opacity: 1;
    margin-top: 4px;
}
.ai-toggles-header .ai-toggles-arrow {
    display: inline-block;
    transition: transform 0.3s ease;
}
.ai-toggles-header.open .ai-toggles-arrow {
    transform: rotate(90deg);
}

.setting-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 4px 0;
}

.setting-toggle span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.tog-ico {
    color: var(--primary);
    flex-shrink: 0;
}

.sub-btn-ico {
    display: inline-flex;
    align-items: center;
    color: var(--primary);
}

.sub-sidebar-btn:hover .sub-btn-ico {
    color: #fff;
}

/* Vault button icon — бирюзово-фиолетовый glow */
.vault-btn-ico {
    color: #5eead4 !important;
    filter: drop-shadow(0 0 6px rgba(94, 234, 212, 0.35));
    transition: color 200ms, filter 200ms;
}
.sub-sidebar-btn:hover .vault-btn-ico {
    color: #99f6e4 !important;
    filter: drop-shadow(0 0 10px rgba(94, 234, 212, 0.6));
}
body.light-theme .vault-btn-ico { color: #0d9488 !important; filter: drop-shadow(0 0 4px rgba(13, 148, 136, 0.25)); }
body.light-theme .sub-sidebar-btn:hover .vault-btn-ico { color: #115e59 !important; }

/* ── Subscription diamond — custom SVG ──────────────────────────
   Раньше постоянно крутилось (9s loop) — отвлекало и выглядело как
   эмодзи-стикер. Теперь статичный градиент с лёгкой пульсацией
   sparkle'а; полный поворот только при hover. */
.diamond-emoji {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    line-height: 1;
    filter: drop-shadow(0 0 6px rgba(162, 155, 254, 0.40));
    transition: filter 220ms;
}
.diamond-emoji .diamond-svg {
    transform-origin: 50% 50%;
    transition: transform 600ms cubic-bezier(.4,0,.2,1);
}
.diamond-emoji .diamond-sparkle {
    animation: diamondSparkle 2.4s ease-in-out infinite;
    transform-origin: 16px 16px;
}

@keyframes diamondSparkle {
    0%, 100% { opacity: 0.35; transform: scale(0.7); }
    50%      { opacity: 1;    transform: scale(1.3); }
}

.sub-sidebar-btn:hover .diamond-emoji {
    filter: drop-shadow(0 0 12px rgba(162, 155, 254, 0.75));
}
.sub-sidebar-btn:hover .diamond-emoji .diamond-svg {
    transform: rotateY(180deg);
}
@media (prefers-reduced-motion: reduce) {
    .diamond-emoji .diamond-svg,
    .diamond-emoji .diamond-sparkle { animation: none; transition: none; }
    .sub-sidebar-btn:hover .diamond-emoji .diamond-svg { transform: none; }
}

.setting-toggle input { display: none; }

.toggle-slider {
    width: 48px;
    height: 26px;
    background: var(--border);
    border-radius: 13px;
    position: relative;
    transition: var(--transition);
    flex-shrink: 0;
}

.toggle-slider::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    width: 20px;
    height: 20px;
    background: var(--text-muted);
    border-radius: 50%;
    transition: var(--transition);
}

.setting-toggle input:checked + .toggle-slider {
    background: var(--primary);
}

.setting-toggle input:checked + .toggle-slider::after {
    left: 25px;
    background: #c8c8d8;
    box-shadow: 0 0 6px rgba(108, 92, 231, 0.35);
}

/* Provider selector */
.provider-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    padding: 6px 10px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 12px;
    transition: var(--transition);
}
.provider-btn:hover {
    background: var(--bg-secondary);
    border-color: var(--primary);
}
.provider-btn.active {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}
.provider-btn.active .provider-status {
    color: rgba(255,255,255,0.8) !important;
}
.provider-btn .provider-status {
    margin-left: auto;
    font-weight: 500;
}

/* Token bar */
.token-bar {
    background: var(--bg);
    border-radius: 10px;
    padding: 10px 12px;
    margin-bottom: 12px;
}

.token-bar-info {
    display: flex;
    justify-content: space-between;
    margin-bottom: 6px;
}

.token-bar-label {
    font-size: 11px;
    color: var(--text-muted);
}

.token-bar-value {
    font-size: 11px;
    color: var(--text-secondary);
    font-family: var(--font-code);
}

.token-bar-track {
    height: 4px;
    background: var(--border);
    border-radius: 2px;
    overflow: hidden;
    position: relative;
}

.token-bar-fill {
    height: 100%;
    background: var(--gradient);
    border-radius: 2px;
    transition: width 0.5s ease;
}

/* Pending-полоска (running billing). Растёт справа налево поверх основной,
   показывая «вот сколько прямо сейчас тратится». */
.token-bar-pending {
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(251,191,36,0.55), rgba(239,68,68,0.65));
    border-radius: 2px;
    transition: width 0.18s ease-out;
    pointer-events: none;
    box-shadow: 0 0 8px rgba(251,191,36,0.55);
    animation: token-pending-pulse 1.4s ease-in-out infinite;
}
@keyframes token-pending-pulse {
    0%, 100% { opacity: 0.85; }
    50%      { opacity: 1; }
}

/* Live-строка «Сейчас тратится: +1234» */
.token-live {
    display: flex;
    align-items: center;
    gap: 7px;
    margin-top: 6px;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    color: #fbbf24;
    background: linear-gradient(90deg, rgba(251,191,36,0.10), rgba(239,68,68,0.10));
    border: 1px solid rgba(251,191,36,0.35);
    box-shadow: 0 0 10px rgba(251,191,36,0.25);
    animation: token-live-fade 0.25s ease-out;
}
@keyframes token-live-fade {
    from { opacity: 0; transform: translateY(-2px); }
    to   { opacity: 1; transform: translateY(0); }
}
.token-live-pulse {
    width: 6px; height: 6px; border-radius: 50%;
    background: #fbbf24;
    box-shadow: 0 0 8px #fbbf24;
    animation: token-live-pulse 1s ease-in-out infinite;
    flex-shrink: 0;
}
@keyframes token-live-pulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50%      { transform: scale(1.3); opacity: 0.6; }
}
.token-live-label { color: var(--text-muted); }
.token-live-value {
    color: #fbbf24;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.token-bar-reset {
    font-size: 10px;
    color: var(--text-muted);
    margin-top: 4px;
}

/* 4-уровневая панель токен-окон под основным баром */
.token-windows {
    display: flex; flex-direction: column;
    gap: 2px;
    margin-top: 6px;
    padding: 6px 8px;
    background: rgba(115, 100, 245, 0.05);
    border-radius: 6px;
    font-size: 10.5px;
    line-height: 1.3;
}
.tw-row {
    display: grid;
    grid-template-columns: 60px 1fr auto;
    align-items: center;
    gap: 6px;
}
.tw-label { color: var(--text-muted); }
.tw-rem {
    color: #a78bfa;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    text-align: right;
}
.tw-cap {
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
    font-size: 10px;
}
body.light-theme .token-windows { background: rgba(115, 100, 245, 0.06); }
body.light-theme .tw-rem { color: #6b5fd6; }

/* Bonus tokens bar — золотой/янтарный градиент чтобы отличался от основного.
   Появляется под основным token-bar когда bonus_tokens > 0. */
.token-bar-bonus {
    margin-top: -4px;
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.06), rgba(245, 158, 11, 0.04));
    border: 1px solid rgba(251, 191, 36, 0.18);
}
.token-bar-bonus .token-bar-label {
    color: #fbbf24;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
}
.token-bar-bonus .token-bar-value {
    color: #fcd34d;
    font-weight: 700;
}
.token-bar-fill.bonus-fill {
    background: linear-gradient(90deg, #fbbf24, #f59e0b, #ec4899);
}
body.light-theme .token-bar-bonus {
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.12), rgba(245, 158, 11, 0.08));
    border-color: rgba(217, 119, 6, 0.35);
}
body.light-theme .token-bar-bonus .token-bar-label { color: #b45309; }
body.light-theme .token-bar-bonus .token-bar-value { color: #92400e; }

/* User section */
.sidebar-user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px;
    border-radius: 10px;
    background: var(--bg);
}

.user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background-color: #6366f1;
    background-image: var(--gradient);
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
    overflow: hidden;
    overflow: hidden;
    position: relative;
}

.user-info {
    flex: 1;
    min-width: 0;
}

.user-name {
    display: block;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-sub {
    font-size: 11px;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 5px;
    font-weight: 600;
    letter-spacing: 0.2px;
}
.user-sub svg {
    flex-shrink: 0;
    vertical-align: -1px;
}
/* Tier-colored label — premium особенно выделяем градиентом, чтоб юзер видел
   что у него топ-тариф. Cosmos-тема и light-theme не ломают. */
.user-sub[data-tier="premium"] {
    background: linear-gradient(90deg, #c084fc, #f0abfc);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.user-sub[data-tier="pro"]      { color: #f59e0b; }
.user-sub[data-tier="standard"] { color: #60a5fa; }
.user-sub[data-tier="basic"]    { color: #4ade80; }

.btn-logout {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 6px;
    border-radius: 6px;
    transition: var(--transition);
}

.btn-logout:hover {
    color: #f87171;
    background: rgba(248, 113, 113, 0.1);
}

/* ── Main Chat ── */
.chat-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100vh;
    height: 100dvh;
    min-height: 0;
}

/* Top bar */
.chat-topbar {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border);
    background: rgba(7, 8, 14, 0.85);
    backdrop-filter: blur(12px);
    min-height: 52px;
    position: relative;
    z-index: 100;
    flex-shrink: 0;
}

.sidebar-open-btn {
    display: none;
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 4px;
    border-radius: 6px;
    transition: var(--transition);
}

.sidebar-open-btn:hover {
    background: var(--bg-hover);
    color: var(--text);
}

/* Show sidebar-open-btn when sidebar collapsed */
.sidebar.collapsed ~ .chat-main .sidebar-open-btn {
    display: block;
}

.chat-topbar-logo {
    display: flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    color: var(--text);
    font-weight: 700;
    font-size: 14px;
    transition: var(--transition);
}

.chat-topbar-logo:hover {
    opacity: 0.8;
    text-decoration: none;
}

.chat-topbar-brand {
    background: linear-gradient(135deg, #7364f5, #38dced);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-family: 'Sora', sans-serif;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.chat-topbar-title {
    font-size: 14px;
    font-weight: 600;
    margin-left: 8px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 200px;
}

.chat-topbar-model {
    font-size: 11px;
    color: var(--text-muted);
    font-family: var(--font-code);
    background: rgba(115,100,245,.08);
    border: 1px solid rgba(115,100,245,.18);
    padding: 4px 10px;
    border-radius: 999px;
    cursor: pointer;
    transition: background .18s, border-color .18s, color .18s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    line-height: 1;
}
.chat-topbar-model::after {
    content: '▾';
    font-size: 10px;
    opacity: 0.7;
}
.chat-topbar-model:hover {
    background: rgba(115,100,245,.18);
    border-color: rgba(115,100,245,.35);
    color: var(--text);
}
/* Embed mode: keep pill plain to match parent pane */
html.embed-mode .chat-topbar-model,
body.embed-mode .chat-topbar-model {
    background: rgba(115,100,245,.08);
    border-color: rgba(115,100,245,.18);
    color: var(--text-muted);
    font-weight: 400;
    padding: 4px 10px;
}
html.embed-mode .chat-topbar-model:hover,
body.embed-mode .chat-topbar-model:hover {
    background: rgba(115,100,245,.18);
    border-color: rgba(115,100,245,.35);
    color: var(--text);
}

.topbar-controls {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-left: auto;
}

.topbar-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 16px;
    padding: 6px;
    border-radius: 6px;
    transition: background var(--transition), color var(--transition);
    display: flex;
    align-items: center;
    justify-content: center;
}

.topbar-btn:hover {
    background: var(--bg-hover);
    color: var(--text);
}

/* Topbar language selector */
.topbar-lang {
    position: relative;
}

.topbar-lang-trigger {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 0;
    background: transparent;
    border: 0;
    color: var(--text);
    cursor: pointer;
    min-height: 36px;
}

.lang-flag-holder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.lang-flag-fixed {
    width: 22px;
    height: 16px;
    border-radius: 3px;
    object-fit: cover;
    box-shadow: 0 0 0 1px rgba(255,255,255,0.14), 0 4px 10px rgba(0,0,0,0.26);
}

.topbar-lang-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    min-width: 52px;
    min-height: 32px;
    padding: 6px 9px;
    background: rgba(6, 7, 12, 0.78);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 11px;
    color: #f7f7fb;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1;
    transition: background var(--transition), border-color var(--transition), box-shadow var(--transition), color var(--transition);
    position: relative;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 8px 22px rgba(0,0,0,0.22);
}

.topbar-lang-trigger:hover .topbar-lang-btn,
.topbar-lang-trigger:focus-visible .topbar-lang-btn,
.topbar-lang-trigger[aria-expanded="true"] .topbar-lang-btn {
    background: rgba(12, 13, 20, 0.96);
    border-color: rgba(162, 155, 254, 0.36);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 10px 26px rgba(0,0,0,0.30);
}

.topbar-lang-trigger:focus-visible {
    outline: 2px solid rgba(162, 155, 254, 0.75);
    outline-offset: 3px;
    border-radius: 13px;
}

.topbar-lang-btn .lang-code { opacity: 0.92; }
.topbar-lang-btn .lang-chev { opacity: 0.55; transition: transform var(--transition); }
.topbar-lang-trigger:hover .lang-chev,
.topbar-lang-trigger[aria-expanded="true"] .lang-chev {
    opacity: 1;
    transform: translateY(1px);
}
.topbar-lang-trigger[aria-expanded="true"] .lang-chev { transform: rotate(180deg); }

.topbar-lang-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    overflow: hidden;
    z-index: 9000;
    box-shadow: 0 12px 32px rgba(0,0,0,0.35), 0 2px 8px rgba(0,0,0,0.2);
    min-width: 220px;
    max-width: 260px;
    max-height: min(340px, 70vh);
    padding: 6px;
    flex-direction: column;
}

.topbar-lang-dropdown.show { display: flex; animation: langFade 140ms ease-out; }

@keyframes langFade {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

.lang-search-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--bg-input, var(--bg-tertiary, #1e1e2e));
    border: 1px solid var(--border);
    border-radius: 10px;
    margin-bottom: 6px;
    color: var(--text-muted);
    transition: border-color .15s, background .15s;
    flex-shrink: 0;
}
.lang-search-wrap svg {
    flex-shrink: 0;
    display: block;
    align-self: center;
    margin-top: 0;
    opacity: 0.75;
}
.lang-search-wrap:focus-within {
    border-color: var(--accent, var(--primary, #6366f1));
    background: var(--bg-input, var(--bg-tertiary, #1e1e2e));
}
.lang-search-wrap:focus-within svg { opacity: 1; color: var(--primary, #6366f1); }

/* Light theme overrides */
body.light .lang-search-wrap,
html.light .lang-search-wrap,
[data-theme="light"] .lang-search-wrap {
    background: #f3f4f6;
    border-color: #d1d5db;
    color: #4b5563;
}
body.light .lang-search,
html.light .lang-search,
[data-theme="light"] .lang-search { color: #111827; }
body.light .lang-search::placeholder,
html.light .lang-search::placeholder,
[data-theme="light"] .lang-search::placeholder { color: #6b7280; }
body.light .topbar-lang-dropdown,
html.light .topbar-lang-dropdown,
[data-theme="light"] .topbar-lang-dropdown {
    background: #ffffff;
    border-color: #e5e7eb;
    box-shadow: 0 12px 32px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.06);
}
body.light .topbar-lang-option,
html.light .topbar-lang-option,
[data-theme="light"] .topbar-lang-option { color: #111827; }
body.light .topbar-lang-option:hover,
html.light .topbar-lang-option:hover,
[data-theme="light"] .topbar-lang-option:hover { background: #f3f4f6; }

body.light-theme .topbar-lang-btn,
body.light .topbar-lang-btn,
html.light .topbar-lang-btn,
[data-theme="light"] .topbar-lang-btn {
    background: #ffffff;
    border-color: #d8dbe8;
    color: #24243a;
    box-shadow: 0 8px 20px rgba(24, 28, 55, 0.08), inset 0 1px 0 rgba(255,255,255,0.9);
}
body.light-theme .topbar-lang-trigger:hover .topbar-lang-btn,
body.light-theme .topbar-lang-trigger:focus-visible .topbar-lang-btn,
body.light-theme .topbar-lang-trigger[aria-expanded="true"] .topbar-lang-btn,
body.light .topbar-lang-trigger:hover .topbar-lang-btn,
html.light .topbar-lang-trigger:hover .topbar-lang-btn,
[data-theme="light"] .topbar-lang-trigger:hover .topbar-lang-btn {
    background: #f6f7fb;
    border-color: rgba(115, 100, 245, 0.35);
    color: #17172b;
}

.lang-search {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: var(--text);
    font-size: 14px;
    line-height: 1.3;
    font-family: inherit;
    padding: 0;
    caret-color: var(--accent, #6366f1);
}
.lang-search:focus { outline: none; box-shadow: none; background: transparent; }

.lang-search::placeholder {
    color: var(--text-muted);
    opacity: 0.6;
    font-weight: 400;
}
.lang-search::-webkit-input-placeholder { color: var(--text-muted); opacity: 0.6; }
.lang-search:focus::placeholder { opacity: 0.45; }

.topbar-lang-dropdown .lang-options-list {
    flex: 1 1 auto;
    min-height: 0;
    max-height: 252px;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    scrollbar-color: rgba(108, 92, 231, 0.45) transparent;
    padding-right: 2px;
}

.lang-options-list {
    max-height: 252px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 1px;
    scrollbar-width: thin;
    scrollbar-color: rgba(108, 92, 231, 0.45) transparent;
    padding-right: 2px;
}

.lang-options-list::-webkit-scrollbar,
.topbar-lang-dropdown .lang-options-list::-webkit-scrollbar {
    width: 6px;
}
.lang-options-list::-webkit-scrollbar-track,
.topbar-lang-dropdown .lang-options-list::-webkit-scrollbar-track {
    background: transparent;
    margin: 2px 0;
}
.lang-options-list::-webkit-scrollbar-thumb,
.topbar-lang-dropdown .lang-options-list::-webkit-scrollbar-thumb {
    background: rgba(108, 92, 231, 0.35);
    border-radius: 10px;
    transition: background .15s;
}
.lang-options-list::-webkit-scrollbar-thumb:hover,
.topbar-lang-dropdown .lang-options-list::-webkit-scrollbar-thumb:hover {
    background: rgba(108, 92, 231, 0.6);
}

body.light .lang-options-list,
html.light .lang-options-list,
[data-theme="light"] .lang-options-list,
body.light .topbar-lang-dropdown .lang-options-list,
html.light .topbar-lang-dropdown .lang-options-list,
[data-theme="light"] .topbar-lang-dropdown .lang-options-list {
    scrollbar-color: rgba(99, 102, 241, 0.4) transparent;
}
body.light .lang-options-list::-webkit-scrollbar-thumb,
html.light .lang-options-list::-webkit-scrollbar-thumb,
[data-theme="light"] .lang-options-list::-webkit-scrollbar-thumb,
body.light .topbar-lang-dropdown .lang-options-list::-webkit-scrollbar-thumb,
html.light .topbar-lang-dropdown .lang-options-list::-webkit-scrollbar-thumb,
[data-theme="light"] .topbar-lang-dropdown .lang-options-list::-webkit-scrollbar-thumb {
    background: rgba(99, 102, 241, 0.35);
}

.topbar-lang-option {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 8px 10px;
    background: transparent;
    border: none;
    color: var(--text);
    font-size: 12.5px;
    cursor: pointer;
    transition: background var(--transition);
    white-space: nowrap;
    border-radius: 6px;
    text-align: left;
}

.topbar-lang-option span { flex: 1; }
.topbar-lang-option .lang-check { color: var(--primary); flex-shrink: 0; }

.topbar-lang-option:hover { background: var(--bg-hover); }

.topbar-lang-option.active {
    background: rgba(108, 92, 231, 0.15);
    color: var(--primary-light);
    font-weight: 600;
}

/* Messages area */
.chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* Scrollbar */
.chat-messages::-webkit-scrollbar {
    width: 6px;
}

.chat-messages::-webkit-scrollbar-track {
    background: transparent;
}

.chat-messages::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 3px;
}

/* Sidebar scrollbars — unified thin style */
.sidebar-section::-webkit-scrollbar,
.sidebar-bottom::-webkit-scrollbar {
    width: 4px;
}
.sidebar-section::-webkit-scrollbar-track,
.sidebar-bottom::-webkit-scrollbar-track {
    background: transparent;
}
.sidebar-section::-webkit-scrollbar-thumb,
.sidebar-bottom::-webkit-scrollbar-thumb {
    background: rgba(108, 92, 231, 0.25);
    border-radius: 4px;
}
.sidebar-section::-webkit-scrollbar-thumb:hover,
.sidebar-bottom::-webkit-scrollbar-thumb:hover {
    background: rgba(108, 92, 231, 0.45);
}
.sidebar-section,
.sidebar-bottom {
    scrollbar-width: thin;
    scrollbar-color: rgba(108, 92, 231, 0.25) transparent;
}

/* Welcome */
.chat-welcome {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    text-align: center;
    padding: 40px 20px;
}

.welcome-icon {
    margin-bottom: 16px;
    opacity: 0.8;
}

.chat-welcome h2 {
    font-family: 'Sora', sans-serif;
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 8px;
    letter-spacing: -0.03em;
}

.chat-welcome p {
    color: var(--text-secondary);
    font-size: 14px;
    margin-bottom: 28px;
}

.template-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    max-width: 560px;
    width: 100%;
}

@media (min-width: 768px) {
    .template-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.template-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 10px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: 12px;
    cursor: pointer;
    font-family: inherit;
    transition: var(--transition);
}

.template-card:hover {
    background: rgba(115, 100, 245, 0.1);
    color: var(--text);
    border-color: rgba(115, 100, 245, 0.4);
    transform: translateY(-2px);
}

.template-icon {
    font-size: 24px;
}

.template-title {
    font-weight: 500;
    line-height: 1.3;
    text-align: center;
}

/* Drag-and-drop overlay */
.drag-over {
    outline: 2px dashed var(--primary);
    outline-offset: -8px;
    background: rgba(115, 100, 245, 0.03);
}

/* ─── Agent Switcher (Welcome screen) ─── */
.welcome-accent {
    background: linear-gradient(135deg, #7364f5 0%, #ec4899 50%, #f59e0b 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 700;
}

.agent-switcher {
    display: inline-flex;
    gap: 8px;
    padding: 6px;
    background: rgba(15, 17, 28, 0.55);
    border: 1px solid rgba(115, 100, 245, 0.18);
    border-radius: 18px;
    margin: 18px auto 24px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    /* плавный resize контейнера если кнопки меняют размер */
    transition: background 0.45s ease, border-color 0.45s ease;
    position: relative;
}

/* Скользящий индикатор — единая «таблетка», которая ездит за активным
   pill'ом туда-сюда. Позицию (translateX/width/height) выставляет JS,
   замеряя getBoundingClientRect активного pill'а. */
.agent-switcher-thumb {
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    border-radius: 14px;
    pointer-events: none;
    z-index: 0;
    opacity: 0;
    transition:
        transform 0.5s cubic-bezier(0.34, 1.16, 0.64, 1),
        width 0.5s cubic-bezier(0.34, 1.16, 0.64, 1),
        height 0.5s cubic-bezier(0.34, 1.16, 0.64, 1),
        background 0.55s ease,
        border-color 0.55s ease,
        box-shadow 0.55s ease,
        opacity 0.3s ease;
    will-change: transform, width, height;
    background: linear-gradient(135deg, rgba(115, 100, 245, 0.32), rgba(236, 72, 153, 0.22));
    border: 1px solid rgba(115, 100, 245, 0.5);
    box-shadow: 0 4px 20px rgba(115, 100, 245, 0.30), inset 0 1px 0 rgba(255, 255, 255, 0.10);
}
.agent-switcher-thumb[data-tier="2"] {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.32), rgba(236, 72, 153, 0.22), rgba(115, 100, 245, 0.30));
    border-color: rgba(245, 158, 11, 0.5);
    box-shadow: 0 4px 20px rgba(245, 158, 11, 0.30), inset 0 1px 0 rgba(255, 255, 255, 0.10);
}
@media (prefers-reduced-motion: reduce) {
    .agent-switcher-thumb {
        transition: opacity 0.2s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    }
}

.agent-pill {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 12px 22px;
    border-radius: 14px;
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-muted, #8b8ba8);
    font-family: inherit;
    cursor: pointer;
    /* Pill сам почти ничего не анимирует визуально — слайдер-thumb едет
       снизу. Здесь только мягкие изменения цвета/scale при hover/active. */
    transition:
        color 0.35s ease,
        transform 0.45s cubic-bezier(0.34, 1.16, 0.64, 1);
    overflow: hidden;
    min-width: 180px;
    will-change: transform;
}
.agent-pill:active { transform: scale(0.97); }

.agent-pill .agent-pill-glow {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: radial-gradient(circle at 50% 100%, rgba(115, 100, 245, 0.25), transparent 70%);
    opacity: 0;
    transition: opacity .55s ease;
    pointer-events: none;
}

.agent-pill:hover {
    color: var(--text, #e2e2f0);
}
.agent-pill:not(.agent-pill-active):hover .agent-pill-glow { opacity: .35; }

/* Active-state визуал теперь обеспечивается слайдером-thumb'ом,
   pill сам остаётся «прозрачным» — только цвет текста становится ярче. */
.agent-pill-active {
    color: var(--text, #fff);
    background: transparent;
    border-color: transparent;
    box-shadow: none;
}
.agent-pill-active .agent-pill-glow { opacity: 0; }

/* Иконка получает мягкий бликующий «вдох» при активации,
   текст слегка подсвечивается — не вспышка, а плавное переключение. */
.agent-pill .agent-pill-ico {
    transition: background 0.5s cubic-bezier(0.34, 1.16, 0.64, 1),
                color 0.35s ease,
                transform 0.5s cubic-bezier(0.34, 1.16, 0.64, 1);
}
.agent-pill-active .agent-pill-ico { transform: scale(1.06) rotate(-2deg); }
.agent-pill[data-agent="2"].agent-pill-active .agent-pill-ico { transform: scale(1.06) rotate(2deg); }
.agent-pill .agent-pill-name,
.agent-pill .agent-pill-sub {
    transition: color 0.4s ease, opacity 0.4s ease;
}

.agent-pill-ico {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 10px;
    background: rgba(115, 100, 245, 0.12);
    flex-shrink: 0;
}
.agent-pill-ico svg { width: 18px; height: 18px; }

.agent-pill[data-agent="2"] .agent-pill-ico {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.18), rgba(236, 72, 153, 0.15));
    color: #fbbf24;
}

.agent-pill-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    line-height: 1.15;
}

.agent-pill-name {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: -0.2px;
}

.agent-pill-sub {
    font-size: 10.5px;
    font-weight: 500;
    opacity: 0.72;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.agent-pill-badge {
    position: absolute;
    top: -8px;
    right: -10px;
    background: linear-gradient(135deg, #22c55e, #10b981);
    color: #ffffff;
    font-size: 10px;
    font-weight: 900;
    padding: 3px 9px;
    border-radius: 999px;
    letter-spacing: 0.8px;
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
    border: 1.5px solid rgba(15, 17, 28, 0.95);
    box-shadow: 0 3px 14px rgba(34, 197, 94, 0.55), 0 0 0 1px rgba(34, 197, 94, 0.4);
    animation: agent-badge-pulse 2.4s ease-in-out infinite;
    z-index: 2;
}

@keyframes agent-badge-pulse {
    0%, 100% { transform: scale(1); box-shadow: 0 3px 14px rgba(34, 197, 94, 0.55), 0 0 0 1px rgba(34, 197, 94, 0.4); }
    50% { transform: scale(1.1); box-shadow: 0 4px 18px rgba(34, 197, 94, 0.85), 0 0 0 2px rgba(34, 197, 94, 0.5); }
}

body.light-theme .agent-pill-badge {
    border-color: rgba(255, 255, 255, 0.95);
    box-shadow: 0 3px 14px rgba(34, 197, 94, 0.5), 0 0 0 1px rgba(34, 197, 94, 0.5);
}

body.light-theme .agent-switcher {
    background: rgba(255, 255, 255, 0.86);
    border-color: rgba(118, 126, 160, 0.22);
    box-shadow: 0 14px 34px rgba(20, 24, 50, 0.08), inset 0 1px 0 rgba(255,255,255,0.9);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}
body.light-theme .agent-switcher-thumb {
    background: linear-gradient(135deg, rgba(115, 100, 245, 0.12), rgba(236, 72, 153, 0.10));
    border-color: rgba(115, 100, 245, 0.24);
    box-shadow: 0 10px 24px rgba(115, 100, 245, 0.14), inset 0 1px 0 rgba(255,255,255,0.9);
}
body.light-theme .agent-switcher-thumb[data-tier="2"] {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.18), rgba(236, 72, 153, 0.10), rgba(115, 100, 245, 0.12));
    border-color: rgba(245, 158, 11, 0.38);
    box-shadow: 0 10px 24px rgba(245, 158, 11, 0.14), inset 0 1px 0 rgba(255,255,255,0.9);
}
body.light-theme .agent-pill {
    color: #7b8197;
}
body.light-theme .agent-pill:hover,
body.light-theme .agent-pill-active {
    color: #202238;
}
body.light-theme .agent-pill-sub {
    color: #5f667a;
    opacity: 0.86;
}

@media (max-width: 600px) {
    .agent-switcher { gap: 4px; padding: 4px; }
    .agent-pill { padding: 10px 14px; min-width: 0; gap: 8px; }
    .agent-pill-ico { width: 28px; height: 28px; }
    .agent-pill-name { font-size: 12.5px; }
    .agent-pill-sub { font-size: 9.5px; }
}

.suggestion-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    align-content: flex-start;
    max-width: 600px;
    margin: 0 auto;
    /* Контейнер заранее «забивает» свою максимальную высоту через min-height
       (выставляется из JS после замера обоих тиров) — welcome-экран не
       поднимается/опускается при swap'е чипов. contain:layout изолирует
       реflow от родителя на случай если что-то меняется внутри. */
    transition:
        opacity 0.22s ease,
        filter 0.22s ease;
    contain: layout;
}
/* Класс ставится из JS перед swap'ом — плавный fade-out, потом innerHTML, потом снимаем класс */
.suggestion-chips.is-swapping {
    opacity: 0;
    filter: blur(2px);
}

.suggestion-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 100px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text-secondary);
    font-size: 13px;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    white-space: nowrap;
    /* Каждый чип появляется со staggered slide-in. Задержку выставляем
       инлайново из JS через --chip-i. Без анимации (если чипа нет в свежем
       свапе) — просто сидит на месте. */
    animation: chip-pop-in 0.42s cubic-bezier(0.34, 1.32, 0.64, 1) both;
    animation-delay: calc(var(--chip-i, 0) * 30ms);
}
@keyframes chip-pop-in {
    0%   { opacity: 0; transform: translateY(6px) scale(0.94); }
    60%  { opacity: 1; }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}
@media (prefers-reduced-motion: reduce) {
    .suggestion-chip { animation: none; }
    .suggestion-chips, .suggestion-chips.is-swapping { transition: none; filter: none; }
}

.suggestion-chip:hover {
    background: rgba(115, 100, 245, 0.08);
    color: var(--text);
    border-color: rgba(115, 100, 245, 0.25);
    transform: translateY(-1px);
    box-shadow: 0 2px 12px rgba(115, 100, 245, 0.1);
}

.chip-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 7px;
    background: rgba(115, 100, 245, 0.1);
    flex-shrink: 0;
    color: var(--primary, #7364f5);
}
.chip-icon svg {
    stroke: var(--primary, #7364f5);
    opacity: 0.85;
}

@media (max-width: 600px) {
    .suggestion-chips { max-width: 100%; padding: 0 12px; }
    .suggestion-chip { font-size: 12px; padding: 8px 14px; }
}

/* ── Messages (ChatGPT-style layout) ── */
.message {
    display: flex;
    gap: 12px;
    animation: msg-in 0.3s ease;
    position: relative;
    max-width: 960px;
    width: 100%;
    margin: 0 auto;
    padding: 4px 0;
    contain: layout style;
}

@keyframes msg-in {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

.message-user {
    flex-direction: row-reverse;
    justify-content: flex-start;
    margin-left: auto;
    margin-right: 0;
}

.message-ai {
    flex-direction: row;
    justify-content: flex-start;
    margin-left: 0;
    margin-right: auto;
}

.message-notice {
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    padding: 6px 0;
}

.notice-bubble {
    display: inline-flex;
    align-items: flex-start;
    gap: 8px;
    max-width: min(720px, calc(100% - 32px));
    padding: 9px 13px;
    border-radius: 12px;
    background: rgba(245, 158, 11, 0.10);
    border: 1px solid rgba(245, 158, 11, 0.28);
    color: var(--text);
    font-size: 13px;
    line-height: 1.45;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.10);
}

.notice-icon {
    flex: 0 0 auto;
    line-height: 1.45;
}

.notice-content {
    min-width: 0;
    overflow-wrap: anywhere;
}

/* Avatars */
.message-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 700;
    flex-shrink: 0;
    margin-top: 2px;
    overflow: hidden;
}
.message-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
    display: block;
}

.message-avatar.msg-user-avatar {
    background-color: #6366f1;
    background-image: var(--gradient);
    color: #fff;
}

.message-avatar.msg-ai-avatar {
    background: #1e1e35;
    color: var(--primary-light);
    border: 1px solid var(--border);
}

.msg-ai-avatar svg {
    width: 18px;
    height: 18px;
}

/* User message bubble */
.message-user .message-bubble {
    background: rgba(115, 100, 245, 0.12);
    border: 1px solid rgba(115, 100, 245, 0.2);
    border-radius: 18px 18px 4px 18px;
    padding: 10px 16px;
    max-width: 70%;
}

/* AI message body */
.message-body {
    flex: 1;
    min-width: 0;
}

/* Action buttons under AI messages */
.message-actions {
    display: flex;
    gap: 4px;
    margin-top: 8px;
    opacity: 0;
    transition: opacity 0.2s;
}
.message:hover .message-actions,
.message-actions.visible { opacity: 1; }

.msg-action {
    background: none;
    border: 1px solid transparent;
    border-radius: 6px;
    padding: 4px 8px;
    cursor: pointer;
    font-size: 14px;
    color: #888;
    transition: all 0.15s;
    line-height: 1;
    /* WCAG 2.2 SC 2.5.8: цель ≥ 24×24px */
    min-width: 24px;
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.msg-action:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }
.msg-action.liked { color: #22c55e; }
.msg-action.disliked { color: #ef4444; }
.msg-action.voted { pointer-events: none; opacity: 0.5; }
.message-actions.voted { opacity: 1; }
.feedback-thanks {
    font-size: 11px;
    color: #22c55e;
    margin-left: 8px;
    animation: fadeInThanks 0.3s ease;
}
@keyframes fadeInThanks { from { opacity: 0; transform: translateX(-4px); } to { opacity: 1; transform: translateX(0); } }

.message-tokens {
    font-size: 10px;
    color: var(--text-muted);
    margin-top: 4px;
    font-family: var(--font-code);
}

/* ── Rich metrics bar (tokens / time / model / tools / iter) ── */
.msg-metrics {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    margin-top: 8px;
    padding: 6px 8px;
    background: rgba(115, 100, 245, 0.05);
    border: 1px solid rgba(115, 100, 245, 0.12);
    border-radius: 9px;
    font-family: var(--font-code, ui-monospace, SFMono-Regular, Menlo, monospace);
    font-size: 10.5px;
    line-height: 1;
    color: var(--text-muted, #8b8ba8);
    transition: background .2s ease, border-color .2s ease;
}
.msg-metrics:hover {
    background: rgba(115, 100, 245, 0.08);
    border-color: rgba(115, 100, 245, 0.22);
}
.msg-metric {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 7px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.05);
    font-weight: 600;
    white-space: nowrap;
}
.msg-metric svg { width: 11px; height: 11px; opacity: 0.7; }
.msg-metric-label { opacity: 0.6; font-weight: 500; margin-right: 2px; }
.msg-metric-value { color: var(--text, #e2e2f0); }
.msg-metric-tier {
    font-weight: 800;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    font-size: 9.5px;
    padding: 3px 8px;
    border-radius: 999px;
}
.msg-metric-tier-1 {
    background: rgba(115, 100, 245, 0.15);
    color: #a78bfa;
    border: 1px solid rgba(115, 100, 245, 0.3);
}
.msg-metric-tier-2 {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.18), rgba(236, 72, 153, 0.15));
    color: #fbbf24;
    border: 1px solid rgba(245, 158, 11, 0.32);
    box-shadow: 0 1px 6px rgba(245, 158, 11, 0.15);
}
.msg-metric-model { color: var(--text, #e2e2f0); font-weight: 700; }
.msg-metric-cost {
    background: rgba(168, 85, 247, 0.12);
    color: #c084fc;
    border-color: rgba(168, 85, 247, 0.25);
}
@media (max-width: 600px) {
    .msg-metrics { gap: 4px; padding: 5px 6px; font-size: 10px; }
    .msg-metric { padding: 2px 6px; }
}
body.light-theme .msg-metrics { background: rgba(115, 100, 245, 0.06); border-color: rgba(115, 100, 245, 0.18); }
body.light-theme .msg-metric { background: rgba(0, 0, 0, 0.03); border-color: rgba(0, 0, 0, 0.06); }


/* Streaming cursor animation */
.streaming .message-content::after {
    content: '▋';
    animation: cursor-blink 1s step-end infinite;
    color: #10c4d6;
    margin-left: 1px;
    font-size: 14px;
}
@keyframes cursor-blink { 50% { opacity: 0; } }
@keyframes blink { 0%,20% { opacity: 0; } 50% { opacity: 1; } 100% { opacity: 0; } }

/* ── Queue overlay ── */
.queue-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 70;
    backdrop-filter: blur(6px);
    animation: fadeIn 0.3s ease;
}
.queue-box {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 32px 40px;
    text-align: center;
    max-width: 380px;
    width: 90%;
    animation: msg-in 0.3s ease;
}
.queue-spinner-wrap { display: flex; justify-content: center; margin-bottom: 16px; }
.queue-spinner {
    width: 40px; height: 40px;
    border: 3px solid var(--border);
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: spin-enhance 0.8s linear infinite;
}
.queue-title { font-size: 20px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.queue-eta { font-size: 28px; font-weight: 800; color: var(--primary-light); margin-bottom: 12px; }
.queue-info { font-size: 14px; color: var(--text-secondary); margin-bottom: 6px; }
.queue-slots-info { font-size: 13px; color: var(--text-muted); margin-bottom: 12px; }
.queue-upsell {
    margin: 12px 0;
    padding: 10px 14px;
    background: rgba(115, 100, 245, 0.08);
    border: 1px solid rgba(115, 100, 245, 0.2);
    border-radius: 10px;
    font-size: 13px;
    color: var(--primary-light);
}
.queue-upsell a { color: var(--primary-light); text-decoration: underline; cursor: pointer; }
.queue-cancel-btn { margin-top: 8px; }

/* ── Message edit/bookmark ── */
.user-actions { display: flex; gap: 2px; margin-top: 4px; opacity: 0; transition: opacity 0.15s; }
.message-user:hover .user-actions { opacity: 1; }
.bookmarked { border-left: 3px solid #ffc107 !important; }

/* ── Think streaming ── */
.think-streaming { opacity: 0.7; white-space: pre-wrap; font-family: monospace; font-size: 12px; }

/* ── Context indicator ── */
.context-indicator { font-size: 11px; color: var(--text-muted); margin-left: 12px; }

/* ── Diff button (polished) ── */
.diff-btn {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(124,137,246,0.10); border: 1px solid rgba(124,137,246,0.28);
    border-radius: 7px; padding: 3px 10px; font-size: 11px; font-weight: 600;
    color: var(--primary-light, #a5b4fc); cursor: pointer; margin-left: 8px;
    transition: all 0.18s; font-family: inherit; line-height: 1.3;
    letter-spacing: 0.02em; vertical-align: middle;
}
.diff-btn:hover { background: rgba(124,137,246,0.22); border-color: rgba(124,137,246,0.55); color: #fff; }
.diff-btn.diff-has-changes { background: rgba(245,158,11,0.14); border-color: rgba(245,158,11,0.45); color: #fbbf24; }
.diff-btn.diff-active { background: rgba(34,197,94,0.16); border-color: rgba(34,197,94,0.5); color: #4ade80; }
.diff-btn .diff-ico svg { width: 12px; height: 12px; display: block; }

/* ── Inline Diff (in-chat split view) ── */
.inline-diff {
    margin-top: 8px;
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
    background: var(--code-bg, #0d1117);
}
.inline-diff-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 12px;
    background: rgba(115,100,245,0.06);
    border-bottom: 1px solid var(--border);
    font-size: 12px;
}
.inline-diff-split {
    display: grid;
    grid-template-columns: var(--diff-split, 50%) 8px 1fr;
    position: relative;
    user-select: text;
}
.inline-diff-pane {
    overflow-x: auto;
    min-width: 0;
}
body.is-diff-resizing,
body.is-diff-resizing * {
    user-select: none !important;
    cursor: col-resize !important;
}

/* Draggable slider between panes (CSS-themed) */
.inline-diff-resizer {
    position: relative;
    cursor: col-resize;
    background: linear-gradient(
        to bottom,
        transparent 0%,
        rgba(124, 137, 246, 0.15) 20%,
        rgba(124, 137, 246, 0.35) 50%,
        rgba(124, 137, 246, 0.15) 80%,
        transparent 100%
    );
    transition: background 0.15s ease;
    touch-action: none;
}
.inline-diff-resizer::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 1px;
    transform: translateX(-50%);
    background: rgba(124, 137, 246, 0.4);
}
.inline-diff-resizer:hover,
body.is-diff-resizing .inline-diff-resizer {
    background: linear-gradient(
        to bottom,
        transparent 0%,
        rgba(124, 137, 246, 0.4) 20%,
        rgba(124, 137, 246, 0.75) 50%,
        rgba(124, 137, 246, 0.4) 80%,
        transparent 100%
    );
}
.inline-diff-resizer:hover::before,
body.is-diff-resizing .inline-diff-resizer::before {
    background: rgba(124, 137, 246, 0.9);
    box-shadow: 0 0 8px rgba(124, 137, 246, 0.6);
}
.inline-diff-resizer-grip {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 14px;
    height: 36px;
    border-radius: 3px;
    background: rgba(124, 137, 246, 0.25);
    border: 1px solid rgba(124, 137, 246, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
    pointer-events: none;
}
.inline-diff-resizer-grip::before,
.inline-diff-resizer-grip::after {
    content: '';
    width: 1px;
    height: 14px;
    background: rgba(200, 210, 255, 0.75);
    border-radius: 1px;
}
.inline-diff-resizer:hover .inline-diff-resizer-grip,
body.is-diff-resizing .inline-diff-resizer-grip {
    background: rgba(124, 137, 246, 0.55);
    border-color: rgba(180, 195, 255, 0.9);
    box-shadow: 0 0 10px rgba(124, 137, 246, 0.5);
}

/* Range slider header control — themed */
.inline-diff-slider {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    color: var(--text-muted);
}
.inline-diff-slider-label {
    font-family: var(--font-code, monospace);
    letter-spacing: 1px;
    color: rgba(124, 137, 246, 0.8);
    user-select: none;
}
.inline-diff-range {
    -webkit-appearance: none;
    appearance: none;
    width: 120px;
    height: 4px;
    background: rgba(124, 137, 246, 0.18);
    border-radius: 4px;
    outline: none;
    cursor: pointer;
    border: 1px solid rgba(124, 137, 246, 0.25);
    padding: 0;
    margin: 0;
}
.inline-diff-range::-webkit-slider-runnable-track {
    height: 4px;
    border-radius: 4px;
    background: linear-gradient(
        90deg,
        rgba(239, 68, 68, 0.35) 0%,
        rgba(124, 137, 246, 0.5) 50%,
        rgba(34, 197, 94, 0.35) 100%
    );
}
.inline-diff-range::-moz-range-track {
    height: 4px;
    border-radius: 4px;
    background: linear-gradient(
        90deg,
        rgba(239, 68, 68, 0.35) 0%,
        rgba(124, 137, 246, 0.5) 50%,
        rgba(34, 197, 94, 0.35) 100%
    );
}
.inline-diff-range::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #c4cefc, #7c89f6);
    border: 1px solid rgba(255, 255, 255, 0.35);
    box-shadow: 0 0 6px rgba(124, 137, 246, 0.5);
    margin-top: -5px;
    cursor: grab;
    transition: transform 0.1s ease;
}
.inline-diff-range::-moz-range-thumb {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #c4cefc, #7c89f6);
    border: 1px solid rgba(255, 255, 255, 0.35);
    box-shadow: 0 0 6px rgba(124, 137, 246, 0.5);
    cursor: grab;
}
.inline-diff-range:active::-webkit-slider-thumb { cursor: grabbing; transform: scale(1.12); }
.inline-diff-range:active::-moz-range-thumb { cursor: grabbing; transform: scale(1.12); }
.inline-diff-range:focus-visible {
    box-shadow: 0 0 0 2px rgba(124, 137, 246, 0.35);
}
.inline-diff-pane-header {
    padding: 4px 10px;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-muted);
    background: rgba(0,0,0,0.15);
    border-bottom: 1px solid var(--border);
}
.inline-diff .diff-code {
    max-height: 400px;
    overflow: auto;
    font-size: 12px;
}

@media (max-width: 600px) {
    .inline-diff-split { grid-template-columns: 1fr; }
    .inline-diff-resizer { display: none; }
    .inline-diff-pane + .inline-diff-pane { border-top: 1px solid var(--border); }
    .inline-diff-slider { display: none; }
}

/* ── Cursor-style Diff Modal ── */
.cursor-diff-overlay {
    position: fixed; inset: 0; z-index: 9000;
    background: rgba(0,0,0,0.75); backdrop-filter: blur(6px);
    display: flex; align-items: center; justify-content: center; padding: 20px;
}
.cursor-diff-panel {
    background: #0d0e18; border: 1px solid #2a2d4a;
    border-radius: 10px; width: 100%; max-width: 1100px; max-height: 90vh;
    display: flex; flex-direction: column; box-shadow: 0 24px 80px rgba(0,0,0,0.6);
    overflow: hidden;
}
.cursor-diff-titlebar {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 16px; background: #111220; border-bottom: 1px solid #1e2038;
    flex-shrink: 0;
}
.cursor-diff-title {
    display: flex; align-items: center; gap: 8px;
    font-size: 13px; font-weight: 600; color: #c0c0d8;
    font-family: var(--font-code, monospace);
}
.diff-badge {
    padding: 1px 7px; border-radius: 10px; font-size: 11px; font-weight: 700;
    font-family: var(--font-code, monospace);
}
.diff-badge-add { background: rgba(34,197,94,0.15); color: #4ade80; border: 1px solid rgba(34,197,94,0.3); }
.diff-badge-del { background: rgba(239,68,68,0.15); color: #f87171; border: 1px solid rgba(239,68,68,0.3); }
.diff-badge-new { background: rgba(99,102,241,0.15); color: #a78bfa; border: 1px solid rgba(99,102,241,0.3); }
.cursor-diff-controls {
    display: flex; align-items: center; gap: 6px;
}
.cursor-diff-view-btn {
    background: none; border: 1px solid #2a2d4a; color: #666888;
    padding: 3px 10px; border-radius: 5px; font-size: 12px; cursor: pointer;
    font-family: inherit; transition: all 0.15s;
}
.cursor-diff-view-btn.active { background: rgba(115,100,245,0.15); border-color: #7364f5; color: #a78bfa; }
.cursor-diff-view-btn:hover { border-color: #444666; color: #9090b0; }
.cursor-diff-accept {
    background: rgba(34,197,94,0.15); border: 1px solid rgba(34,197,94,0.4);
    color: #4ade80; padding: 3px 14px; border-radius: 5px; font-size: 12px;
    font-weight: 600; cursor: pointer; font-family: inherit; transition: all 0.15s;
}
.cursor-diff-accept:hover { background: rgba(34,197,94,0.25); box-shadow: 0 0 10px rgba(34,197,94,0.2); }
.cursor-diff-close {
    background: none; border: none; color: #666; font-size: 20px;
    cursor: pointer; line-height: 1; padding: 0 4px; transition: color 0.15s;
}
.cursor-diff-close:hover { color: #ccc; }
.cursor-diff-body {
    flex: 1; overflow: auto; min-height: 0;
}
.diff-view-container { font-family: var(--font-code, monospace); font-size: 12.5px; line-height: 1.6; }
.diff-col-headers {
    display: grid; grid-template-columns: 1fr 24px 1fr;
    font-size: 11px; font-weight: 600; color: #555888; text-transform: uppercase;
    letter-spacing: 0.05em; padding: 4px 8px; background: #0a0b15;
    border-bottom: 1px solid #1a1c30;
}
.diff-code { }
.diff-row {
    display: flex; align-items: baseline; min-height: 20px; padding: 0 8px;
    white-space: pre-wrap; word-break: break-all;
}
.diff-row:hover { background: rgba(255,255,255,0.02); }
.diff-ln {
    min-width: 36px; text-align: right; margin-right: 10px;
    color: #3a3c5a; font-size: 11px; flex-shrink: 0; user-select: none;
}
.diff-prefix {
    min-width: 14px; flex-shrink: 0; font-weight: 700; color: #666;
    margin-right: 6px;
}
.diff-text { flex: 1; word-break: break-all; }
.diff-row.diff-add { background: rgba(16,185,129,0.07); }
.diff-row.diff-add .diff-prefix { color: #34d399; }
.diff-row.diff-add .diff-text { color: #a7f3d0; }
.diff-row.diff-del { background: rgba(239,68,68,0.07); }
.diff-row.diff-del .diff-prefix { color: #f87171; }
.diff-row.diff-del .diff-text { color: #fca5a5; }
.diff-row.diff-same .diff-text { color: #7070a0; }
.diff-row.diff-empty { background: rgba(0,0,0,0.15); }
.diff-row.diff-empty .diff-text { color: transparent; }
/* Inline character-level diff */
.diff-inline-add { background: rgba(16,185,129,0.3); border-radius: 2px; }
.diff-inline-del { background: rgba(239,68,68,0.3); border-radius: 2px; text-decoration: line-through; }
/* Split view */
.diff-split-view { display: flex; height: 100%; }
.diff-split-pane { flex: 1; min-width: 0; overflow: auto; }
.diff-split-header {
    font-size: 11px; font-weight: 600; color: #555888; text-transform: uppercase;
    letter-spacing: 0.05em; padding: 4px 8px; background: #0a0b15;
    border-bottom: 1px solid #1a1c30; position: sticky; top: 0; z-index: 1;
}
.diff-split-divider { width: 1px; background: #1e2038; flex-shrink: 0; }
/* Footer */
.cursor-diff-footer {
    display: flex; justify-content: space-between; align-items: center;
    padding: 6px 16px; background: #0a0b15; border-top: 1px solid #1a1c30;
    font-size: 11px; color: #555888; flex-shrink: 0;
}

/* ── Agent Panel (Claude Code-style «Работа Агента») ── */
.agent-panel {
    margin: 10px 20px 10px 52px;
    border: 1px solid rgba(115,100,245,0.22);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(18,18,32,0.72), rgba(12,12,22,0.88));
    overflow: hidden;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, sans-serif;
    box-shadow: 0 2px 12px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.03);
    transition: border-color 0.2s, box-shadow 0.2s;
}
.agent-panel:hover { border-color: rgba(115,100,245,0.35); }
.agent-panel.history { opacity: 0.92; }

/* Header — clickable, collapses the whole panel */
.agent-panel-header {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px;
    cursor: pointer;
    user-select: none;
    transition: background 0.15s;
}
.agent-panel-header:hover { background: rgba(115,100,245,0.05); }
.agent-panel-chevron {
    display: none !important;  /* Скрыт: на header'е сидит click-handler, отдельная стрелка-индикатор лишняя визуально (юзер просил убрать). */
}
.agent-panel.collapsed .agent-panel-chevron { transform: rotate(-90deg); }
.agent-panel-icon {
    display: inline-flex; align-items: center; justify-content: center;
    color: #a78bfa; flex-shrink: 0;
}
.agent-panel-title {
    font-size: 13px; font-weight: 600; color: #cbd5e1; flex: 1;
    letter-spacing: 0.01em;
}
.agent-step-counter {
    font-size: 11px; font-weight: 500; color: #8b8ba8;
    padding: 2px 8px; background: rgba(255,255,255,0.04);
    border-radius: 10px; flex-shrink: 0;
}
.agent-stop-btn {
    background: rgba(239,68,68,0.12); border: 1px solid rgba(239,68,68,0.25);
    color: #f87171; padding: 3px 9px; border-radius: 6px; font-size: 11px;
    cursor: pointer; font-family: inherit; font-weight: 600;
    transition: all 0.15s; display: none;
}
.agent-stop-btn:hover { background: rgba(239,68,68,0.22); }
.agent-panel.live .agent-stop-btn { display: inline-block; }

/* Body — hidden when collapsed */
.agent-panel-body {
    border-top: 1px solid rgba(255,255,255,0.05);
    overflow: hidden;
    /* Без жёсткого max-height — иначе при многих шагах панель обрезается
       и юзер видит только верхушку «Создаю папку...» + кусочек статуса.
       transition оставляем только для свёртывания через collapsed. */
    max-height: 9999px;
    transition: opacity 0.2s;
}
.agent-panel.collapsed .agent-panel-body { max-height: 0; opacity: 0; border-top-color: transparent; transition: max-height 0.3s ease, opacity 0.2s; }

.agent-panel-steps { max-height: none; overflow-y: visible; padding: 4px 0; }
.agent-panel.history .agent-panel-steps { max-height: none; }
.agent-panel-steps::-webkit-scrollbar { width: 6px; }
.agent-panel-steps::-webkit-scrollbar-thumb { background: rgba(115,100,245,0.25); border-radius: 3px; }

.agent-step-item { position: relative; }
.agent-step-row {
    display: flex; align-items: center; gap: 10px;
    padding: 7px 14px 7px 18px;
    cursor: pointer; font-size: 12.5px;
    transition: background 0.12s;
}
.agent-step-row:hover { background: rgba(255,255,255,0.025); }

/* Dots by kind — Claude Code palette */
.agent-step-status-dot {
    width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
    background: #34d399;
    box-shadow: 0 0 0 3px rgba(52,211,153,0.14);
}
.agent-step-status-dot.k-info   { background: #34d399; box-shadow: 0 0 0 3px rgba(52,211,153,0.14); }
.agent-step-status-dot.k-cmd    { background: #fb923c; box-shadow: 0 0 0 3px rgba(251,146,60,0.16); }
.agent-step-status-dot.k-write  { background: #fb923c; box-shadow: 0 0 0 3px rgba(251,146,60,0.16); }
.agent-step-status-dot.k-danger { background: #f87171; box-shadow: 0 0 0 3px rgba(248,113,113,0.16); }
.agent-step-status-dot.k-net    { background: #60a5fa; box-shadow: 0 0 0 3px rgba(96,165,250,0.16); }
.agent-step-status-dot.running  { background: #a78bfa; box-shadow: 0 0 0 3px rgba(167,139,250,0.16); animation: pulse-dot 1.2s ease-in-out infinite; }
.agent-step-status-dot.error    { background: #f87171; box-shadow: 0 0 0 3px rgba(248,113,113,0.16); }

.agent-step-icon-sm {
    display: inline-flex; align-items: center; justify-content: center;
    width: 16px; height: 16px; flex-shrink: 0; color: #9ca3af;
}
.agent-step-item.k-cmd    .agent-step-icon-sm { color: #fb923c; }
.agent-step-item.k-write  .agent-step-icon-sm { color: #fbbf24; }
.agent-step-item.k-info   .agent-step-icon-sm { color: #34d399; }
.agent-step-item.k-danger .agent-step-icon-sm { color: #f87171; }
.agent-step-item.k-net    .agent-step-icon-sm { color: #60a5fa; }

.agent-step-fn { color: #e5e7eb; font-weight: 500; flex-shrink: 0; }
.agent-step-arg {
    color: #7a7a98; flex: 1;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, "Liberation Mono", monospace;
    font-size: 11.5px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    background: rgba(255,255,255,0.03); padding: 1px 6px; border-radius: 4px;
}
.agent-step-arg:empty { display: none; }

.agent-step-check {
    display: inline-flex; align-items: center; justify-content: center;
    width: 14px; height: 14px; color: #34d399; flex-shrink: 0;
    opacity: 0.75;
}
.agent-step-item.running .agent-step-check,
.agent-step-item.error   .agent-step-check { display: none; }
.agent-step-item.error   .agent-step-row   { background: rgba(239,68,68,0.04); }

.agent-step-chevron {
    display: inline-flex; align-items: center; justify-content: center;
    width: 14px; height: 14px; color: #4a4a68; flex-shrink: 0;
    transition: transform 0.2s;
}
.agent-step-item.open .agent-step-chevron { transform: rotate(90deg); color: #a78bfa; }

.agent-step-output {
    display: none; padding: 8px 14px 10px 46px;
    background: rgba(0,0,0,0.25);
    max-height: 180px; overflow: auto;
}
.agent-step-item.open .agent-step-output { display: block; }
.agent-step-output pre {
    margin: 0;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: 11px; white-space: pre-wrap; word-break: break-all;
    color: #8b8bb0; line-height: 1.55;
}

/* Status footer (live panel only) */
.agent-panel-status {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 14px 10px; font-size: 11.5px; color: #7a7a98;
    border-top: 1px solid rgba(255,255,255,0.04);
}
.agent-panel.history .agent-panel-status { display: none; }
.agent-status-dot {
    width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0;
    background: #a78bfa; box-shadow: 0 0 0 3px rgba(167,139,250,0.16);
    animation: pulse-dot 1.2s ease-in-out infinite;
}
.agent-status-dot.done  { background: #34d399; box-shadow: 0 0 0 3px rgba(52,211,153,0.16); animation: none; }
.agent-status-dot.error { background: #f87171; box-shadow: 0 0 0 3px rgba(248,113,113,0.16); animation: none; }
.agent-status-text { flex: 1; }

/* Running dots indicator */
.agent-step-running-dots {
    display: inline-flex; gap: 3px; align-items: center; flex-shrink: 0;
}
.agent-step-running-dots span {
    width: 4px; height: 4px; border-radius: 50%; background: #a78bfa;
    animation: pulse-dot 1.2s ease-in-out infinite;
}
.agent-step-running-dots span:nth-child(2) { animation-delay: 0.2s; }
.agent-step-running-dots span:nth-child(3) { animation-delay: 0.4s; }
.agent-step-item.running .agent-step-row { opacity: 0.85; }

/* Light theme overrides */
body.light-theme .agent-panel {
    background: linear-gradient(180deg, rgba(250,250,253,0.92), rgba(244,244,249,0.95));
    border-color: rgba(99,102,241,0.2);
    box-shadow: 0 1px 4px rgba(0,0,0,0.04);
}
body.light-theme .agent-panel-header:hover { background: rgba(99,102,241,0.04); }
body.light-theme .agent-panel-title { color: #1f2937; }
body.light-theme .agent-step-counter { color: #4b5563; background: rgba(99,102,241,0.08); }
body.light-theme .agent-step-fn { color: #1f2937; }
body.light-theme .agent-step-arg { color: #4b5563; background: rgba(0,0,0,0.03); }
body.light-theme .agent-panel-chevron { color: #6b7280; }

/* ── Legacy agent steps (backward compat) ── */
.agent-steps { margin-bottom: 12px; }
.agent-step {
    border: 1px solid var(--border); border-radius: 8px; margin-bottom: 4px;
    background: rgba(99, 102, 241, 0.05); overflow: hidden;
}
.agent-step-header {
    display: flex; align-items: center; gap: 8px; padding: 6px 10px;
    cursor: pointer; font-size: 12px; color: var(--text-secondary);
    transition: background 0.15s;
}
.agent-step-header:hover { background: rgba(99, 102, 241, 0.1); }
.agent-step-icon { font-size: 14px; }
.agent-step-label { flex: 1; font-family: monospace; }
.agent-step-arrow { transition: transform 0.2s; font-size: 10px; }
.agent-step.expanded .agent-step-arrow { transform: rotate(90deg); }
.agent-step-body {
    display: none; padding: 8px 10px; border-top: 1px solid var(--border);
    background: var(--bg-secondary); max-height: 200px; overflow: auto;
}
.agent-step.expanded .agent-step-body { display: block; }
.agent-step-body pre {
    margin: 0; font-size: 11px; white-space: pre-wrap; word-break: break-all;
    color: var(--text-secondary);
}

/* ── Templates dropdown ── */
.templates-dropdown {
    position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%);
    background: var(--bg-card); border: 1px solid var(--border); border-radius: 12px;
    padding: 16px; z-index: 100; min-width: 300px; max-width: 90vw;
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
.templates-dropdown h3 { margin-bottom: 12px; font-size: 16px; }
.template-item {
    display: flex; align-items: center; gap: 10px; padding: 10px 12px;
    border-radius: 8px; cursor: pointer; font-size: 13px; color: var(--text);
    border: none; background: none; width: 100%; text-align: left;
}
.template-item:hover { background: var(--bg-input); }
.template-icon { font-size: 18px; }

/* ── Setting slider ── */
.setting-slider {
    display: flex; align-items: center; justify-content: space-between;
    padding: 4px 0; font-size: 13px; color: var(--text-secondary);
}

/* ── Branch nav ── */
.branch-nav {
    display: flex; align-items: center; gap: 4px; margin-bottom: 8px;
    font-size: 12px; color: var(--text-muted);
}
.branch-nav button {
    background: none; border: 1px solid var(--border); color: var(--text-muted);
    padding: 2px 6px; border-radius: 4px; cursor: pointer; font-size: 11px;
}

/* ── Typing indicator ── */
.typing-indicator {
    display: flex; align-items: center; gap: 6px;
    padding: 12px 16px; max-width: 200px;
    animation: msg-in 0.3s ease;
}
.typing-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--primary); opacity: 0.4;
    animation: typing-bounce 1.4s infinite;
}
.typing-dot:nth-child(2) { animation-delay: 0.2s; }
.typing-dot:nth-child(3) { animation-delay: 0.4s; }
.typing-text { font-size: 12px; color: var(--text-muted); margin-left: 4px; }
@keyframes typing-bounce {
    0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
    30% { transform: translateY(-6px); opacity: 1; }
}

/* ── Code block improvements ── */
.code-lines { font-size: 11px; color: var(--text-muted); font-weight: 400; margin-left: 4px; }

/* Per-block collapse (body only, header stays visible) */
pre.code-block-collapsed > code,
.code-collapsed {
    max-height: 0 !important;
    overflow: hidden !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    opacity: 0.0;
    transition: max-height 0.22s ease, opacity 0.18s ease, padding 0.18s ease;
}
pre > code {
    transition: max-height 0.28s ease, opacity 0.22s ease, padding 0.2s ease;
}
pre.code-block-collapsed {
    padding-bottom: 0 !important;
}

/* Custom-icon toolbar buttons */
.code-actions .cb-icon-btn {
    background: none;
    border: 1px solid transparent;
    color: var(--text-muted);
    cursor: pointer;
    padding: 4px;
    width: 26px;
    height: 26px;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
}
.code-actions .cb-icon-btn svg { display: block; }
.code-actions .cb-icon-btn:hover {
    color: var(--text, #e8e8f0);
    background: rgba(124, 137, 246, 0.12);
    border-color: rgba(124, 137, 246, 0.3);
}
.code-actions .cb-icon-btn:active { transform: scale(0.94); }
.code-actions .cb-icon-btn.copied {
    color: #34d399;
    background: rgba(52, 211, 153, 0.14);
    border-color: rgba(52, 211, 153, 0.35);
}
.code-actions .cb-icon-btn.is-active {
    color: #7c89f6;
    background: rgba(124, 137, 246, 0.18);
    border-color: rgba(124, 137, 246, 0.5);
}

/* Collapse chevron: rotates when collapsed */
.code-actions .btn-collapse .cb-ico-chev {
    transition: transform 0.22s cubic-bezier(0.4, 0.0, 0.2, 1);
}
.code-actions .btn-collapse.is-collapsed .cb-ico-chev {
    transform: rotate(-90deg);
}
.code-actions .btn-collapse.is-collapsed {
    color: rgba(124, 137, 246, 0.85);
}

body.light-theme .code-actions .cb-icon-btn:hover {
    background: rgba(99, 102, 241, 0.08);
    border-color: rgba(99, 102, 241, 0.25);
    color: #1f2937;
}

/* ── Drag & Drop hint over input area only ──
   Никаких overlay'ев на весь чат — только подсветка зоны куда писать,
   чтоб не перекрывать читаемый контент. */
.chat-main.chat-drag-active .chat-input-area,
.chat-main.chat-drag-active .chat-input-wrapper {
    outline: 2px dashed var(--primary, #6366f1);
    outline-offset: 4px;
    background: rgba(99, 102, 241, 0.06);
    transition: outline 0.15s, background 0.15s;
    border-radius: 14px;
    position: relative;
}
.chat-main.chat-drag-active .chat-input-wrapper::before {
    content: '⬆ Отпустите файл — он прикрепится к сообщению';
    position: absolute;
    left: 50%;
    top: -28px;
    transform: translateX(-50%);
    background: var(--primary, #6366f1);
    color: #fff;
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 11.5px;
    font-weight: 600;
    white-space: nowrap;
    pointer-events: none;
    box-shadow: 0 4px 14px rgba(99,102,241,0.4);
    animation: chat-drag-bob 1.4s ease-in-out infinite;
}
@keyframes chat-drag-bob {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50%      { transform: translateX(-50%) translateY(-3px); }
}
/* Legacy rule, kept for back-compat with any stale .drag-overlay nodes */
.drag-overlay { display: none; }
.drag-text { display: none; }

/* ── Chat search bar ── */
.chat-search-bar {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 16px; background: var(--bg-card);
    border-bottom: 1px solid var(--border);
    animation: msg-in 0.2s ease;
}
.chat-search-input {
    flex: 1; padding: 6px 12px; background: var(--bg-input);
    border: 1px solid var(--border); border-radius: 8px;
    color: var(--text); font-size: 13px; outline: none;
}
.chat-search-close {
    background: none; border: none; color: var(--text-muted);
    font-size: 18px; cursor: pointer; padding: 0 4px;
}

/* ── Sidebar improvements ── */
.chat-item-archived { opacity: 0.5; }
.chat-item-pinned { border-left: 2px solid var(--primary); }
.sidebar-sort-btn {
    background: none; border: none; color: var(--text-muted);
    cursor: pointer; font-size: 12px; padding: 2px 6px;
}
.sidebar-sort-btn:hover { color: var(--text); }

/* ── File Manager ── */
.fm-overlay {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: 360px;
    max-width: 90vw;
    background: var(--bg-card);
    border-left: 1px solid var(--border);
    z-index: 500;
    display: flex;
    flex-direction: column;
    animation: slideInRight 0.25s ease;
    box-shadow: -4px 0 24px rgba(0,0,0,0.3);
}
@keyframes slideInRight {
    from { transform: translateX(100%); }
    to { transform: translateX(0); }
}
.fm-panel { display: flex; flex-direction: column; height: 100%; position: relative; }
.fm-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 20px; border-bottom: 1px solid var(--border);
    font-size: 16px; font-weight: 700;
}
.fm-toolbar {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 16px; border-bottom: 1px solid var(--border);
    gap: 8px;
}
.fm-breadcrumb {
    font-size: 12px; color: var(--text-muted); flex: 1;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fm-breadcrumb span { cursor: pointer; color: var(--primary-light); }
.fm-actions { display: flex; gap: 4px; }
.fm-btn {
    background: none; border: 1px solid var(--border); border-radius: 6px;
    color: var(--text); padding: 4px 8px; cursor: pointer; font-size: 13px;
    min-width: 24px; min-height: 24px;
}
.fm-btn:hover { background: var(--bg-input); }
.fm-list {
    flex: 1; overflow-y: auto; padding: 8px 12px;
    scrollbar-width: thin;
    scrollbar-color: rgba(99,102,241,0.3) transparent;
}
.fm-list::-webkit-scrollbar { width: 5px; }
.fm-list::-webkit-scrollbar-track { background: transparent; }
.fm-list::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.3); border-radius: 10px; }
.fm-item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 10px; border-radius: 8px; cursor: pointer;
    font-size: 13px; color: var(--text);
    transition: background 0.15s;
}
.fm-item:hover { background: var(--bg-input); }
.fm-item-icon { font-size: 18px; flex-shrink: 0; }
.fm-item-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fm-item-size { color: var(--text-muted); font-size: 11px; flex-shrink: 0; }
.fm-item-actions { display: flex; gap: 2px; opacity: 0; transition: opacity 0.15s; }
.fm-item:hover .fm-item-actions { opacity: 1; }
.fm-item-btn {
    background: none; border: none; color: var(--text-muted); cursor: pointer;
    padding: 2px 4px; font-size: 13px; border-radius: 4px;
}
.fm-item-btn:hover { color: var(--text); background: var(--bg); }
.fm-empty { text-align: center; padding: 40px 20px; color: var(--text-muted); font-size: 13px; }

/* ── New-build reload notice (bottom-center) ── */
#osc-reload-notice {
    position: fixed;
    bottom: calc(96px + env(safe-area-inset-bottom));
    left: 50%;
    transform: translateX(-50%);
    z-index: 10020;
    display: flex;
    align-items: center;
    gap: 8px;
    max-width: min(420px, calc(100vw - 28px));
    background: rgba(25, 24, 44, 0.96);
    color: #fff;
    padding: 8px 8px 8px 12px;
    border: 1px solid rgba(139, 124, 246, 0.32);
    border-radius: 14px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: 0 14px 34px rgba(0,0,0,0.34), 0 0 0 1px rgba(255,255,255,0.04) inset;
    backdrop-filter: blur(14px);
    animation: osc-reload-in 0.32s cubic-bezier(.2,.7,.2,1);
}
@keyframes osc-reload-in {
    from { opacity: 0; transform: translate(-50%, 18px); }
    to   { opacity: 1; transform: translate(-50%, 0); }
}
.reload-notice-text {
    color: #fff;
    display: inline-flex;
    align-items: center;
    min-width: 0;
    white-space: nowrap;
}
.reload-notice-btn {
    background: rgba(139, 124, 246, 0.24);
    border: 1px solid rgba(196, 181, 253, 0.34);
    color: #fff;
    padding: 7px 12px;
    border-radius: 11px;
    cursor: pointer;
    font-size: 12.5px;
    font-weight: 700;
    transition: background 0.15s;
}
.reload-notice-btn:hover { background: rgba(255,255,255,0.32); }
.reload-notice-close {
    background: transparent;
    border: none;
    color: rgba(255,255,255,0.8);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    padding: 4px 6px;
    transition: color 0.15s;
}
.reload-notice-close:hover { color: #fff; }

@media (max-width: 640px) {
    #osc-reload-notice {
        top: calc(62px + env(safe-area-inset-top));
        right: 10px;
        bottom: auto;
        left: auto;
        transform: none;
        width: min(270px, calc(100vw - 20px));
        max-width: none;
        justify-content: space-between;
        padding: 7px 7px 7px 10px;
        border-radius: 13px;
        font-size: 12px;
    }
    @keyframes osc-reload-in {
        from { opacity: 0; transform: translateY(-8px); }
        to   { opacity: 1; transform: translateY(0); }
    }
    .reload-notice-text {
        font-size: 12px;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .reload-notice-btn {
        flex: 0 0 auto;
        padding: 6px 10px;
        font-size: 12px;
    }
    .reload-notice-close {
        flex: 0 0 auto;
        width: 32px;
        height: 32px;
        padding: 0;
    }
}

/* ── FM file-icon wrapper: единый размер/выравнивание для всех SVG-иконок ── */
.fm-fi {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}
.fm-fi > svg {
    width: 100%;
    height: 100%;
    display: block;
}
/* Иконка в строке файла — чуть больше */
.fm-item .fm-fi {
    width: 19px;
    height: 19px;
}
/* Folder-row hover: подсветка иконки */
.fm-item:hover .fm-fi { filter: brightness(1.15); }

/* ── FM Context Menu (custom SVG icons, single visual style) ── */
.fm-ctx-menu {
    background: rgba(18, 20, 32, 0.985);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 6px;
    min-width: 220px;
    box-shadow:
        0 18px 48px rgba(0,0,0,0.55),
        0 4px 12px rgba(0,0,0,0.32);
    font-size: 13px;
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    animation: fm-ctx-pop 0.14s ease-out;
}
[data-theme="cosmos"] .fm-ctx-menu { background: rgba(8, 10, 22, 0.985); }
[data-theme="light"] .fm-ctx-menu  { background: rgba(252, 253, 255, 0.985); }

/* ZIP/search button icon polish */
.fm-zip-action .fm-zip-icon { color: var(--primary, #818cf8); transition: transform .2s ease; }
.fm-zip-action:hover .fm-zip-icon { transform: scale(1.08) rotate(-3deg); }
.fm-zip-spin { animation: osc-spin .9s linear infinite; }
@keyframes fm-ctx-pop {
    from { opacity: 0; transform: scale(0.96) translateY(-4px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}
.fm-ctx-item {
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 8px 12px;
    border-radius: 8px;
    cursor: pointer;
    color: var(--text);
    transition: background 0.12s, color 0.12s;
    user-select: none;
}
.fm-ctx-item:hover {
    background: rgba(99, 102, 241, 0.14);
    color: var(--text);
}
.fm-ctx-item.danger { color: #ef4444; }
.fm-ctx-item.danger:hover { background: rgba(239, 68, 68, 0.14); }
.fm-ctx-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    color: var(--text-muted);
    transition: color 0.12s;
}
.fm-ctx-item:hover .fm-ctx-icon { color: var(--primary-light); }
.fm-ctx-item.danger .fm-ctx-icon { color: #ef4444; }
.fm-ctx-label { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.fm-ctx-sep {
    height: 1px;
    background: var(--border);
    margin: 4px 6px;
}

body.light-theme .fm-ctx-menu {
    box-shadow:
        0 12px 36px rgba(0,0,0,0.18),
        0 2px 8px rgba(0,0,0,0.08);
}

/* Web search indicator */
.search-step {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    margin-bottom: 8px;
    background: rgba(115, 100, 245, 0.06);
    border: 1px solid rgba(115, 100, 245, 0.12);
    border-radius: 10px;
    font-size: 13px;
    color: var(--text-secondary);
    animation: msg-in 0.3s ease;
}
.search-icon { display: inline-flex; align-items: center; color: var(--primary-light); }
.search-icon svg { display: block; }
.search-label { font-weight: 600; color: var(--text); }
.search-query { color: var(--primary-light); font-style: italic; }
.search-status { color: #22c55e; margin-left: auto; display: inline-flex; align-items: center; }
.search-status svg { display: block; }
.search-step.searching .search-status {
    animation: pulse-search 1.2s infinite;
    color: var(--primary-light);
}
@keyframes pulse-search {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}
@keyframes osc-spin { to { transform: rotate(360deg); } }

/* ──────────────────────────────────────────────────────────────
   CLI-mode agent activity cards — Claude-Code-UI style
   Each tool call gets a full card with [●] [Bash] [title] + IN + OUT
   ────────────────────────────────────────────────────────────── */
.cli-agent-steps,
.message-events-stream {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 4px 0 8px;
}
/* пустой stream (только свёрнутый бэйдж рассуждений) не должен занимать место */
.message-events-stream:empty { display: none; margin: 0; }

.cli-step-card {
    border: 1px solid rgba(115,100,245,0.16);
    border-radius: 12px;
    background: rgba(18,18,28,0.55);
    overflow: hidden;
    animation: msg-in 0.3s ease;
}
.cli-step-card.cli-step-running { border-color: rgba(99,179,255,0.3); }
.cli-step-card.cli-step-done    { border-color: rgba(34,197,94,0.28); }
.cli-step-card.cli-step-error   { border-color: rgba(239,68,68,0.35); }

.cli-step-header {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px;
    border-bottom: 1px solid rgba(115,100,245,0.08);
    background: rgba(115,100,245,0.035);
}
.cli-step-card.cli-step-done .cli-step-header    { background: rgba(34,197,94,0.04); }
.cli-step-card.cli-step-error .cli-step-header   { background: rgba(239,68,68,0.05); }

.cli-step-dot {
    width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
    background: var(--primary);
    box-shadow: 0 0 0 3px rgba(115,100,245,0.15);
}
.cli-step-running .cli-step-dot { animation: pulse-search 1.1s infinite; }
.cli-step-done    .cli-step-dot { background: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,0.2); }
.cli-step-error   .cli-step-dot { background: #ef4444; box-shadow: 0 0 0 3px rgba(239,68,68,0.22); }

.cli-step-badge {
    font-size: 11px; font-weight: 700;
    padding: 3px 8px;
    border-radius: 6px;
    background: rgba(115,100,245,0.15);
    color: var(--primary-light, #a29cff);
    letter-spacing: 0.2px;
    flex-shrink: 0;
}
.cli-step-done  .cli-step-badge { background: rgba(34,197,94,0.15);  color: #5dd89c; }
.cli-step-error .cli-step-badge { background: rgba(239,68,68,0.16);  color: #ff7b7b; }

.cli-step-title {
    font-size: 13.5px;
    color: var(--text);
    font-weight: 500;
    flex: 1;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.cli-step-in, .cli-step-out {
    padding: 8px 14px;
    font-size: 12.5px;
    border-top: 1px solid rgba(115,100,245,0.06);
}
.cli-step-in  { background: rgba(255,255,255,0.015); }
.cli-step-out { background: rgba(34,197,94,0.035); }
.cli-step-card.cli-step-error .cli-step-out { background: rgba(239,68,68,0.05); }

.cli-step-label {
    display: inline-block;
    font-size: 9.5px; font-weight: 700;
    letter-spacing: 1px;
    color: var(--text-muted);
    padding: 2px 6px;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 4px;
    margin-bottom: 6px;
}

.cli-step-code {
    margin: 0;
    background: rgba(0,0,0,0.28);
    border-radius: 6px;
    padding: 8px 12px;
    overflow-x: auto;
    max-height: 260px;
    overflow-y: auto;
}
.cli-step-code code {
    font-family: 'JetBrains Mono', ui-monospace, 'Fira Code', monospace;
    font-size: 12px;
    line-height: 1.55;
    color: var(--text);
    white-space: break-spaces;
    word-break: break-word;
}

/* TodoWrite — checklist with strikethroughs */
.cli-todos { display: flex; flex-direction: column; gap: 4px; padding: 4px 0; }
.cli-todo {
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; padding: 3px 4px;
    color: var(--text);
}
.cli-todo-mark {
    width: 16px; text-align: center;
    color: var(--text-muted);
    font-weight: 700;
    flex-shrink: 0;
}
.cli-todo-completed             { color: var(--text-muted); }
.cli-todo-completed .cli-todo-mark { color: #22c55e; }
.cli-todo-completed > span:last-child { text-decoration: line-through; opacity: 0.7; }
.cli-todo-in_progress .cli-todo-mark { color: var(--primary); }
.cli-todo-in_progress > span:last-child { font-weight: 600; }

/* Mode-aware assistant answers */
.message.agent-mode-plan .message-body {
    border-left: 3px solid #60a5fa;
    background: linear-gradient(180deg, rgba(96,165,250,0.08), rgba(96,165,250,0.025));
}
.message.agent-mode-plan .message-content::before {
    content: "План";
    display: inline-flex;
    align-items: center;
    margin: 0 0 10px;
    padding: 3px 9px;
    border-radius: 999px;
    border: 1px solid rgba(96,165,250,0.32);
    background: rgba(96,165,250,0.12);
    color: #93c5fd;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .02em;
}
.message.agent-mode-ask .message-body {
    border-left: 3px solid rgba(167,139,250,0.65);
}
.message.agent-mode-auto-edit .message-body,
.message.agent-mode-auto .message-body {
    border-left: 3px solid rgba(74,222,128,0.62);
}
.message.agent-mode-bypass .message-body {
    border-left: 3px solid rgba(248,113,113,0.62);
}

/* Ask-user-question tool modal */
.agent-question-overlay {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(5, 7, 18, 0.68);
    backdrop-filter: blur(10px);
}
.agent-question-modal {
    width: min(560px, 92vw);
    border: 1px solid rgba(167,139,250,0.36);
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(21,21,42,0.98), rgba(12,13,28,0.98));
    box-shadow: 0 24px 70px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.03) inset;
    padding: 22px;
}
.agent-question-kicker {
    color: #a78bfa;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 8px;
}
.agent-question-modal h3 {
    margin: 0 0 8px;
    font-size: 18px;
    color: var(--text);
}
.agent-question-modal p {
    margin: 0 0 14px;
    color: var(--text-muted);
    line-height: 1.55;
}
.agent-question-options {
    display: grid;
    gap: 8px;
    margin-bottom: 12px;
}
.agent-question-option {
    text-align: left;
    border: 1px solid rgba(115,100,245,0.24);
    border-radius: 10px;
    background: rgba(255,255,255,0.035);
    color: var(--text);
    padding: 10px 12px;
    cursor: pointer;
    font: inherit;
}
.agent-question-option:hover,
.agent-question-option.selected {
    border-color: rgba(96,165,250,0.62);
    background: rgba(96,165,250,0.11);
}
.agent-question-option span {
    display: block;
    font-weight: 700;
}
.agent-question-option small {
    display: block;
    margin-top: 3px;
    color: var(--text-muted);
}
.agent-question-input {
    width: 100%;
    resize: vertical;
    min-height: 74px;
    border: 1px solid rgba(115,100,245,0.25);
    border-radius: 10px;
    background: rgba(0,0,0,0.22);
    color: var(--text);
    padding: 10px 12px;
    font: inherit;
    outline: none;
}
.agent-question-input:focus {
    border-color: rgba(96,165,250,0.62);
}
.agent-question-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 14px;
}
.agent-question-btn {
    border: 0;
    border-radius: 9px;
    padding: 9px 15px;
    color: var(--text);
    font-weight: 700;
    cursor: pointer;
}
.agent-question-btn.ghost {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
}
.agent-question-btn.primary {
    background: linear-gradient(135deg, #7364f5, #4f46e5);
    color: #fff;
}

.message-content {
    font-size: 14px;
    line-height: 1.65;
    color: var(--text);
    word-wrap: break-word;
    overflow-wrap: break-word;
}

/* Code blocks in messages */
.message-content pre {
    background: var(--code-bg);
    border: 1px solid var(--code-border);
    border-radius: 10px;
    overflow-x: auto;       /* горизонтальный скролл для длинных строк */
    overflow-y: visible;    /* вертикальный — НЕ внутри pre, а вместе с чатом */
    margin: 12px 0;
    position: relative;
}

/* ── Кнопка «Запустить» в шапке кода ── */
.cb-icon-btn-run {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.18), rgba(34, 197, 94, 0.08)) !important;
    border: 1px solid rgba(34, 197, 94, 0.35) !important;
    color: #22c55e !important;
    padding: 4px 9px !important;
    width: auto !important;
    display: inline-flex !important;
    align-items: center;
    gap: 5px;
    border-radius: 6px !important;
    font-weight: 600;
    font-size: 11px;
    transition: all 0.15s ease;
}
.cb-icon-btn-run:hover {
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.28), rgba(34, 197, 94, 0.14)) !important;
    border-color: rgba(34, 197, 94, 0.55) !important;
    box-shadow: 0 0 12px rgba(34, 197, 94, 0.25);
}
.cb-icon-btn-run.running .cb-ico-play { animation: pyRunPulse 1s ease infinite; }
.cb-icon-btn-run:disabled { opacity: 0.7; cursor: progress; }
.cb-run-label { font-size: 11px; }

@keyframes pyRunPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

/* ── Python Runtime Box ── */
.py-runtime-box {
    margin: -8px 0 14px;
    border: 1px solid rgba(34, 197, 94, 0.25);
    border-top: none;
    border-radius: 0 0 10px 10px;
    background: linear-gradient(180deg, rgba(34, 197, 94, 0.04), rgba(0, 0, 0, 0.18));
    overflow: hidden;
    animation: pyBoxIn 0.2s ease-out;
}
@keyframes pyBoxIn {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

.py-runtime-head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    background: rgba(34, 197, 94, 0.06);
    border-bottom: 1px solid rgba(34, 197, 94, 0.18);
    font-size: 12px;
}
.py-runtime-title {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #22c55e;
    font-weight: 600;
}
.py-runtime-title svg { color: #22c55e; }
.py-runtime-status {
    flex: 1;
    color: var(--text-muted);
    font-size: 11px;
    font-family: 'JetBrains Mono', monospace;
}
.py-runtime-close {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    padding: 2px 8px;
    border-radius: 4px;
    transition: all 0.15s;
}
.py-runtime-close:hover { background: rgba(255, 255, 255, 0.08); color: var(--text); }

.py-runtime-plots {
    padding: 12px;
    background: #fafafa;
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: center;
    border-bottom: 1px solid rgba(34, 197, 94, 0.18);
}
.py-runtime-plot {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
    background: #fff;
}

/* ── Canvas для интерактивной графики (Pygame-like через js-модуль) ── */
.py-runtime-canvas-wrap {
    padding: 14px;
    background: #0a0a16;
    display: flex;
    justify-content: center;
    border-bottom: 1px solid rgba(34, 197, 94, 0.18);
}
.py-runtime-canvas {
    background: #1a1a2e;
    border-radius: 6px;
    max-width: 100%;
    height: auto;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
    outline: none;
    cursor: crosshair;
}
.py-runtime-canvas:focus {
    box-shadow: 0 0 0 2px var(--primary), 0 4px 16px rgba(0, 0, 0, 0.4);
}

.py-runtime-output {
    max-height: 320px;
    overflow-y: auto;
    padding: 10px 14px;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 12.5px;
    line-height: 1.55;
    white-space: break-spaces;
    word-break: break-word;
}
.py-runtime-output:empty { display: none; }

.py-log {
    padding: 1px 0;
}
.py-log-stdout { color: var(--text); }
.py-log-stderr { color: #f87171; }
.py-log-info   { color: #a78bfa; opacity: 0.85; font-style: italic; }
.py-log-ok     { color: #22c55e; font-weight: 500; }
.py-log-warn   { color: #fbbf24; }

/* ── Fix helper: при ошибке с неподдерживаемой либой ── */
.py-fix-helper {
    margin-top: 12px;
    padding: 12px;
    border: 1px solid rgba(167, 139, 250, 0.3);
    border-radius: 10px;
    background: rgba(167, 139, 250, 0.06);
}
.py-fix-hint {
    font-size: 12.5px;
    color: #c4b5fd;
    margin-bottom: 10px;
    font-family: 'Inter', sans-serif;
    font-style: normal;
}
.py-fix-buttons {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.py-fix-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    border-radius: 8px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text);
    font-family: inherit;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s;
}
.py-fix-btn:hover {
    border-color: var(--primary);
    background: rgba(115, 100, 245, 0.08);
}
.py-fix-btn-primary {
    background: linear-gradient(135deg, #7c89f6, #a78bfa);
    border-color: transparent;
    color: #fff;
    font-weight: 600;
}
.py-fix-btn-primary:hover {
    box-shadow: 0 4px 14px rgba(167, 139, 250, 0.4);
    background: linear-gradient(135deg, #8a96f7, #b39bfb);
}

/* Скроллбар под общий стиль */
.py-runtime-output::-webkit-scrollbar { width: 6px; }
.py-runtime-output::-webkit-scrollbar-track { background: rgba(255,255,255,0.02); }
.py-runtime-output::-webkit-scrollbar-thumb { background: rgba(34, 197, 94, 0.3); border-radius: 3px; }
.py-runtime-output::-webkit-scrollbar-thumb:hover { background: rgba(34, 197, 94, 0.5); }

/* Mobile compact */
@media (max-width: 600px) {
    .cb-run-label { display: none; }
    .cb-icon-btn-run { padding: 4px 6px !important; }
    .py-runtime-output { max-height: 240px; font-size: 11.5px; }
    .py-runtime-canvas { width: 100% !important; }
}

.message-content pre .code-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 14px;
    background: var(--code-bg, #0a0a16);
    border-bottom: 1px solid var(--code-border);
    font-family: var(--font-code);
    font-size: 11px;
    color: var(--text-muted);
    position: sticky;
    top: 0;
    z-index: 5;
}

.code-actions {
    display: flex;
    align-items: center;
    gap: 4px;
}

.code-actions button {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 11px;
    font-family: inherit;
    padding: 2px 8px;
    border-radius: 4px;
    transition: var(--transition);
}

.code-actions button:hover {
    color: var(--text);
    background: var(--bg-hover);
}

.code-actions button.liked { color: #22c55e; }
.code-actions button.disliked { color: #ef4444; }

.btn-copy {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 11px;
    font-family: inherit;
    padding: 2px 8px;
    border-radius: 4px;
    transition: var(--transition);
}

.btn-copy:hover {
    color: var(--text);
    background: var(--bg-hover);
}

.btn-copy.copied {
    color: #22c55e;
}

.message-content pre code {
    display: block;
    padding: 14px;
    font-family: var(--font-code);
    font-size: 13px;
    line-height: 1.6;
    color: var(--text);
    overflow-x: auto;
    /* Не даём длинному коду растягивать чат простынёй — кэп + внутренний скролл.
       Кэп на <code>, а не на <pre>, чтобы шапка (.code-header) оставалась видимой. */
    max-height: 360px;
    overflow-y: auto;
}

/* Стилизованный горизонтальный скролл для кода */
.message-content pre code::-webkit-scrollbar { height: 6px; }
.message-content pre code::-webkit-scrollbar-track { background: rgba(255,255,255,0.02); border-radius: 3px; }
.message-content pre code::-webkit-scrollbar-thumb { background: rgba(115,100,245,0.3); border-radius: 3px; }
.message-content pre code::-webkit-scrollbar-thumb:hover { background: rgba(115,100,245,0.5); }
.message-content pre::-webkit-scrollbar { height: 6px; }
.message-content pre::-webkit-scrollbar-track { background: rgba(255,255,255,0.02); border-radius: 3px; }
.message-content pre::-webkit-scrollbar-thumb { background: rgba(115,100,245,0.3); border-radius: 3px; }
.message-content pre::-webkit-scrollbar-thumb:hover { background: rgba(115,100,245,0.5); }

/* Inline code */
.message-content code:not(pre code) {
    /* Audit 2026-06-05: убран яркий фиолетовый border/bg/цвет — inline-чипсы делали
       визуальные «сдвиги» строк и пестрили после каждого предложения. Нейтрально,
       padding БЕЗ вертикали → строки ровные. Кликабельный osc-path-чип ниже сохраняет вид. */
    background: rgba(255, 255, 255, 0.06);
    border-radius: 4px;
    padding: 0 5px;
    font-family: var(--font-code);
    font-size: 0.88em;
    color: var(--text-primary, #e6e6f0);
    vertical-align: baseline;
}
/* Кликабельный path-чип: визуально отличается от обычного inline-code
   (рамка ярче + иконка-документ + pointer + hover) и от ссылки (нет ↗).
   Совместное решение с Codex 2026-05-26. */
.message-content code.osc-path {
    cursor: pointer;
    border: 1px solid rgba(115, 100, 245, 0.45);
    background: rgba(115, 100, 245, 0.12);
    color: var(--primary-light);
    padding: 0 6px 0 20px;
    position: relative;
    transition: background .14s ease, border-color .14s ease;
}
.message-content code.osc-path::before {
    content: "";
    position: absolute;
    left: 5px; top: 50%;
    width: 11px; height: 12px; margin-top: -6px;
    border: 1.3px solid currentColor;
    border-radius: 1.5px;
    opacity: .55;
    /* срез верхнего-правого угла = «лист бумаги» */
    clip-path: polygon(0 0, 70% 0, 100% 26%, 100% 100%, 0 100%);
}
.message-content code.osc-path:hover {
    background: rgba(115, 100, 245, 0.2);
    border-color: rgba(115, 100, 245, 0.7);
    text-decoration: underline dotted;
}
.message-content code.osc-path:focus-visible {
    outline: 2px solid var(--primary-light, #a29bfe);
    outline-offset: 1px;
}
/* visually-hidden: видно только скринридеру (для #osc-sr-status и т.п.) */
.sr-only {
    position: absolute !important;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Syntax highlighting */
.hl-keyword { color: #c792ea; }
.hl-string { color: #c3e88d; }
.hl-comment { color: #546e7a; font-style: italic; }
.hl-number { color: #f78c6c; }
.hl-function { color: #82aaff; }
.hl-builtin { color: #ffcb6b; }
.hl-self { color: #f07178; }
.hl-decorator { color: #c792ea; font-style: italic; }

/* Think mode — collapsible details */
.think-block {
    margin: 12px 0;
    background: rgba(139, 92, 246, 0.08);
    border: 1px solid rgba(139, 92, 246, 0.2);
    border-left: 3px solid #a78bfa;
    border-radius: 0 10px 10px 0;
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.7;
    overflow: hidden;
}
/* Компактный вариант — только бейдж длительности, содержимое скрыто навсегда.
   Юзер видит «💭 Думал 12s» без раскрывающейся стрелки. Чтобы случайно не
   раскрыть — отключаем поинтер на summary. */
.think-block-compact { margin: 6px 0; }
.think-block-compact > summary { cursor: default; pointer-events: none; padding: 4px 10px; }
.think-block-compact > summary::-webkit-details-marker { display: none; }
.think-block-compact > summary::marker { display: none; }
.think-block-compact .think-chevron { display: none !important; }
.think-block-compact .think-content { display: none !important; }

.think-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    color: #a78bfa;
    user-select: none;
    list-style: none;
    transition: background 0.15s;
}

.think-header:hover {
    background: rgba(139, 92, 246, 0.12);
}

.think-header::-webkit-details-marker { display: none; }
.think-header::marker { display: none; content: ''; }

.think-icon { font-size: 15px; }

.think-chevron {
    margin-left: auto;
    transition: transform 0.2s;
    font-size: 16px;
    font-weight: 700;
}

.think-block[open] .think-chevron {
    transform: rotate(90deg);
}

.think-content {
    padding: 0 16px 14px;
    font-style: italic;
    color: rgba(167, 139, 250, 0.8);
    white-space: pre-wrap;
    border-top: 1px solid rgba(139, 92, 246, 0.15);
    margin-top: 0;
    padding-top: 12px;
    font-size: 12.5px;
    line-height: 1.7;
}

/* Loading dots */
.loading-dots {
    display: flex;
    gap: 4px;
    padding: 8px 0;
}

.loading-dots span {
    width: 6px;
    height: 6px;
    background: var(--primary-light);
    border-radius: 50%;
    animation: bounce-dot 1.2s infinite;
}

.loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.loading-dots span:nth-child(3) { animation-delay: 0.4s; }

@keyframes bounce-dot {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.3; }
    40% { transform: scale(1); opacity: 1; }
}

/* ── Input Area ── */
.chat-input-area {
    position: relative;
    padding: 12px 20px 16px;
    border-top: 1px solid var(--border);
    background: var(--bg);
}

/* ── Гостевой режим: смотреть можно, писать нельзя ──────────────────── */
.guest-cta {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    background: linear-gradient(135deg, rgba(168,85,247,.10), rgba(236,72,153,.08));
    border: 1px solid rgba(168,85,247,.28);
    border-radius: var(--radius);
    font-size: 13px;
    color: var(--text);
}
.guest-cta-text { flex: 1; min-width: 0; line-height: 1.45; }
.guest-cta .btn { flex-shrink: 0; white-space: nowrap; }
/* В гостевом режиме прячем реальный composer и подсказку, показываем CTA. */
body.osc-guest .chat-input-wrapper,
body.osc-guest .chat-input-hint { display: none; }
body.osc-guest #guest-cta { display: flex; }
/* Боковые действия, требующие аккаунта — приглушены и не кликабельны. */
body.osc-guest #btn-new-chat,
body.osc-guest #sidebar-chats-section {
    opacity: .5;
    pointer-events: none;
}

/* Welcome-блок гостя в области сообщений. */
.guest-welcome {
    max-width: 520px;
    margin: auto;
    padding: 40px 24px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
}
.guest-welcome-icon {
    line-height: 1;
    filter: drop-shadow(0 6px 20px rgba(168, 85, 247, 0.35));
}
.guest-welcome-icon svg .gw-bracket {
    animation: gw-bracket-pulse 2.6s ease-in-out infinite;
    transform-origin: 32px 32px;
}
.guest-welcome-icon svg .gw-bracket-r { animation-delay: .25s; }
.guest-welcome-icon svg .gw-slash {
    opacity: .55;
    animation: gw-slash-fade 2.6s ease-in-out infinite;
}
@keyframes gw-bracket-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: .82; transform: scale(.92); }
}
@keyframes gw-slash-fade {
    0%, 100% { opacity: .35; }
    50%      { opacity: .9; }
}
@media (prefers-reduced-motion: reduce) {
    .guest-welcome-icon svg .gw-bracket,
    .guest-welcome-icon svg .gw-slash { animation: none; }
}
.guest-welcome h2 {
    font-size: 20px;
    font-weight: 700;
    color: var(--text);
    margin: 0;
}
.guest-welcome p {
    font-size: 14px;
    line-height: 1.6;
    color: var(--text-muted);
    margin: 0;
}
.guest-welcome .btn { margin-top: 6px; }

.chat-input-wrapper {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 6px 10px;
    transition: var(--transition);
    min-height: 48px;
}
/* Normalize toolbar button sizes so they sit on a single visual baseline.
   Icon-only buttons = 32×32. Pill button (mode) keeps own width, 32 tall. */
.chat-input-wrapper > .btn-attach,
.chat-input-wrapper > .btn-send,
.chat-input-wrapper > .btn-stop,
.chat-input-wrapper > .btn-voice,
.chat-input-wrapper > .btn-filesystem,
.chat-input-wrapper > .btn-slash,
.chat-input-wrapper > .context-meter,
.chat-input-wrapper > #enhance-btn {
    width: 32px;
    height: 32px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.context-meter {
    --context-used: 0deg;
    border: 0;
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
}

.context-meter-ring {
    position: relative;
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: conic-gradient(var(--primary) var(--context-used), rgba(148,163,184,.18) 0);
    transition: background .25s ease, color .25s ease;
}

.context-meter-ring::before {
    content: '';
    position: absolute;
    inset: 4px;
    border-radius: 50%;
    background: var(--bg-input);
}

.context-meter-ring > span {
    position: relative;
    z-index: 1;
    font-size: 8px;
    font-weight: 700;
    letter-spacing: -.25px;
}

.context-meter.is-warning { color: #f59e0b; }
.context-meter.is-warning .context-meter-ring { background: conic-gradient(#f59e0b var(--context-used), rgba(245,158,11,.16) 0); }
.context-meter.is-critical { color: #ef4444; }
.context-meter.is-critical .context-meter-ring { background: conic-gradient(#ef4444 var(--context-used), rgba(239,68,68,.16) 0); }

.sidebar-chats-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.chat-archive-toggle {
    border: 0;
    padding: 2px 7px;
    border-radius: 6px;
    color: var(--text-muted);
    background: transparent;
    font: inherit;
    font-size: 10px;
    cursor: pointer;
    text-transform: none;
    letter-spacing: 0;
}

.chat-archive-toggle:hover,
.chat-archive-toggle.active {
    color: var(--text);
    background: var(--bg-hover);
}
.chat-input-wrapper > .btn-mode { height: 32px; align-self: center; }
.chat-input-wrapper > #chat-input { align-self: stretch; min-height: 32px; padding: 6px 4px; }

.chat-input-wrapper:focus-within {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(115, 100, 245, 0.1);
}

#chat-input {
    flex: 1;
    background: none;
    border: none;
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
    resize: none;
    outline: none;
    max-height: 200px;
    line-height: 1.5;
    padding: 4px 0;
}

#chat-input::placeholder {
    color: var(--text-muted);
}

.btn-voice {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 8px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    transition: var(--transition);
    position: relative;
}
.btn-voice:hover { color: var(--primary-light); }
.btn-voice.recording {
    color: #ef4444;
    background: rgba(239,68,68,0.10);
    box-shadow: 0 0 0 1px rgba(239,68,68,0.18), 0 0 18px rgba(239,68,68,0.20);
    animation: pulse-stop 1.5s ease-in-out infinite;
}
.voice-lang-badge {
    display: none;
    position: absolute;
    bottom: -4px;
    right: -4px;
    font-size: 9.5px;
    font-weight: 700;
    color: var(--primary-light);
    background: var(--bg-card);
    border: 1px solid rgba(124,137,246,0.5);
    border-radius: 5px;
    padding: 1px 4px;
    line-height: 12px;
    pointer-events: auto;   /* кликабельный — открывает picker */
    cursor: pointer;
    letter-spacing: 0.4px;
    white-space: nowrap;
    min-width: 22px;
    text-align: center;
    transition: transform 0.15s ease, border-color 0.15s ease;
}
.voice-lang-badge:hover {
    transform: scale(1.1);
    border-color: var(--primary-light);
}
.btn-voice.recording .voice-lang-badge { color: #ef4444; border-color: rgba(239,68,68,0.3); }

/* Voice language picker */
.voice-lang-picker {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 6px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.5);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2px;
    max-height: 400px;
    overflow-y: auto;
    min-width: 280px;
}
.voice-lang-title {
    grid-column: 1 / -1;
    padding: 8px 10px 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
    margin-bottom: 4px;
}
.voice-lang-opt {
    background: none;
    border: none;
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    padding: 8px 12px;
    border-radius: 8px;
    cursor: pointer;
    text-align: left;
    transition: background 0.15s;
}
.voice-lang-opt:hover { background: var(--bg-hover); }
/* ── Voice recording overlay (Telegram-style hold-to-record) ──────── */
.voice-overlay {
    position: fixed;
    right: max(14px, env(safe-area-inset-right));
    bottom: calc(72px + env(safe-area-inset-bottom));
    display: none;
    z-index: 9000;
    pointer-events: none;
    animation: voiceOverlayIn 0.14s ease-out;
}
.voice-overlay.active { display: flex; }
@keyframes voiceOverlayIn {
    from { transform: translateY(8px) scale(0.96); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}
.voice-overlay-body {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 9px;
    min-height: 38px;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(15,17,32,0.94);
    border: 1px solid rgba(239,68,68,0.30);
    box-shadow: 0 10px 34px rgba(0,0,0,0.38), 0 0 18px rgba(239,68,68,0.14);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    pointer-events: auto;
}
.voice-amp-wrap {
    width: 24px; height: 24px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(239,68,68,0.14);
    border: 1px solid rgba(239,68,68,0.28);
    border-radius: 50%;
}
.voice-amp {
    width: 4px; height: 15px;
    background: linear-gradient(to top, #ef4444, #f87171);
    border-radius: 3px;
    transform-origin: center;
    transform: scaleY(0.2);
    transition: transform 60ms ease-out;
    box-shadow: 0 0 12px rgba(239,68,68,0.45);
}
.voice-timer-row {
    display: inline-flex; align-items: center; gap: 8px;
    font-variant-numeric: tabular-nums;
    font-size: 13px; font-weight: 700;
    color: #fafafa;
}
.voice-rec-dot {
    width: 9px; height: 9px;
    border-radius: 50%;
    background: #ef4444;
    box-shadow: 0 0 10px rgba(239,68,68,0.7);
    animation: voiceRecPulse 1s ease-in-out infinite;
}
@keyframes voiceRecPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: 0.5; transform: scale(0.85); }
}
.voice-timer { color: #fff; }
.voice-hint {
    font-size: 11.5px;
    color: rgba(255,255,255,0.65);
    text-align: center;
    line-height: 1.2;
    white-space: nowrap;
}
.voice-overlay.locked .voice-hint {
    display: inline-flex;
    gap: 6px;
    align-items: center;
}
.voice-locked-label {
    color: rgba(255,255,255,0.72);
    font-size: 11.5px;
    font-weight: 600;
}
.voice-overlay.processing .voice-amp-wrap { opacity: 0.4; }
.voice-overlay.processing .voice-rec-dot { animation: none; background: #fbbf24; }
.voice-overlay.processing .voice-hint {
    color: #fbbf24;
    font-weight: 600;
}
.voice-btn {
    appearance: none;
    border: 0;
    border-radius: 999px;
    width: 28px;
    height: 28px;
    padding: 0;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
    font-family: inherit;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.voice-btn-stop {
    background: linear-gradient(135deg, #22c55e, #10b981);
    color: #fff;
}
.voice-btn-stop:hover { filter: brightness(1.08); }
.voice-btn-cancel {
    background: rgba(239,68,68,0.18);
    color: #fca5a5;
    border: 1px solid rgba(239,68,68,0.35);
}
.voice-btn-cancel:hover { background: rgba(239,68,68,0.28); }

/* В recording (hold) — динамические подсказки swipe-направлений */
.voice-overlay:not(.locked):not(.processing)::before {
    content: '↑ lock';
    position: absolute;
    right: 8px;
    bottom: calc(100% + 8px);
    font-size: 11px;
    color: rgba(255,255,255,0.55);
    pointer-events: none;
    padding: 3px 7px;
    border-radius: 999px;
    background: rgba(15,17,32,0.72);
}
.voice-overlay.locked::before { display: none; }

.voice-lang-opt.active {
    background: rgba(115,100,245,0.15);
    color: var(--primary-light);
    font-weight: 600;
}

.btn-attach, .btn-send, .btn-filesystem {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 6px;
    border-radius: 6px;
    transition: var(--transition);
    flex-shrink: 0;
}

.btn-attach:hover { color: var(--text-secondary); }
.btn-send:hover { color: var(--primary-light); }
.btn-filesystem:hover { color: var(--primary-light); background: rgba(115,100,245,0.08); }

/* Commands button (/) */
.btn-slash {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 6px;
    border-radius: 6px;
    transition: var(--transition);
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.btn-slash:hover { color: var(--primary-light); background: rgba(115,100,245,0.08); }

/* Agent mode pill */
.btn-mode {
    background: rgba(115,100,245,0.10);
    border: 1px solid rgba(115,100,245,0.28);
    color: var(--text-secondary);
    cursor: pointer;
    padding: 5px 12px 5px 9px;
    border-radius: 999px;
    transition: background 140ms, border-color 140ms, color 140ms;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 12.5px;
    font-weight: 500;
    line-height: 1;
    height: 30px;
    max-width: 200px;
    white-space: nowrap;
}
.btn-mode:hover { background: rgba(115,100,245,0.20); border-color: rgba(115,100,245,0.48); color: var(--text); }
.btn-mode-icon { display: inline-flex; align-items: center; line-height: 0; }
.btn-mode-icon svg { width: 16px; height: 16px; }
.btn-mode-label { overflow: hidden; text-overflow: ellipsis; max-width: 140px; }
.btn-mode-chev { width: 12px; height: 12px; opacity: 0.6; flex-shrink: 0; }
@media (max-width: 640px) {
    .btn-mode-label { display: none; }
    .btn-mode { padding: 5px 8px; max-width: none; }
}
.btn-mode[data-mode="auto-edit"] { color: #fbbf24; border-color: rgba(251,191,36,0.32); background: rgba(251,191,36,0.08); }
.btn-mode[data-mode="auto-edit"]:hover { background: rgba(251,191,36,0.16); }
.btn-mode[data-mode="auto"]    { color: #4ade80; border-color: rgba(74,222,128,0.32); background: rgba(74,222,128,0.08); }
.btn-mode[data-mode="auto"]:hover    { background: rgba(74,222,128,0.16); }
.btn-mode[data-mode="plan"]    { color: #60a5fa; border-color: rgba(96,165,250,0.32); background: rgba(96,165,250,0.08); }
.btn-mode[data-mode="plan"]:hover    { background: rgba(96,165,250,0.16); }
.btn-mode[data-mode="bypass"]  { color: #f87171; border-color: rgba(248,113,113,0.32); background: rgba(248,113,113,0.08); }
.btn-mode[data-mode="bypass"]:hover  { background: rgba(248,113,113,0.18); }

/* Agent mode popover — fully opaque, шире чтобы текст не резался */
.agent-mode-popover {
    position: fixed;
    z-index: 600;
    width: 420px;
    max-width: calc(100vw - 24px);
    background: #16182a;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.7), 0 0 0 1px rgba(255,255,255,0.03) inset;
    padding: 6px;
    animation: amp-fade-in 120ms ease-out;
}
:root[data-theme="cosmos"] .agent-mode-popover {
    background: #0d1027;
    border-color: rgba(125, 100, 255, 0.18);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.75), 0 0 24px rgba(125,100,255,0.12);
}
:root[data-theme="cosmos"] .slash-cmd-menu {
    background: #0d1027;
    border-color: rgba(125, 100, 255, 0.18);
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.7), 0 0 24px rgba(125,100,255,0.1);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}
body.light-theme .agent-mode-popover { background: #ffffff; border-color: rgba(0,0,0,0.08); box-shadow: 0 24px 64px rgba(0,0,0,0.15); }
@keyframes amp-fade-in {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}
.agent-mode-popover .amp-title {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    padding: 8px 10px 4px;
}
.agent-mode-popover .amp-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px 8px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    margin-bottom: 4px;
}
.amp-header-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
}
.amp-header-hint {
    font-size: 11px;
    color: var(--text-muted);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.amp-kbd {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 4px;
    padding: 1px 5px;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 10px;
    color: var(--text-secondary);
}
body.light-theme .agent-mode-popover .amp-header { border-bottom-color: rgba(0,0,0,0.06); }
body.light-theme .amp-kbd { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.1); }
.amp-item {
    display: flex;
    gap: 12px;
    padding: 11px 12px;
    border-radius: 10px;
    cursor: pointer;
    transition: background 120ms;
    align-items: flex-start;
    --amp-c: #a78bfa;
}
.amp-item:hover { background: rgba(255,255,255,0.04); }
/* Per-mode fallback colors (без color-mix, чтобы работало везде) */
.amp-item[data-mode="ask"]       { --amp-c: #a78bfa; --amp-bg: rgba(167,139,250,0.10); --amp-bg-active: rgba(167,139,250,0.14); }
.amp-item[data-mode="auto-edit"] { --amp-c: #fbbf24; --amp-bg: rgba(251,191,36,0.10);  --amp-bg-active: rgba(251,191,36,0.14); }
.amp-item[data-mode="plan"]      { --amp-c: #60a5fa; --amp-bg: rgba(96,165,250,0.10);  --amp-bg-active: rgba(96,165,250,0.14); }
.amp-item[data-mode="auto"]      { --amp-c: #4ade80; --amp-bg: rgba(74,222,128,0.10);  --amp-bg-active: rgba(74,222,128,0.14); }
.amp-item[data-mode="bypass"]    { --amp-c: #f87171; --amp-bg: rgba(248,113,113,0.10); --amp-bg-active: rgba(248,113,113,0.14); }
.amp-item.amp-active { background: var(--amp-bg-active, rgba(115,100,245,0.14)); }
.amp-item.amp-active .amp-name { color: var(--amp-c); }
.amp-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--amp-bg, rgba(167,139,250,0.12));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--amp-c);
    margin-top: 1px;
}
.amp-icon svg { width: 22px; height: 22px; display: block; }
.amp-body {
    flex: 1;
    min-width: 0;
    /* Главный фикс: тексту нужно min-width:0 чтобы он не выпадал из flex'а */
}
.amp-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    line-height: 1.3;
    margin: 2px 0 4px;
    /* НЕ wrap — это полностраничные модальные пункты, должны быть в одну строку */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.amp-desc {
    font-size: 12px;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.5;
    /* Описание МОЖЕТ переноситься — это нормально */
    white-space: normal;
    word-break: normal;
    overflow-wrap: break-word;
    /* Ограничиваем 2 строками, дальше — троеточие */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.amp-check { color: var(--amp-c); width: 20px; height: 20px; flex-shrink: 0; align-self: center; opacity: 0; margin-left: 4px; }
.amp-item.amp-active .amp-check { opacity: 1; }
body.light-theme .amp-item:hover { background: rgba(0,0,0,0.04); }

.btn-send.active {
    color: var(--primary);
}

.btn-stop {
    background: none;
    border: none;
    color: #f87171;
    cursor: pointer;
    padding: 6px;
    border-radius: 6px;
    transition: var(--transition);
    flex-shrink: 0;
    animation: pulse-stop 1.5s infinite;
}

.btn-stop:hover {
    background: rgba(248, 113, 113, 0.1);
}

@keyframes pulse-stop {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

.chat-input-hint {
    font-size: 11px;
    color: var(--text-muted);
    text-align: center;
    margin-top: 6px;
}

/* Attachments preview */
.chat-input-attachments {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding: 8px 0;
}

.attachment-preview {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    font-size: 12px;
    color: var(--text-secondary);
}

.attachment-preview .attachment-remove {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 0;
    font-size: 14px;
}

/* ── Global File Viewer ── */
#gfv-panel {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    border-bottom: 2px solid var(--border);
    z-index: 50;
    background: var(--bg-card, #13132b);
}

.gfv-tabbar {
    display: flex;
    align-items: stretch;
    background: var(--bg-card, #13132b);
    border-bottom: 1px solid var(--border);
    min-height: 36px;
    user-select: none;
}

.gfv-tabbar.drop-highlight {
    background: rgba(99, 102, 241, 0.12);
    outline: 2px dashed var(--primary, #6366f1);
    outline-offset: -2px;
}

.gfv-tabs-scroll {
    display: flex;
    flex: 1;
    overflow-x: auto;
    scrollbar-width: none;
    gap: 0;
}
.gfv-tabs-scroll::-webkit-scrollbar { display: none; }

.gfv-tab {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    cursor: pointer;
    font-size: 12px;
    color: var(--text-muted);
    white-space: nowrap;
    border-bottom: 2px solid transparent;
    border-right: 1px solid var(--border);
    transition: all 0.15s;
    flex-shrink: 0;
}
.gfv-tab:hover {
    background: var(--bg-hover, rgba(255,255,255,0.04));
    color: var(--text);
}
.gfv-tab.active {
    color: var(--text);
    border-bottom-color: var(--primary, #6366f1);
    background: var(--bg, #0d0d1a);
}
.gfv-tab.dragging { opacity: 0.4; }
.gfv-tab.drag-target { border-left: 2px solid var(--primary, #6366f1); }

.gfv-tab-icon { opacity: 0.6; font-size: 14px; }
.gfv-tab-name { max-width: 140px; overflow: hidden; text-overflow: ellipsis; }
.gfv-tab-close {
    background: none; border: none; color: var(--text-muted); cursor: pointer;
    padding: 0 0 0 4px; font-size: 14px; line-height: 1; opacity: 0;
    transition: opacity 0.15s;
}
.gfv-tab:hover .gfv-tab-close { opacity: 0.6; }
.gfv-tab-close:hover { opacity: 1 !important; color: var(--text); }

.gfv-controls {
    display: flex;
    align-items: center;
    gap: 2px;
    padding: 0 6px;
    flex-shrink: 0;
    border-left: 1px solid var(--border);
}
.gfv-btn {
    background: none; border: none; color: var(--text-muted); cursor: pointer;
    padding: 4px 6px; font-size: 14px; border-radius: 4px;
    transition: all 0.15s;
}
.gfv-btn:hover { color: var(--text); background: var(--bg-hover); }

.gfv-viewer-code {
    overflow: auto;
    background: var(--bg, #0d0d1a);
}
.gfv-viewer-code pre {
    margin: 0;
    padding: 12px 16px;
    font-size: 13px;
    line-height: 1.6;
    color: var(--text);
    font-family: 'Fira Code', 'JetBrains Mono', Consolas, monospace;
    height: 100%;
    box-sizing: border-box;
}
.gfv-viewer-code code { background: none; }

.gfv-viewer-img {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    background: var(--bg, #0d0d1a);
    overflow: auto;
}
.gfv-viewer-img img {
    max-width: 100%;
    max-height: 100%;
    border-radius: 8px;
    object-fit: contain;
}

.gfv-resize-handle {
    height: 4px;
    cursor: ns-resize;
    background: var(--border);
    transition: background 0.2s;
    flex-shrink: 0;
}
.gfv-resize-handle:hover {
    background: var(--primary, #6366f1);
}

/* ── Embed Mode (for split-view iframe / floating window) ──
   В embed-режиме полностью прячем сайдбар, лого и ВСЕ кнопки тулбара —
   управление едиными кнопками идёт из main-чата через postMessage.
   Остаётся только заголовок чата + чип «модель/память». */
/* В embed-чате (плавающее окно) скрываем только глобальный chrome (sidebar, лого, auth-screen)
   и кнопки которые завязаны на главный workspace (file-manager, queue, share, экспорт-HTML).
   Локальные для каждого чата кнопки — тема, язык, модель, поиск, память, экспорт-MD —
   ОСТАЮТСЯ, чтобы юзер мог управлять каждым окном независимо. */
.embed-mode .sidebar,
.embed-mode .sidebar-open-btn,
.embed-mode .chat-topbar-logo,
.embed-mode #auth-screen,
.embed-mode #export-chat-btn,
.embed-mode #btn-share-chat,
.embed-mode #btn-filemanager,
.embed-mode #btn-queue {
    display: none !important;
}
/* Заголовок и модель — сохраняются */
.embed-mode .chat-topbar-title { display: block !important; }
.embed-mode .chat-topbar-model { display: inline-flex !important; }
/* Топбар-кнопки в embed — компактнее (меньше padding, меньше gap), чтобы
   уместились в узком плавающем окне без переноса */
.embed-mode .topbar-controls {
    gap: 4px !important;
}
.embed-mode .topbar-controls .topbar-btn {
    padding: 4px !important;
    width: 28px !important;
    height: 28px !important;
}
.embed-mode .topbar-controls .topbar-btn svg {
    width: 14px !important;
    height: 14px !important;
}
/* Чипы памяти и Top-4 — скрываем в embed чтобы не загромождать узкий topbar */
.embed-mode .resource-chips { display: none !important; }
/* В embed-режиме main = вся высота МИНУС chat-topbar. Это лечит «срезанный чат» — раньше
   chat-main принудительно ставился в 100vh, поэтому суммарно topbar(40)+main(100vh)
   уходило за нижний край окна. */
.embed-mode .chat-main {
    height: 100%;
    min-height: 0;
    flex: 1 1 auto;
    overflow: hidden;
}
.embed-mode .chat-screen { flex-direction: column; height: 100vh; height: 100dvh; }
.embed-mode .chat-topbar {
    background: var(--bg-card) !important;
    border-bottom: 1px solid var(--border) !important;
    -webkit-app-region: drag;          /* для Electron-like — игнорируется в браузере */
    cursor: grab;
    user-select: none;
    flex-shrink: 0;
}
.embed-mode .chat-topbar:active { cursor: grabbing; }
.embed-mode .chat-topbar > * {
    -webkit-app-region: no-drag;
}
/* Кнопки управления окном (min/max/close) — справа в embed-topbar */
.embed-mode .fwin-embed-controls {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    margin-left: 6px;
    -webkit-app-region: no-drag;
}
.embed-mode .fwin-embed-btn {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    width: 32px;
    height: 28px;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.14s ease, color 0.14s ease;
    padding: 0;
}
.embed-mode .fwin-embed-btn:hover {
    background: rgba(255,255,255,0.10);
    color: var(--text);
}
.embed-mode .fwin-embed-btn:active {
    background: rgba(255,255,255,0.14);
    transform: scale(0.96);
}
.embed-mode .fwin-embed-btn.close-btn:hover {
    background: #e81123;
    color: #fff;
}
.embed-mode .fwin-embed-btn.close-btn:active {
    background: #c50f1f;
    color: #fff;
}
body.light-theme.embed-mode .fwin-embed-btn:hover { background: rgba(15,23,42,0.08); }

/* Скрываем .fwin-head когда окно содержит чат-iframe — он сам показывает свою шапку */
.fwin-chat-window > .fwin-head {
    display: none !important;
}
.fwin-chat-window > .fwin-body {
    /* без шапки сверху — body начинается прямо у границы окна */
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
    overflow: hidden;
}
.fwin-chat-window.fwin-snapped-right > .fwin-body { border-top-right-radius: 0; }
/* Embed: всё что подцеплено к toggleSplitView/toggleDualChat — скрыть, чтобы
   не было рекурсивных split'ов */
.embed-mode [onclick*="toggleSplitView"],
.embed-mode [onclick*="toggleDualChat"] {
    display: none !important;
}
/* Заголовок embed-чата: компактный, центрируется */
.embed-mode .chat-topbar-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
    opacity: 0.9;
    flex: 1;
    text-align: left;
    margin-left: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ── Split Chat Input (mirrors main chat) ── */
#split-chat-input {
    flex: 1;
    background: none;
    border: none;
    color: var(--text);
    font-size: 14px;
    font-family: inherit;
    resize: none;
    outline: none;
    max-height: 200px;
    line-height: 1.5;
    padding: 4px 0;
}
#split-chat-input::placeholder {
    color: var(--text-muted);
}

#dual-chat-pane .chat-input-wrapper {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 8px 12px;
    transition: var(--transition);
}
#dual-chat-pane .chat-input-wrapper:focus-within {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(115, 100, 245, 0.1);
}

#split-file-tabs::-webkit-scrollbar { display: none; }

#dual-chat-pane.drag-over {
    outline: 2px dashed var(--primary, #6366f1);
    outline-offset: -4px;
    background: rgba(99, 102, 241, 0.03);
}

/* ══════════════════════════════════════
   Responsive
   ══════════════════════════════════════ */

/* ── Model Selector ── */
.model-selector {
    margin-bottom: 12px;
    position: relative;
}

.model-selector-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.model-advanced-btn {
    appearance: none; background: transparent; border: none;
    color: var(--text-muted); cursor: pointer; padding: 2px 4px;
    border-radius: 5px; display: inline-flex; align-items: center;
    margin-left: auto;
    transition: background .15s, color .15s;
}
.model-advanced-btn:hover {
    background: rgba(115,100,245,.15); color: #b9aeff;
}

.model-selector-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 10px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-size: 12px;
    font-family: inherit;
    cursor: pointer;
    transition: var(--transition);
}

.model-selector-btn:hover {
    border-color: var(--primary);
}

.model-selector-icon { font-size: 14px; }
.model-selector-name { flex: 1; text-align: left; font-weight: 600; }
.model-selector-cost {
    font-size: 10px;
    color: var(--text-muted);
    font-family: var(--font-code);
    background: rgba(115, 100, 245, 0.1);
    padding: 1px 6px;
    border-radius: 4px;
}

.model-dropdown {
    display: none;
    position: fixed;
    left: 12px;
    width: calc(var(--sidebar-w) - 24px);
    bottom: auto;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 6px;
    z-index: 9100;
    box-shadow: 0 -8px 32px rgba(0,0,0,0.4);
    max-height: 320px;
    overflow-y: auto;
}

.model-dropdown.show { display: block; }

.model-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 6px;
    cursor: pointer;
    transition: var(--transition);
    border: none;
    background: none;
    width: 100%;
    font-family: inherit;
    text-align: left;
    color: var(--text);
}

.model-option:hover { background: var(--bg-hover); }
.model-option.active { background: rgba(115, 100, 245, 0.12); }
.model-option.model-option-new {
    background:
        linear-gradient(135deg, rgba(217, 119, 87, 0.10), rgba(124, 58, 237, 0.08));
    box-shadow: inset 0 0 0 1px rgba(217, 119, 87, 0.18);
}
.model-option.model-option-new:hover {
    background:
        linear-gradient(135deg, rgba(217, 119, 87, 0.16), rgba(124, 58, 237, 0.12));
}

.model-option.locked {
    opacity: 0.4;
    cursor: not-allowed;
}

.model-option-icon {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.035));
    border: 1px solid rgba(255, 255, 255, 0.075);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
    padding: 0;
    overflow: hidden;
    transition: background 0.2s, border-color 0.2s, transform 0.2s;
}
.model-option-icon svg { width: 100%; height: 100%; }
.model-option:hover .model-option-icon { background: rgba(255, 255, 255, 0.1); border-color: rgba(255, 255, 255, 0.14); transform: scale(1.05); }
.model-option.active .model-option-icon { background: rgba(124, 77, 255, 0.18); border-color: rgba(168, 85, 247, 0.36); }
#model-icon { width: 20px; height: 20px; display: inline-flex; align-items: center; justify-content: center; }
#model-icon svg { width: 100%; height: 100%; }
.brand-ico {
    width: 100%;
    height: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.brand-ico-tile {
    border-radius: inherit;
    overflow: hidden;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.16),
        inset 0 -10px 18px rgba(0, 0, 0, 0.16);
}
.brand-ico svg,
.brand-ico-img {
    display: block;
    max-width: 76%;
    max-height: 76%;
    object-fit: contain;
}
.model-option-icon .brand-ico,
#model-icon .brand-ico,
.mm-item-ico .brand-ico,
.mm-detail-ico .brand-ico,
.mm-trial-card-ico .brand-ico,
.mm-col-item-ico .brand-ico,
.retry-model-icon .brand-ico {
    width: 100%;
    height: 100%;
}
.model-option-icon .brand-ico-img,
#model-icon .brand-ico-img,
.mm-item-ico .brand-ico-img,
.mm-detail-ico .brand-ico-img,
.mm-trial-card-ico .brand-ico-img,
.mm-col-item-ico .brand-ico-img,
.retry-model-icon .brand-ico-img {
    width: 74% !important;
    height: 74% !important;
}
.model-option-lock { display: inline-flex; align-items: center; justify-content: center; color: var(--text-muted); }

.model-option-info { flex: 1; min-width: 0; }

.model-option-name {
    font-size: 12px;
    font-weight: 600;
    display: block;
}

.model-option-desc {
    font-size: 10px;
    color: var(--text-muted);
    display: block;
}

.model-option-cost {
    font-size: 10px;
    color: var(--text-muted);
    font-family: var(--font-code);
    flex-shrink: 0;
}

.model-option-lock {
    font-size: 12px;
    flex-shrink: 0;
}

/* ── Cost Warning ── */
.cost-warning-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 70;
    backdrop-filter: blur(4px);
}

.cost-warning-box {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 28px;
    max-width: 420px;
    text-align: center;
    box-shadow: var(--shadow);
}

.cost-warning-icon { font-size: 36px; margin-bottom: 12px; }
.cost-warning-title { font-size: 16px; font-weight: 700; margin-bottom: 8px; }

.cost-warning-text {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.6;
    margin-bottom: 20px;
}

.cost-warning-actions {
    display: flex;
    gap: 10px;
    justify-content: center;
}

.cost-warning-actions .btn {
    padding: 8px 20px;
    font-size: 13px;
}

.btn-ghost {
    background: rgba(115, 100, 245, 0.08);
    color: var(--text);
    border: 1px solid var(--border);
}

.btn-ghost:hover {
    background: rgba(115, 100, 245, 0.15);
    border-color: var(--primary);
}

/* ── Suggestion chips: цветные SVG-иконки + glow на hover ── */
.welcome-suggestions {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px;
    justify-content: center;
    max-width: 760px;
    margin: 0 auto;
}

.suggestion-chip {
    --chip-accent: #7364f5;
    padding: 12px 16px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
    border: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
    display: flex;
    align-items: center;
    gap: 10px;
    text-align: left;
    position: relative;
    overflow: hidden;
}

.suggestion-chip::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0; width: 3px;
    background: var(--chip-accent);
    opacity: 0.6;
    transition: opacity 0.18s ease, width 0.18s ease;
}

.chip-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--chip-accent) 15%, transparent);
    flex-shrink: 0;
}
.chip-icon svg {
    width: 18px;
    height: 18px;
    color: var(--chip-accent);
}
.chip-text {
    flex: 1;
    line-height: 1.3;
}

.suggestion-chip:hover {
    transform: translateY(-2px);
    border-color: var(--chip-accent);
    background: color-mix(in srgb, var(--chip-accent) 10%, rgba(255,255,255,0.02));
    color: var(--text);
    box-shadow: 0 8px 24px color-mix(in srgb, var(--chip-accent) 25%, transparent);
}
.suggestion-chip:hover::before { opacity: 1; width: 4px; }
.suggestion-chip:active { transform: translateY(0); }

/* ── Template cards (welcome screen) ── */
.template-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    max-width: 560px;
    width: 100%;
}

@media (min-width: 768px) {
    .template-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.template-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 10px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: 12px;
    cursor: pointer;
    font-family: inherit;
    transition: var(--transition);
}

.template-card:hover {
    background: rgba(115, 100, 245, 0.1);
    color: var(--text);
    border-color: rgba(115, 100, 245, 0.4);
    transform: translateY(-2px);
}

.template-icon { font-size: 24px; }
.template-title { font-weight: 500; line-height: 1.3; text-align: center; }

/* Drag-and-drop overlay */
.drag-over {
    outline: 2px dashed var(--primary);
    outline-offset: -8px;
    background: rgba(115, 100, 245, 0.03);
}

/* ─── Mobile drawer overlay (хорошо видим backdrop при открытом меню) ─── */
.sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(5, 5, 12, 0.62);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    z-index: 49;
    opacity: 0;
    transition: opacity 0.22s ease;
    pointer-events: none;
}
.sidebar-mobile-close {
    display: none;
    background: transparent;
    border: none;
    color: var(--text);
    padding: 6px;
    cursor: pointer;
    border-radius: 8px;
    transition: background 0.15s;
}
.sidebar-mobile-close:hover { background: rgba(255,255,255,0.08); }

@media (max-width: 768px) {
    /* Sidebar становится off-canvas drawer'ом */
    .sidebar {
        position: fixed;
        left: 0;
        top: 0;
        height: 100dvh;
        width: min(88vw, 320px);
        min-width: 0;
        max-width: 100vw;
        z-index: 50;
        transform: translateX(0);
        transition: transform 0.25s ease;
        box-shadow: 4px 0 24px rgba(0,0,0,0.35);
    }

    .sidebar.collapsed {
        transform: translateX(-105%);
        box-shadow: none;
    }

    /* Когда drawer открыт — показываем оверлей */
    body.sidebar-open .sidebar-overlay {
        display: block;
        opacity: 1;
        pointer-events: auto;
    }

    /* Контент основного чата всегда занимает 100% ширины — sidebar плавает над ним */
    .chat-main {
        margin-left: 0 !important;
        width: 100%;
    }

    /* На мобиле скрываем строко-стрелочный toggle, показываем большой X */
    .sidebar-toggle { display: none !important; }
    .sidebar-mobile-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 36px;
        height: 36px;
        margin-left: auto;
    }

    /* Гамбургер всегда виден на mobile — он открывает drawer */
    .sidebar-open-btn {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
    }

    /* Запрет скролла body когда drawer открыт */
    body.sidebar-open {
        overflow: hidden;
    }

    .chat-messages {
        padding: 12px;
    }

    .message {
        padding: 4px 0;
    }

    .message-user .message-bubble {
        max-width: 85%;
    }

    .message-avatar {
        width: 28px;
        height: 28px;
        font-size: 11px;
    }

    .chat-input-area {
        padding: 8px 12px 12px;
    }

    .topbar-controls {
        gap: 4px;
    }
    .topbar-btn {
        min-width: 40px;
        min-height: 40px;
        padding: 6px;
        font-size: 16px;
    }

    .model-dropdown {
        left: 8px;
        right: 8px;
        max-height: 60vh;
    }

    .template-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .suggestion-chips {
        flex-wrap: wrap;
    }
    .suggestion-chip {
        font-size: 12px;
        padding: 8px 14px;
    }

    .message-content pre {
        font-size: 12px;
        overflow-x: auto;
        overflow-y: visible;
    }
    .code-actions button {
        min-width: 44px;
        min-height: 44px;
    }

    /* Disable heavy animations on mobile for performance */
    .message, .message-bubble, .message-body {
        animation: none !important;
    }
    .typing-dot {
        animation-duration: 2s !important;
    }
    * {
        transition-duration: 0.05s !important;
    }
    .chat-topbar, .sidebar, .chat-input-wrapper {
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }
    /* Large code blocks: contain layout */
    .message-content pre code {
        contain: content;
    }
    /* Limit file-saved-block preview height */
    .file-code-preview {
        max-height: 300px !important;
        overflow: auto;
    }
}

@media (max-width: 480px) {
    /* Топбар — НЕ уменьшаем touch-targets ниже 44px */
    .chat-topbar-title {
        max-width: 140px;
        font-size: 13px;
    }
    .topbar-btn {
        min-width: 44px;
        min-height: 44px;
        padding: 4px;
        font-size: 15px;
    }
    .topbar-controls { gap: 2px; }

    /* Сообщения */
    .message-user .message-bubble { max-width: 92%; }
    .chat-messages { padding-bottom: 80px; font-size: 14px; }
    .message-content { font-size: 14px; }
    .message-bubble { padding: 9px 12px; }

    /* Код в сообщениях */
    .message-content pre { font-size: 11.5px; }
    .message-content pre code { max-width: 100%; }

    /* Suggestion chips — крупнее для tap */
    .suggestion-chip {
        padding: 10px 16px;
        font-size: 12px;
        min-height: 40px;
        display: flex;
        align-items: center;
    }

    /* Dropdown ограничиваем высоту */
    .model-dropdown { max-height: 50vh; }
    .slash-cmd-menu { max-height: 260px; }

    /* Шаблоны — 1 колонка */
    .template-grid { grid-template-columns: 1fr !important; }

    /* Auth */
    .auth-container { padding: 20px 16px; }
    .auth-logo h1 { font-size: 18px; }
    .auth-subtitle { font-size: 12px; }
    .sms-code-input { letter-spacing: 4px; font-size: 20px !important; }

    /* Link account modal */
    .link-account-box { padding: 20px 14px; }
    .link-account-title { font-size: 17px; }
    .link-account-desc { font-size: 13px; margin-bottom: 16px; }
    .link-step { padding: 10px 12px; gap: 10px; }

    /* Agreement overlay */
    .agreement-box { padding: 24px 16px 20px; }
    .agreement-title { font-size: 17px; }
    .agreement-text, .agreement-list li { font-size: 13px; }

    /* Input area */
    #chat-input, .chat-input { font-size: 16px !important; }
    .chat-input-wrapper { padding: 6px 8px; gap: 6px; }

    /* Token bar */
    .token-bar, .proj-mem-bar { padding: 8px 10px !important; font-size: 11px; }
}

/* ══════════════════════════════════════════════════════════════════
   ── MOBILE UI: полная переработка для удобства на телефоне ──
   Цели: читаемость, touch-targets ≥44px, безопасные зоны iPhone X+,
   landscape-режим со скроллом, правильный порядок layout.
   ══════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    /* iOS не зумит input если font-size ≥ 16px */
    input, textarea, select { font-size: 16px !important; }

    /* Глобальный safe-area для iPhone notch */
    .chat-screen {
        padding-bottom: env(safe-area-inset-bottom);
    }
    .chat-topbar {
        padding-top: max(10px, env(safe-area-inset-top));
        padding-left: max(12px, env(safe-area-inset-left));
        padding-right: max(12px, env(safe-area-inset-right));
        position: sticky;
        top: 0;
        z-index: 120;
        background: rgba(15, 15, 30, 0.95);
        backdrop-filter: blur(8px);
        gap: 6px;
        min-width: 0;
        overflow: visible;
    }
    .chat-input-area {
        padding-bottom: max(10px, env(safe-area-inset-bottom));
        padding-left: max(10px, env(safe-area-inset-left));
        padding-right: max(10px, env(safe-area-inset-right));
    }

    .chat-topbar > [data-style*="flex:1"] {
        display: none !important;
    }
    .chat-topbar-logo {
        flex: 0 0 auto;
        gap: 0;
    }
    .chat-topbar-brand,
    .chat-topbar-title,
    .resource-chips {
        display: none !important;
    }
    .chat-topbar-model {
        flex: 0 1 auto;
        min-width: 0;
        max-width: 112px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        padding: 7px 9px;
        font-size: 10.5px;
    }
    .topbar-controls {
        margin-left: auto;
        min-width: 0;
        flex: 0 1 auto;
        gap: 3px;
        overflow: visible;
    }
    .topbar-controls .topbar-btn,
    .topbar-lang-btn {
        width: 38px;
        height: 38px;
        min-width: 38px;
        min-height: 38px;
        padding: 0;
        border-radius: 10px;
        flex: 0 0 auto;
    }
    .topbar-lang-btn {
        justify-content: center;
        gap: 0;
    }
    .topbar-lang-btn .lang-code,
    .topbar-lang-btn .lang-chev {
        display: none;
    }
    .topbar-lang-dropdown {
        position: fixed;
        top: calc(max(50px, env(safe-area-inset-top) + 44px));
        left: 12px;
        right: 12px;
        width: auto;
        min-width: 0;
        max-width: none;
    }

    .chat-welcome {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        padding-left: 14px;
        padding-right: 14px;
        overflow-x: hidden;
    }
    .chat-welcome h2,
    .chat-welcome p {
        max-width: 100%;
        overflow-wrap: anywhere;
    }
    .agent-switcher {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        width: min(100%, 440px);
        max-width: calc(100vw - 28px);
        gap: 5px;
        padding: 5px;
        overflow: hidden;
    }
    .agent-pill {
        width: 100%;
        min-width: 0;
        padding: 10px 9px;
        gap: 8px;
    }
    .agent-pill-text {
        min-width: 0;
    }
    .agent-pill-name,
    .agent-pill-sub {
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .guest-cta {
        flex-wrap: wrap;
        align-items: stretch;
        gap: 10px;
        padding: 12px;
    }
    .guest-cta-text {
        flex-basis: 100%;
    }
    .guest-cta .btn {
        width: 100%;
        justify-content: center;
        min-height: 44px;
    }

    /* Touch targets — минимум 44x44 */
    .topbar-btn,
    .sidebar-toggle,
    .sidebar-mobile-close,
    .sidebar-open-btn,
    .btn-new-chat,
    .auth-btn,
    .send-btn,
    .chat-list-item .item-actions button {
        min-width: 44px;
        min-height: 44px;
    }

    /* Чтобы кнопки не были «сжатыми» — отступы внутри */
    .auth-btn { padding: 14px 18px; font-size: 15px; height: auto; }
    .auth-btn-tg-oauth { height: 50px; }
    .btn-new-chat {
        padding: 12px 14px;
        font-size: 14px;
        gap: 8px;
    }

    /* Sidebar шире для удобства, но не во весь экран */
    .sidebar {
        width: min(86vw, 340px);
        height: 100dvh;
        padding-bottom: env(safe-area-inset-bottom);
    }

    /* Кнопки в sidebar — нормальные размеры */
    .sidebar-section,
    .sidebar-bottom {
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
    }
    .chat-list-item {
        padding: 12px 14px;
        font-size: 14px;
        line-height: 1.4;
        min-height: 48px;
    }
    .chat-list-item .item-title {
        font-size: 14px;
        line-height: 1.35;
    }
    .sub-sidebar-btn {
        padding: 12px 14px;
        font-size: 14px;
        min-height: 48px;
    }
    .sidebar-user {
        padding: 10px 12px;
        min-height: 56px;
    }
    .user-name { font-size: 14px; }
    .setting-toggle {
        padding: 10px 6px;
        font-size: 14px;
    }
    .model-selector-btn {
        padding: 12px 14px;
        font-size: 14px;
        min-height: 48px;
    }

    /* Чат-сообщения — нормальный размер шрифта и padding */
    .chat-messages {
        font-size: 15px;
        line-height: 1.55;
        padding: 14px 12px 100px; /* отступ снизу под input */
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
    }
    .message-content {
        font-size: 15px;
        line-height: 1.55;
    }
    .message-bubble {
        padding: 10px 14px;
        border-radius: 14px;
    }
    .message-user .message-bubble { max-width: 88%; }
    .message-assistant .message-bubble { max-width: 95%; }

    /* Топбар — кнопки и текст */
    .chat-topbar-title {
        font-size: 14px;
        font-weight: 600;
    }
    .topbar-btn {
        padding: 8px;
        font-size: 18px;
    }
    .topbar-btn svg { width: 20px; height: 20px; }

    /* Input area — крупная и удобная */
    .chat-input-wrapper {
        padding: 8px 10px;
        gap: 8px;
        border-radius: 16px;
        min-width: 0;
    }
    #chat-input,
    .chat-input {
        font-size: 16px !important;
        line-height: 1.4;
        padding: 10px 4px;
        min-height: 24px;
        max-height: 30vh;
    }
    .send-btn {
        min-width: 44px;
        min-height: 44px;
        border-radius: 12px;
    }
    .chat-input-wrapper > .btn-attach,
    .chat-input-wrapper > .btn-send,
    .chat-input-wrapper > .btn-stop,
    .chat-input-wrapper > .btn-voice,
    .chat-input-wrapper > .btn-filesystem,
    .chat-input-wrapper > .btn-slash,
    .chat-input-wrapper > .context-meter,
    .chat-input-wrapper > #enhance-btn {
        width: 38px;
        height: 38px;
    }
    .chat-input-wrapper > .btn-mode {
        width: 38px;
        height: 38px;
        padding: 0;
        justify-content: center;
    }
    .btn-mode-chev {
        display: none;
    }

    /* Token bar и memory bar — компактные но читаемые */
    .token-bar, .proj-mem-bar {
        padding: 10px 12px !important;
        font-size: 12px;
    }
    .token-bar-value, #proj-mem-value { font-size: 12px; }

    /* Sidebar header — выравнивание */
    .sidebar-header {
        padding: 14px 14px;
        gap: 10px;
    }
    .sidebar-logo span { font-size: 16px; font-weight: 700; }

    /* Подавляем resize cursor / drag-divider на мобиле — он там не нужен */
    .sidebar-divider { display: none; }

    /* Сделаем чтобы крупные модалки скроллились внутри */
    .modal,
    .pp-modal,
    .link-account-box,
    .auth-container {
        max-height: 92dvh;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    /* Auth screen на мобиле — больше воздуха и видимости */
    .auth-container {
        max-width: 100%;
        padding: 24px 18px;
    }
    .auth-logo h1 { font-size: 22px; }
    .auth-subtitle { font-size: 13px; }
    .auth-divider span { font-size: 12px; }

    /* Skeleton для горизонтальной ориентации */
    .auth-screen { align-items: flex-start; padding-top: 32px; }
}

/* ── Landscape: чат и auth должны прокручиваться вниз ── */
@media (max-width: 900px) and (orientation: landscape) {
    .auth-screen {
        padding-top: 16px;
        padding-bottom: 16px;
        align-items: flex-start;
    }
    .auth-container {
        padding: 16px 18px;
        max-width: 480px;
    }
    .auth-logo { margin-bottom: 6px; }
    .auth-logo h1 { font-size: 18px; }
    /* Убираем большой логотип в landscape — экономим место */
    .auth-logo img { width: 36px; height: 36px; }
    .auth-btn { padding: 10px 16px; font-size: 14px; }
    .auth-btn-tg-oauth { height: 44px; }

    /* Чтобы chat-messages и input не «зарезались» в горизонтали */
    .chat-screen { height: 100dvh; }
    .chat-main { height: 100dvh; }
    .chat-messages { padding-bottom: 80px; font-size: 14px; }
    .chat-topbar {
        padding-top: 4px;
        padding-bottom: 4px;
        min-height: 44px;
    }
    .topbar-btn { min-width: 40px; min-height: 40px; }
    .message-content pre { font-size: 11.5px; }
}

/* Очень узкие устройства (iPhone SE, 375px и ниже) */
@media (max-width: 380px) {
    .auth-container { padding: 16px 12px; }
    .auth-logo h1 { font-size: 16px; }
    .auth-logo img { width: 40px; height: 40px; }
    .sidebar { width: 93vw; }
    .chat-list-item { padding: 10px 10px; font-size: 13px; min-height: 44px; }
    .chat-topbar-title { max-width: 110px; font-size: 12px; }
    .topbar-btn { min-width: 40px; min-height: 40px; }
    .topbar-controls { gap: 1px; }
    .model-selector-btn { font-size: 13px; padding: 10px 12px; }
    .message-content pre { font-size: 11px; }
    .chat-messages { padding: 10px 8px 76px; font-size: 13px; }
    .message-bubble { padding: 8px 10px; }
    .link-account-box { padding: 16px 12px; border-radius: 16px; }
    .agreement-box { padding: 20px 12px 16px; border-radius: 16px; }
    .suggestion-chip { padding: 8px 12px; font-size: 11.5px; }
}

@media (max-width: 520px) {
    .topbar-controls .topbar-btn[data-act="exportChat"],
    .topbar-controls .topbar-btn[data-act="exportChatMarkdown"],
    .topbar-controls .topbar-btn[data-act="showShortcuts"],
    .topbar-controls .topbar-btn[data-act="searchMessages"],
    .topbar-controls .topbar-btn[title*="Экспорт"],
    .topbar-controls .topbar-btn[aria-label*="Экспорт"],
    .topbar-controls .topbar-btn[title*="Горячие"],
    .topbar-controls .topbar-btn[aria-label*="Горячие"],
    .topbar-controls .topbar-btn[title*="Поиск"],
    .topbar-controls .topbar-btn[aria-label*="Поиск"] {
        display: none !important;
    }
    .chat-topbar-model {
        max-width: 92px;
    }
    .chat-welcome {
        padding-top: 28px;
    }
    .agent-pill-ico {
        width: 28px;
        height: 28px;
        border-radius: 9px;
    }
    .agent-pill-name {
        font-size: 12.5px;
    }
    .agent-pill-sub {
        font-size: 9px;
        letter-spacing: 0.2px;
    }
}

@media (max-width: 430px) {
    .chat-topbar {
        padding-left: 8px;
        padding-right: 8px;
    }
    .sidebar-open-btn,
    .topbar-controls .topbar-btn,
    .topbar-lang-btn {
        width: 36px;
        height: 36px;
        min-width: 36px;
        min-height: 36px;
    }
    .chat-topbar-model {
        max-width: 72px;
        padding-left: 7px;
        padding-right: 7px;
    }
    .chat-input-wrapper {
        gap: 5px;
        padding: 7px;
    }
    .chat-input-wrapper > .btn-attach,
    .chat-input-wrapper > .btn-send,
    .chat-input-wrapper > .btn-stop,
    .chat-input-wrapper > .btn-voice,
    .chat-input-wrapper > .btn-filesystem,
    .chat-input-wrapper > .btn-slash,
    .chat-input-wrapper > .context-meter,
    .chat-input-wrapper > #enhance-btn,
    .chat-input-wrapper > .btn-mode {
        width: 36px;
        height: 36px;
    }
}

/* Reduce animations for users who prefer it */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation: none !important;
        transition-duration: 0.01ms !important;
    }
}

/* ══════════════════════════════════════
   Subscription Modal
   ══════════════════════════════════════ */

.modal {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.6);
    backdrop-filter: blur(4px);
}

.modal-content {
    position: relative;
    z-index: 2;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: var(--shadow);
}

/* Custom scrollbar */
.modal-content::-webkit-scrollbar { width: 6px; }
.modal-content::-webkit-scrollbar-track { background: transparent; }
.modal-content::-webkit-scrollbar-thumb {
    background: rgba(115, 100, 245, 0.3);
    border-radius: 3px;
}
.modal-content::-webkit-scrollbar-thumb:hover {
    background: rgba(115, 100, 245, 0.6);
}

.modal-wide { max-width: 520px; width: 90%; }

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px;
    border-bottom: 1px solid var(--border);
}

.modal-header h3 { font-size: 16px; font-weight: 700; }

.modal-close {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 24px;
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
    transition: var(--transition);
    min-width: 24px;
    min-height: 24px;
}

.modal-close:hover { color: var(--text); }

.modal-body { padding: 18px 22px; }

.modal-divider {
    height: 1px;
    background: var(--border);
    margin: 18px 0;
}

.modal-section-title {
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 10px;
}

.modal-input {
    width: 100%;
    padding: 8px 12px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    outline: none;
    margin-bottom: 8px;
    transition: var(--transition);
}

.modal-input:focus {
    border-color: var(--primary);
}

.modal-select {
    padding: 6px 10px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-size: 12px;
    font-family: inherit;
    outline: none;
}

/* ── Account Modal ── */
.acc-body { display: flex; flex-direction: column; gap: 14px; }
.acc-avatar-wrap { display: flex; justify-content: center; }
.acc-avatar {
    width: 64px; height: 64px; font-size: 28px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%; background: var(--gradient); color: #fff;
}
.acc-row { display: flex; gap: 10px; }
.acc-row .acc-field { flex: 1; }
.acc-field { display: flex; flex-direction: column; gap: 4px; }
.acc-field .modal-input { margin-bottom: 0; }
.acc-label { font-size: 11px; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.5px; }
.acc-inline { display: flex; gap: 8px; align-items: center; }
.acc-inline .modal-input { flex: 1; margin-bottom: 0; }
.acc-inline .btn { white-space: nowrap; padding: 6px 14px; font-size: 12px; }
.acc-hint { font-size: 11px; color: var(--text-secondary); margin-top: 4px; }
.acc-status-ok { font-size: 11px; color: #22c55e; white-space: nowrap; }
.acc-gh-login { font-size: 13px; font-weight: 500; }
.acc-unlink-btn { margin-left: auto; font-size: 11px; padding: 4px 12px; color: #f66 !important; }
.acc-logout-btn { color: #f66 !important; font-size: 13px; padding: 8px 16px; align-self: flex-start; }

/* Sub current info */
.sub-current {
    padding: 12px;
    background: rgba(115,100,245,0.08);
    border: 1px solid rgba(115,100,245,0.2);
    border-radius: 10px;
    font-size: 13px;
    line-height: 1.6;
}

/* ── Subscription countdown ── */
.sub-countdown-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    padding: 8px 10px;
    background: rgba(0, 206, 201, 0.08);
    border: 1px solid rgba(0, 206, 201, 0.25);
    border-radius: 8px;
    font-size: 12px;
}
.sub-countdown-label {
    color: var(--text-secondary);
    font-weight: 500;
}
.sub-countdown-value {
    font-family: 'JetBrains Mono', 'SF Mono', ui-monospace, Consolas, monospace;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.3px;
    color: var(--accent-light, #55efc4);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

/* Sub grid */
.sub-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-top: 16px;
}

.sub-card {
    padding: 14px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    cursor: pointer;
    transition: var(--transition);
    text-align: center;
}

.sub-card:hover { border-color: var(--border-light); }
.sub-card.active { border-color: var(--primary); background: rgba(115,100,245,0.08); }
.sub-card.current { opacity: 0.5; cursor: default; }

.sub-card-emoji { width: 32px; height: 32px; margin: 0 auto 4px; display: flex; align-items: center; justify-content: center; }
.sub-card-emoji svg { width: 100%; height: 100%; }
.sub-inline-ico { display: inline-flex; width: 16px; height: 16px; vertical-align: -3px; margin-right: 2px; }
.sub-inline-ico svg { width: 100%; height: 100%; }
.sub-card-name { font-size: 13px; font-weight: 700; margin: 4px 0; }
.sub-card-price { font-size: 11px; color: var(--text-muted); }
.sub-card-model { font-size: 10px; color: var(--text-muted); margin-top: 4px; }

/* Slider */
.sub-slider-section { margin-top: 20px; }

.sub-selected-name {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 12px;
    text-align: center;
}

/* 6-сегментный выбор периода (2026-05-12) */
.sub-period-segments {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 4px;
    padding: 4px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    margin-bottom: 14px;
}
.sub-period-seg {
    padding: 8px 0;
    background: transparent;
    border: none;
    border-radius: 7px;
    color: var(--text-secondary);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: background 140ms, color 140ms;
}
.sub-period-seg:hover { background: rgba(255, 255, 255, 0.05); color: var(--text); }
.sub-period-seg.sub-period-active {
    background: linear-gradient(135deg, #6c5ce7, #00cec9);
    color: #fff;
    font-weight: 600;
    box-shadow: 0 2px 10px rgba(108, 92, 231, 0.30);
}
.sub-savings {
    margin: 6px 0 14px;
    min-height: 18px;
    text-align: center;
    font-size: 12px;
    font-weight: 500;
}
.sub-save { color: #4ade80; }
.sub-burst { color: #fbbf24; }

body.light-theme .sub-period-segments { background: #f5f5fc; border-color: #e0e0eb; }
body.light-theme .sub-period-seg { color: #6b6b85; }
body.light-theme .sub-period-seg:hover { background: rgba(0, 0, 0, 0.04); color: #1a1a2e; }
body.light-theme .sub-save { color: #16a34a; }
body.light-theme .sub-burst { color: #d97706; }

.sub-slider-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 4px;
}

.sub-slider {
    flex: 1;
    -webkit-appearance: none;
    appearance: none;
    height: 6px;
    background: var(--border);
    border-radius: 3px;
    outline: none;
}

.sub-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    background: var(--primary);
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid var(--bg);
}
.sub-slider::-moz-range-thumb {
    width: 18px;
    height: 18px;
    background: var(--primary);
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid var(--bg);
}
.sub-slider::-moz-range-track {
    height: 6px;
    background: var(--border);
    border-radius: 3px;
}

/* ── Универсальная защита: любой input[type="range"] получает базовый стиль ── */
input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    height: 6px;
    background: var(--border);
    border-radius: 3px;
    outline: none;
    cursor: pointer;
}
input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    background: var(--primary);
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid var(--bg);
    transition: transform 0.12s ease;
}
input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.15); }
input[type="range"]::-moz-range-thumb {
    width: 16px;
    height: 16px;
    background: var(--primary);
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid var(--bg);
}
input[type="range"]::-moz-range-track {
    height: 6px;
    background: var(--border);
    border-radius: 3px;
}

.sub-days-label {
    font-size: 14px;
    font-weight: 700;
    min-width: 75px;
    text-align: right;
}

.sub-price-row {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 10px;
    margin: 14px 0;
}

.sub-price { font-size: 28px; font-weight: 800; letter-spacing: -1px; }
.sub-price-per-day { font-size: 12px; color: var(--text-muted); }
.sub-model-info { font-size: 12px; color: var(--text-secondary); text-align: center; margin-bottom: 14px; }

/* Gift tabs */
.gift-tabs {
    display: flex;
    gap: 6px;
    margin-bottom: 10px;
}

.gift-tab {
    padding: 5px 14px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-muted);
    font-family: inherit;
    font-size: 12px;
    cursor: pointer;
    transition: var(--transition);
}

.gift-tab.active {
    border-color: var(--primary);
    color: var(--primary-light);
}

.gift-sub-row {
    display: flex;
    gap: 6px;
    align-items: center;
    flex-wrap: wrap;
}

.gift-sub-row .modal-input {
    flex: 1;
    min-width: 100px;
    margin-bottom: 0;
}

.gift-sub-tier-btn {
    flex: 1;
    padding: 8px 6px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-secondary);
    font-family: inherit;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    text-align: center;
}

.gift-sub-tier-btn:hover {
    border-color: var(--border-light);
    color: var(--text);
}

.gift-sub-tier-btn.active {
    border-color: var(--primary);
    color: var(--primary-light);
    background: rgba(115, 100, 245, 0.1);
}

/* Sidebar sub button */
.sub-sidebar-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 0;
    background: none;
    border: none;
    color: var(--text);
    font-family: inherit;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    margin-bottom: 8px;
}

.sub-sidebar-btn:hover { color: var(--primary-light); }
.sub-arrow { margin-left: auto; color: var(--text-muted); font-size: 14px; }

/* ── Enhance prompt button ── */
.enhance-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: none;
    color: var(--text-muted);
    cursor: pointer;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.25s ease;
    position: relative;
}

.enhance-btn:hover {
    color: #ffc107;
    background: rgba(255, 193, 7, 0.1);
    transform: scale(1.1);
    animation: shimmer-enhance 1.5s ease-in-out infinite;
}

@keyframes shimmer-enhance {
    0%, 100% { color: #ffc107; filter: brightness(1); text-shadow: 0 0 0 transparent; }
    25% { color: #ffe082; filter: brightness(1.3); text-shadow: 0 0 8px rgba(255,193,7,0.5); }
    50% { color: #ffab00; filter: brightness(0.9); text-shadow: 0 0 3px rgba(255,193,7,0.2); }
    75% { color: #ffd54f; filter: brightness(1.2); text-shadow: 0 0 12px rgba(255,193,7,0.6); }
}

.enhance-btn.loading {
    color: #ffc107;
    animation: spin-enhance 0.8s linear infinite;
}

.enhance-btn.done {
    color: #00e676;
}

@keyframes spin-enhance {
    0% { transform: rotate(0deg) scale(1.1); }
    100% { transform: rotate(360deg) scale(1.1); }
}

.enhance-mode-menu {
    position: fixed;
    z-index: 12000;
    width: 230px;
    padding: 10px;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    box-shadow: var(--shadow-lg);
    display: grid;
    gap: 6px;
}

.enhance-mode-title {
    padding: 2px 4px 6px;
    font-size: 12px;
    font-weight: 800;
    color: var(--text-muted);
    letter-spacing: .02em;
}

.enhance-mode-item {
    width: 100%;
    border: 1px solid transparent;
    border-radius: 12px;
    background: transparent;
    color: var(--text);
    padding: 9px 10px;
    font: inherit;
    text-align: left;
    cursor: pointer;
    display: grid;
    gap: 2px;
    transition: var(--transition);
}

.enhance-mode-item span {
    font-size: 13px;
    font-weight: 800;
}

.enhance-mode-item small {
    font-size: 11px;
    color: var(--text-muted);
}

.enhance-mode-item:hover,
.enhance-mode-item:focus-visible {
    outline: none;
    border-color: var(--primary);
    background: var(--surface-hover);
}

.prompt-enhance-card {
    display: none;
    width: min(100%, 860px);
    margin: 0 auto 10px;
    padding: 12px;
    border-radius: 18px;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    box-shadow: var(--shadow);
}

.prompt-enhance-card.is-visible {
    display: block;
}

.prompt-enhance-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.prompt-enhance-kicker {
    display: block;
    margin-bottom: 2px;
    font-size: 11px;
    font-weight: 800;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: .06em;
}

.prompt-enhance-close {
    width: 28px;
    height: 28px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
}

.prompt-enhance-close:hover {
    color: var(--text);
    background: var(--surface-hover);
}

.prompt-enhance-meta {
    margin-top: 6px;
    font-size: 12px;
    color: var(--text-muted);
}

.prompt-enhance-preview {
    margin-top: 10px;
    max-height: 150px;
    overflow: auto;
    white-space: pre-wrap;
    word-break: break-word;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: var(--bg);
    font-size: 13px;
    line-height: 1.45;
}

.prompt-enhance-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.prompt-enhance-action {
    border: 1px solid var(--border);
    border-radius: 999px;
    background: transparent;
    color: var(--text);
    padding: 7px 12px;
    font: inherit;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
}

.prompt-enhance-action:hover {
    background: var(--surface-hover);
}

.prompt-enhance-action.is-primary {
    border-color: var(--primary);
    background: var(--primary);
    color: white;
}

/* ── Markdown in messages ── */
.message-content h1,
.message-content h2,
.message-content h3 {
    margin: 12px 0 4px;
    font-weight: 700;
}

.message-content h1 { font-size: 18px; }
.message-content h2 { font-size: 16px; }
.message-content h3 { font-size: 15px; }

.message-content p {
    margin: 2px 0;
    line-height: 1.45;
}
.message-content p:empty { display: none; }

.message-content ul, .message-content ol {
    margin: 4px 0;
    padding-left: 22px;
}

.message-content li {
    margin: 0 !important;
    list-style: disc;
    line-height: 1.45;
}

.message-content ol li {
    list-style: decimal;
}

/* Markdown часто оборачивает каждый <li> в <p> (loose list) — это создаёт огромные
   вертикальные пробелы между пунктами. Принудительно схлопываем margin у <p> внутри li. */
.message-content li > p {
    margin: 0 !important;
    display: inline;
}
.message-content li > p:not(:last-child)::after {
    content: '';
    display: block;
    height: 1px;
}
.message-content li + li {
    margin-top: 0 !important;
}
.message-content li > ul,
.message-content li > ol {
    margin: 2px 0;
}

.message-content blockquote {
    border-left: 3px solid var(--border-light);
    padding-left: 14px;
    margin: 8px 0;
    color: var(--text-secondary);
}

.message-content strong { font-weight: 700; }
.message-content em { font-style: italic; }

.message-content hr {
    border: none;
    border-top: 1px solid var(--border);
    margin: 16px 0;
}

.message-content table {
    border-collapse: collapse;
    width: 100%;
    margin: 12px 0;
    font-size: 13px;
}

.message-content th,
.message-content td {
    border: 1px solid var(--border);
    padding: 8px 12px;
    text-align: left;
}

.message-content th {
    background: var(--bg-card);
    font-weight: 600;
}

/* ══════════════════════════════════════
   Light Theme
   ══════════════════════════════════════ */

body.light-theme {
    --bg: #f5f5f7;
    --bg-card: #ffffff;
    --bg-hover: #e8e8ec;
    --bg-input: #f0f0f4;
    --border: #d4d4dc;
    --border-light: #c0c0cc;

    --text: #1a1a2e;
    --text-secondary: #555570;
    --text-muted: #5e5e7a;

    --code-bg: #f8f8fc;
    --code-border: #d4d4dc;

    --msg-user: #eeeef4;
    --msg-ai: #f8f8fc;
}

body.light-theme .chat-topbar {
    background: rgba(245, 245, 247, 0.9);
}

body.light-theme .message-avatar.msg-ai-avatar {
    background: #e8e8f0;
    color: var(--primary);
}

body.light-theme .message-user .message-bubble {
    background: rgba(115, 100, 245, 0.08);
    border-color: rgba(115, 100, 245, 0.15);
}

body.light-theme .msg-action {
    color: #555;
}
body.light-theme .msg-action:hover {
    background: rgba(0, 0, 0, 0.06);
    border-color: rgba(0, 0, 0, 0.1);
}

body.light-theme .message-content pre {
    background: var(--code-bg);
    border-color: var(--code-border);
}

body.light-theme .message-content code:not(pre code) {
    background: rgba(0, 0, 0, 0.05);
    color: var(--text);
}
body.light-theme .message-content code.osc-path {
    background: rgba(115, 100, 245, 0.10);
    color: var(--primary);
}

body.light-theme .template-card {
    background: rgba(0, 0, 0, 0.02);
}

body.light-theme .suggestion-chip {
    background: rgba(0, 0, 0, 0.04);
    border-color: rgba(0, 0, 0, 0.08);
}
body.light-theme .suggestion-chip:hover {
    background: rgba(0, 0, 0, 0.08);
    border-color: rgba(0, 0, 0, 0.15);
}
body.light-theme .chip-icon {
    background: rgba(115, 100, 245, 0.08);
}
body.light-theme .chip-icon svg {
    stroke: var(--primary, #7364f5);
}

body.light-theme .message-content pre .code-header {
    background: rgba(0, 0, 0, 0.03);
}

body.light-theme .code-output {
    background: #f0f0f8;
    color: #1a6a1a;
}
body.light-theme .code-output.error {
    color: #dc2626;
}

body.light-theme .search-step {
    background: rgba(115, 100, 245, 0.06);
    border-color: rgba(115, 100, 245, 0.15);
}

body.light-theme .templates-overlay {
    background: var(--bg-card);
    border-color: var(--border);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

body.light-theme .template-item:hover {
    background: rgba(0, 0, 0, 0.04);
}

body.light-theme .auth-screen,
body.light-theme .auth-container {
    background: var(--bg);
}
body.light-theme .auth-container {
    background: #ffffff;
    border-color: #e0e4f0;
    box-shadow: 0 24px 70px rgba(24, 28, 55, 0.12);
}
body.light-theme .auth-particles {
    background-image:
        radial-gradient(circle at 20% 30%, rgba(115, 100, 245, 0.06) 0%, transparent 50%),
        radial-gradient(circle at 80% 70%, rgba(16, 196, 214, 0.05) 0%, transparent 50%);
}
body.light-theme .link-account-box {
    box-shadow: 0 24px 64px rgba(0,0,0,0.15);
}
body.light-theme .link-account-overlay {
    background: rgba(0,0,0,0.4);
}
body.light-theme .auth-error {
    color: #dc2626;
}
body.light-theme .auth-choice-head h2 { color: #1f2435; }
body.light-theme .auth-choice-head p,
body.light-theme .auth-subtitle { color: #697086; }
body.light-theme .auth-choice-kicker { color: #747b91; }
body.light-theme .auth-btn-google {
    background: #ffffff;
    border-color: #dde2ef;
    color: #252a3d;
    box-shadow: 0 10px 24px rgba(24, 28, 55, 0.06);
}
body.light-theme .auth-btn-google:hover {
    background: #f7f8fc;
    border-color: rgba(99,102,241,0.38);
}

/* ── Light theme: comprehensive text/element fixes ── */
body.light-theme .sidebar {
    background: #fff;
    border-color: #e0e0e0;
}
body.light-theme .sidebar-header { border-color: #e0e0e0; }
body.light-theme .sidebar-bottom { background: #fff; }
body.light-theme .sidebar-footer { background: #fff; border-color: #e0e0e0; }
body.light-theme .sidebar-logo span { color: #1a1a2e; }
body.light-theme .sidebar-section-title { color: #555; }
body.light-theme .chat-list-item { color: #333; }
body.light-theme .chat-list-item.active { background: rgba(115,100,245,0.1); }
body.light-theme .chat-list-item:hover { background: rgba(0,0,0,0.04); }
body.light-theme .chat-group-label { color: #888 !important; }
body.light-theme .btn-new-chat { background: linear-gradient(135deg, #7364f5, #10c4d6); color: #fff; }
body.light-theme .model-selector-btn { background: #f0f0f4; border-color: #d4d4dc; color: #333; }
body.light-theme .model-dropdown { background: #fff; border-color: #d4d4dc; }
body.light-theme .model-option { color: #333; }
body.light-theme .model-option:hover { background: #f0f0f4; }
body.light-theme .setting-toggle span { color: #333; }
body.light-theme .token-bar-label { color: #555; }
body.light-theme .token-bar-value { color: #333; }
body.light-theme .token-bar-track { background: #e0e0e0; }
body.light-theme .user-name { color: #333; }
body.light-theme .user-sub { color: #666; }
body.light-theme .sub-sidebar-btn { background: transparent; border: none; color: #333; padding: 8px 6px; border-radius: 8px; }
body.light-theme .sub-sidebar-btn:hover { background: rgba(108, 92, 231, 0.08); color: #4f46e5; }
body.light-theme .sub-sidebar-btn:hover .sub-arrow { color: #6366f1; }

/* ── Account modal — Google email pill (both themes) ── */
.acc-google-email {
    display: inline-flex;
    align-items: center;
    padding: 8px 12px;
    font-size: 13px;
    font-family: inherit;
    color: var(--text);
    background: var(--bg-input, rgba(255,255,255,0.04));
    border: 1px solid var(--border, rgba(255,255,255,0.08));
    border-radius: 10px;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
body.light-theme .acc-google-email {
    color: #2d2b4a;
    background: #f5f5f7;
    border-color: #d4d4dc;
}

/* ── Account modal — neutralize default <button.btn.btn-sm> in dark theme ── */
/* Base .btn has no background, so browser default (near-white) leaks through
   on dark theme. Give .btn.btn-sm inside the account modal a proper dark look. */
#account-modal .btn.btn-sm:not(.btn-primary):not(.acc-unlink-btn):not(.acc-logout-btn) {
    background: rgba(255,255,255,0.04);
    color: var(--text);
    border: 1px solid var(--border, rgba(255,255,255,0.1));
    transition: background .18s, border-color .18s, transform .1s;
}
#account-modal .btn.btn-sm:not(.btn-primary):not(.acc-unlink-btn):not(.acc-logout-btn):hover {
    background: rgba(108, 92, 231, 0.14);
    border-color: rgba(139, 124, 246, 0.45);
    color: var(--text);
}
#account-modal .btn.btn-sm:not(.btn-primary):not(.acc-unlink-btn):not(.acc-logout-btn):active {
    transform: translateY(1px);
}
/* Light theme equivalents */
body.light-theme #account-modal .btn.btn-sm:not(.btn-primary):not(.acc-unlink-btn):not(.acc-logout-btn) {
    background: #f5f5f7;
    color: #2d2b4a;
    border-color: #d4d4dc;
}
body.light-theme #account-modal .btn.btn-sm:not(.btn-primary):not(.acc-unlink-btn):not(.acc-logout-btn):hover {
    background: #ebebf1;
    border-color: #6366f1;
    color: #4f46e5;
}

#account-modal #link-google-btn {
    color: var(--text) !important;
    background: var(--bg-input, rgba(255,255,255,0.04)) !important;
    border-color: var(--border, rgba(255,255,255,0.10)) !important;
}
body.light-theme #account-modal #link-google-btn {
    color: #2d2b4a !important;
    background: #f7f8fc !important;
    border-color: #d5d9e8 !important;
}
body.light-theme #account-modal #link-google-btn:hover {
    background: #eef0f8 !important;
    border-color: rgba(99, 102, 241, 0.42) !important;
}

/* Unlink buttons — danger-tinted, works on both themes */
#account-modal .acc-unlink-btn {
    background: rgba(239, 68, 68, 0.08) !important;
    color: #ef4444 !important;
    border: 1px solid rgba(239, 68, 68, 0.28) !important;
    transition: background .18s, border-color .18s, transform .1s !important;
}
#account-modal .acc-unlink-btn:hover {
    background: rgba(239, 68, 68, 0.18) !important;
    border-color: rgba(239, 68, 68, 0.5) !important;
    color: #f87171 !important;
}
body.light-theme #account-modal .acc-unlink-btn {
    background: #fff1f1 !important;
    color: #dc2626 !important;
    border-color: #fecaca !important;
}
body.light-theme #account-modal .acc-unlink-btn:hover {
    background: #ffe1e1 !important;
    border-color: #f87171 !important;
}

/* Logout button */
#account-modal .acc-logout-btn {
    background: rgba(239, 68, 68, 0.08) !important;
    color: #ef4444 !important;
    border: 1px solid rgba(239, 68, 68, 0.28) !important;
}
#account-modal .acc-logout-btn:hover {
    background: rgba(239, 68, 68, 0.18) !important;
    border-color: rgba(239, 68, 68, 0.5) !important;
}
body.light-theme #account-modal .acc-logout-btn {
    background: #fff1f1 !important;
    color: #dc2626 !important;
    border-color: #fecaca !important;
}
body.light-theme #account-modal .acc-logout-btn:hover {
    background: #ffe1e1 !important;
    border-color: #f87171 !important;
}

/* Copy / export buttons within account modal get same neutral treatment */
#account-modal #btn-copy-referral,
#account-modal #btn-export-all-chats {
    background: rgba(255,255,255,0.04);
    color: var(--text);
    border: 1px solid var(--border, rgba(255,255,255,0.1));
    transition: background .18s, border-color .18s, transform .1s;
}
#account-modal #btn-copy-referral:hover,
#account-modal #btn-export-all-chats:hover {
    background: rgba(108, 92, 231, 0.14);
    border-color: rgba(139, 124, 246, 0.45);
}
body.light-theme #account-modal #btn-copy-referral,
body.light-theme #account-modal #btn-export-all-chats {
    background: #f5f5f7;
    color: #2d2b4a;
    border-color: #d4d4dc;
}
body.light-theme #account-modal #btn-copy-referral:hover,
body.light-theme #account-modal #btn-export-all-chats:hover {
    background: #ebebf1;
    border-color: #6366f1;
    color: #4f46e5;
}

/* FM light theme */
body.light-theme .fm-panel { background: #fff; border-color: #e0e0e0; }
body.light-theme .fm-header { color: #333; border-color: #e0e0e0; }
body.light-theme .fm-item { color: #333; }
body.light-theme .fm-item:hover { background: rgba(0,0,0,0.03); }
body.light-theme .fm-item-name { color: #333; }
body.light-theme .fm-item-date { color: #888; }
body.light-theme .fm-item-size { color: #888; }
body.light-theme .fm-breadcrumb span { color: #555; }
body.light-theme #fm-ctx { background: #fff; border-color: #e0e0e0; }
body.light-theme #fm-ctx div { color: #333; }
body.light-theme #fm-ctx div:hover { background: #f0f0f4; }

/* Input/modal light theme */
body.light-theme input, body.light-theme textarea, body.light-theme select {
    color: #333;
}
body.light-theme .modal-content { background: #fff; border-color: #e0e0e0; color: #333; }
body.light-theme .modal-header { color: #333; border-color: #e0e0e0; }
body.light-theme .modal-body { color: #333; }
body.light-theme .acc-label { color: #555; }
body.light-theme .acc-field input { color: #333; background: #f5f5f7; border-color: #d4d4dc; }
body.light-theme .modal-input { color: #333; background: #f5f5f7; border-color: #d4d4dc; }
body.light-theme .modal-section-title { color: #333; }
body.light-theme .modal-divider { background: #e0e0e0; }

/* Welcome screen light */
body.light-theme .chat-welcome h2 { color: #333; }
body.light-theme .chat-welcome p { color: #666; }
body.light-theme .chat-input-hint { color: #888; }

/* Topbar light */
body.light-theme .topbar-btn { color: #555; }
body.light-theme .topbar-btn:hover { background: rgba(0,0,0,0.06); }
body.light-theme .chat-topbar-title { color: #333; }
body.light-theme .chat-topbar-model { color: #666; }

/* Chat input light */
body.light-theme #chat-input {
    color: #333;
    background: transparent !important;
}
body.light-theme .chat-input-wrapper {
    background: #ffffff;
    border-color: #d7dbe7;
    box-shadow: 0 16px 42px rgba(24, 28, 55, 0.08);
}
body.light-theme .chat-input-wrapper:focus-within {
    border-color: rgba(115, 100, 245, 0.34);
    box-shadow: 0 18px 46px rgba(24, 28, 55, 0.10), 0 0 0 3px rgba(115, 100, 245, 0.08);
}
body.light-theme .btn-send { color: #555; }
body.light-theme .btn-attach { color: #555; }

/* Sub modal light */
body.light-theme .sub-card { background: #f8f8f8; border-color: #e0e0e0; color: #333; }
body.light-theme .sub-card-name { color: #333; }
body.light-theme .sub-card-price { color: #333; }
body.light-theme .sub-current { color: #333; }

/* Token info light */
body.light-theme .message-tokens { color: #888; }

/* Cost warning light */
body.light-theme .cost-warning-box { background: #fff; border-color: #e0e0e0; }
body.light-theme .cost-warning-title { color: #333; }
body.light-theme .cost-warning-text { color: #555; }

/* Tutorials light */
body.light-theme .tutorial-item { color: #333; background: #f8f8f8; border-color: #e0e0e0; }
body.light-theme .tutorial-item:hover { background: #f0f0f4; }

/* Queue light */
body.light-theme .queue-box { background: #fff; border-color: #e0e0e0; }
body.light-theme .queue-title { color: #333; }

/* Sidebar settings light */
body.light-theme .sidebar-settings { border-color: #e0e0e0; }
body.light-theme .sidebar-extra-btn { color: #555; border-color: #e0e0e0; }
body.light-theme .sidebar-extra-btn:hover { background: #f0f0f4; }

/* ══════════════════════════════════════
   Code Block Action Buttons (Run, Convert, Tests, Docs)
   ══════════════════════════════════════ */

.btn-run, .btn-convert, .btn-tests, .btn-docs {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 11px;
    font-family: inherit;
    padding: 2px 8px;
    border-radius: 4px;
    transition: var(--transition);
    white-space: nowrap;
}

.btn-run:hover { color: #22c55e; background: rgba(34, 197, 94, 0.1); }
.btn-convert:hover { color: #10c4d6; background: rgba(6, 182, 212, 0.1); }
.btn-tests:hover { color: #10c4d6; background: rgba(245, 158, 11, 0.1); }
.btn-docs:hover { color: #10c4d6; background: rgba(129, 140, 248, 0.1); }

/* Code output block */
.code-output {
    background: #0a0a14;
    border: 1px solid var(--code-border);
    border-top: none;
    border-radius: 0 0 10px 10px;
    padding: 10px 14px;
    font-family: var(--font-code);
    font-size: 12px;
    color: #a0ffa0;
    white-space: pre-wrap;
    max-height: 200px;
    overflow-y: auto;
    margin-top: -12px;
    margin-bottom: 12px;
}

.code-output.error {
    color: #f87171;
}

.code-output-header {
    font-size: 10px;
    color: var(--text-muted);
    margin-bottom: 4px;
    font-family: inherit;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* File saved block */
.file-saved-block { margin: 12px 0; max-width: 100%; }
.file-saved-label { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; margin-bottom: 6px; font-size: 13px; color: var(--text); line-height: 1.4; }
.file-saved-label code { background: rgba(115,100,245,0.15); padding: 2px 6px; border-radius: 4px; font-size: 12px; color: #a78bfa; }
.file-code-preview { margin: 0 !important; border-radius: 10px !important; max-height: 200px; overflow: auto; }
.file-saved-actions { display: inline-flex; align-items: center; gap: 6px; margin-left: auto; flex-wrap: wrap; }
.fsb-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 4px 10px;
    background: rgba(115, 100, 245, 0.10);
    border: 1px solid rgba(115, 100, 245, 0.28);
    border-radius: 7px;
    color: #c4b5fd;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: background 140ms, border-color 140ms, color 140ms;
}
.fsb-btn:hover { background: rgba(115, 100, 245, 0.22); border-color: rgba(115, 100, 245, 0.5); color: #fff; }
.fsb-btn svg { flex-shrink: 0; }
.fsb-download-btn { background: rgba(74, 222, 128, 0.10); border-color: rgba(74, 222, 128, 0.28); color: #4ade80; }
.fsb-download-btn:hover { background: rgba(74, 222, 128, 0.22); border-color: rgba(74, 222, 128, 0.5); color: #86efac; }
.fsb-open-btn { background: rgba(96, 165, 250, 0.10); border-color: rgba(96, 165, 250, 0.28); color: #60a5fa; }
.fsb-open-btn:hover { background: rgba(96, 165, 250, 0.22); border-color: rgba(96, 165, 250, 0.5); color: #93c5fd; }
body.light-theme .fsb-btn { background: rgba(115,100,245,0.08); border-color: rgba(115,100,245,0.30); color: #6b5fd6; }
body.light-theme .fsb-btn:hover { background: rgba(115,100,245,0.16); color: #4c3fc8; }
body.light-theme .fsb-download-btn { background: rgba(22,163,74,0.08); border-color: rgba(22,163,74,0.30); color: #16a34a; }
body.light-theme .fsb-open-btn { background: rgba(37,99,235,0.08); border-color: rgba(37,99,235,0.30); color: #2563eb; }
/* No negative margins — keep block within message bubble so avatar stays aligned */

/* (code-output light theme defined above) */

/* ══════════════════════════════════════
   Convert Dropdown
   ══════════════════════════════════════ */

.convert-dropdown {
    position: fixed;
    z-index: 200;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 4px;
    box-shadow: var(--shadow);
    min-width: 160px;
}

.convert-dropdown button {
    display: block;
    width: 100%;
    padding: 8px 12px;
    background: none;
    border: none;
    color: var(--text);
    font-size: 12px;
    font-family: inherit;
    text-align: left;
    cursor: pointer;
    border-radius: 6px;
    transition: var(--transition);
}

.convert-dropdown button:hover {
    background: var(--bg-hover);
}

/* ══════════════════════════════════════
   Sidebar Extra Buttons (Cheatsheets, Tutorials)
   ══════════════════════════════════════ */

.sidebar-extra-btns {
    display: flex;
    gap: 6px;
    margin-bottom: 10px;
}

.sidebar-extra-btn {
    flex: 1;
    padding: 7px 10px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-secondary);
    font-size: 11px;
    font-family: inherit;
    cursor: pointer;
    transition: var(--transition);
    text-align: center;
}

.sidebar-extra-btn:hover {
    background: rgba(115, 100, 245, 0.1);
    color: var(--text);
    border-color: rgba(115, 100, 245, 0.3);
}

/* ══════════════════════════════════════
   Cheatsheet & Tutorial Grids
   ══════════════════════════════════════ */

.cheatsheet-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}

.cheatsheet-item, .tutorial-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 16px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    border-radius: 10px;
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    cursor: pointer;
    transition: var(--transition);
    text-align: left;
    width: 100%;
}

.cheatsheet-item:hover, .tutorial-item:hover {
    background: rgba(115, 100, 245, 0.1);
    border-color: rgba(115, 100, 245, 0.3);
    transform: translateY(-1px);
}

.tutorial-grid {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.tutorial-meta {
    margin-left: auto;
    font-size: 11px;
    color: var(--text-muted);
    font-weight: 400;
}

/* ══════════════════════════════════════
   Notes Overlay
   ══════════════════════════════════════ */

.notes-overlay {
    position: fixed;
    top: 60px;
    right: 20px;
    z-index: 150;
}

.notes-box {
    width: 320px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: var(--shadow);
    overflow: hidden;
}

.notes-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    border-bottom: 1px solid var(--border);
    font-size: 13px;
    font-weight: 600;
}

.notes-textarea {
    width: 100%;
    min-height: 180px;
    padding: 12px 14px;
    background: transparent;
    border: none;
    color: var(--text);
    font-size: 13px;
    font-family: inherit;
    resize: vertical;
    outline: none;
    line-height: 1.6;
}

.notes-textarea::placeholder {
    color: var(--text-muted);
}

/* ── Pyodide Progress Bar ── */

.pyodide-progress {
    padding: 8px 0;
}

.pyodide-progress-label {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

.pyodide-progress-track {
    height: 8px;
    background: var(--bg-input);
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid var(--border);
}

.pyodide-progress-fill {
    height: 100%;
    background: var(--gradient);
    border-radius: 4px;
    transition: width 0.3s ease;
}

.pyodide-progress-pct {
    font-size: 11px;
    color: var(--accent);
    margin-top: 4px;
    text-align: right;
    font-family: var(--font-code);
    font-weight: 600;
}

/* ── Language Selector ── */

.lang-selector-wrap {
    padding: 0 12px;
    margin-bottom: 4px;
}

.lang-selector {
    position: relative;
}

.lang-selector-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 12px;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-size: 12px;
    cursor: pointer;
    transition: background var(--transition);
}

.lang-selector-btn:hover {
    background: var(--bg-hover);
}

.lang-dropdown {
    display: none;
    position: absolute;
    bottom: 100%;
    left: 0;
    right: 0;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    z-index: 200;
    margin-bottom: 4px;
    box-shadow: var(--shadow);
}

.lang-dropdown.show {
    display: block;
}

.lang-option {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 12px;
    background: transparent;
    border: none;
    color: var(--text);
    font-size: 12px;
    cursor: pointer;
    transition: background var(--transition);
}

.lang-option:hover {
    background: var(--bg-hover);
}

.lang-option.active {
    background: var(--primary);
    color: #fff;
}

/* ── Fullscreen mode ── */
body.fullscreen-mode .sidebar { display: none !important; }
body.fullscreen-mode .sidebar-open-btn { display: none !important; }
body.fullscreen-mode .chat-main { margin-left: 0 !important; }

/* ── Compact mode ── */
body.compact-mode .message { padding: 6px 0; }
body.compact-mode .message-body { padding: 8px 12px; font-size: 13px; }
body.compact-mode .message-content { font-size: 13px; line-height: 1.5; }
body.compact-mode .message-content pre { font-size: 12px; padding: 8px; }
body.compact-mode .message-avatar { width: 28px; height: 28px; font-size: 12px; }
body.compact-mode .chat-group-label { padding: 2px 12px !important; }

/* ── Sidebar force hidden ── */
.sidebar.force-hidden { display: none !important; }

/* ── Search result highlight ── */
mark { background: rgba(115, 100, 245, 0.3); color: inherit; border-radius: 2px; padding: 0 2px; }

/* ── Chat color dot ── */
.chat-list-item { display: flex; align-items: center; gap: 6px; }
.chat-select-cb { width: 14px; height: 14px; flex-shrink: 0; cursor: pointer; }

/* ══════════════════════════════════════
   NEW FEATURES CSS (Blocks 1-10)
   ══════════════════════════════════════ */

/* ── Archive toggle button ── */
.archive-toggle-btn {
    width: 100%;
    padding: 6px 12px;
    background: none;
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-muted);
    font-size: 11px;
    cursor: pointer;
    margin: 4px 12px;
    width: calc(100% - 24px);
    transition: var(--transition);
}
.archive-toggle-btn:hover { color: var(--text); border-color: var(--primary); }

/* ── Bulk delete bar ── */
.bulk-delete-bar {
    position: sticky;
    bottom: 0;
    padding: 8px 12px;
    background: var(--bg-card);
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    font-size: 12px;
}
.bulk-delete-bar button {
    padding: 6px 14px;
    border-radius: 6px;
    border: none;
    font-size: 12px;
    cursor: pointer;
    font-family: inherit;
}
.bulk-delete-bar .btn-del { background: #ef4444; color: #fff; }
.bulk-delete-bar .btn-cancel { background: var(--bg-hover); color: var(--text); }

/* ── System prompt modal ── */
.system-prompt-modal {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(4px);
}
.system-prompt-box {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 24px;
    width: 90%;
    max-width: 480px;
}
.system-prompt-box textarea {
    width: 100%;
    min-height: 80px;
    padding: 10px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-family: inherit;
    font-size: 13px;
    resize: vertical;
    outline: none;
    margin: 8px 0 12px;
}

/* ── Autoscroll button ── */
.autoscroll-btn {
    font-size: 16px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
}
.autoscroll-btn.paused { opacity: 0.5; }

/* ── Resize handle ── */
.resize-handle {
    height: 4px;
    cursor: ns-resize;
    background: linear-gradient(90deg, transparent, var(--border), transparent);
    margin: 0 20%;
    border-radius: 2px;
}

/* ── Word count ── */
.word-count-indicator {
    font-size: 10px;
    color: var(--text-muted);
    margin-left: 8px;
}

/* Legacy .scroll-top-btn rules removed — single button now lives in features.js
   and uses the .scroll-to-top-btn (full word) styling block below. */

/* ── Reading progress bar ── */
.reading-progress {
    position: absolute;
    top: 0;
    left: 0;
    height: 2px;
    background: var(--gradient);
    z-index: 20;
    transition: width 0.1s;
    pointer-events: none;
}

/* ── Code block enhancements ── */
pre code.show-line-numbers {
    counter-reset: line;
    padding-left: 3em;
}
pre code.show-line-numbers .code-line {
    counter-increment: line;
    display: block;
    position: relative;
}
pre code.show-line-numbers .code-line::before {
    content: counter(line);
    position: absolute;
    left: -2.5em;
    width: 2em;
    text-align: right;
    color: var(--text-muted);
    font-size: 0.85em;
    opacity: 0.5;
}

/* ── Live HTML preview ── */
.html-preview-frame {
    width: 100%;
    height: 200px;
    border: 1px solid var(--border);
    border-radius: 8px;
    margin-top: 8px;
    background: #fff;
}

/* ── Data viewer (CSV table / JSON tree) ── */
.data-viewer {
    max-height: 300px;
    overflow: auto;
    margin-top: 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
}
.data-viewer table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}
.data-viewer th, .data-viewer td {
    padding: 6px 10px;
    border: 1px solid var(--border);
    text-align: left;
}
.data-viewer th { background: var(--bg-hover); font-weight: 600; }
.data-viewer tr:nth-child(even) { background: rgba(255,255,255,0.02); }

.json-tree { font-family: var(--font-code); font-size: 12px; padding: 8px; }
.json-tree details { margin-left: 16px; }
.json-tree summary { cursor: pointer; color: var(--primary-light); }
.json-tree .json-key { color: #10c4d6; }
.json-tree .json-string { color: #22c55e; }
.json-tree .json-number { color: #10c4d6; }
.json-tree .json-bool { color: #ec4899; }
.json-tree .json-null { color: var(--text-muted); }

/* ── Tool modals ── */
.tool-modal {
    position: fixed;
    inset: 0;
    z-index: 2000;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(4px);
}
.tool-modal-box {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 0;
    width: 90%;
    max-width: 600px;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
.tool-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    font-size: 15px;
    font-weight: 600;
}
.tool-modal-header button {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 18px;
    cursor: pointer;
}
.tool-modal-body {
    padding: 16px 20px;
    overflow-y: auto;
    flex: 1;
}
.tool-modal-body input, .tool-modal-body textarea, .tool-modal-body select {
    width: 100%;
    padding: 8px 12px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-family: inherit;
    font-size: 13px;
    outline: none;
    margin-bottom: 8px;
}
.tool-modal-body textarea { min-height: 100px; resize: vertical; font-family: var(--font-code); }
.tool-modal-body label { font-size: 12px; color: var(--text-secondary); display: block; margin-bottom: 4px; font-weight: 600; }
.tool-modal-body .tool-result {
    padding: 12px;
    background: var(--code-bg);
    border: 1px solid var(--code-border);
    border-radius: 8px;
    font-family: var(--font-code);
    font-size: 12px;
    white-space: pre-wrap;
    word-break: break-all;
    max-height: 200px;
    overflow: auto;
    margin-top: 8px;
}
.tool-modal-body .tool-btn {
    padding: 8px 16px;
    background: var(--gradient);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-family: inherit;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    margin-top: 8px;
}
.tool-modal-body .tool-btn:hover { box-shadow: 0 4px 20px rgba(115,100,245,0.4); }
.tool-modal-body .tool-btn-ghost {
    background: rgba(115,100,245,0.08);
    color: var(--text);
    border: 1px solid var(--border);
}
.tool-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 12px;
}
.tool-tab {
    flex: 1;
    padding: 8px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text-secondary);
    font-size: 12px;
    cursor: pointer;
    text-align: center;
    font-family: inherit;
    transition: var(--transition);
}
.tool-tab.active { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ── Tools dropdown ── */
.tools-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 6px 0;
    min-width: 220px;
    max-height: 400px;
    overflow-y: auto;
    box-shadow: var(--shadow);
    z-index: 100;
}
.tools-dropdown button {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 14px;
    background: none;
    border: none;
    color: var(--text);
    font-size: 13px;
    cursor: pointer;
    font-family: inherit;
    text-align: left;
}
.tools-dropdown button:hover { background: var(--bg-hover); }

/* ── File Manager enhancements ── */
.fm-search {
    width: 100%;
    padding: 6px 10px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text);
    font-size: 12px;
    outline: none;
    margin-bottom: 6px;
}
.fm-sort-select {
    padding: 4px 8px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text);
    font-size: 11px;
    outline: none;
}
.fm-item.selected { background: rgba(115,100,245,0.15); border-color: var(--primary); }
.fm-multi-bar {
    padding: 8px;
    background: var(--bg-card);
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
}
.fm-preview-pane {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 50%;
    background: var(--bg);
    border-left: 1px solid var(--border);
    overflow: auto;
    padding: 12px;
    font-family: var(--font-code);
    font-size: 12px;
    white-space: pre-wrap;
}
.fm-context-menu {
    position: fixed;
    z-index: 999;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 6px 0;
    min-width: 160px;
    box-shadow: var(--shadow);
}
.fm-context-menu button {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 14px;
    background: none;
    border: none;
    color: var(--text);
    font-size: 12px;
    cursor: pointer;
    font-family: inherit;
}
.fm-context-menu button:hover { background: var(--bg-hover); }

/* ── TODO Panel ── */
.todo-panel {
    position: fixed;
    right: 0;
    top: 0;
    bottom: 0;
    width: 320px;
    background: var(--bg-card);
    border-left: 1px solid var(--border);
    z-index: 100;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.3s;
    box-shadow: -4px 0 20px rgba(0,0,0,0.2);
}
.todo-panel.open { transform: translateX(0); }
.todo-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
    font-weight: 600;
}
.todo-header button { background: none; border: none; color: var(--text-muted); font-size: 18px; cursor: pointer; }
.todo-input-row {
    display: flex;
    gap: 6px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
}
.todo-input-row input {
    flex: 1;
    padding: 6px 10px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text);
    font-size: 12px;
    outline: none;
}
.todo-input-row button {
    padding: 6px 12px;
    background: var(--primary);
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: 12px;
    cursor: pointer;
}
.todo-list { flex: 1; overflow-y: auto; padding: 8px; }
.todo-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px;
    border-radius: 6px;
    margin-bottom: 4px;
    transition: var(--transition);
}
.todo-item:hover { background: var(--bg-hover); }
.todo-item.done { opacity: 0.5; text-decoration: line-through; }
.todo-item input[type="checkbox"] { flex-shrink: 0; }
.todo-item span { flex: 1; font-size: 13px; }
.todo-item button { background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 14px; opacity: 0; }
.todo-item:hover button { opacity: 1; }

/* ── Kanban Board ── */
.kanban-overlay {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: var(--bg);
    display: flex;
    flex-direction: column;
}
.kanban-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
    font-weight: 600;
}
.kanban-header button { background: none; border: none; color: var(--text-muted); font-size: 20px; cursor: pointer; }
.kanban-board {
    display: flex;
    flex: 1;
    gap: 16px;
    padding: 16px;
    overflow-x: auto;
}
.kanban-col {
    flex: 1;
    min-width: 260px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    display: flex;
    flex-direction: column;
}
.kanban-col-header {
    padding: 12px;
    border-bottom: 1px solid var(--border);
    font-weight: 600;
    font-size: 13px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.kanban-col-header .count {
    background: var(--bg-hover);
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 11px;
    color: var(--text-muted);
}
.kanban-cards {
    flex: 1;
    padding: 8px;
    min-height: 60px;
    overflow-y: auto;
}
.kanban-card {
    padding: 10px 12px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    margin-bottom: 6px;
    cursor: grab;
    font-size: 13px;
    transition: var(--transition);
}
.kanban-card:hover { border-color: var(--primary); }
.kanban-card.dragging { opacity: 0.5; }
.kanban-add-btn {
    width: 100%;
    padding: 8px;
    background: none;
    border: 1px dashed var(--border);
    border-radius: 6px;
    color: var(--text-muted);
    font-size: 12px;
    cursor: pointer;
}
.kanban-add-btn:hover { border-color: var(--primary); color: var(--text); }

/* ── Quick Switcher (Ctrl+K) ── */
.quick-switcher {
    position: fixed;
    inset: 0;
    z-index: 300;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 20vh;
    backdrop-filter: blur(4px);
}
.quick-switcher-box {
    width: 90%;
    max-width: 540px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
.quick-switcher-input {
    width: 100%;
    padding: 14px 18px;
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--border);
    color: var(--text);
    font-size: 15px;
    outline: none;
    font-family: inherit;
}
.quick-switcher-results {
    max-height: 300px;
    overflow-y: auto;
}
.quick-switcher-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px;
    cursor: pointer;
    font-size: 13px;
    transition: background 0.1s;
}
.quick-switcher-item:hover, .quick-switcher-item.active { background: var(--bg-hover); }
.quick-switcher-item .qs-icon { font-size: 16px; flex-shrink: 0; }
.quick-switcher-item .qs-label { flex: 1; }
.quick-switcher-item .qs-hint { font-size: 11px; color: var(--text-muted); }

/* ── Split View ── */
.split-view-active .chat-main {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto 1fr auto;
}
.split-divider {
    width: 4px;
    cursor: col-resize;
    background: var(--border);
    transition: background 0.2s;
}
.split-divider:hover { background: var(--primary); }

/* ── Prompt History ── */
.prompt-history-dropdown {
    position: absolute;
    bottom: 100%;
    left: 0;
    right: 0;
    max-height: 240px;
    overflow-y: auto;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px 12px 0 0;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
    z-index: 50;
}
.prompt-history-item {
    padding: 8px 14px;
    cursor: pointer;
    font-size: 12px;
    border-bottom: 1px solid var(--border);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.prompt-history-item:hover { background: var(--bg-hover); }

/* ── Snippet Library ── */
.snippet-panel {
    position: fixed;
    right: 0;
    top: 0;
    bottom: 0;
    width: 360px;
    background: var(--bg-card);
    border-left: 1px solid var(--border);
    z-index: 100;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.3s;
    box-shadow: -4px 0 20px rgba(0,0,0,0.2);
}
.snippet-panel.open { transform: translateX(0); }
.snippet-item {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
}
.snippet-item-title { font-weight: 600; font-size: 13px; margin-bottom: 4px; }
.snippet-item-code {
    font-family: var(--font-code);
    font-size: 11px;
    background: var(--code-bg);
    padding: 6px 8px;
    border-radius: 6px;
    max-height: 60px;
    overflow: hidden;
    white-space: pre-wrap;
    color: var(--text-secondary);
}
.snippet-item-actions {
    display: flex;
    gap: 4px;
    margin-top: 6px;
}
.snippet-item-actions button {
    padding: 3px 8px;
    font-size: 11px;
    background: var(--bg-hover);
    border: 1px solid var(--border);
    border-radius: 4px;
    color: var(--text);
    cursor: pointer;
}

/* ── Custom Themes ── */
.theme-picker {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
    padding: 8px 0;
}
.theme-swatch {
    width: 100%;
    padding: 6px;
    border-radius: 8px;
    border: 2px solid var(--border);
    cursor: pointer;
    text-align: center;
    font-size: 11px;
    transition: var(--transition);
}
.theme-swatch.active { border-color: var(--primary); box-shadow: 0 0 0 2px rgba(115,100,245,0.3); }
.theme-swatch:hover { border-color: var(--primary-light); }

/* ── Animated background ── */
#particles-canvas {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    opacity: 0.3;
}

/* ── Glassmorphism ── */
html.adv-glass .sidebar {
    background: rgba(15, 15, 26, 0.7);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}
html.adv-glass .modal-content {
    background: rgba(15, 15, 26, 0.8);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}
html.adv-glass .tool-modal-box {
    background: rgba(15, 15, 26, 0.8);
    backdrop-filter: blur(18px);
}

/* ── Sound toggle ── */
.sound-toggle { font-size: 14px; cursor: pointer; }

/* ── Breadcrumbs ── */
.topbar-breadcrumbs {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    color: var(--text-muted);
}
.topbar-breadcrumbs span { cursor: pointer; }
.topbar-breadcrumbs span:hover { color: var(--text); }
.topbar-breadcrumbs .sep { color: var(--text-muted); opacity: 0.5; }

/* ── Message context menu ── */
.msg-context-menu {
    position: fixed;
    z-index: 999;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 6px 0;
    min-width: 180px;
    box-shadow: var(--shadow);
}
.msg-context-menu button {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 14px;
    background: none;
    border: none;
    color: var(--text);
    font-size: 13px;
    cursor: pointer;
    font-family: inherit;
}
.msg-context-menu button:hover { background: var(--bg-hover); }
.msg-context-menu button.danger { color: #ef4444; }

/* ── Active Sessions ── */
.session-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    margin-bottom: 6px;
    font-size: 12px;
}
.session-item .session-info { display: flex; flex-direction: column; gap: 2px; }
.session-item .session-info small { color: var(--text-muted); }
.session-item .session-current { color: #22c55e; font-weight: 600; }
.session-item button {
    padding: 4px 10px;
    background: #ef4444;
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: 11px;
    cursor: pointer;
}

/* ── E2E encryption indicator ── */
.e2e-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    background: rgba(34, 197, 94, 0.1);
    color: #22c55e;
    border-radius: 10px;
    font-size: 10px;
    font-weight: 600;
}

/* ── Admin charts ── */
.admin-chart-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 12px;
}
.admin-chart-title { font-size: 12px; font-weight: 600; color: var(--text-secondary); margin-bottom: 8px; }
.admin-chart-value { font-size: 24px; font-weight: 700; margin-bottom: 4px; }
.admin-chart svg { width: 100%; height: 60px; }
.admin-chart svg polyline { fill: none; stroke: var(--primary); stroke-width: 2; }
.admin-chart svg .area { fill: rgba(115,100,245,0.1); stroke: none; }

/* ── Cohort analysis grid ── */
.cohort-grid { font-size: 11px; }
.cohort-grid table { width: 100%; border-collapse: collapse; }
.cohort-grid th, .cohort-grid td { padding: 4px 6px; text-align: center; border: 1px solid var(--border); }
.cohort-grid .cohort-cell { border-radius: 2px; }

/* ── Cost tracking bars ── */
.cost-bar-wrap { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; font-size: 12px; }
.cost-bar { flex: 1; height: 18px; background: var(--bg-input); border-radius: 4px; overflow: hidden; }
.cost-bar-fill { height: 100%; background: var(--gradient); border-radius: 4px; transition: width 0.3s; }

/* ── Bundle cards ── */
.bundle-card {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 10px;
    position: relative;
    cursor: pointer;
    transition: var(--transition);
}
.bundle-card:hover { border-color: var(--primary); transform: translateY(-2px); }
.bundle-badge {
    position: absolute;
    top: -6px;
    right: 12px;
    background: #22c55e;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 10px;
}
.bundle-price { font-size: 20px; font-weight: 700; margin: 8px 0 4px; }
.bundle-original { text-decoration: line-through; color: var(--text-muted); font-size: 13px; }

/* ── Compare models split view ── */
.compare-view {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 8px;
}
.compare-col {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 12px;
    font-size: 13px;
    line-height: 1.6;
    overflow: auto;
    max-height: 400px;
}
.compare-col-header {
    font-weight: 600;
    font-size: 12px;
    color: var(--primary-light);
    margin-bottom: 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border);
}

/* ── Webhook settings ── */
.webhook-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    margin-bottom: 6px;
    font-size: 12px;
}
.webhook-item input[type="text"] { flex: 1; }
.webhook-item button {
    padding: 4px 8px;
    background: none;
    border: 1px solid var(--border);
    border-radius: 4px;
    color: var(--text);
    font-size: 11px;
    cursor: pointer;
}

/* ── Workspace template picker ── */
.template-picker-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}
.template-picker-item {
    padding: 12px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    cursor: pointer;
    text-align: center;
    font-size: 13px;
    transition: var(--transition);
}
.template-picker-item:hover { border-color: var(--primary); background: rgba(115,100,245,0.05); }
.template-picker-icon { font-size: 24px; display: block; margin-bottom: 6px; }

/* ── Print styles for PDF export ── */
@media print {
    body * { visibility: hidden; }
    .chat-messages, .chat-messages * { visibility: visible; }
    .chat-messages { position: absolute; top: 0; left: 0; width: 100%; padding: 20px; }
    .message-actions, .code-actions, .message-avatar, .sidebar, .chat-topbar, .chat-input-area { display: none !important; }
    .message { page-break-inside: avoid; }
    pre { white-space: pre-wrap; word-wrap: break-word; }
}

/* ── Chat search bar (Ctrl+F) ── */
.chat-search-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
}
.chat-search-input {
    flex: 1;
    padding: 6px 10px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text);
    font-size: 13px;
    outline: none;
}
.chat-search-close {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 18px;
    cursor: pointer;
}

/* ── Auto-continue badge ── */
.auto-continue-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    background: rgba(115,100,245,0.1);
    color: var(--primary-light);
    border-radius: 10px;
    font-size: 10px;
    margin-left: 6px;
}

/* ── Light theme overrides for new features ── */
body.light-theme .tool-modal-box { background: #fff; border-color: #e0e0e0; }
body.light-theme .tools-dropdown { background: #fff; border-color: #e0e0e0; }
body.light-theme .todo-panel { background: #fff; border-color: #e0e0e0; }
body.light-theme .kanban-col { background: #f8f8f8; border-color: #e0e0e0; }
body.light-theme .kanban-card { background: #fff; border-color: #e0e0e0; }
body.light-theme .quick-switcher-box { background: #fff; border-color: #e0e0e0; }
body.light-theme .fm-context-menu { background: #fff; border-color: #e0e0e0; }
body.light-theme .msg-context-menu { background: #fff; border-color: #e0e0e0; }
body.light-theme .snippet-panel { background: #fff; border-color: #e0e0e0; }
body.light-theme .prompt-history-dropdown { background: #fff; border-color: #e0e0e0; }
body.light-theme .session-item { border-color: #e0e0e0; }
body.light-theme .admin-chart-card { background: #fff; border-color: #e0e0e0; }
body.light-theme .bundle-card { background: #f8f8f8; border-color: #e0e0e0; }
body.light-theme .compare-col { background: #f8f8f8; border-color: #e0e0e0; }
body.light-theme .data-viewer th { background: #f0f0f0; }
body.light-theme .system-prompt-box { background: #fff; border-color: #e0e0e0; }
body.light-theme .tool-modal-body input,
body.light-theme .tool-modal-body textarea,
body.light-theme .tool-modal-body select { background: #f5f5f5; border-color: #ddd; color: #333; }
body.light-theme html.adv-glass .sidebar { background: rgba(255,255,255,0.8); }
body.light-theme html.adv-glass .modal-content { background: rgba(255,255,255,0.9); }

/* ══════════════════════════════════════
   Cursor-style UI Components
   ══════════════════════════════════════ */

/* ── File Block (replaces file-saved-block) ── */
.cursor-file-block {
    margin: 12px 0;
    border: 1px solid var(--border);
    border-radius: 10px;
    overflow: hidden;
    background: var(--code-bg, #0d0f17);
}
.cursor-file-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: rgba(255,255,255,0.03);
    border-bottom: 1px solid var(--border);
    cursor: pointer;
    user-select: none;
    transition: background 0.15s;
}
.cursor-file-header:hover {
    background: rgba(255,255,255,0.06);
}
.cursor-file-icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    opacity: 0.7;
}
.cursor-file-path {
    font-family: var(--font-code, 'JetBrains Mono', monospace);
    font-size: 12.5px;
    color: #88c0d0;
    font-weight: 600;
}
.cursor-file-meta {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 8px;
}
.cursor-file-ext {
    font-size: 10px;
    padding: 1px 6px;
    border-radius: 4px;
    background: rgba(115,100,245,0.15);
    color: #a78bfa;
    font-family: var(--font-code, monospace);
    font-weight: 700;
    text-transform: uppercase;
}
.cursor-file-lines {
    font-size: 11px;
    color: var(--text-muted);
    font-family: var(--font-code, monospace);
}
.cursor-file-chevron {
    font-size: 14px;
    color: var(--text-muted);
    transition: transform 0.2s;
    margin-left: 4px;
}
.cursor-file-block.collapsed .cursor-file-chevron {
    transform: rotate(-90deg);
}
.cursor-file-body {
    max-height: 2000px;
    overflow: hidden;
    transition: max-height 0.3s ease;
}
.cursor-file-block.collapsed .cursor-file-body {
    max-height: 0;
}
.cursor-file-body pre {
    margin: 0 !important;
    border-radius: 0 !important;
    border: none !important;
}
.cursor-file-actions {
    display: flex;
    gap: 2px;
    padding: 4px 8px;
    background: rgba(255,255,255,0.02);
    border-top: 1px solid var(--border);
}
.cursor-file-actions button {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 11px;
    padding: 3px 8px;
    border-radius: 4px;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.15s;
}
.cursor-file-actions button:hover {
    background: rgba(255,255,255,0.08);
    color: var(--text);
}

/* ── Action Block (step-by-step actions) ── */
.cursor-action-block {
    margin: 6px 0;
    padding: 6px 12px;
    border-left: 2px solid rgba(115,100,245,0.4);
    border-radius: 0 6px 6px 0;
    background: rgba(115,100,245,0.04);
}
.cursor-action-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--text-secondary);
}
.cursor-action-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #7364f5;
    flex-shrink: 0;
}
.streaming .cursor-action-dot {
    animation: pulse-dot 1.5s ease-in-out infinite;
}
@keyframes pulse-dot {
    0%, 100% { opacity: 0.4; transform: scale(0.8); }
    50% { opacity: 1; transform: scale(1.2); }
}
.cursor-action-summary {
    font-weight: 500;
}
.cursor-action-detail {
    margin-top: 4px;
    font-size: 12px;
    color: var(--text-muted);
    padding-left: 15px;
}

/* ── Inline File Reference ── */
.cursor-file-ref {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 1px 6px;
    background: rgba(136,192,208,0.1);
    border: 1px solid rgba(136,192,208,0.2);
    border-radius: 4px;
    font-family: var(--font-code, monospace);
    font-size: 0.85em;
    color: #88c0d0;
    cursor: default;
    white-space: nowrap;
}
.cursor-file-ref::before {
    content: '📄';
    font-size: 0.8em;
}

/* ── Status Indicator (Cursor-style) ── */
.cursor-status {
    padding: 6px 14px;
    margin: 4px 0;
    font-size: 13px;
    color: #a78bfa;
    display: flex;
    align-items: center;
    gap: 8px;
    border-left: 2px solid #7364f5;
    background: rgba(115,100,245,0.05);
    border-radius: 0 6px 6px 0;
}
.cursor-status-dots {
    display: inline-flex;
    gap: 2px;
}
.cursor-status-dots span {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: #a78bfa;
    animation: blink 1.4s infinite;
}
.cursor-status-dots span:nth-child(2) { animation-delay: 0.2s; }
.cursor-status-dots span:nth-child(3) { animation-delay: 0.4s; }

/* ── Enhanced Think Block ── */
.think-block {
    margin: 10px 0;
    border: 1px solid rgba(115,100,245,0.15);
    border-left: 3px solid #7364f5;
    border-radius: 0 8px 8px 0;
    background: rgba(115,100,245,0.03);
    overflow: hidden;
}
.think-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    color: #a78bfa;
    user-select: none;
}
.think-header:hover {
    background: rgba(115,100,245,0.06);
}
.think-chevron {
    margin-left: auto;
    transition: transform 0.2s;
    font-size: 14px;
}
.think-block[open] .think-chevron {
    transform: rotate(90deg);
}
.think-content {
    padding: 10px 14px;
    font-size: 13px;
    line-height: 1.6;
    color: var(--text-secondary);
    border-top: 1px solid rgba(115,100,245,0.1);
    white-space: pre-wrap;
    max-height: 400px;
    overflow-y: auto;
    /* Кастомный тонкий scrollbar — раньше был дефолтный браузерный (толстый
       серый), на тёмной теме ломал визуал. Теперь полупрозрачная фиолетовая
       полоска под наш palette. Поддерживается в Chromium/Safari + Firefox. */
    scrollbar-width: thin;
    scrollbar-color: rgba(115,100,245,0.4) transparent;
}
.think-content::-webkit-scrollbar { width: 6px; }
.think-content::-webkit-scrollbar-track { background: transparent; }
.think-content::-webkit-scrollbar-thumb {
    background: rgba(115,100,245,0.35);
    border-radius: 3px;
    transition: background 0.2s ease;
}
.think-content::-webkit-scrollbar-thumb:hover { background: rgba(115,100,245,0.55); }
/* Тот же скроллбар-стиль для других кодо-/output-областей где он раньше
   был дефолтным «серым» */
.cli-step-code,
.fwin-pre,
.fwin-code-pre,
.agent-panel-steps {
    scrollbar-width: thin;
    scrollbar-color: rgba(115,100,245,0.4) transparent;
}
.cli-step-code::-webkit-scrollbar,
.fwin-pre::-webkit-scrollbar,
.fwin-code-pre::-webkit-scrollbar,
.agent-panel-steps::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
.cli-step-code::-webkit-scrollbar-track,
.fwin-pre::-webkit-scrollbar-track,
.fwin-code-pre::-webkit-scrollbar-track,
.agent-panel-steps::-webkit-scrollbar-track { background: transparent; }
.cli-step-code::-webkit-scrollbar-thumb,
.fwin-pre::-webkit-scrollbar-thumb,
.fwin-code-pre::-webkit-scrollbar-thumb,
.agent-panel-steps::-webkit-scrollbar-thumb {
    background: rgba(115,100,245,0.35);
    border-radius: 3px;
}
.cli-step-code::-webkit-scrollbar-thumb:hover,
.fwin-pre::-webkit-scrollbar-thumb:hover,
.fwin-code-pre::-webkit-scrollbar-thumb:hover,
.agent-panel-steps::-webkit-scrollbar-thumb:hover { background: rgba(115,100,245,0.55); }

/* ── Light theme overrides ── */
body.light-theme .cursor-file-block { background: #f8f9fc; border-color: #d4d4dc; }
body.light-theme .cursor-file-header { background: rgba(0,0,0,0.02); border-color: #d4d4dc; }
body.light-theme .cursor-file-header:hover { background: rgba(0,0,0,0.04); }
body.light-theme .cursor-file-path { color: #2563eb; }
body.light-theme .cursor-file-ext { background: rgba(115,100,245,0.08); color: #7364f5; }
body.light-theme .cursor-file-actions { background: rgba(0,0,0,0.02); border-color: #d4d4dc; }
body.light-theme .cursor-file-actions button:hover { background: rgba(0,0,0,0.06); color: #333; }
body.light-theme .cursor-action-block { background: rgba(115,100,245,0.03); border-color: rgba(115,100,245,0.3); }
body.light-theme .cursor-file-ref { background: rgba(37,99,235,0.06); border-color: rgba(37,99,235,0.15); color: #2563eb; }
body.light-theme .think-block { background: rgba(115,100,245,0.02); border-color: rgba(115,100,245,0.1); }
body.light-theme .think-content { color: #555; }
body.light-theme .cursor-status { background: rgba(115,100,245,0.04); }

/* ── Support Button (topbar) ── */
.topbar-support-wrap {
    position: relative;
}

.support-popup {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: 8px;
    width: 280px;
    background: var(--bg-sidebar, #1a1a2e);
    border: 1px solid var(--border);
    border-radius: 16px;
    z-index: 9999;
    box-shadow: 0 8px 40px rgba(0,0,0,0.5);
    animation: supportPopupIn 0.25s ease-out;
    overflow: hidden;
}
@keyframes supportPopupIn {
    from { opacity: 0; transform: translateY(12px) scale(0.95); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
.support-popup-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
}
.support-popup-close {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 20px;
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
}
.support-popup-close:hover { color: var(--text); }
.support-popup-body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}
.support-popup-avatar {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--primary, #7364f5);
}
.support-popup-avatar-fallback {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, #7364f5, #10c4d6);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    font-weight: 700;
    color: #fff;
    border: 3px solid var(--primary, #7364f5);
}
.support-popup-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--text);
    margin-top: 4px;
}
.support-popup-username {
    font-size: 13px;
    color: var(--text-secondary);
}
.support-popup-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 12px;
    margin-top: 8px;
    background: #2AABEE;
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    border: none;
    border-radius: 12px;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.2s;
}
.support-popup-btn:hover { background: #1e96d1; }
.support-popup-desc {
    font-size: 12px;
    color: var(--text-muted);
    text-align: center;
    line-height: 1.5;
    margin: 2px 0;
}

/* ── Agreement Popup ── */
.agreement-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.8);
    backdrop-filter: blur(8px);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeIn 0.3s ease;
}
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
.agreement-box {
    background: var(--bg-sidebar, #1a1a2e);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 36px 32px 28px;
    max-width: 440px;
    width: 90%;
    text-align: center;
    box-shadow: 0 12px 60px rgba(0,0,0,0.6);
    animation: agreementIn 0.35s ease-out;
}
@keyframes agreementIn {
    from { opacity: 0; transform: scale(0.9) translateY(20px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}
.agreement-icon { margin-bottom: 16px; }
.agreement-title {
    font-size: 22px;
    font-weight: 700;
    color: var(--text);
    margin: 0 0 12px;
}
.agreement-text {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.6;
    margin: 0 0 16px;
}
.agreement-list {
    text-align: left;
    list-style: none;
    padding: 0;
    margin: 0 0 16px;
}
.agreement-list li {
    font-size: 13px;
    color: var(--text-secondary);
    padding: 6px 0;
    padding-left: 20px;
    position: relative;
}
.agreement-list li::before {
    content: '•';
    position: absolute;
    left: 4px;
    color: var(--primary, #7364f5);
    font-weight: bold;
}
.agreement-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 20px;
    font-size: 12px;
}
.agreement-links a {
    color: var(--primary, #7364f5);
    text-decoration: none;
}
.agreement-links a:hover { text-decoration: underline; }
.agreement-links span { color: var(--text-muted); }
.agreement-actions {
    display: flex;
    gap: 12px;
}
.agreement-decline {
    flex: 1;
    padding: 12px;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: 12px;
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}
.agreement-decline:hover { border-color: var(--text-secondary); color: var(--text); }
.agreement-accept {
    flex: 2;
    padding: 12px;
    background: linear-gradient(135deg, #7364f5, #6355e0);
    border: none;
    border-radius: 12px;
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}
.agreement-accept:hover { background: linear-gradient(135deg, #8275f7, #7364f5); }

/* Light theme */
body.light-theme .support-popup { background: #fff; }
body.light-theme .agreement-overlay { background: rgba(0,0,0,0.5); }
body.light-theme .agreement-box { background: #fff; }

/* ══════════════════════════════════════
   Slash Commands Menu
   ══════════════════════════════════════ */

.slash-cmd-menu {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    width: min(640px, calc(100% - 16px));
    max-height: 460px;
    overflow-y: auto;
    background: rgba(20, 20, 28, 0.96);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.6), 0 0 0 1px rgba(255,255,255,0.02) inset;
    z-index: 100;
    padding: 6px;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.12) transparent;
    animation: slashMenuIn 140ms ease-out;
}

@keyframes slashMenuIn {
    from { opacity: 0; transform: translateX(-50%) translateY(6px); }
    to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.slash-cmd-group {
    padding: 10px 14px 6px;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.4);
    text-transform: none;
}

.slash-cmd-menu::-webkit-scrollbar { width: 6px; }
.slash-cmd-menu::-webkit-scrollbar-track { background: transparent; }
.slash-cmd-menu::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.12); border-radius: 10px; }
.slash-cmd-menu::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.2); }

.slash-cmd-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 9px 12px;
    cursor: pointer;
    transition: background 100ms;
    border-radius: 8px;
    margin: 1px 4px;
}

.slash-cmd-item:hover,
.slash-cmd-selected {
    background: rgba(255, 255, 255, 0.06);
}
.slash-cmd-selected {
    background: rgba(115, 100, 245, 0.14);
}

.slash-cmd-icon {
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: rgba(115, 100, 245, 0.10);
    border-radius: 8px;
    color: #c4b5fd;
    transition: background 140ms, color 140ms;
}
.slash-cmd-icon svg { width: 16px; height: 16px; display: block; }
.slash-cmd-item:hover .slash-cmd-icon,
.slash-cmd-selected .slash-cmd-icon { background: rgba(115, 100, 245, 0.20); color: #e0d5ff; }
/* Per-command tint — group-based */
.slash-cmd-menu .slash-cmd-item[data-idx]:has(.slash-cmd-name[data-cmd^="/refactor"]) .slash-cmd-icon,
.slash-cmd-menu .slash-cmd-item:nth-child(n) .slash-cmd-icon { /* fallback */ }
body.light-theme .slash-cmd-icon { background: rgba(115, 100, 245, 0.08); color: #6b5fd6; }
body.light-theme .slash-cmd-item:hover .slash-cmd-icon,
body.light-theme .slash-cmd-selected .slash-cmd-icon { background: rgba(115, 100, 245, 0.16); color: #4c3fc8; }

.slash-cmd-info {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
}

.slash-cmd-name {
    font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 12.5px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.55);
    white-space: nowrap;
    flex-shrink: 0;
}

.slash-cmd-label {
    font-size: 13.5px;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.95);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}

.slash-cmd-desc {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.4);
    margin-left: auto;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 260px;
    text-align: right;
    flex-shrink: 0;
}

/* Light theme */
body.light-theme .slash-cmd-menu {
    background: rgba(255, 255, 255, 0.96);
    border-color: rgba(0, 0, 0, 0.08);
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.12);
}
body.light-theme .slash-cmd-group { color: rgba(0,0,0,0.45); }
body.light-theme .slash-cmd-item:hover { background: rgba(0,0,0,0.05); }
body.light-theme .slash-cmd-selected { background: rgba(115,100,245,0.1); }
body.light-theme .slash-cmd-icon { color: rgba(0,0,0,0.6); }
body.light-theme .slash-cmd-name { color: rgba(0,0,0,0.45); }
body.light-theme .slash-cmd-label { color: rgba(0,0,0,0.92); }
body.light-theme .slash-cmd-desc { color: rgba(0,0,0,0.45); }

@media (max-width: 768px) {
    .slash-cmd-desc { display: none; }
    .slash-cmd-menu { max-height: 340px; width: calc(100% - 12px); }
    .slash-cmd-item { padding: 10px 12px; }
}

/* ══════════════════════════════════════
   @-Mention File Dropdown
   ══════════════════════════════════════ */

.mention-menu {
    display: none;
    position: absolute;
    bottom: 100%;
    left: 0;
    right: 0;
    max-height: 380px;
    overflow-y: auto;
    background: var(--bg-card, #16162a);
    border: 1px solid var(--border, #2a2a4a);
    border-radius: 12px;
    box-shadow: 0 -8px 32px rgba(0,0,0,0.45);
    z-index: 100;
    padding: 6px 0;
    margin-bottom: 4px;
    scrollbar-width: thin;
    scrollbar-color: rgba(99,102,241,0.3) transparent;
}

.mention-menu::-webkit-scrollbar { width: 5px; }
.mention-menu::-webkit-scrollbar-track { background: transparent; }
.mention-menu::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.3); border-radius: 10px; }

.mention-menu-group {
    padding: 10px 16px 4px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted, #666);
}

.mention-menu-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 16px;
    cursor: pointer;
    transition: background 0.12s;
}

.mention-menu-item:hover,
.mention-menu-selected {
    background: rgba(99,102,241,0.12);
}

.mention-menu-icon {
    font-size: 18px;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: rgba(99,102,241,0.1);
    border-radius: 8px;
}

.mention-menu-info {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.mention-menu-name {
    font-family: 'JetBrains Mono', monospace;
    font-size: 13px;
    font-weight: 500;
    color: var(--text, #e0e0e0);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}

.mention-menu-size {
    font-size: 11px;
    color: var(--text-muted, #666);
    white-space: nowrap;
    flex-shrink: 0;
    min-width: 50px;
    text-align: right;
}

/* Light theme */
body.light-theme .mention-menu {
    background: #fff;
    border-color: #e0e0e0;
    box-shadow: 0 -8px 32px rgba(0,0,0,0.12);
}
body.light-theme .mention-menu-item:hover,
body.light-theme .mention-menu-selected {
    background: rgba(99,102,241,0.08);
}
body.light-theme .mention-menu-icon {
    background: rgba(99,102,241,0.08);
}

@media (max-width: 768px) {
    .mention-menu { max-height: 280px; }
    .mention-menu-item { padding: 10px 14px; }
    .mention-menu-size { display: none; }
}

@media (max-width: 600px) {
    .support-popup { width: calc(100vw - 32px); right: -60px; }
    .agreement-box { padding: 24px 20px 20px; }
}

/* ════════════════════════════════════
   Обновление сайта: исправления UI
   ════════════════════════════════════ */

/* 1) Diff icon (light theme tweaks only — base styles above) */
.diff-btn .diff-ico { display: inline-flex; color: currentColor; opacity: .95; }
body.light-theme .diff-btn { background: #eef1ff; border-color: #cdd3ef; color: #4f5baf; }
body.light-theme .diff-btn:hover { background: #e0e5ff; color: #2b3494; }

/* 2) Код: нормальный горизонтальный слайдер вместо прокрутки колесом */
pre, .file-code-preview, .code-block pre {
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--primary, #7c89f6) transparent;
}
pre::-webkit-scrollbar, .file-code-preview::-webkit-scrollbar, .code-block pre::-webkit-scrollbar { height: 10px; width: 10px }
pre::-webkit-scrollbar-track, .file-code-preview::-webkit-scrollbar-track { background: rgba(124,137,246,.06); border-radius: 6px }
pre::-webkit-scrollbar-thumb, .file-code-preview::-webkit-scrollbar-thumb { background: linear-gradient(90deg, #6366f1, #06b6d4); border-radius: 6px }
pre::-webkit-scrollbar-thumb:hover { background: linear-gradient(90deg, #818cf8, #22d3ee) }

/* 3) Синхронный и плавный переход темы — все важные элементы меняются одновременно */
body,
body *,
body *::before,
body *::after {
    transition: background-color .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease;
}
/* Анимации не должны замедляться transition */
.spinner, .loader, .dot-flashing, [data-animate], .hero-sparkle, .anim-chat-scene, .anim-bolt-scene, .anim-rocket-scene, .chat-bubble, .bolt-ring, .spark, .flame, .energy-dot, .starfield-bg, .stars, .star { transition: none !important }

/* 4) Крестик закрытия в split-режиме не должен перекрывать файловую систему */
.split-close-btn, .split-pane-close, button[data-split-close], .split-chat-close {
    z-index: 20 !important;
    right: 8px !important;
    top: 8px !important;
    pointer-events: auto;
}
/* Файловый менеджер в split-окне должен иметь более высокий слой */
.split-pane .file-manager, .split-pane .fm-panel, .split-pane-files { z-index: 30; position: relative; padding-top: 38px }

/* 5) Блок подписок не должен перекрывать фон */
.sub-grid, .sub-panel, .subscription-wrap, .subscription-panel, #sub-panel,
.pricing-grid { background: transparent !important }
.sub-card { background: var(--bg-card, #0f0f1a); }
body.light-theme .sub-card { background: #f8f9fc }

/* 6) Блоки «Начни кодить с ИИ» и «Возможности» — прозрачная подложка */
.section-cta, #features, .features-section, .how-section, #how { background: transparent !important }
.cta-content, .features-grid, .steps { background: transparent !important }

/* 7) Файловое меню в стиле Windows Explorer */
.fm-explorer-menu {
    position: absolute;
    background: var(--bg-card, #0f0f1a);
    border: 1px solid var(--border, #1a1a2e);
    border-radius: 8px;
    min-width: 220px;
    padding: 4px;
    box-shadow: 0 8px 30px rgba(0,0,0,.4);
    z-index: 9999;
}
.fm-explorer-menu-item {
    display: flex; align-items: center; gap: 10px;
    padding: 7px 12px;
    font-size: 13px; color: var(--text, #e2e2f0);
    border-radius: 5px; cursor: pointer;
}
.fm-explorer-menu-item:hover { background: rgba(99,102,241,.15) }
.fm-explorer-menu-item .fm-ico { width: 16px; height: 16px; color: var(--primary-light, #818cf8) }
.fm-explorer-menu-sep { height: 1px; background: var(--border, #1a1a2e); margin: 4px 0 }
.fm-explorer-menu-hint { font-size: 11px; color: var(--text-muted, #4e4e6a); margin-left: auto; font-family: 'JetBrains Mono', monospace }

/* 8) Память и Top-4 модели — индикаторы в шапке */
.resource-indicators {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 8px;
    flex-wrap: wrap;
}
.resource-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 8px;
    background: var(--bg-card, #0f0f1a);
    border: 1px solid var(--border, #1a1a2e);
    border-radius: 12px;
    font-size: 10.5px;
    font-weight: 600;
    color: var(--text-secondary, #a0a0c0);
    cursor: pointer;
    transition: all .15s;
    white-space: nowrap;
    line-height: 1;
    height: 24px;
}
.resource-chip:hover { border-color: var(--primary, #7c89f6); color: var(--text, #fff) }
.resource-chip .chip-ico { color: var(--primary-light, #818cf8); display: inline-flex; flex-shrink: 0 }
.resource-chip .chip-label { white-space: nowrap }
.resource-chip .chip-val { white-space: nowrap; color: var(--text, #fff) }
.resource-chip .chip-bar { width: 40px; height: 5px; background: var(--bg-input, #0c0c18); border-radius: 3px; overflow: hidden; margin: 0 2px; flex-shrink: 0 }
.resource-chip .chip-bar-fill { height: 100%; background: linear-gradient(90deg, #22c55e, #06b6d4); transition: width .3s }
.resource-chip.warning .chip-bar-fill { background: linear-gradient(90deg, #f59e0b, #ef4444) }
.resource-chip.exhausted { opacity: .5; text-decoration: line-through }

/* 9) Welcome-modal (первый вход) */
.welcome-overlay {
    position: fixed; inset: 0;
    background: rgba(9, 9, 15, .92);
    backdrop-filter: blur(10px);
    z-index: 9998;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
}
.welcome-modal {
    max-width: 820px; width: 100%; max-height: 90vh; overflow: auto;
    background: var(--bg-card, #0f0f1a);
    border: 1px solid var(--border, #1a1a2e);
    border-radius: 16px;
    padding: 28px 30px;
    box-shadow: 0 20px 80px rgba(99,102,241,.18);
}
.welcome-title {
    font-size: 22px; font-weight: 800;
    background: linear-gradient(90deg, #6366f1, #06b6d4);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    margin-bottom: 8px;
}
.welcome-sub { font-size: 13px; color: var(--text-muted, #8080a0); margin-bottom: 20px }
.welcome-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 18px }
.welcome-card {
    background: var(--bg-input, #0c0c18);
    border: 1.5px solid var(--border, #1a1a2e);
    border-radius: 12px;
    padding: 16px;
    cursor: pointer;
    transition: all .18s;
    position: relative;
}
.welcome-card:hover { border-color: var(--primary, #7c89f6); transform: translateY(-2px) }
.welcome-card.selected { border-color: var(--primary, #7c89f6); background: rgba(99,102,241,.1) }
.welcome-card-ico { font-size: 26px; margin-bottom: 8px }
.welcome-card-title { font-size: 14px; font-weight: 700; margin-bottom: 4px; color: var(--text, #e2e2f0) }
.welcome-card-desc { font-size: 12px; color: var(--text-muted, #8080a0); line-height: 1.5 }
.welcome-actions { display: flex; gap: 10px; justify-content: flex-end; border-top: 1px solid var(--border, #1a1a2e); padding-top: 16px }
.welcome-btn { padding: 9px 20px; border-radius: 9px; font-family: inherit; font-size: 13px; font-weight: 700; cursor: pointer; border: none; transition: all .15s }
.welcome-btn-primary { background: linear-gradient(135deg, #6366f1, #06b6d4); color: #fff }
.welcome-btn-primary:disabled { opacity: .45; cursor: not-allowed }
.welcome-btn-ghost { background: transparent; color: var(--text-secondary, #a0a0c0); border: 1px solid var(--border, #1a1a2e) }
.welcome-btn-ghost:hover { color: var(--text, #fff); border-color: var(--primary, #7c89f6) }
.welcome-btn-cancel { background: transparent; color: var(--text-muted, #8080a0); border: 1px dashed var(--border, #2a2a3e) }
@media (max-width: 620px) {
    .welcome-grid { grid-template-columns: 1fr }
    .welcome-modal { padding: 20px 18px }
}

/* 10) Servers panel (мини-меню мониторинга серверов) */
.servers-panel-overlay {
    position: fixed; inset: 0; background: rgba(9,9,15,.88);
    z-index: 9997; display: none; align-items: center; justify-content: center; padding: 20px;
}
.servers-panel-overlay.active { display: flex }
.servers-panel {
    max-width: 960px; width: 100%; max-height: 90vh; overflow: auto;
    background: var(--bg-card, #0f0f1a);
    border: 1px solid var(--border, #1a1a2e);
    border-radius: 16px;
    padding: 24px 28px;
}
.servers-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px }
.server-card {
    background: var(--bg-input, #0c0c18);
    border: 1px solid var(--border, #1a1a2e);
    border-radius: 12px; padding: 14px 16px;
}
.server-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px }
.server-card-name { font-weight: 700; font-size: 14px }
.server-card-status { font-size: 11px; padding: 2px 8px; border-radius: 10px }
.server-card-status.online { background: rgba(34,197,94,.15); color: #22c55e }
.server-card-status.offline { background: rgba(239,68,68,.15); color: #ef4444 }
.server-card-row { display: flex; justify-content: space-between; font-size: 12px; margin: 4px 0; color: var(--text-secondary, #a0a0c0) }
.server-card-bar { height: 6px; background: var(--bg, #09090f); border-radius: 3px; overflow: hidden; margin-top: 3px }
.server-card-bar-fill { height: 100%; background: linear-gradient(90deg, #22c55e, #06b6d4); transition: width .4s }
.server-card-bar-fill.warn { background: linear-gradient(90deg, #f59e0b, #ef4444) }

/* ═════════════════════════════════════════════════════════════
   SERVERS v2 — Sidebar section, Live monitor panel, Wizard
   ═════════════════════════════════════════════════════════════ */

/* ── Sidebar section ──────────────────────────────────── */
.sb-servers-section {
    padding: 8px 12px 4px;
    border-top: 1px dashed var(--border, #1a1a2e);
    margin-top: 4px;
    flex: 0 0 auto !important;
    max-height: 220px;
    overflow-y: auto;
    min-height: 0;
}
.sb-servers-section.sb-collapsed .sb-servers-list { display: none }
.sb-servers-section.sb-collapsed { max-height: 40px; overflow: hidden }
.sb-servers-title {
    display:flex; align-items:center; justify-content:space-between;
    font-size:10.5px; font-weight:700; letter-spacing:.6px; color: var(--text-muted,#8080a0);
    padding: 6px 0 4px; cursor:pointer; user-select:none;
}
.sb-servers-title:hover { color: var(--text,#e2e2f0) }
.sb-servers-list { display: flex; flex-direction: column; gap: 4px }
.sb-server-add-btn {
    display:flex; align-items:center; gap:8px;
    width:100%; padding:8px 10px; font-size:12.5px; font-weight:600;
    background: linear-gradient(135deg, rgba(99,102,241,.08), rgba(6,182,212,.05));
    border: 1px dashed rgba(99,102,241,.3);
    color: var(--text,#e2e2f0); border-radius:8px;
    cursor:pointer; font-family:inherit;
    transition: all .2s;
}
.sb-server-add-btn:hover { border-color: rgba(99,102,241,.6); background: linear-gradient(135deg, rgba(99,102,241,.15), rgba(6,182,212,.1)) }
.sb-server-add-btn svg { color:#7c7fff }
.sb-servers-items { display: flex; flex-direction: column; gap: 2px; margin-top: 2px }
.sb-server-item {
    display:flex; align-items:center; gap:8px;
    padding: 7px 10px; font-size:12px; text-align:left;
    background: transparent; border: 1px solid transparent;
    color: var(--text,#e2e2f0); border-radius:7px;
    cursor:pointer; font-family:inherit; width:100%;
    transition: all .15s;
}
.sb-server-item:hover { background: rgba(255,255,255,.03); border-color: var(--border,#1a1a2e) }
.sb-server-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap }
.sb-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; box-shadow:0 0 6px currentColor }
.sb-dot-ok { background:#22c55e; color:#22c55e }
.sb-dot-bad { background:#ef4444; color:#ef4444 }
.sb-dot-idle { background:#6b7280; color:transparent; box-shadow:none }
.sb-server-del { color: var(--text-muted,#8080a0); padding: 0 4px; border-radius:4px; font-size:10px }
.sb-server-del:hover { color:#ef4444; background: rgba(239,68,68,.12) }

/* ── Live monitor panel ───────────────────────────────── */
.srv-panel-v2 {
    max-width: 1080px; padding: 22px 26px;
    background: linear-gradient(180deg, #0f0f1e 0%, #0a0a14 100%);
    border: 1px solid rgba(99,102,241,.2);
    box-shadow: 0 20px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(99,102,241,.08) inset;
}
.srv-panel-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:18px; gap:16px }
.srv-panel-title { font-size:22px; font-weight:800; background: linear-gradient(135deg,#a29bfe,#06b6d4); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent }
.srv-panel-sub { font-size:12px; color: var(--text-muted,#8080a0); margin-top:4px }
.srv-btn {
    padding: 8px 14px; border-radius:8px; font-family:inherit; cursor:pointer;
    font-size:13px; font-weight:600; border:1px solid var(--border,#1a1a2e);
    background: transparent; color: var(--text,#e2e2f0);
    display:inline-flex; align-items:center; gap:6px; transition: all .2s;
}
.srv-btn-ghost:hover { background: rgba(255,255,255,.04); border-color: rgba(99,102,241,.4) }
.srv-btn-primary {
    background: linear-gradient(135deg,#6366f1,#06b6d4); color:#fff; border:none;
    box-shadow: 0 4px 14px rgba(99,102,241,.3);
}
.srv-btn-primary:hover { box-shadow: 0 6px 20px rgba(99,102,241,.45); transform: translateY(-1px) }

.srv-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 14px }
.srv-empty { grid-column:1/-1; text-align:center; padding: 50px 20px }
.srv-empty-ico { font-size:52px; margin-bottom:14px; filter: drop-shadow(0 4px 12px rgba(99,102,241,.3)) }
.srv-empty-title { font-size:18px; font-weight:700; margin-bottom:6px; color: var(--text,#e2e2f0) }
.srv-empty-sub { font-size:13px; color: var(--text-muted,#8080a0); line-height:1.6 }

.srv-card {
    background: linear-gradient(180deg, #13131f 0%, #0c0c18 100%);
    border: 1px solid rgba(99,102,241,.15);
    border-radius: 14px; padding: 16px 18px;
    transition: all .25s;
    display:flex; flex-direction:column; gap:12px;
}
.srv-card:hover { border-color: rgba(99,102,241,.35); transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,0,0,.3) }
.srv-card-loading { opacity:.7 }
.srv-card-disabled { opacity:.68; filter:saturate(.75) }
.srv-card-disabled:hover { transform:none; box-shadow:none }
.srv-card-head { display:flex; justify-content:space-between; align-items:flex-start; gap:10px }
.srv-card-head-left { display:flex; flex-direction:column; gap:3px; min-width:0; flex:1 }
.srv-card-name { font-weight:700; font-size:15px; color: var(--text,#e2e2f0); overflow:hidden; text-overflow:ellipsis; white-space:nowrap }
.srv-card-host { font-size:11px; color: var(--text-muted,#8080a0); font-family:'JetBrains Mono',monospace; overflow:hidden; text-overflow:ellipsis; white-space:nowrap }
.srv-card-status { display:inline-flex; align-items:center; gap:6px; font-size:11px; padding:4px 10px; border-radius:20px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.05); white-space:nowrap; flex-shrink:0; font-weight:600 }
.srv-card-status.srv-status-online { background: rgba(34,197,94,.12); border-color: rgba(34,197,94,.3); color:#86efac }
.srv-card-status.srv-status-offline { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.3); color:#fca5a5 }
.srv-card-status.srv-status-idle { background: rgba(107,114,128,.12); border-color: rgba(107,114,128,.25); color:#9ca3af }
.srv-status-dot { width:7px; height:7px; border-radius:50%; display:inline-block; flex-shrink:0 }
.srv-status-dot.srv-on { background:#22c55e; box-shadow:0 0 8px #22c55e; animation: pyRunPulse 2s ease-in-out infinite }
.srv-status-dot.srv-off { background:#ef4444 }
.srv-status-dot.srv-idle { background:#6b7280 }

.srv-card-metrics { display:flex; flex-direction:column; gap:9px }
.srv-metric { display:flex; flex-direction:column; gap:4px }
.srv-metric-row { display:flex; justify-content:space-between; align-items:baseline; font-size:12px }
.srv-metric-label { color: var(--text-muted,#8080a0); font-weight:600; letter-spacing:.2px }
.srv-metric-val { font-weight:700; color: var(--text,#e2e2f0); font-variant-numeric: tabular-nums; font-size:12.5px }
.srv-bar { height:6px; background: rgba(255,255,255,.05); border-radius:4px; overflow:hidden; position:relative }
.srv-bar-fill { height:100%; border-radius:4px; transition: width .6s cubic-bezier(.4,0,.2,1), background .3s; background: linear-gradient(90deg, #6366f1, #06b6d4) }
.srv-bar-fill.idle { background: linear-gradient(90deg, #475569, #64748b) }
.srv-bar-fill.ok   { background: linear-gradient(90deg, #22c55e, #10b981) }
.srv-bar-fill.warn { background: linear-gradient(90deg, #f59e0b, #eab308) }
.srv-bar-fill.crit { background: linear-gradient(90deg, #ef4444, #f97316); box-shadow: 0 0 8px rgba(239,68,68,.35) }
.srv-bar-fill.hot  { background: linear-gradient(90deg, #06b6d4, #f59e0b) } /* legacy */

.srv-card-info { display:flex; flex-wrap:wrap; gap:6px; padding-top:4px }
.srv-info-chip {
    display:inline-flex; align-items:center; gap:5px;
    font-size:10.5px; font-weight:600; font-family:'JetBrains Mono',monospace;
    padding:3px 9px; border-radius:20px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.05);
    color: var(--text-muted,#8080a0);
}
.srv-info-chip svg { opacity:.7; flex-shrink:0 }
.srv-info-chip.srv-chip-crit { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.3); color:#fca5a5 }
.srv-net-sep { opacity:.4; margin:0 1px }
/* Phase 3: счётчик команд/мин */
.srv-cmd-counter { font-size:11px; font-weight:700; font-family:'JetBrains Mono',monospace; padding:4px 10px; border-radius:20px; background:rgba(124,137,246,.14); border:1px solid rgba(124,137,246,.3); color:#a5b4fc; white-space:nowrap }
.srv-cmd-counter.srv-cmd-counter-warn { background:rgba(245,158,11,.16); border-color:rgba(245,158,11,.4); color:#fbbf24 }
.srv-cmd-counter.is-hidden { display:none }
/* Phase 3: бейдж среды сервера */
.srv-scope-badge { font-size:9px; font-weight:800; letter-spacing:.04em; padding:2px 6px; border-radius:5px; vertical-align:middle; margin-left:6px }
.srv-scope-prod { background:rgba(239,68,68,.16); color:#fca5a5; border:1px solid rgba(239,68,68,.3) }
.srv-scope-staging { background:rgba(245,158,11,.16); color:#fcd34d; border:1px solid rgba(245,158,11,.3) }
.srv-scope-dev { background:rgba(34,197,94,.14); color:#86efac; border:1px solid rgba(34,197,94,.3) }
/* Phase 3: scope-табы в визарде */
.srv-scope-tabs { display:flex; gap:6px; margin:10px 0 4px }
.srv-scope-tab { flex:1; padding:8px 6px; font-size:12px; font-weight:600; border-radius:9px; cursor:pointer; background:var(--bg-input,#14141d); border:1px solid var(--border,rgba(255,255,255,.12)); color:var(--text-muted,#8a93a2) }
.srv-scope-tab.active { background:rgba(124,137,246,.18); border-color:#6c5ce7; color:#fff }
/* Phase 3: журнал действий */
.srv-jr-row { padding:8px 10px; border:1px solid rgba(255,255,255,.06); border-radius:9px; background:rgba(255,255,255,.02) }
.srv-jr-line { display:flex; align-items:center; gap:6px; margin-bottom:4px; flex-wrap:wrap }
.srv-jr-tool { font-size:11px; font-weight:700; font-family:'JetBrains Mono',monospace; padding:2px 7px; border-radius:5px }
.srv-jr-tool.srv-jr-ok { background:rgba(34,197,94,.14); color:#86efac }
.srv-jr-tool.srv-jr-warn { background:rgba(245,158,11,.16); color:#fcd34d }
.srv-jr-tool.srv-jr-crit { background:rgba(239,68,68,.16); color:#fca5a5 }
.srv-jr-tag { font-size:9.5px; font-weight:700; padding:1px 6px; border-radius:4px }
.srv-jr-tag.srv-jr-conf { background:rgba(34,197,94,.14); color:#86efac }
.srv-jr-tag.srv-jr-warn { background:rgba(245,158,11,.16); color:#fcd34d }
.srv-jr-time { margin-left:auto; font-size:10.5px; color:var(--text-muted,#8a93a2); font-family:'JetBrains Mono',monospace }
.srv-jr-cmd { display:block; font-size:11.5px; font-family:'JetBrains Mono',monospace; color:#cbd5e1; word-break:break-all; white-space:pre-wrap }

.srv-card-foot { display:flex; justify-content:space-between; align-items:center; padding-top:10px; border-top: 1px solid rgba(255,255,255,.05) }
.srv-card-uptime { font-size:11px; color: var(--text-muted,#8080a0); font-family:'JetBrains Mono',monospace }
.srv-card-actions { display:flex; gap:6px; flex-wrap:wrap; padding-top:6px; border-top: 1px solid rgba(255,255,255,.05) }
.srv-mini {
    display:inline-flex; align-items:center; gap:5px;
    padding: 6px 10px; font-size:11.5px; font-weight:600;
    border-radius:7px; cursor:pointer; font-family:inherit;
    border: 1px solid transparent; background: rgba(255,255,255,.04); color: var(--text-secondary,#a0a0c0);
    transition: all .15s; white-space:nowrap;
}
.srv-mini svg { flex-shrink:0 }
.srv-mini:hover { transform: translateY(-1px) }
.srv-mini:disabled { opacity:.48; cursor:not-allowed; transform:none; box-shadow:none }
.srv-mini:disabled:hover { transform:none; background: rgba(255,255,255,.04); color: var(--text-secondary,#a0a0c0); border-color: transparent }
.srv-mini-ghost:hover { background: rgba(99,102,241,.15); color:#a5b4fc; border-color: rgba(99,102,241,.3) }
.srv-mini-primary { background: linear-gradient(135deg, rgba(99,102,241,.18), rgba(6,182,212,.15)); color:#a5b4fc; border-color: rgba(99,102,241,.28) }
.srv-mini-primary:hover { background: linear-gradient(135deg, rgba(99,102,241,.3), rgba(6,182,212,.25)); color:#c7d2fe; border-color: rgba(99,102,241,.5); box-shadow: 0 4px 14px rgba(99,102,241,.25) }
.srv-mini-danger { margin-left:auto }
.srv-mini-danger:hover { background: rgba(239,68,68,.15); color:#f87171; border-color: rgba(239,68,68,.3) }

/* ── Wizard ──────────────────────────────────────────── */
.srv-wizard-overlay {
    position:fixed; inset:0; background: rgba(0,0,0,.85);
    z-index:10000; align-items:center; justify-content:center; padding:20px;
    backdrop-filter: blur(8px);
}
.srv-wizard {
    background: #0a0a14;
    border: 1px solid rgba(99,102,241,.25);
    border-radius: 20px;
    padding: 40px 40px 32px;
    max-width: 540px; width: 100%;
    box-shadow: 0 30px 80px rgba(0,0,0,.6), 0 0 60px rgba(99,102,241,.1);
    position:relative; overflow:hidden;
}
.srv-wizard::before {
    content:''; position:absolute; top:-40%; left:-40%; width:180%; height:80%;
    background: radial-gradient(ellipse at center, rgba(99,102,241,.12) 0%, transparent 60%);
    pointer-events:none;
}
.srv-steps { display:flex; align-items:center; justify-content:center; gap:0; margin-bottom:30px; position:relative; z-index:1 }
.srv-step-dot {
    width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center;
    background: #1a1a2e; border:2px solid #2a2a42; color: var(--text-muted,#8080a0);
    font-weight:700; font-size:14px; flex-shrink:0;
    transition: all .3s; position:relative;
}
.srv-step-dot.active {
    background: #06b6d4; border-color:#06b6d4; color:#fff;
    box-shadow: 0 0 0 4px rgba(6,182,212,.2), 0 0 24px rgba(6,182,212,.6);
    transform: scale(1.08);
}
.srv-step-dot.done {
    background:#22c55e; border-color:#22c55e; color:#fff;
}
.srv-step-dot.done span::before { content:'✓'; }
.srv-step-dot.done span { font-size:0 }
.srv-step-dot.done span::before { font-size:16px }
.srv-step-line { height:2px; width:60px; background:#1a1a2e; transition: background .4s; margin: 0 -2px; z-index:0 }
.srv-step-line.done { background: linear-gradient(90deg, #22c55e, #06b6d4) }

.srv-step-pane { display:none; text-align:center; position:relative; z-index:1 }
.srv-step-pane.active { display:block; animation: srv-fadein .4s ease }
@keyframes srv-fadein { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none} }
.srv-wizard-title { font-size:22px; font-weight:800; margin:0 0 6px; color:#fff }
.srv-wizard-sub { font-size:13px; color: var(--text-muted,#8080a0); margin:0 0 16px; line-height:1.55 }
/* Phase: редизайн визарда добавления сервера */
.srv-wz-hero { display:flex; justify-content:center; margin:2px 0 14px }
.srv-wz-hero svg { padding:13px; background:rgba(124,137,246,.1); border:1px solid rgba(124,137,246,.22); border-radius:16px }
.srv-wz-bullets { list-style:none; padding:0; margin:0 0 18px; display:flex; flex-direction:column; gap:9px }
.srv-wz-bullets li { display:flex; align-items:flex-start; gap:9px; font-size:12.5px; color:#c7c7e0; line-height:1.45; text-align:left }
.srv-wz-bullets li svg { flex-shrink:0; margin-top:1px }
.srv-wz-label { display:block; text-align:left; font-size:12px; font-weight:700; color:#a5b4fc; margin:10px 0 6px }
.srv-wz-label-note { font-weight:400; color:var(--text-muted,#8080a0) }
.srv-wz-hint { text-align:left; font-size:11.5px; color:var(--text-muted,#8080a0); margin:0 0 8px; line-height:1.4 }
.srv-scope-hint { background:rgba(124,137,246,.07); border-left:2px solid rgba(124,137,246,.45); padding:7px 10px; border-radius:0 7px 7px 0; margin:0 0 10px; color:#b9c0e0 }
.srv-wz-adv { margin:4px 0; text-align:left }
.srv-wz-adv > summary { cursor:pointer; font-size:12.5px; color:#a5b4fc; padding:6px 0; list-style:none; user-select:none }
.srv-wz-adv > summary::-webkit-details-marker { display:none }
.srv-wz-adv > summary::before { content:'▸ ' }
.srv-wz-adv[open] > summary::before { content:'▾ ' }
.srv-scope-tab small { display:block; font-size:9px; font-weight:600; opacity:.55; margin-top:1px; font-family:'JetBrains Mono',monospace }
.srv-wizard-input {
    width:100%; padding: 14px 18px; font-size:14px;
    background: #13132a; border: 1px solid #1e1e36; color:#e2e2f0;
    border-radius: 12px; font-family:inherit; outline:none;
    transition: all .2s; margin-bottom:10px; box-sizing:border-box;
}
.srv-wizard-input:focus { border-color: #06b6d4; box-shadow: 0 0 0 3px rgba(6,182,212,.15) }
.srv-wizard-input::placeholder { color:#555577 }
.srv-wizard-textarea { font-family:'JetBrains Mono',monospace; font-size:11.5px; resize:vertical; min-height:110px }
.srv-wizard-grid { display:grid; grid-template-columns: 2fr 1fr; gap:10px }
.srv-wizard-grid > * { margin-bottom:0 }

.srv-auth-tabs { display:flex; gap:8px; margin: 14px 0 12px; background:#0f0f1e; padding:4px; border-radius:10px; border:1px solid #1e1e36 }
.srv-auth-tab {
    flex:1; padding:8px 12px; font-size:12.5px; font-weight:600; font-family:inherit;
    background:transparent; border:none; color: var(--text-muted,#8080a0); cursor:pointer;
    border-radius:7px; transition: all .2s;
}
.srv-auth-tab.active { background: #06b6d4; color:#fff; box-shadow: 0 2px 8px rgba(6,182,212,.3) }
.srv-auth-tab:not(.active):hover { color: var(--text,#e2e2f0) }

.srv-wizard-btn {
    width:100%; padding: 14px; font-size:14px; font-weight:700;
    border-radius:12px; cursor:pointer; border:none; font-family:inherit;
    transition: all .2s; margin-top:6px;
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
}
.srv-wizard-btn-sm { width:auto; padding:12px 22px; flex:1 }
.srv-wizard-btn-primary {
    background: linear-gradient(135deg, #6366f1, #06b6d4); color:#fff;
    box-shadow: 0 6px 20px rgba(99,102,241,.35);
}
.srv-wizard-btn-primary:hover:not(:disabled) { transform:translateY(-1px); box-shadow: 0 8px 24px rgba(99,102,241,.5) }
.srv-wizard-btn-ghost {
    background:#13132a; border:1px solid #1e1e36; color: var(--text-muted,#8080a0);
}
.srv-wizard-btn-ghost:hover:not(:disabled) { background:#18182e; color: var(--text,#e2e2f0); border-color: #2a2a42 }
.srv-wizard-btn:disabled { opacity:.55; cursor:not-allowed }
.srv-wizard-cancel {
    display:block; margin: 14px auto 0; background:transparent; border:none;
    color: var(--text-muted,#8080a0); font-size:12px; cursor:pointer; font-family:inherit;
    padding:6px 10px; border-radius:6px;
}
.srv-wizard-cancel:hover { color:#ef4444; background: rgba(239,68,68,.08) }

/* Step 3 test states */
.srv-test-state { text-align:center; padding: 20px 0 }
.srv-test-ico { font-size:48px; margin-bottom:10px; width:68px; height:68px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-weight:800 }
.srv-test-loading .srv-test-spinner {
    width:56px; height:56px; margin:0 auto 14px;
    border: 3px solid rgba(99,102,241,.2); border-top-color: #06b6d4;
    border-radius:50%; animation: osc-spin 1s linear infinite;
}
.srv-test-ok .srv-test-ico { background: rgba(34,197,94,.15); color:#22c55e; font-size:36px }
.srv-test-fail .srv-test-ico { background: rgba(239,68,68,.15); color:#ef4444; font-size:36px }
.srv-test-title { font-size:17px; font-weight:700; margin-bottom:4px; color:#fff }
.srv-test-sub { font-size:12px; color: var(--text-muted,#8080a0); line-height:1.6 }
.srv-test-sub code { background: rgba(99,102,241,.15); padding:2px 8px; border-radius:5px; font-family:'JetBrains Mono',monospace; color:#a5b4fc }
.srv-test-out {
    margin: 12px 0 0; padding: 10px 14px; font-size:11px;
    background: #0a0a14; border: 1px solid #1e1e36; border-radius:8px;
    color: #22c55e; font-family:'JetBrains Mono',monospace;
    max-height:120px; overflow:auto; text-align:left; white-space:pre-wrap; word-break:break-all;
}
.srv-test-out-err { color:#f87171 }

/* Responsive */
@media (max-width:600px) {
    .srv-wizard { padding: 30px 20px 24px }
    .srv-step-line { width:40px }
    .srv-wizard-grid { grid-template-columns: 1fr }
    .srv-grid { grid-template-columns: 1fr }
}

/* 11) Loading bar / stop generation button — плавная остановка */
.ai-stop-hint { font-size: 11px; color: #f59e0b; margin-top: 4px }

/* 12) Подсветка кода в сообщениях ИИ — inline подсветка для лучшей читаемости */
.msg-assistant pre code { font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 13.5px }
.msg-assistant code:not(pre code) {
    background: rgba(99,102,241,.12);
    padding: 1px 6px;
    border-radius: 4px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12.5px;
    color: #a5b4fc;
    border: 1px solid rgba(99,102,241,.2);
}
body.light-theme .msg-assistant code:not(pre code) {
    background: rgba(99,102,241,.1);
    color: #4338ca;
    border-color: rgba(99,102,241,.15);
}
/* Ключевые слова в inline-тексте ассистента */
.msg-assistant .hl-kw { color: #c084fc; font-weight: 600 }
.msg-assistant .hl-fn { color: #60a5fa }
.msg-assistant .hl-str { color: #4ade80 }
.msg-assistant .hl-num { color: #fbbf24 }

/* ═══════════════════════════════════════════════════════════════
   "Pretty Panel" — reusable polished modal for memory, Top-4,
   dialog summaries, tools, etc. Glassy, with gradient header,
   icon badge, section cards, copy/close actions.
   ═══════════════════════════════════════════════════════════════ */
.pp-overlay {
    position: fixed; inset: 0; z-index: 10050;
    display: flex; align-items: center; justify-content: center;
    background: rgba(8, 8, 18, 0.62);
    backdrop-filter: blur(10px) saturate(1.1);
    -webkit-backdrop-filter: blur(10px) saturate(1.1);
    animation: fadeIn .22s ease-out;
}
@keyframes ppScaleIn {
    from { opacity: 0; transform: scale(.96) translateY(8px); }
    to   { opacity: 1; transform: scale(1)  translateY(0);    }
}
.pp-overlay.pp-closing { animation: ppFadeOut .18s ease-in forwards; }
@keyframes ppFadeOut { to { opacity: 0 } }

.pp-panel {
    position: relative;
    width: min(560px, 92vw);
    max-height: 86vh;
    display: flex; flex-direction: column;
    background: linear-gradient(175deg, rgba(28,28,42,.96) 0%, rgba(18,18,30,.98) 100%);
    border: 1px solid rgba(115,100,245,.28);
    border-radius: 18px;
    box-shadow:
        0 24px 60px -12px rgba(0,0,0,.6),
        0 0 0 1px rgba(255,255,255,.04) inset,
        0 40px 80px -40px rgba(115,100,245,.35);
    overflow: hidden;
    animation: ppScaleIn .24s cubic-bezier(.16,1,.3,1);
}
body.light-theme .pp-panel {
    background: linear-gradient(175deg, #ffffff 0%, #f6f7fb 100%);
    border-color: rgba(115,100,245,.22);
    box-shadow:
        0 24px 60px -12px rgba(40,30,90,.18),
        0 0 0 1px rgba(115,100,245,.06) inset;
}
.pp-panel.pp-wide { width: min(720px, 94vw); }

/* Decorative gradient glow strip at the top */
.pp-panel::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(0,206,201,.9) 20%,
        rgba(115,100,245,.95) 50%,
        rgba(253,121,168,.9) 80%,
        transparent 100%);
    pointer-events: none;
    filter: blur(.4px);
}

.pp-head {
    display: flex; align-items: center; gap: 14px;
    padding: 18px 22px 16px;
    border-bottom: 1px solid rgba(115,100,245,.12);
    position: relative;
}
body.light-theme .pp-head { border-bottom-color: rgba(115,100,245,.12); }

.pp-head-icon {
    width: 40px; height: 40px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, rgba(115,100,245,.25), rgba(0,206,201,.18));
    border: 1px solid rgba(115,100,245,.35);
    color: #b9aeff;
    flex-shrink: 0;
    position: relative;
}
.pp-head-icon svg { width: 22px; height: 22px; }
.pp-head-icon::after {
    content: ''; position: absolute; inset: 2px;
    border-radius: 10px;
    background: radial-gradient(120% 80% at 30% 20%, rgba(255,255,255,.14), transparent 55%);
    pointer-events: none;
}

.pp-head-text { flex: 1; min-width: 0; }
.pp-title {
    font-size: 15.5px; font-weight: 700; line-height: 1.25;
    color: var(--text, #e8e8f0);
    letter-spacing: -0.01em;
    display: flex; align-items: center; gap: 8px;
}
.pp-subtitle {
    margin-top: 3px;
    font-size: 12px; font-weight: 500;
    color: var(--text-muted, #8f8fa8);
    line-height: 1.35;
}

.pp-close {
    appearance: none; background: transparent; border: none;
    color: var(--text-muted, #9090a8);
    width: 32px; height: 32px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background .15s, color .15s, transform .15s;
}
.pp-close:hover {
    background: rgba(255,255,255,.06);
    color: var(--text, #e8e8f0);
    transform: rotate(90deg);
}
body.light-theme .pp-close:hover { background: rgba(0,0,0,.05); }
.pp-close svg { width: 16px; height: 16px; }

.pp-body {
    flex: 1; overflow-y: auto;
    padding: 16px 22px 20px;
    scrollbar-width: thin;
    scrollbar-color: rgba(115,100,245,.4) transparent;
}
.pp-body::-webkit-scrollbar { width: 6px; }
.pp-body::-webkit-scrollbar-thumb { background: rgba(115,100,245,.35); border-radius: 3px; }
.pp-body::-webkit-scrollbar-thumb:hover { background: rgba(115,100,245,.6); }

.pp-section {
    background: rgba(255,255,255,.025);
    border: 1px solid rgba(115,100,245,.1);
    border-radius: 12px;
    padding: 12px 14px;
    margin-bottom: 12px;
}
body.light-theme .pp-section {
    background: rgba(115,100,245,.04);
    border-color: rgba(115,100,245,.12);
}
.pp-section:last-child { margin-bottom: 0; }

.pp-section-title {
    font-size: 11px; font-weight: 700;
    letter-spacing: .06em; text-transform: uppercase;
    color: var(--text-muted, #8f8fa8);
    display: flex; align-items: center; gap: 8px;
    margin-bottom: 10px;
}
.pp-section-title svg { width: 13px; height: 13px; opacity: .7; }
.pp-section-title .pp-badge {
    margin-left: auto;
    padding: 2px 8px;
    border-radius: 10px;
    background: rgba(115,100,245,.18);
    color: #b9aeff;
    font-size: 10.5px;
    letter-spacing: .02em;
    text-transform: none;
    font-weight: 600;
}

.pp-section-body {
    font-size: 13px; line-height: 1.55;
    color: var(--text, #e0e0ec);
    word-wrap: break-word; white-space: pre-wrap;
}
.pp-section-body.pp-mono {
    font-family: 'JetBrains Mono', ui-monospace, Menlo, monospace;
    font-size: 12.25px;
    background: rgba(0,0,0,.22);
    padding: 10px 12px; border-radius: 8px;
    max-height: 260px; overflow-y: auto;
}
body.light-theme .pp-section-body.pp-mono { background: rgba(0,0,0,.04); }

.pp-empty {
    padding: 22px 12px;
    text-align: center;
    color: var(--text-muted, #8f8fa8);
    font-style: italic; font-size: 13px;
}
.pp-empty svg {
    width: 36px; height: 36px; display: block;
    margin: 0 auto 10px; opacity: .45;
}

/* Fact list — used by memory panel */
.pp-fact-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.pp-fact {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 8px 10px;
    background: rgba(115,100,245,.05);
    border-left: 3px solid rgba(115,100,245,.45);
    border-radius: 4px 8px 8px 4px;
    font-size: 13px; line-height: 1.45;
}
.pp-fact-num {
    flex-shrink: 0;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(115,100,245,.4), rgba(0,206,201,.3));
    color: #fff;
    font-size: 10.5px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    line-height: 1; padding-top: 1px;
}
.pp-fact-text { flex: 1; min-width: 0; }

/* Stat row — used by Top-4 panel */
.pp-stat-row {
    display: flex; flex-direction: column; gap: 4px;
    padding: 10px 0;
    border-bottom: 1px dashed rgba(115,100,245,.15);
}
.pp-stat-row:last-child { border-bottom: none; }
.pp-stat-header {
    display: flex; align-items: center; gap: 8px;
    font-size: 13px; font-weight: 600;
}
.pp-stat-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pp-stat-pct {
    padding: 1px 7px; border-radius: 8px;
    background: rgba(115,100,245,.22);
    font-size: 11px; font-weight: 700;
    color: #b9aeff;
    letter-spacing: .01em;
    font-variant-numeric: tabular-nums;
}
.pp-stat-pct[data-level="warn"] { background: rgba(253,186,116,.22); color: #fdba74; }
.pp-stat-pct[data-level="crit"] { background: rgba(248,113,113,.25); color: #fca5a5; }
.pp-stat-bar {
    position: relative; height: 6px; border-radius: 10px;
    background: rgba(255,255,255,.05);
    overflow: hidden;
}
body.light-theme .pp-stat-bar { background: rgba(0,0,0,.06); }
.pp-stat-fill {
    height: 100%;
    border-radius: 10px;
    background: linear-gradient(90deg, #6c5ce7, #00cec9);
    transition: width .4s cubic-bezier(.16,1,.3,1);
}
.pp-stat-fill[data-level="warn"] { background: linear-gradient(90deg, #fbbf24, #f97316); }
.pp-stat-fill[data-level="crit"] { background: linear-gradient(90deg, #ef4444, #f472b6); }
.pp-stat-meta {
    font-size: 11.5px; color: var(--text-muted, #8f8fa8);
    font-variant-numeric: tabular-nums;
    display: flex; justify-content: space-between;
}

/* Top-4 section inside subscription modal */
.sub-top4-section {
    background: linear-gradient(135deg, rgba(115,100,245,.06), rgba(0,206,201,.04));
    border: 1px solid rgba(115,100,245,.18);
    border-radius: 14px;
    padding: 14px 16px 10px;
}
body.light-theme .sub-top4-section {
    background: linear-gradient(135deg, rgba(115,100,245,.04), rgba(0,206,201,.03));
    border-color: rgba(115,100,245,.2);
}
.sub-top4-hint {
    font-size: 11.5px; line-height: 1.45;
    color: var(--text-muted, #8f8fa8);
    margin: -4px 0 10px;
}
.sub-top4-list {
    display: flex; flex-direction: column; gap: 2px;
}
.sub-top4-empty {
    padding: 14px 4px;
    text-align: center;
    font-size: 12.5px;
    color: var(--text-muted, #8f8fa8);
}
.sub-top4-section .pp-stat-row { padding: 9px 0; }
.sub-top4-section .pp-stat-row:first-child { padding-top: 4px; }
.sub-top4-section .pp-stat-row:last-child { padding-bottom: 2px; }

/* Footer action bar */
.pp-footer {
    padding: 12px 22px;
    border-top: 1px solid rgba(115,100,245,.12);
    background: rgba(0,0,0,.15);
    display: flex; gap: 8px; justify-content: flex-end;
    flex-wrap: wrap;
}
body.light-theme .pp-footer { background: rgba(115,100,245,.03); }

.pp-btn {
    appearance: none;
    padding: 8px 14px;
    border-radius: 10px;
    border: 1px solid rgba(115,100,245,.25);
    background: rgba(115,100,245,.08);
    color: var(--text, #e0e0ec);
    font-size: 12.5px; font-weight: 600;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 6px;
    transition: background .15s, transform .1s, border-color .15s;
    font-family: inherit;
}
.pp-btn:hover { background: rgba(115,100,245,.18); border-color: rgba(115,100,245,.45); }
.pp-btn:active { transform: translateY(1px); }
.pp-btn svg { width: 14px; height: 14px; }
.pp-btn.pp-btn-primary {
    background: linear-gradient(135deg, #6c5ce7, #00cec9);
    border-color: transparent; color: #fff;
}
.pp-btn.pp-btn-primary:hover { filter: brightness(1.1); }
.pp-btn.pp-btn-ghost { background: transparent; }

/* Pretty toast (replaces plain alert for transient feedback) */
.pp-toast-zone {
    position: fixed; top: 18px; left: 50%; transform: translateX(-50%);
    z-index: 200;
    display: flex; flex-direction: column; gap: 8px;
    pointer-events: none;
}
.pp-toast {
    pointer-events: auto;
    min-width: 240px; max-width: 420px;
    padding: 11px 16px 11px 14px;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(35,35,50,.96), rgba(22,22,36,.96));
    border: 1px solid rgba(115,100,245,.28);
    box-shadow: 0 12px 32px -8px rgba(0,0,0,.55);
    color: var(--text, #e8e8f0);
    font-size: 13px; line-height: 1.4;
    display: flex; align-items: center; gap: 10px;
    animation: ppToastIn .28s cubic-bezier(.16,1,.3,1);
}
body.light-theme .pp-toast {
    background: linear-gradient(135deg, #ffffff, #f3f4fb);
    border-color: rgba(115,100,245,.2);
    color: #1b1b28;
}
@keyframes ppToastIn {
    from { opacity: 0; transform: translateY(-14px) scale(.95); }
    to   { opacity: 1; transform: translateY(0)     scale(1);   }
}
.pp-toast.pp-toast-out { animation: ppToastOut .22s ease-in forwards; }
@keyframes ppToastOut {
    to { opacity: 0; transform: translateY(-10px) scale(.96); }
}
.pp-toast-ico {
    flex-shrink: 0; width: 22px; height: 22px;
    display: flex; align-items: center; justify-content: center;
    color: #00cec9;
}
.pp-toast-ico svg { width: 18px; height: 18px; }
.pp-toast.pp-toast-info  .pp-toast-ico { color: #6c5ce7; }
.pp-toast.pp-toast-ok    .pp-toast-ico { color: #22c55e; }
.pp-toast.pp-toast-warn  .pp-toast-ico { color: #fbbf24; }
.pp-toast.pp-toast-error .pp-toast-ico { color: #ef4444; }
.pp-toast-text { flex: 1; min-width: 0; }

@media (prefers-reduced-motion: reduce) {
    .pp-overlay, .pp-panel, .pp-toast, .pp-close, .pp-stat-fill { animation: none !important; transition: none !important; }
}

/* ── Advanced model menu (two-column) ── */
.mm-wrap { display: grid; grid-template-columns: 230px 1fr; gap: 14px; min-height: 380px; }
@media (max-width: 720px) {
    .mm-wrap { grid-template-columns: 1fr; }
    .mm-detail { min-height: 220px; }
}
.mm-list {
    display: flex; flex-direction: column; gap: 4px;
    max-height: 58vh; overflow-y: auto;
    padding-right: 4px;
    scrollbar-width: thin; scrollbar-color: rgba(115,100,245,.4) transparent;
}
.mm-list::-webkit-scrollbar { width: 5px; }
.mm-list::-webkit-scrollbar-thumb { background: rgba(115,100,245,.35); border-radius: 3px; }

.mm-item {
    appearance: none;
    display: flex; align-items: center; gap: 9px;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px solid transparent;
    background: transparent;
    color: var(--text, #e0e0ec);
    cursor: pointer; text-align: left;
    font-family: inherit; font-size: 12.5px;
    transition: background .15s, border-color .15s, transform .12s;
}
.mm-item:hover { background: rgba(115,100,245,.08); border-color: rgba(115,100,245,.2); }
.mm-item.mm-item-focus {
    background: rgba(115,100,245,.14);
    border-color: rgba(115,100,245,.45);
}
.mm-item.mm-item-active {
    background: linear-gradient(135deg, rgba(115,100,245,.25), rgba(0,206,201,.15));
    border-color: rgba(115,100,245,.55);
}
.mm-item.mm-item-locked { opacity: .45; cursor: not-allowed; }
.mm-item-ico {
    flex-shrink: 0; width: 22px; height: 22px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 7px;
    background: linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.035));
    border: 1px solid rgba(255,255,255,.075);
    overflow: hidden;
}
.mm-item-ico svg { width: 20px; height: 20px; }
.mm-item-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.mm-item-name {
    font-size: 13px; font-weight: 600;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mm-item-tier {
    font-size: 10.5px; color: var(--text-muted);
    letter-spacing: .02em;
}
.mm-item-cost {
    flex-shrink: 0;
    padding: 2px 7px; border-radius: 8px;
    background: rgba(0,206,201,.18); color: #6ee7e0;
    font-size: 10.5px; font-weight: 700;
    font-variant-numeric: tabular-nums;
}
.mm-item-lock {
    flex-shrink: 0; color: #fbbf24;
    display: flex; align-items: center;
}

.mm-detail {
    background: rgba(255,255,255,.025);
    border: 1px solid rgba(115,100,245,.12);
    border-radius: 12px;
    padding: 16px 18px;
    display: flex; flex-direction: column; gap: 12px;
}
body.light-theme .mm-detail { background: rgba(115,100,245,.04); }

.mm-detail-head {
    display: flex; align-items: center; gap: 12px;
}
.mm-detail-ico {
    width: 44px; height: 44px; border-radius: 12px;
    background: linear-gradient(135deg, rgba(255,255,255,.095), rgba(255,255,255,.04));
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 10px 26px rgba(0,0,0,.22);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
}
/* brand-ico wrapper from _BRAND_FB sits inside; it provides its own absolute layout. */
.mm-detail-ico > .brand-ico { width: 100%; height: 100%; }
.mm-detail-ico .brand-ico-fb { width: 26px !important; height: 26px !important; }
.mm-detail-ico .brand-ico-img { width: 72% !important; height: 72% !important; }
/* Legacy inline SVG (без brand wrapper) — оставляем flex-центрирование. */
.mm-detail-ico > svg { width: 26px; height: 26px; display: block; flex-shrink: 0; }
.mm-detail-title {
    flex: 1; min-width: 0;
    font-size: 17px; font-weight: 700;
    line-height: 1.15;
}
.mm-detail-tag {
    font-size: 11px; color: var(--text-muted);
    text-transform: uppercase; letter-spacing: .06em;
    margin-top: 2px; font-weight: 600;
}

.mm-detail-desc {
    font-size: 13px; line-height: 1.55;
    color: var(--text, #d8d8e4);
    padding: 10px 12px;
    background: rgba(0,0,0,.18);
    border-radius: 8px;
    border-left: 3px solid rgba(115,100,245,.5);
}
body.light-theme .mm-detail-desc { background: rgba(115,100,245,.06); }

.mm-spec-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 8px;
}
.mm-spec {
    padding: 8px 10px;
    background: rgba(0,0,0,.15);
    border: 1px solid rgba(115,100,245,.1);
    border-radius: 8px;
}
body.light-theme .mm-spec { background: rgba(115,100,245,.04); }
.mm-spec-label {
    font-size: 10.5px; color: var(--text-muted);
    text-transform: uppercase; letter-spacing: .05em;
    margin-bottom: 3px; font-weight: 600;
}
.mm-spec-value {
    font-size: 14px; font-weight: 700;
    font-variant-numeric: tabular-nums;
}

/* Custom bolt icons for the speed meter */
.mm-speed-meter {
    display: inline-flex;
    gap: 2px;
    align-items: center;
    line-height: 1;
}
.mm-bolt {
    width: 18px;
    height: 18px;
    transition: transform .15s ease, filter .15s ease;
}
.mm-speed-meter:hover .mm-bolt[style*="opacity:1"] {
    filter: drop-shadow(0 0 4px currentColor);
    transform: translateY(-1px);
}

.mm-select-btn {
    margin-top: auto;
    align-self: stretch;
    padding: 10px;
    border-radius: 10px;
    border: none;
    background: linear-gradient(135deg, #6c5ce7, #00cec9);
    color: #fff; font-size: 13px; font-weight: 700;
    cursor: pointer; font-family: inherit;
    transition: filter .15s, transform .1s;
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
.mm-select-btn:hover { filter: brightness(1.1); }
.mm-select-btn:active { transform: translateY(1px); }
.mm-select-btn:disabled {
    background: rgba(100,100,120,.25);
    color: var(--text-muted); cursor: not-allowed;
    filter: none;
}
.mm-select-btn svg { width: 14px; height: 14px; }

/* Enhanced model detail: sub-text, flags, IQ bar, use-case, estimate */
.mm-spec-sub {
    font-size: 10px; color: var(--text-muted);
    margin-top: 2px; font-weight: 500; letter-spacing: .02em;
}
.mm-iq-bar {
    display: block; width: 100%; height: 4px;
    background: rgba(255,255,255,.08); border-radius: 2px;
    overflow: hidden; margin-top: 3px;
}
.mm-iq-bar-fill { display: block; height: 100%; border-radius: 2px; transition: width .3s; }
.mm-use-case {
    margin: 10px 0; padding: 10px 12px;
    background: rgba(124,137,246,.08);
    border-left: 3px solid var(--primary, #7c89f6);
    border-radius: 0 8px 8px 0;
    font-size: 12.5px; line-height: 1.55;
    color: var(--text-secondary);
}
.mm-use-case b { color: var(--text); font-weight: 700; }
.mm-flag-row {
    display: flex; flex-wrap: wrap; gap: 6px;
    margin: 10px 0;
}
.mm-flag {
    display: inline-flex; align-items: center;
    padding: 3px 9px; border-radius: 999px;
    font-size: 10.5px; font-weight: 600; letter-spacing: .01em;
    border: 1px solid transparent;
}
.mm-flag-on {
    background: rgba(34,197,94,.14); color: #4ade80;
    border-color: rgba(34,197,94,.25);
}
.mm-flag-off {
    background: rgba(100,100,120,.12); color: var(--text-muted);
    border-color: rgba(100,100,120,.2);
}
.mm-flag-warn {
    background: rgba(245,158,11,.14); color: #fbbf24;
    border-color: rgba(245,158,11,.35);
}
.mm-estimate {
    margin: 8px 0 12px; padding: 8px 12px;
    background: rgba(0,206,201,.08);
    border: 1px dashed rgba(0,206,201,.4);
    border-radius: 8px;
    font-size: 12.5px; color: var(--text-secondary);
    text-align: center;
}
.mm-estimate b { color: #22d3ee; font-size: 14px; font-weight: 800; }

/* Theme switch — CSS View Transitions crossfade (same as landing) plus a
   targeted perf freeze during the flip. While the class .theme-transitioning
   is on <html> we:
     1) pause (NOT kill) every running keyframe animation — so diamondSpin,
        typing-bounce, pulse-dot, msg-in and friends freeze at their current
        frame and resume exactly where they were afterwards. No snapping, no
        message jumps.
     2) drop every backdrop-filter — these are the single biggest cost during
        the View Transitions rasterization of the 2 snapshots. Falling back
        to the solid background underneath for ~220ms is invisible.
     3) zero all transitions — prevents double-animation on top of the
        crossfade. */
html.theme-transitioning,
html.theme-transitioning *,
html.theme-transitioning *::before,
html.theme-transitioning *::after {
    animation-play-state: paused !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    transition: none !important;
}

/* The toggle-slider knob itself must keep its slide transition alive,
   otherwise the circle snaps to the new position. View Transition captures
   old+new snapshots and crossfades — with a live 200ms transition on the
   ::after dot, the crossfade interpolates both the color change AND the
   position change smoothly. */
html.theme-transitioning .toggle-slider,
html.theme-transitioning .toggle-slider::after {
    transition: background 200ms cubic-bezier(0.4, 0, 0.2, 1),
                left 200ms cubic-bezier(0.4, 0, 0.2, 1),
                transform 200ms cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Give the theme toggle a dedicated view-transition-name so the knob
   doesn't get baked into the root snapshot — the browser animates it
   as its own group, so the dot visually slides between positions. */
#toggle-theme + .toggle-slider {
    view-transition-name: theme-toggle-slider;
}
::view-transition-old(theme-toggle-slider),
::view-transition-new(theme-toggle-slider) {
    animation-duration: 220ms;
    animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

::view-transition-old(root),
::view-transition-new(root) {
    animation-duration: 220ms;
    animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    mix-blend-mode: normal;
}
::view-transition-old(root) { z-index: 1; }
::view-transition-new(root) { z-index: 2; }

/* Light-theme Diff button visibility fix */
body.light-theme .diff-btn {
    background: #f0f2ff;
    border: 1px solid #b8c1f0;
    color: #3d47a8;
    box-shadow: 0 1px 2px rgba(99,102,241,0.08);
}
body.light-theme .diff-btn:hover {
    background: #e4e8ff;
    border-color: #8a95e0;
    color: #1e2680;
}
body.light-theme .diff-btn.diff-has-changes {
    background: #fef3c7;
    border-color: #f59e0b;
    color: #92400e;
}
body.light-theme .diff-btn.diff-active {
    background: #d1fae5;
    border-color: #10b981;
    color: #065f46;
}

/* ═════════════════════════════════════════
   Vault / Security features (#18 #19 #20)
   ═════════════════════════════════════════ */
/* ═══ Vault panel ═══ */
.vault-intro{
  display:flex;gap:12px;align-items:flex-start;
  padding:12px 14px;margin-bottom:14px;
  border-radius:12px;
  border:1px solid rgba(124,137,246,.22);
  background:linear-gradient(135deg,rgba(124,137,246,.08),rgba(0,206,201,.05));
  font-size:12.5px;line-height:1.5;color:var(--text);
}
body.light-theme .vault-intro{
  background:linear-gradient(135deg,rgba(124,137,246,.07),rgba(0,206,201,.04));
  border-color:rgba(124,137,246,.28);
  color:#1b1b24;
}
.vault-intro-ico{font-size:18px;line-height:1;flex-shrink:0;padding-top:1px}
.vault-intro-text{flex:1;min-width:0}
.vault-intro-text b{color:var(--text);font-weight:700}
body.light-theme .vault-intro-text b{color:#0f172a}
.vault-intro-text i{color:var(--text-muted);font-style:italic}

.vault-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;margin-bottom:14px;flex-wrap:wrap;
}
.vault-meta{
  display:flex;align-items:center;gap:10px;
  font-size:13px;color:var(--text-muted);flex-wrap:wrap;
}
.vault-badge{
  padding:4px 12px;border-radius:8px;
  background:rgba(124,137,246,.16);
  color:var(--primary-light,#7c89f6);
  font-weight:700;font-variant-numeric:tabular-nums;
}
body.light-theme .vault-badge{
  background:rgba(79,70,229,.12);color:#4f46e5;
}
.vault-hint b{color:var(--text);font-weight:600}
body.light-theme .vault-hint b{color:#1b1b24}
.vault-add-btn{flex-shrink:0;white-space:nowrap}

.vault-settings{
  display:flex;flex-direction:column;gap:10px;
  margin:0 0 16px;padding:14px;
  border:1px solid var(--border);border-radius:12px;
  background:rgba(124,137,246,.04);
}
body.light-theme .vault-settings{
  background:rgba(124,137,246,.05);
  border-color:rgba(0,0,0,.08);
}
.vault-settings-row{
  display:grid;grid-template-columns:1fr auto;gap:14px;
  align-items:center;font-size:13px;color:var(--text);
  min-width:0;
}
.vault-settings-label{
  min-width:0;overflow-wrap:anywhere;line-height:1.4;color:var(--text);
}
body.light-theme .vault-settings-label{color:#1b1b24}
/* Custom dropdown (replaces native <select>) */
.vault-dd{
  position:relative;
  width:240px;max-width:60vw;
  justify-self:end;
}
.vault-dd-trigger{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  width:100%;padding:9px 12px;
  border:1px solid var(--border);border-radius:9px;
  background:rgba(255,255,255,.03);
  color:var(--text);
  font-size:13px;font-family:inherit;
  cursor:pointer;
  transition:border-color .12s, background .12s;
}
.vault-dd-trigger:hover{border-color:rgba(124,137,246,.45);background:rgba(124,137,246,.06)}
.vault-dd.is-open .vault-dd-trigger{border-color:var(--primary-light,#7c89f6);box-shadow:0 0 0 2px rgba(124,137,246,.18)}
.vault-dd-value{
  flex:1;min-width:0;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  text-align:left;
}
.vault-dd-chev{flex-shrink:0;color:var(--text-muted);transition:transform .15s}
.vault-dd.is-open .vault-dd-chev{transform:rotate(180deg);color:var(--primary-light,#7c89f6)}

.vault-dd-menu{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  z-index:50;
  padding:4px;
  border:1px solid var(--border);border-radius:10px;
  background:var(--bg-elev,#1a1a2e);
  box-shadow:0 10px 30px rgba(0,0,0,.45), 0 0 0 1px rgba(124,137,246,.1);
  max-height:240px;overflow-y:auto;
  animation:vaultDdOpen .14s ease-out;
}
@keyframes vaultDdOpen{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}
.vault-dd-item{
  padding:8px 12px;border-radius:7px;
  font-size:13px;color:var(--text);
  cursor:pointer;
  transition:background .1s, color .1s;
  user-select:none;
}
.vault-dd-item:hover{background:rgba(124,137,246,.16)}
.vault-dd-item.is-active{
  background:linear-gradient(90deg,rgba(108,92,231,.28),rgba(0,206,201,.18));
  color:#fff;font-weight:600;
}

body.light-theme .vault-dd-trigger{
  background:#fff;color:#1b1b24;
  border-color:rgba(0,0,0,.14);
}
body.light-theme .vault-dd-trigger:hover{background:rgba(124,137,246,.05);border-color:rgba(124,137,246,.45)}
body.light-theme .vault-dd-menu{
  background:#fff;
  border-color:rgba(0,0,0,.1);
  box-shadow:0 10px 30px rgba(0,0,0,.12),0 0 0 1px rgba(0,0,0,.04);
}
body.light-theme .vault-dd-item{color:#1b1b24}
body.light-theme .vault-dd-item:hover{background:rgba(124,137,246,.1)}
body.light-theme .vault-dd-item.is-active{
  background:linear-gradient(90deg,rgba(108,92,231,.16),rgba(0,206,201,.1));
  color:#2d1f6b;
}

@media (max-width: 560px){
  .vault-settings-row{grid-template-columns:1fr}
  .vault-dd{width:100%;max-width:100%;justify-self:stretch}
}

.vault-list{display:flex;flex-direction:column;gap:8px;max-height:55vh;overflow-y:auto;padding-right:2px}
.vault-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  border:1px solid var(--border);border-radius:10px;
  background:rgba(124,137,246,.04);
  transition:border-color .15s,background .15s;
}
body.light-theme .vault-row{background:rgba(124,137,246,.04);border-color:rgba(0,0,0,.08)}
.vault-row:hover{border-color:rgba(124,137,246,.35)}
.vault-row-main{flex:1;min-width:0}
.vault-row-name{
  font-weight:700;font-size:14px;color:var(--text);
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  word-break:break-all;
}
.vault-row-mask{margin-left:10px;font-size:12px;color:var(--text-muted);font-weight:400;letter-spacing:1px}
.vault-row-desc{margin-top:3px;font-size:12.5px;color:var(--text-secondary,var(--text-muted));line-height:1.4}
.vault-row-meta{margin-top:4px;font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums}
.vault-row-actions{display:flex;gap:4px;flex-shrink:0}
.vault-row-actions .btn{padding:6px 10px;font-size:14px;line-height:1}

/* Красивое подтверждение удаления секрета */
.vault-del-confirm{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:4px 8px 8px;gap:10px;
}
.vault-del-icon{
  width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:30px;margin-bottom:2px;
  background:radial-gradient(circle at 30% 30%, rgba(239,68,68,.22), rgba(239,68,68,.08));
  border:1px solid rgba(239,68,68,.35);
  box-shadow:0 0 0 6px rgba(239,68,68,.05), inset 0 0 18px rgba(239,68,68,.1);
}
body.light-theme .vault-del-icon{
  background:radial-gradient(circle at 30% 30%, rgba(239,68,68,.14), rgba(239,68,68,.04));
  border-color:rgba(239,68,68,.45);
  box-shadow:0 0 0 6px rgba(239,68,68,.06);
}
.vault-del-title{
  margin:0;font-size:17px;font-weight:600;color:var(--text);letter-spacing:.1px;
}
.vault-del-name{
  padding:8px 14px;border-radius:8px;
  background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);
  max-width:100%;
}
.vault-del-name code{
  color:#ef4444;font-weight:600;font-size:14px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  word-break:break-all;
}
body.light-theme .vault-del-name{background:rgba(239,68,68,.06);border-color:rgba(239,68,68,.3)}
.vault-del-hint{
  margin:4px 0 0;font-size:12.5px;line-height:1.55;color:var(--text-muted);
  max-width:320px;
}
.btn-danger{
  background:linear-gradient(135deg,#ef4444,#dc2626);
  color:#fff;border:1px solid rgba(239,68,68,.6);
  font-weight:600;
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease;
}
.btn-danger:hover{
  filter:brightness(1.08);
  box-shadow:0 6px 18px rgba(239,68,68,.35);
  transform:translateY(-1px);
}
.btn-danger:active{transform:translateY(0)}
.btn-danger:focus-visible{outline:2px solid rgba(239,68,68,.55);outline-offset:2px}

.vault-empty{
  padding:28px 20px;text-align:center;
  color:var(--text-muted);font-size:13px;line-height:1.5;
  border:1px dashed var(--border);border-radius:10px;
  background:rgba(124,137,246,.02);
}
body.light-theme .vault-empty{background:rgba(0,0,0,.015);border-color:rgba(0,0,0,.12)}
.vault-empty b{color:var(--text)}
body.light-theme .vault-empty b{color:#1b1b24}

.vault-editor{display:flex;flex-direction:column;gap:12px}
.vault-editor label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--text-muted)}
.vault-editor input,.vault-editor textarea{
  padding:10px 12px;border:1px solid var(--border);border-radius:8px;
  background:rgba(255,255,255,.02);color:var(--text);
  font-size:13px;font-family:inherit;resize:vertical;
  width:100%;box-sizing:border-box;
}
body.light-theme .vault-editor input,
body.light-theme .vault-editor textarea{background:#fff;border-color:rgba(0,0,0,.14)}
.vault-editor input:focus,.vault-editor textarea:focus{
  outline:none;border-color:var(--primary-light,#7c89f6);
  box-shadow:0 0 0 2px rgba(124,137,246,.18);
}
.vault-editor input[readonly]{opacity:.65;cursor:not-allowed}
.vault-editor-hint{
  font-size:12px;color:var(--text-muted);line-height:1.5;
  padding:8px 10px;border-radius:8px;
  background:rgba(124,137,246,.07);
}
body.light-theme .vault-editor-hint{background:rgba(124,137,246,.06)}

/* ═══════════════════════════════════════════════════════
   Server exec + help Pretty Panels
   ═══════════════════════════════════════════════════════ */
.srv-exec-form { display:flex; flex-direction:column; gap:10px }
.srv-exec-input {
    width:100%; box-sizing:border-box;
    min-height:96px; padding:12px 14px;
    background: var(--bg-input,#0c0c18);
    border:1px solid var(--border,#1a1a2e);
    border-radius:10px;
    color: var(--text,#e2e2f0);
    font-family:'JetBrains Mono',ui-monospace,monospace;
    font-size:13px; line-height:1.55;
    resize:vertical; outline:none;
    transition: border-color .2s, box-shadow .2s;
}
.srv-exec-input:focus {
    border-color: var(--primary,#7c89f6);
    box-shadow: 0 0 0 3px rgba(124,137,246,.18);
}
.srv-exec-hint { font-size:11.5px; color: var(--text-muted,#8080a0); line-height:1.5 }
.srv-exec-hint code { padding:1px 6px; background: rgba(124,137,246,.12); border-radius:4px; font-size:11px }
.srv-exec-output {
    margin-top:12px; border:1px solid var(--border,#1a1a2e); border-radius:10px;
    background: rgba(0,0,0,.25); overflow:hidden;
}
.srv-exec-head {
    display:flex; align-items:center; justify-content:space-between; gap:8px;
    padding:8px 12px; font-size:11px; font-weight:700; letter-spacing:.5px;
    text-transform:uppercase; color: var(--text-muted,#8080a0);
    background: rgba(255,255,255,.02); border-bottom:1px solid var(--border,#1a1a2e);
}
.srv-exec-head-right { display:flex; align-items:center; gap:8px }
.srv-exec-exit { font-family:'JetBrains Mono',monospace; font-weight:600 }
.srv-exec-exit-ok { color:#22c55e }
.srv-exec-exit-bad { color:#ef4444 }
.srv-exec-copy {
    padding:4px 10px; font-size:11px; border-radius:6px;
    border:1px solid var(--border,#1a1a2e);
    background: transparent; color: var(--text,#e2e2f0);
    cursor:pointer; transition: all .15s;
}
.srv-exec-copy:hover { border-color: var(--primary,#7c89f6); color: var(--primary,#7c89f6) }
.srv-exec-pre {
    margin:0; padding:12px 14px;
    font-family:'JetBrains Mono',ui-monospace,monospace; font-size:12px; line-height:1.55;
    color:#cfd2e8; white-space:pre-wrap; word-break:break-all;
    max-height:360px; overflow:auto;
}
.srv-exec-err .srv-exec-pre { color:#ffb2b2 }
.srv-exec-rerun { display:inline-flex; align-items:center; gap:6px }

/* Help / command palette */
.srv-help-search {
    width:100%; box-sizing:border-box;
    padding:10px 14px;
    background: var(--bg-input,#0c0c18);
    border:1px solid var(--border,#1a1a2e); border-radius:10px;
    color: var(--text,#e2e2f0); font-family:inherit; font-size:13px;
    outline:none; transition: all .2s;
}
.srv-help-search:focus { border-color: var(--primary,#7c89f6); box-shadow: 0 0 0 3px rgba(124,137,246,.18) }
.srv-help-list { display:flex; flex-direction:column; gap:14px; margin-top:12px }
.srv-help-group > .srv-help-items { display:flex !important; flex-direction:column !important; overflow:visible !important; max-height:none !important }
.srv-help-group .srv-help-item { display:block !important; overflow:visible !important; max-height:none !important }
.srv-help-group { border:1px solid var(--border,#1a1a2e); border-radius:10px; overflow:hidden }
.srv-help-title {
    padding:9px 14px; font-size:11px; font-weight:700;
    letter-spacing:.6px; text-transform:uppercase;
    color: var(--text-muted,#8080a0);
    background: rgba(255,255,255,.02);
    border-bottom:1px solid var(--border,#1a1a2e);
}
.srv-help-items { display:flex; flex-direction:column }
.srv-help-item {
    display:flex; align-items:center; justify-content:space-between; gap:14px;
    padding:10px 14px; cursor:pointer; border:none; width:100%;
    background: transparent; color: var(--text,#e2e2f0); text-align:left;
    font-family:inherit; font-size:13px; border-bottom:1px solid rgba(255,255,255,.03);
    transition: background .15s;
}
.srv-help-item:last-child { border-bottom:none }
.srv-help-item:hover { background: rgba(124,137,246,.08) }
.srv-help-item-label { font-weight:600 }
.srv-help-item-cmd {
    font-family:'JetBrains Mono',ui-monospace,monospace; font-size:11.5px;
    color: var(--text-muted,#8080a0);
    padding:3px 8px; border-radius:5px;
    background: rgba(0,0,0,.3);
}
.srv-help-empty { padding:30px 20px; text-align:center; color:var(--text-muted,#8080a0); font-size:13px }

/* ── Enhanced card action buttons ───────────────────────── */
.srv-mini {
    display:inline-flex; align-items:center; gap:5px;
    padding:5px 9px; font-size:11.5px; font-weight:600;
    background: rgba(255,255,255,.02);
    border:1px solid var(--border,#1a1a2e); border-radius:7px;
    color: var(--text,#e2e2f0); cursor:pointer;
    transition: all .15s ease;
    line-height:1; white-space:nowrap;
}
.srv-mini:hover { background: rgba(124,137,246,.1); border-color: rgba(124,137,246,.5); color:#fff; transform:translateY(-1px) }
.srv-mini svg { flex-shrink:0 }
.srv-mini-ghost { background: transparent }
.srv-mini-primary {
    background: linear-gradient(135deg, rgba(124,137,246,.18), rgba(6,182,212,.12));
    border-color: rgba(124,137,246,.35); color:#cfd2e8;
}
.srv-mini-primary:hover { background: linear-gradient(135deg, rgba(124,137,246,.28), rgba(6,182,212,.2)); border-color: rgba(124,137,246,.7) }
.srv-mini-danger { color:#fca5a5 }
.srv-mini-danger:hover { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.5); color:#fecaca }
.srv-mini:disabled,
.srv-mini:disabled:hover {
    opacity:.48;
    cursor:not-allowed;
    transform:none;
    box-shadow:none;
    background: rgba(255,255,255,.02);
    color: var(--text-muted,#8080a0);
    border-color: var(--border,#1a1a2e);
}

/* ── SSH console (modernized exec input) ────────────────── */
.srv-console-wrap {
    background: linear-gradient(180deg,#0b0d16 0%,#0a0b12 100%);
    border:1px solid rgba(124,137,246,.22); border-radius:11px;
    padding:12px 14px; position:relative;
}
.srv-console-bar {
    display:flex; align-items:center; gap:10px; flex-wrap:wrap;
    font-family:'JetBrains Mono',ui-monospace,monospace; font-size:12px;
    padding-bottom:8px; border-bottom:1px dashed rgba(124,137,246,.18);
    margin-bottom:10px;
}
.srv-console-prompt { color:#7cc95b; font-weight:700 }
.srv-console-sep { color:#6b7280 }
.srv-console-tip { color:#6b7280; font-size:10.5px; font-family:inherit; margin-left:auto }
.srv-console-input {
    width:100%; box-sizing:border-box;
    font-family:'JetBrains Mono',ui-monospace,monospace; font-size:13px;
    background: transparent; border:none; outline:none; resize:vertical;
    color:#e0e3ea; line-height:1.55; min-height:44px;
    padding:4px 0;
}
.srv-console-input::placeholder { color:#4a5160 }
.srv-console-quick { display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; padding-top:8px; border-top:1px dashed rgba(124,137,246,.12) }
.srv-quick-chip {
    display:inline-flex; align-items:center; gap:5px;
    padding:4px 10px; font-size:11.5px; font-family:'JetBrains Mono',ui-monospace,monospace;
    background: rgba(124,137,246,.08); border:1px solid rgba(124,137,246,.22);
    color:#a8b1c9; border-radius:14px; cursor:pointer;
    transition: all .15s;
}
.srv-quick-chip svg { flex-shrink:0; opacity:.75 }
.srv-quick-chip:hover { background: rgba(124,137,246,.18); color:#fff; border-color: rgba(124,137,246,.5) }
.srv-quick-chip:hover svg { opacity:1 }
.srv-exec-output-tall .srv-exec-pre { min-height:320px; max-height:62vh }

/* ── Loading spinner ────────────────────────────────────── */
.srv-spinner-sm {
    display:inline-block; width:14px; height:14px; vertical-align:-3px;
    border:2px solid rgba(124,137,246,.2);
    border-top-color:#7c89f6; border-radius:50%;
    animation: osc-spin .8s linear infinite;
}
.srv-exec-loading {
    display:flex; align-items:center; gap:10px;
    padding:18px 16px; color:var(--text-muted,#8080a0); font-size:13px;
}

/* ── Exec result (prettified head with SVG status) ─────── */
.srv-exec-head { text-transform:none !important; letter-spacing: normal !important; font-weight: 500 !important; font-size: 12px !important }
.srv-exec-cmd { color:#cfd2e8; font-family:'JetBrains Mono',ui-monospace,monospace; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; min-width:0; flex:1 }
.srv-exec-cmd code { color:#7cc95b; background:transparent; padding:0 }
.srv-exec-cmd b { color:#e2e2f0; font-weight:700; font-family:inherit }
.srv-exec-meta { display:flex; align-items:center; gap:8px; flex-shrink:0 }
.srv-exec-rc {
    display:inline-flex; align-items:center; gap:5px;
    padding:3px 8px; border-radius:6px; font-size:11px; font-weight:700;
    font-family:'JetBrains Mono',ui-monospace,monospace;
}
.srv-exec-rc.ok  { background: rgba(34,197,94,.12); color:#4ade80; border:1px solid rgba(34,197,94,.3) }
.srv-exec-rc.bad { background: rgba(239,68,68,.12); color:#f87171; border:1px solid rgba(239,68,68,.3) }
.srv-exec-rc svg { flex-shrink:0 }
.srv-exec-copy { display:inline-flex; align-items:center; gap:5px }
.srv-exec-empty { padding: 20px; text-align:center; color: #6b7280; font-style:italic; font-size:12px }
.srv-exec-err-label {
    padding:6px 14px; font-size:10.5px; font-weight:700; letter-spacing:.6px;
    text-transform:uppercase; color:#f87171;
    background: rgba(239,68,68,.06); border-top:1px solid rgba(239,68,68,.18);
}
.srv-exec-pre-err { color:#fca5a5 !important; background: rgba(239,68,68,.04) }
.srv-exec-err {
    padding:14px 16px; color:#fca5a5; font-size:13px;
    background: rgba(239,68,68,.08); border-left:3px solid #ef4444;
}

/* ── Help panel (upgraded: search ico, category ico, per-item desc+run) ─── */
.srv-help-search-wrap { position:relative }
.srv-help-search-ico {
    position:absolute; left:12px; top:50%; transform:translateY(-50%);
    color: var(--text-muted,#6b7280); pointer-events:none;
}
.srv-help-search-wrap .srv-help-search { padding-left:36px }
.srv-help-title {
    display:flex !important; align-items:center; gap:8px;
    text-transform:none !important; font-size:13px !important; letter-spacing:normal !important;
    padding:11px 14px !important; color: var(--text,#e2e2f0) !important;
    background: linear-gradient(90deg, rgba(124,137,246,.08), transparent) !important;
    border-bottom:1px solid rgba(124,137,246,.15) !important;
}
.srv-help-ico { display:inline-flex; color:#a0a6f9 }
.srv-help-count {
    margin-left:auto; padding:1px 8px; font-size:10.5px; font-weight:700;
    background: rgba(124,137,246,.15); color:#a0a6f9;
    border-radius:10px; border:1px solid rgba(124,137,246,.3);
}
.srv-help-item {
    display:block !important; padding:10px 14px !important;
    border-bottom:1px solid rgba(255,255,255,.03); cursor:pointer;
    transition: background .15s;
}
.srv-help-item:hover { background: rgba(124,137,246,.06) }
.srv-help-item-head { display:flex; align-items:center; justify-content:space-between; gap:10px }
.srv-help-item-t { font-weight:600; color: var(--text,#e2e2f0); font-size:13px }
.srv-help-item-run {
    display:inline-flex; align-items:center; gap:5px;
    padding:3px 9px; font-size:11px; font-weight:600;
    background: rgba(34,197,94,.12); color:#4ade80;
    border:1px solid rgba(34,197,94,.3); border-radius:6px;
    cursor:pointer; transition: all .15s;
    font-family:inherit; line-height:1.2;
}
.srv-help-item-run:hover { background: rgba(34,197,94,.22); border-color: rgba(34,197,94,.6); transform:translateY(-1px) }
.srv-help-item-desc {
    margin-top:4px; color: var(--text-muted,#8080a0); font-size:11.5px; line-height:1.45;
}
.srv-help-item-c {
    display:block; margin-top:6px; padding:5px 9px;
    font-family:'JetBrains Mono',ui-monospace,monospace; font-size:11px;
    color:#b8bed3; background: rgba(0,0,0,.3); border-radius:5px;
    white-space:pre-wrap; word-break:break-all;
}

/* Light-theme for new controls */
body.light-theme .srv-mini { color:#2b2e45; background:rgba(99,102,241,.04); border-color:rgba(99,102,241,.2) }
body.light-theme .srv-mini:hover { background:rgba(99,102,241,.12); color:#12141f }
body.light-theme .srv-mini-danger { color:#dc2626 }
body.light-theme .srv-mini-danger:hover { background: rgba(239,68,68,.1); color:#b91c1c }
body.light-theme .srv-console-wrap { background:#f7f8ff; border-color:rgba(99,102,241,.2) }
body.light-theme .srv-console-input { color:#12141f }
body.light-theme .srv-console-prompt { color:#059669 }
body.light-theme .srv-help-item-c { background: rgba(0,0,0,.04); color:#2b2e45 }
body.light-theme .srv-help-item-desc { color:#5a6175 }
body.light-theme .srv-help-item-t { color:#12141f }
body.light-theme .srv-help-title { color:#12141f !important; background: linear-gradient(90deg, rgba(99,102,241,.06), transparent) !important }

/* ═══════════════════════════════════════════════════════
   Light-theme overrides for server panels
   ═══════════════════════════════════════════════════════ */
body.light-theme .sb-servers-section { border-top-color: rgba(0,0,0,.08) }
body.light-theme .sb-servers-title { color:#5a6175 }
body.light-theme .sb-servers-title:hover { color:#12141f }
body.light-theme .sb-server-add-btn {
    background: linear-gradient(135deg, rgba(99,102,241,.06), rgba(6,182,212,.03));
    border-color: rgba(99,102,241,.28);
    color:#12141f;
}
body.light-theme .sb-server-add-btn:hover {
    background: linear-gradient(135deg, rgba(99,102,241,.14), rgba(6,182,212,.08));
    border-color: rgba(99,102,241,.55);
}
body.light-theme .sb-server-item { color:#12141f }
body.light-theme .sb-server-item:hover { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.06) }
body.light-theme .sb-server-del { color:#5a6175 }

body.light-theme .srv-panel-v2 {
    background: linear-gradient(180deg,#ffffff 0%,#f5f6fc 100%);
    border-color: rgba(99,102,241,.2);
    box-shadow: 0 20px 60px rgba(15,15,35,.12), 0 0 0 1px rgba(99,102,241,.06) inset;
}
body.light-theme .srv-panel-sub,
body.light-theme .srv-card-host,
body.light-theme .srv-empty-sub,
body.light-theme .srv-metric-label { color:#5a6175 }
body.light-theme .srv-card {
    background: linear-gradient(180deg,#ffffff 0%,#f8f9fd 100%);
    border-color: rgba(99,102,241,.14);
}
body.light-theme .srv-card:hover { border-color: rgba(99,102,241,.4); box-shadow: 0 12px 28px rgba(15,15,35,.08) }
body.light-theme .srv-card-disabled,
body.light-theme .srv-card-disabled:hover { opacity:.68; filter:saturate(.75); transform:none; box-shadow:none }
body.light-theme .srv-card-name, body.light-theme .srv-empty-title { color:#12141f }
body.light-theme .srv-card-status { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.06); color:#5a6175 }
body.light-theme .srv-btn { background:#ffffff; border-color: rgba(0,0,0,.08); color:#12141f }
body.light-theme .srv-btn-ghost:hover { background: rgba(0,0,0,.03); border-color: rgba(99,102,241,.45) }
body.light-theme .srv-metric-val { color:#12141f }
body.light-theme .srv-bar { background: rgba(0,0,0,.07) }
body.light-theme .srv-card-foot { border-top-color: rgba(0,0,0,.06) }
body.light-theme .srv-card-uptime { color:#5a6175 }
body.light-theme .srv-mini {
    background: #ffffff;
    border: 1px solid rgba(0,0,0,.1);
    color: #3a3d52;
    box-shadow: 0 1px 2px rgba(15,15,35,.04);
}
body.light-theme .srv-mini-ghost:hover { background: rgba(99,102,241,.08); color:#6366f1; border-color: rgba(99,102,241,.35) }
body.light-theme .srv-mini-danger:hover { background: rgba(239,68,68,.08); color:#ef4444; border-color: rgba(239,68,68,.3) }
body.light-theme .srv-mini:disabled,
body.light-theme .srv-mini:disabled:hover {
    opacity:.48;
    cursor:not-allowed;
    transform:none;
    background:#ffffff;
    color:#7b8194;
    border-color:rgba(0,0,0,.1);
}
body.light-theme .servers-panel-overlay { background: rgba(15,15,35,.45); backdrop-filter: blur(4px) }
body.light-theme .servers-panel { background:#ffffff; border-color: rgba(0,0,0,.08); box-shadow: 0 24px 70px rgba(15,15,35,.15) }

body.light-theme .srv-exec-input,
body.light-theme .srv-help-search {
    background:#ffffff; border-color: rgba(0,0,0,.1); color:#12141f;
}
body.light-theme .srv-exec-input:focus,
body.light-theme .srv-help-search:focus {
    border-color: var(--primary,#7c89f6);
    box-shadow: 0 0 0 3px rgba(124,137,246,.15);
}
body.light-theme .srv-exec-hint { color:#5a6175 }
body.light-theme .srv-exec-hint code { background: rgba(124,137,246,.12) }
body.light-theme .srv-exec-output { background: rgba(0,0,0,.02); border-color: rgba(0,0,0,.08) }
body.light-theme .srv-exec-head { background: rgba(0,0,0,.03); border-bottom-color: rgba(0,0,0,.06); color:#5a6175 }
body.light-theme .srv-exec-copy { background:#fff; border-color: rgba(0,0,0,.1); color:#12141f }
body.light-theme .srv-exec-copy:hover { border-color: var(--primary,#7c89f6); color: var(--primary,#7c89f6) }
body.light-theme .srv-exec-pre { color:#2b2e45 }
body.light-theme .srv-exec-err .srv-exec-pre { color:#c23b3b }

body.light-theme .srv-help-group { border-color: rgba(0,0,0,.08) }
body.light-theme .srv-help-title { background: rgba(0,0,0,.02); border-bottom-color: rgba(0,0,0,.06); color:#5a6175 }
body.light-theme .srv-help-item { color:#12141f; border-bottom-color: rgba(0,0,0,.04) }
body.light-theme .srv-help-item:hover { background: rgba(124,137,246,.08) }
body.light-theme .srv-help-item-cmd { background: rgba(0,0,0,.05); color:#5a6175 }
body.light-theme .srv-help-empty { color:#5a6175 }

/* ── System-prompt modal (prompt + AI style) ── */
.sp-style-card:hover { transform: translateY(-1px); border-color: rgba(99,102,241,0.45) !important; }
.sp-style-card:active { transform: translateY(0); }
.sp-style-card:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
#sys-prompt-dialog { animation: sp-dialog-in 220ms cubic-bezier(0.2, 0.8, 0.2, 1); }
@keyframes sp-dialog-in {
    from { opacity: 0; transform: translateY(10px) scale(0.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
#sys-prompt-scroll::-webkit-scrollbar { width: 8px; }
#sys-prompt-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
body.light-theme .sp-style-card:hover { border-color: rgba(99,102,241,0.6) !important; }

/* ── Scroll position button ─────────────── */
/* Спокойная кнопка: наверху ведёт вниз, ниже по истории возвращает к началу. */
.scroll-to-top-btn {
    position: absolute;
    bottom: 112px;
    right: 22px;
    top: auto;
    z-index: 50;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 14px 0 12px;
    height: 40px;
    border: 1px solid rgba(177, 185, 222, 0.18);
    border-radius: 999px;
    background: rgba(20, 23, 36, 0.62);
    color: #c4c9df;
    font-family: inherit;
    font-size: 12.5px;
    font-weight: 600;
    letter-spacing: 0;
    cursor: pointer;
    opacity: 0;
    pointer-events: none;
    transform: translateY(6px) scale(0.96);
    transition: opacity .22s ease, transform .24s cubic-bezier(.2,.7,.2,1), border-color .18s, box-shadow .18s, background .18s, color .18s;
    backdrop-filter: blur(10px) saturate(1.2);
    -webkit-backdrop-filter: blur(10px) saturate(1.2);
    box-shadow: 0 8px 22px -14px rgba(0,0,0,0.65), inset 0 1px 0 rgba(255,255,255,0.06);
    overflow: hidden;
}
.scroll-to-top-btn.stt-visible {
    opacity: .82;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}
.scroll-to-top-btn:hover {
    opacity: 1;
    border-color: rgba(156, 150, 255, 0.34);
    background: rgba(30, 33, 49, 0.78);
    color: #eef0ff;
    box-shadow: 0 10px 24px -15px rgba(0,0,0,0.75), inset 0 1px 0 rgba(255,255,255,0.09);
    transform: translateY(-1px) scale(1);
}
.scroll-to-top-btn:active {
    transform: translateY(1px) scale(0.98);
    transition-duration: .08s;
}
.scroll-to-top-btn .stt-arrow {
    width: 15px;
    height: 15px;
    color: #9c96ff;
    filter: none;
    transition: transform .25s cubic-bezier(.2,.7,.2,1);
    flex-shrink: 0;
}
.scroll-to-top-btn.stt-mode-up:hover .stt-arrow { transform: translateY(-2px); }
.scroll-to-top-btn.stt-mode-down:hover .stt-arrow { transform: translateY(2px); }
.scroll-to-top-btn.stt-firing .stt-arrow {
    animation: stt-launch 0.55s cubic-bezier(.4,0,.2,1);
}
.scroll-to-top-btn.stt-mode-down.stt-firing .stt-arrow {
    animation-name: stt-drop;
}
@keyframes stt-launch {
    0%   { transform: translateY(0) scale(1); opacity: 1; }
    40%  { transform: translateY(-18px) scale(1.12); opacity: 0.85; }
    50%  { transform: translateY(-22px) scale(0.8); opacity: 0; }
    51%  { transform: translateY(8px)  scale(0.8); opacity: 0; }
    100% { transform: translateY(0)    scale(1); opacity: 1; }
}
@keyframes stt-drop {
    0%   { transform: translateY(0) scale(1); opacity: 1; }
    40%  { transform: translateY(18px) scale(1.12); opacity: 0.85; }
    50%  { transform: translateY(22px) scale(0.8); opacity: 0; }
    51%  { transform: translateY(-8px) scale(0.8); opacity: 0; }
    100% { transform: translateY(0) scale(1); opacity: 1; }
}
.scroll-to-top-btn .stt-label {
    white-space: nowrap;
    color: currentColor;
}
.scroll-to-top-btn .stt-glow {
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    pointer-events: none;
    background: radial-gradient(120% 60% at 50% 100%, rgba(156, 150, 255, 0.13), transparent 72%);
    opacity: 0;
    transition: opacity .25s;
}
.scroll-to-top-btn:hover .stt-glow { opacity: 1; }

/* Light theme variant */
body.light-theme .scroll-to-top-btn {
    border-color: rgba(134, 143, 166, 0.24);
    background: rgba(255, 255, 255, 0.78);
    color: #5d6578;
    box-shadow: 0 8px 22px -16px rgba(30,41,59,0.35), inset 0 1px 0 rgba(255,255,255,0.65);
}
body.light-theme .scroll-to-top-btn .stt-arrow {
    color: #7069dc;
    filter: none;
}
body.light-theme .scroll-to-top-btn:hover {
    border-color: rgba(112, 105, 220, 0.34);
    background: rgba(255, 255, 255, 0.94);
    color: #3f4657;
}
@media (max-width: 640px) {
    .scroll-to-top-btn {
        padding: 0 12px 0 10px;
        height: 34px;
        font-size: 11.5px;
        gap: 6px;
        bottom: 96px;
        right: 14px;
    }
    .scroll-to-top-btn .stt-arrow { width: 13px; height: 13px; }
}

/* ── Cross-tab sync flash (brief subtle hint when settings change) ── */
.xtab-sync-flash {
    animation: xtab-flash .6s ease-out;
}
@keyframes xtab-flash {
    0%   { box-shadow: 0 0 0 0 rgba(139, 124, 246, 0.55); }
    100% { box-shadow: 0 0 0 18px rgba(139, 124, 246, 0); }
}

/* ══════════════════════════════════════
   Floating Windows — лёгкие плавающие окна для файлов
   ══════════════════════════════════════ */

.fwin {
    position: fixed;
    background: linear-gradient(180deg, rgba(20, 22, 36, 0.96), rgba(15, 17, 28, 0.96));
    backdrop-filter: blur(20px) saturate(150%);
    -webkit-backdrop-filter: blur(20px) saturate(150%);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    box-shadow:
        0 24px 64px -12px rgba(0, 0, 0, 0.55),
        0 8px 24px -8px rgba(0, 0, 0, 0.32),
        inset 0 1px 0 0 rgba(255, 255, 255, 0.06);
    display: flex;
    flex-direction: column;
    overflow: visible;
    min-width: 380px;
    min-height: 280px;
    transition: box-shadow 0.18s, opacity 0.18s, border-color 0.18s;
    animation: fwin-pop 0.22s cubic-bezier(0.2, 0.9, 0.3, 1.1);
    will-change: transform, left, top;
}
/* Внутреннее содержимое скруглено вместе с окном */
.fwin-head, .fwin-body { border-radius: inherit; }
.fwin-body { border-top-left-radius: 0; border-top-right-radius: 0; }
.fwin-head { border-bottom-left-radius: 0; border-bottom-right-radius: 0; overflow: hidden; }
/* Без шапки у chat-window — скругление сверху отдаётся body */
.fwin-chat-window > .fwin-body {
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    overflow: hidden;
}
@keyframes fwin-pop {
    from { opacity: 0; transform: scale(0.96) translateY(8px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}
.fwin.closing {
    opacity: 0;
    transform: scale(0.97) translateY(4px);
    transition: opacity 0.16s, transform 0.16s;
}
.fwin.focused {
    border-color: rgba(99, 102, 241, 0.42);
    box-shadow:
        0 28px 72px -12px rgba(0, 0, 0, 0.62),
        0 10px 30px -8px rgba(99, 102, 241, 0.20),
        0 0 0 1px rgba(99, 102, 241, 0.30),
        inset 0 1px 0 0 rgba(255, 255, 255, 0.08);
}
/* Светлая тема — мягкие тени, белый фон */
body.light-theme .fwin {
    background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.96));
    border-color: rgba(0,0,0,0.08);
    box-shadow: 0 24px 64px -12px rgba(15, 23, 42, 0.20), 0 8px 24px -8px rgba(15,23,42,0.12);
}
body.light-theme .fwin.focused {
    border-color: rgba(99,102,241,0.45);
    box-shadow: 0 28px 72px -12px rgba(15,23,42,0.28), 0 10px 30px -8px rgba(99,102,241,0.18), 0 0 0 1px rgba(99,102,241,0.35);
}

/* Чат-окно — обычное плавающее, скруглено везде. Никаких body-class игр —
   они порождали баги «пустота остаётся / чат ломается / двойной max → 0px main-app». */
.fwin-chat-window {
    border-radius: 14px;
}

/* === Layouts picker (Win11-style) === */
.fwin-layouts {
    position: fixed;
    display: none;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    padding: 16px;
    background: linear-gradient(180deg, rgba(22,24,38,0.97), rgba(15,17,28,0.97));
    backdrop-filter: blur(24px) saturate(160%);
    -webkit-backdrop-filter: blur(24px) saturate(160%);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 16px;
    box-shadow: 0 32px 80px -12px rgba(0,0,0,0.65), 0 12px 32px -8px rgba(0,0,0,0.35);
    z-index: 10001;
    width: 480px;
}
.fwin-layouts::before {
    content: "Снап-разметка";
    position: absolute;
    top: -22px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 10.5px;
    font-weight: 700;
    color: rgba(255,255,255,0.65);
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 4px 12px;
    background: rgba(20,22,36,0.85);
    border: 1px solid rgba(255,255,255,0.10);
    border-radius: 6px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    pointer-events: none;
    white-space: nowrap;
}
.fwin-layouts.fwin-layouts-hover {
    animation: fwin-layouts-pop 0.18s cubic-bezier(0.2, 0.9, 0.3, 1.1) both;
}
@keyframes fwin-layouts-pop {
    from { opacity: 0; transform: translateY(-6px) scale(0.96); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}
/* Drag-режим: спускается сверху-вниз, как в Windows 11 */
.fwin-layouts.fwin-layouts-drag {
    animation: fwin-layouts-descend 0.26s cubic-bezier(0.2, 0.9, 0.3, 1.1) both;
}
@keyframes fwin-layouts-descend {
    from { opacity: 0; transform: translateY(-120%); }
    to { opacity: 1; transform: translateY(0); }
}
.fwin-layout-cell {
    background: rgba(255,255,255,0.025);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 10px;
    padding: 12px 10px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.14s ease, border-color 0.14s ease, transform 0.1s ease;
    min-height: 56px;
}
.fwin-layout-cell svg { width: 100%; height: auto; max-width: 64px; }
.fwin-layout-cell:hover {
    background: rgba(99,102,241,0.20);
    border-color: rgba(129,140,248,0.55);
    transform: translateY(-1px);
}
.fwin-layout-cell.drag-hover {
    background: rgba(99,102,241,0.30);
    border-color: rgba(129,140,248,0.85);
    box-shadow: 0 0 0 2px rgba(129,140,248,0.25);
    transform: translateY(-1px);
}
.fwin-layout-cell:active {
    transform: scale(0.95);
    background: rgba(99,102,241,0.32);
}
body.light-theme .fwin-layouts {
    background: linear-gradient(180deg, rgba(255,255,255,0.97), rgba(248,250,252,0.97));
    border-color: rgba(0,0,0,0.10);
    box-shadow: 0 32px 80px -12px rgba(15,23,42,0.30);
}
body.light-theme .fwin-layouts::before {
    background: rgba(255,255,255,0.92);
    border-color: rgba(0,0,0,0.08);
    color: rgba(15,23,42,0.7);
}
body.light-theme .fwin-layout-cell { background: rgba(15,23,42,0.025); border-color: rgba(15,23,42,0.06); }
body.light-theme .fwin-layout-cell:hover { background: rgba(99,102,241,0.10); }
@media (max-width: 700px) {
    .fwin-layouts { width: min(380px, 92vw); grid-template-columns: repeat(3, 1fr); }
}
.fwin.minimized {
    display: none;
}

.fwin-head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px 9px 16px;
    background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
    border-bottom: 1px solid rgba(255,255,255,0.06);
    cursor: grab;
    user-select: none;
    flex-shrink: 0;
    min-height: 40px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.fwin-head:active { cursor: grabbing; }
body.light-theme .fwin-head {
    background: linear-gradient(180deg, rgba(15,23,42,0.04), transparent);
    border-bottom-color: rgba(15,23,42,0.08);
}
.fwin-icon {
    font-size: 15px;
    flex-shrink: 0;
}
.fwin-title {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 13px;
    font-weight: 600;
    color: var(--text);
}
.fwin-buttons {
    display: flex;
    gap: 2px;
    flex-shrink: 0;
}
.fwin-btn {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    width: 30px;
    height: 26px;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.14s ease, color 0.14s ease;
}
.fwin-btn:hover {
    background: rgba(255,255,255,0.10);
    color: var(--text);
}
.fwin-btn:active {
    background: rgba(255,255,255,0.14);
    transform: scale(0.96);
}
.fwin-btn-close:hover {
    background: #e81123;
    color: #fff;
}
.fwin-btn-close:active {
    background: #c50f1f;
    color: #fff;
}

.fwin-body {
    flex: 1;
    min-height: 0;
    overflow: auto;
    background: var(--bg);
    position: relative;
}

/* === Resize handles: 4 края + 4 угла, как в Win11 ===
   Все handle'ы абсолютно позиционируются ВНЕ rounded-rect окна (через outset),
   чтобы курсор-resize ловился на самом краю/углу. Невидимые — только курсор
   меняется на правильный resize-cursor. */
.fwin-rsz { position: absolute; z-index: 5; }
/* Углы: 12×12 квадраты в углах, чуть выходят наружу */
.fwin-rsz-nw { top: -3px; left: -3px;   width: 14px; height: 14px; cursor: nw-resize; }
.fwin-rsz-ne { top: -3px; right: -3px;  width: 14px; height: 14px; cursor: ne-resize; }
.fwin-rsz-sw { bottom: -3px; left: -3px;  width: 14px; height: 14px; cursor: sw-resize; }
.fwin-rsz-se { bottom: -3px; right: -3px; width: 14px; height: 14px; cursor: se-resize; }
/* Края: 5px тонкие полоски, не пересекаются с углами */
.fwin-rsz-n  { top: -3px; left: 11px; right: 11px; height: 6px; cursor: n-resize; }
.fwin-rsz-s  { bottom: -3px; left: 11px; right: 11px; height: 6px; cursor: s-resize; }
.fwin-rsz-w  { left: -3px; top: 11px; bottom: 11px; width: 6px; cursor: w-resize; }
.fwin-rsz-e  { right: -3px; top: 11px; bottom: 11px; width: 6px; cursor: e-resize; }
/* Когда окно snap'нуто — резайз отключаем (Win11 не даёт ресайзить snapped окно) */
.fwin[data-snap] .fwin-rsz { pointer-events: none; }

.fwin-edge {
    position: absolute;
    z-index: 2;
    background: transparent;
}
.fwin-edge-n { top: -3px; left: 12px; right: 12px; height: 8px; cursor: ns-resize; }
.fwin-edge-s { bottom: -3px; left: 12px; right: 12px; height: 8px; cursor: ns-resize; }
.fwin-edge-w { top: 12px; bottom: 12px; left: -3px; width: 8px; cursor: ew-resize; }
.fwin-edge-e { top: 12px; bottom: 12px; right: -3px; width: 8px; cursor: ew-resize; }
.fwin-edge-nw { top: -3px; left: -3px; width: 14px; height: 14px; cursor: nwse-resize; }
.fwin-edge-ne { top: -3px; right: -3px; width: 14px; height: 14px; cursor: nesw-resize; }
.fwin-edge-sw { bottom: -3px; left: -3px; width: 14px; height: 14px; cursor: nesw-resize; }

/* Hint-полоска появляется когда ховер на ребро окна — даёт понять что край ресайзится */
.fwin-edge::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(99, 102, 241, 0);
    transition: background 0.15s;
    pointer-events: none;
}
.fwin-edge:hover::before { background: rgba(99, 102, 241, 0.18); }

/* Inflight bubble — assistant message который ещё стримится в БД с другой
   вкладки / прошлой сессии. Лёгкий пульсирующий border + субтильный glow
   справа сверху, чтобы юзер видел что генерация продолжается на сервере. */
.message.inflight-bubble {
    position: relative;
}
.message.inflight-bubble::after {
    content: '';
    position: absolute;
    top: 6px;
    right: 6px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #22c55e;
    box-shadow: 0 0 0 4px rgba(34,197,94,0.18), 0 0 10px rgba(34,197,94,0.6);
    animation: inflight-pulse 1.6s ease-in-out infinite;
    pointer-events: none;
}
@keyframes inflight-pulse {
    0%, 100% { opacity: 0.6; transform: scale(1); }
    50%      { opacity: 1;   transform: scale(1.25); }
}
@media (prefers-reduced-motion: reduce) {
    .message.inflight-bubble::after { animation: none; }
}

/* File-content presets */
.fwin-pre {
    margin: 0;
    padding: 14px 16px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12.5px;
    line-height: 1.55;
    color: var(--text);
    white-space: pre;
    overflow: auto;
    height: 100%;
    box-sizing: border-box;
}
.fwin-code-pre {
    /* Когда сверху toolbar — pre занимает оставшееся место */
    height: calc(100% - 38px);
}
.fwin-toolbar {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    height: 38px;
    box-sizing: border-box;
    background: rgba(255,255,255,0.025);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.fwin-tool-btn {
    appearance: none;
    border: 1px solid var(--border);
    background: var(--bg-card, rgba(255,255,255,0.04));
    color: var(--text);
    font: 600 11.5px/1 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    padding: 5px 10px;
    border-radius: 7px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    transition: background 0.12s ease, border-color 0.12s ease, transform 0.05s ease;
}
.fwin-tool-btn:hover {
    background: var(--bg-hover, rgba(115,100,245,0.12));
    border-color: rgba(115,100,245,0.45);
}
.fwin-tool-btn:active { transform: translateY(1px); }
.fwin-tool-btn svg { flex-shrink: 0; }
.fwin-tool-btn-active {
    background: rgba(115,100,245,0.18);
    border-color: rgba(115,100,245,0.5);
    color: var(--primary-light, #a29cff);
}
/* Зеленый primary для запуска */
.fwin-tool-btn-primary {
    background: linear-gradient(135deg, rgba(74,222,128,0.18), rgba(34,197,94,0.12));
    border-color: rgba(74,222,128,0.5);
    color: #4ade80;
}
.fwin-tool-btn-primary:hover {
    background: linear-gradient(135deg, rgba(74,222,128,0.28), rgba(34,197,94,0.22));
    border-color: rgba(74,222,128,0.7);
}
/* Icon-only: квадратная без подписи */
.fwin-tool-btn-icon {
    padding: 5px 7px;
    aspect-ratio: 1;
    justify-content: center;
}
.fwin-toolbar-spacer { flex: 1; }
.fwin-toolbar-hint {
    font-size: 10.5px;
    color: var(--text-muted);
    padding: 0 6px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.fwin-html-frame {
    width: 100%;
    height: calc(100% - 38px);
    border: none;
    background: #fff;
    display: block;
}
.fwin-imgwrap {
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        repeating-conic-gradient(rgba(255,255,255,0.04) 0% 25%, transparent 0% 50%) 0 0 / 16px 16px;
    overflow: auto;
    padding: 12px;
}
.fwin-imgwrap img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    box-shadow: 0 4px 18px rgba(0,0,0,0.25);
    border-radius: 4px;
}

/* Snap-zone hint (Aero Snap визуал) */
.fwin-snap-hint {
    position: fixed;
    background: rgba(99, 102, 241, 0.18);
    border: 2px solid rgba(99, 102, 241, 0.6);
    border-radius: 14px;
    pointer-events: none;
    z-index: 999;
    display: none;
    transition: all 0.12s ease-out;
    backdrop-filter: blur(4px);
}

/* Taskbar dock for minimized windows */
.fwin-dock {
    position: fixed;
    bottom: 12px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 6px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 6px;
    box-shadow: 0 8px 28px rgba(0,0,0,0.35);
    z-index: 990;
    max-width: 90vw;
    overflow-x: auto;
}
.fwin-dock-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 6px 12px;
    color: var(--text);
    cursor: pointer;
    font-size: 12px;
    transition: background 0.15s, border-color 0.15s;
    white-space: nowrap;
}
.fwin-dock-chip:hover {
    background: var(--bg-hover, rgba(255,255,255,0.05));
    border-color: rgba(99,102,241,0.4);
}
.fwin-dock-label {
    max-width: 140px;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.light-theme .fwin {
    box-shadow:
        0 12px 36px rgba(0, 0, 0, 0.18),
        0 2px 8px rgba(0, 0, 0, 0.08);
}
body.light-theme .fwin.focused {
    box-shadow:
        0 18px 48px rgba(0, 0, 0, 0.22),
        0 0 0 1px rgba(99, 102, 241, 0.3);
}
body.light-theme .fwin-imgwrap {
    background: repeating-conic-gradient(#f0f0f0 0% 25%, transparent 0% 50%) 0 0 / 16px 16px;
}

/* ════════════════════════════════════════════════════════════
   Agent 2 — карточки субагентов (parallel delegation)
   Появляются под leader-сообщением когда AI выпускает <spawn_agents> блок.
   ════════════════════════════════════════════════════════════ */
.agent2-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 10px;
    margin: 14px 0 4px 0;
}
.agent2-card {
    border-radius: 10px;
    padding: 10px 12px;
    background: linear-gradient(180deg, rgba(99,102,241,0.08), rgba(99,102,241,0.03));
    border: 1px solid rgba(99,102,241,0.30);
    font-size: 12px;
    line-height: 1.45;
    transition: all 0.2s ease;
    overflow: hidden;
}
.agent2-card.running {
    background: linear-gradient(180deg, rgba(251,191,36,0.10), rgba(251,191,36,0.03));
    border-color: rgba(251,191,36,0.50);
    box-shadow: 0 0 12px rgba(251,191,36,0.15);
}
.agent2-card.done {
    background: linear-gradient(180deg, rgba(34,197,94,0.06), rgba(34,197,94,0.02));
    border-color: rgba(34,197,94,0.30);
}
.agent2-card.failed {
    background: linear-gradient(180deg, rgba(239,68,68,0.08), rgba(239,68,68,0.02));
    border-color: rgba(239,68,68,0.40);
}
.agent2-header {
    display: flex;
    align-items: center;
    gap: 7px;
    font-weight: 600;
    font-size: 13px;
    margin-bottom: 6px;
}
.agent2-spinner {
    width: 10px; height: 10px; border-radius: 50%;
    background: #fbbf24;
    box-shadow: 0 0 8px #fbbf24;
    animation: agent2-pulse 1s ease-in-out infinite;
    flex-shrink: 0;
}
.agent2-card.done .agent2-spinner {
    background: #22c55e;
    box-shadow: 0 0 6px #22c55e;
    animation: none;
}
.agent2-card.failed .agent2-spinner {
    background: #ef4444;
    box-shadow: 0 0 6px #ef4444;
    animation: none;
}
@keyframes agent2-pulse {
    0%,100% { transform: scale(1); opacity: 1; }
    50%     { transform: scale(1.4); opacity: 0.5; }
}
.agent2-name {
    color: var(--text);
    font-family: var(--font-mono, ui-monospace, monospace);
}
.agent2-status {
    margin-left: auto;
    font-size: 11px;
    color: var(--text-muted);
    font-weight: 500;
}
.agent2-task {
    color: var(--text-secondary);
    font-size: 11.5px;
    margin-bottom: 6px;
    max-height: 60px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}
.agent2-output {
    margin-top: 8px;
    padding: 8px 10px;
    background: rgba(0,0,0,0.18);
    border-radius: 6px;
    max-height: 320px;
    overflow: auto;
    font-size: 12px;
    line-height: 1.5;
    color: var(--text);
}
.agent2-output pre {
    margin: 4px 0;
    padding: 6px 8px;
    background: rgba(0,0,0,0.30);
    border-radius: 4px;
    font-size: 11px;
    overflow-x: auto;
}
.agent2-meta {
    margin-top: 6px;
    font-size: 10.5px;
    color: var(--text-muted);
    text-align: right;
    font-variant-numeric: tabular-nums;
}
body.light-theme .agent2-card {
    background: linear-gradient(180deg, rgba(99,102,241,0.05), rgba(99,102,241,0.01));
}
body.light-theme .agent2-output {
    background: rgba(0,0,0,0.04);
}
body.light-theme .agent2-output pre {
    background: rgba(0,0,0,0.06);
}

/* osc-pulse keyframes (используется в других местах для пульсирующих точек) */
@keyframes osc-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: 0.45; transform: scale(0.85); }
}

/* ── Model selector offline state ── */
.model-option.offline {
    opacity: 0.6;
}
.model-option.offline:hover {
    opacity: 0.85;
}
.model-option.offline .model-option-icon {
    filter: grayscale(0.6);
}
.model-option-offline {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    margin-left: 8px;
    padding: 1px 7px;
    font-size: 10px;
    font-weight: 600;
    color: #f87171;
    background: rgba(248, 113, 113, 0.12);
    border: 1px solid rgba(248, 113, 113, 0.3);
    border-radius: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    vertical-align: middle;
}
.model-option-offline svg {
    flex-shrink: 0;
}

/* Те же стили для mm-col-item (Pretty Panel «Выбор модели») */
.mm-col-item.mm-col-item-offline-state,
.mm-item.mm-col-item-offline-state {
    opacity: 0.6;
}
.mm-col-item.mm-col-item-offline-state:hover,
.mm-item.mm-col-item-offline-state:hover {
    opacity: 0.9;
}
.mm-col-item.mm-col-item-offline-state .mm-col-item-ico,
.mm-item.mm-col-item-offline-state .mm-item-ico {
    filter: grayscale(0.6);
}
.mm-col-item-offline {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    margin-left: 8px;
    padding: 1px 7px;
    font-size: 9px;
    font-weight: 600;
    color: #f87171;
    background: rgba(248, 113, 113, 0.12);
    border: 1px solid rgba(248, 113, 113, 0.3);
    border-radius: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    vertical-align: middle;
    white-space: nowrap;
}
.mm-col-item-offline svg {
    flex-shrink: 0;
}

/* ── Красивый scrollbar (для textarea, details list, memory list) ── */
.osc-pretty-scroll::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.osc-pretty-scroll::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.02);
    border-radius: 4px;
}
.osc-pretty-scroll::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(129, 140, 248, 0.35), rgba(129, 140, 248, 0.5));
    border-radius: 4px;
    transition: background 0.15s ease;
}
.osc-pretty-scroll::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(129, 140, 248, 0.5), rgba(129, 140, 248, 0.7));
}
.osc-pretty-scroll::-webkit-scrollbar-corner {
    background: transparent;
}
/* Firefox */
.osc-pretty-scroll {
    scrollbar-width: thin;
    scrollbar-color: rgba(129, 140, 248, 0.4) rgba(255, 255, 255, 0.02);
}
/* Применяем ко всем textarea в системе */
textarea {
    scrollbar-width: thin;
    scrollbar-color: rgba(129, 140, 248, 0.4) rgba(255, 255, 255, 0.02);
}
textarea::-webkit-scrollbar {
    width: 8px;
}
textarea::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.02);
    border-radius: 4px;
}
textarea::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(129, 140, 248, 0.35), rgba(129, 140, 248, 0.5));
    border-radius: 4px;
}
textarea::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(129, 140, 248, 0.5), rgba(129, 140, 248, 0.7));
}

/* ══════════════════════════════════════════════════════════════
   WEB-SEARCH BAR (Perplexity-стиль) — компактный, раскрывающийся
   ══════════════════════════════════════════════════════════════ */
.osc-websearch {
    margin: 8px 0 12px;
    max-width: 100%;
}
.osc-websearch .osc-ws-bar {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px 8px 10px;
    background: rgba(129, 140, 248, 0.08);
    border: 1px solid rgba(129, 140, 248, 0.22);
    border-radius: 14px;
    font-size: 13px;
    color: var(--text);
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease;
    user-select: none;
    list-style: none;
    max-width: 100%;
    overflow: hidden;
}
.osc-websearch .osc-ws-bar::-webkit-details-marker { display: none; }
.osc-websearch .osc-ws-bar:hover {
    background: rgba(129, 140, 248, 0.14);
    border-color: rgba(129, 140, 248, 0.35);
}
.osc-websearch.searching .osc-ws-bar {
    background: rgba(129, 140, 248, 0.06);
    border-color: rgba(129, 140, 248, 0.18);
    cursor: default;
}

/* Spinner */
.osc-websearch .osc-ws-spinner {
    width: 14px;
    height: 14px;
    border: 2px solid rgba(129, 140, 248, 0.3);
    border-top-color: #818cf8;
    border-radius: 50%;
    animation: osc-spin 0.8s linear infinite;
    flex-shrink: 0;
}

/* Стек фавиконов (max 3, перекрытие) */
.osc-websearch .osc-ws-favs {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
}
.osc-websearch .osc-ws-fav-wrap {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--bg-secondary, #1a1a2e);
    border: 1.5px solid var(--bg, #0f0f1e);
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.osc-websearch .osc-ws-fav-wrap + .osc-ws-fav-wrap {
    margin-left: -6px;
}
.osc-websearch .osc-ws-fav {
    width: 14px;
    height: 14px;
    object-fit: contain;
    border-radius: 3px;
}

.osc-websearch .osc-ws-label {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 500;
}
.osc-websearch .osc-ws-query {
    color: var(--text-muted, #9ca3af);
    font-size: 12px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 50%;
}
.osc-websearch .osc-ws-provider {
    font-size: 11px;
    color: var(--text-muted, #9ca3af);
    background: rgba(129, 140, 248, 0.12);
    padding: 2px 8px;
    border-radius: 8px;
    flex-shrink: 0;
    font-weight: 500;
    white-space: nowrap;
}
.osc-websearch .osc-ws-chevron {
    color: var(--text-muted, #9ca3af);
    flex-shrink: 0;
    transition: transform 0.18s ease;
}
.osc-websearch details[open] .osc-ws-chevron {
    transform: rotate(180deg);
}

/* Раскрытый список источников */
.osc-websearch .osc-ws-list {
    margin-top: 6px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 8px;
    background: rgba(15, 15, 30, 0.5);
    border: 1px solid rgba(129, 140, 248, 0.18);
    border-radius: 12px;
    max-width: 600px;
    animation: osc-ws-fadein 0.18s ease;
}
@keyframes osc-ws-fadein {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

.osc-websearch .osc-ws-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 8px;
    color: var(--text);
    text-decoration: none;
    transition: background 0.12s ease;
    min-width: 0;
}
.osc-websearch .osc-ws-item:hover {
    background: rgba(129, 140, 248, 0.12);
}
.osc-websearch .osc-ws-item-num {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(129, 140, 248, 0.18);
    color: #a5b4fc;
    font-size: 11px;
    font-weight: 600;
    font-family: var(--font-mono, JetBrains Mono, monospace);
}
.osc-websearch .osc-ws-item-fav {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    border-radius: 4px;
    object-fit: contain;
}
.osc-websearch .osc-ws-fav-blank {
    background: rgba(129, 140, 248, 0.1);
}
.osc-websearch .osc-ws-item-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
    overflow: hidden;
}
.osc-websearch .osc-ws-item-title {
    font-size: 13px;
    color: var(--text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 500;
}
.osc-websearch .osc-ws-item-host {
    font-size: 11px;
    color: var(--text-muted, #9ca3af);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.osc-websearch .osc-ws-item-arrow {
    color: var(--text-muted, #9ca3af);
    opacity: 0;
    flex-shrink: 0;
    transition: opacity 0.15s ease;
}
.osc-websearch .osc-ws-item:hover .osc-ws-item-arrow {
    opacity: 1;
}

/* Mobile — уменьшаем размеры, ховер не нужен */
@media (max-width: 640px) {
    .osc-websearch .osc-ws-bar {
        padding: 7px 10px 7px 8px;
        font-size: 12.5px;
        gap: 8px;
        max-width: 100%;
        flex-wrap: nowrap;
    }
    .osc-websearch .osc-ws-query,
    .osc-websearch .osc-ws-provider {
        display: none;  /* на мобиле скрываем — мало места */
    }
    .osc-websearch .osc-ws-list {
        padding: 6px;
        max-width: 100%;
    }
    .osc-websearch .osc-ws-item {
        padding: 7px 8px;
        gap: 8px;
    }
    .osc-websearch .osc-ws-item-arrow {
        opacity: 1;  /* на мобиле всегда видна т.к. нет hover */
    }
    .osc-websearch .osc-ws-item-num {
        width: 20px;
        height: 20px;
        font-size: 10px;
    }
    .osc-websearch .osc-ws-item-title {
        font-size: 12.5px;
    }
}

/* Узкое окно (split-view, side-by-side) */
@media (max-width: 480px) {
    .osc-websearch .osc-ws-bar {
        padding: 6px 8px;
        font-size: 12px;
    }
    .osc-websearch .osc-ws-fav-wrap {
        width: 16px;
        height: 16px;
    }
    .osc-websearch .osc-ws-fav {
        width: 12px;
        height: 12px;
    }
}

/* ══════════════════════════════════════════════════════════════════
   Custom Emoji SVG (replaces ✅⚠️🎉ℹ️… inside AI messages)
   Line-style, consistent с slash-commands / vault / modes.
   ══════════════════════════════════════════════════════════════════ */
.msg-emoji-wrap {
    display: inline-flex;
    align-items: center;
    vertical-align: -0.2em;
    line-height: 1;
    margin: 0 0.05em;
}
.msg-emoji {
    width: 1.2em;
    height: 1.2em;
    display: inline-block;
    flex-shrink: 0;
    opacity: 0.92;
}
/* Original emoji character stays in DOM (hidden visually) so that
   Ctrl+F search, double-click selection, и копирование работают. */
.msg-emoji-char {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    white-space: nowrap;
    clip-path: inset(100%);
    font-size: 0;
    color: transparent;
}
body.light-theme .msg-emoji { opacity: 1; }
@media (prefers-reduced-motion: reduce) {
    .msg-emoji-wrap { vertical-align: -0.17em; }
}

/* ══════════════════════════════════════════════════════════════════
   USAGE LIMITS MODAL — экран с прогресс-барами по 4 окнам + per-model
   Стиль вдохновлён Claude.ai usage page: чистые ряды с барами и %.
   ══════════════════════════════════════════════════════════════════ */
.ulim-overlay {
    position: fixed; inset: 0;
    z-index: 9000;
    background: rgba(5, 7, 15, 0.72);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: flex; align-items: center; justify-content: center;
    padding: 24px;
    animation: fadeIn 160ms ease-out;
}
.ulim-modal {
    width: 100%;
    max-width: 720px;
    max-height: calc(100vh - 48px);
    background: #14152b;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    box-shadow: 0 32px 80px rgba(0, 0, 0, 0.65);
    display: flex; flex-direction: column;
    overflow: hidden;
    animation: ulimSlideUp 220ms cubic-bezier(.4,0,.2,1);
}
@keyframes ulimSlideUp { from { transform: translateY(10px); opacity: 0 } to { transform: translateY(0); opacity: 1 } }
.ulim-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 22px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.ulim-title-wrap { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.ulim-title {
    margin: 0;
    font-size: 18px; font-weight: 600;
    color: rgba(255, 255, 255, 0.96);
    letter-spacing: -0.01em;
}
.ulim-tier-badge {
    display: inline-flex; align-items: center;
    padding: 3px 10px;
    background: linear-gradient(135deg, rgba(115,100,245,0.20), rgba(94,234,212,0.14));
    border: 1px solid rgba(115, 100, 245, 0.32);
    color: #c4b5fd;
    border-radius: 999px;
    font-size: 11.5px; font-weight: 600;
    letter-spacing: 0.02em;
}
.ulim-close {
    width: 30px; height: 30px;
    background: transparent;
    border: 1px solid transparent;
    color: rgba(255, 255, 255, 0.55);
    border-radius: 8px;
    font-size: 22px; line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background 120ms, color 120ms, border-color 120ms;
}
.ulim-close:hover {
    background: rgba(255, 255, 255, 0.06);
    color: #fff;
    border-color: rgba(255, 255, 255, 0.10);
}
.ulim-body {
    flex: 1;
    overflow-y: auto;
    padding: 18px 22px 22px;
    scrollbar-width: thin;
    scrollbar-color: rgba(115,100,245,0.32) transparent;
}
.ulim-body::-webkit-scrollbar { width: 6px; }
.ulim-body::-webkit-scrollbar-thumb { background: rgba(115,100,245,0.32); border-radius: 3px; }
.ulim-loading, .ulim-error {
    text-align: center;
    padding: 40px 20px;
    color: var(--text-muted);
    font-size: 13.5px;
}
.ulim-error { color: #fca5a5; }

.ulim-section { margin-bottom: 24px; }
.ulim-section:last-of-type { margin-bottom: 12px; }
.ulim-section-title {
    margin: 0 0 12px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.45);
}

.ulim-row {
    padding: 14px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.ulim-row:last-child { border-bottom: none; }
.ulim-row-head {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: 12px;
    margin-bottom: 8px;
}
.ulim-row-label { flex: 1; min-width: 0; }
.ulim-row-name {
    font-size: 14px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.92);
    display: block;
    line-height: 1.3;
}
.ulim-row-sub {
    font-size: 11.5px;
    color: rgba(255, 255, 255, 0.45);
    display: block;
    margin-top: 2px;
    line-height: 1.4;
}
.ulim-row-pct {
    font-size: 13px;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
    white-space: nowrap;
}
.ulim-row-bar {
    height: 6px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 6px;
}
.ulim-row-bar-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 240ms ease-out;
    box-shadow: 0 0 8px currentColor;
}
.ulim-row-amounts {
    font-size: 11.5px;
    color: rgba(255, 255, 255, 0.40);
    font-variant-numeric: tabular-nums;
}

/* Per-model grid */
.ulim-models-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
}
.ulim-model {
    padding: 12px 14px;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
}
.ulim-model-head {
    display: flex; align-items: center; justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
}
.ulim-model-name {
    font-size: 12.5px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.85);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    flex: 1;
}
.ulim-model-pct {
    font-size: 11.5px;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}
.ulim-model-amounts {
    margin-top: 6px;
    font-size: 11px;
    color: rgba(255, 255, 255, 0.40);
    font-variant-numeric: tabular-nums;
}

/* Footer */
.ulim-footer {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: 8px;
    padding-top: 14px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.ulim-updated {
    font-size: 11.5px;
    color: var(--text-muted);
}
.ulim-refresh {
    width: 28px; height: 28px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.55);
    border-radius: 7px;
    font-size: 16px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background 140ms, color 140ms;
}
.ulim-refresh:hover { background: rgba(115, 100, 245, 0.18); color: #c4b5fd; }
.ulim-refresh.spin svg, .ulim-refresh.spin { animation: ulimSpin 700ms linear; }
@keyframes ulimSpin { from { transform: rotate(0) } to { transform: rotate(360deg) } }

/* Mobile */
@media (max-width: 640px) {
    .ulim-overlay { padding: 0; align-items: stretch; }
    .ulim-modal { max-width: 100%; border-radius: 0; max-height: 100vh; }
    .ulim-models-grid { grid-template-columns: 1fr; }
}

/* Light theme */
body.light-theme .ulim-modal { background: #ffffff; border-color: #e0e0eb; box-shadow: 0 32px 80px rgba(20,20,50,0.18); }
body.light-theme .ulim-head { border-bottom-color: #e8e8f0; }
body.light-theme .ulim-title { color: #1a1a2e; }
body.light-theme .ulim-close { color: #6b6b85; }
body.light-theme .ulim-close:hover { background: #f0f0f7; color: #1a1a2e; border-color: #e0e0eb; }
body.light-theme .ulim-section-title { color: #8888a8; }
body.light-theme .ulim-row { border-bottom-color: #f0f0f7; }
body.light-theme .ulim-row-name { color: #1a1a2e; }
body.light-theme .ulim-row-sub { color: #6b6b85; }
body.light-theme .ulim-row-amounts { color: #8888a8; }
body.light-theme .ulim-row-bar { background: #f0f0f7; }
body.light-theme .ulim-model { background: #fafafe; border-color: #e0e0eb; }
body.light-theme .ulim-model-name { color: #1a1a2e; }
body.light-theme .ulim-model-amounts { color: #8888a8; }
body.light-theme .ulim-footer { border-top-color: #e8e8f0; }
body.light-theme .ulim-updated { color: #8888a8; }
body.light-theme .ulim-refresh { background: #f0f0f7; border-color: #e0e0eb; color: #6b6b85; }
body.light-theme .ulim-refresh:hover { background: rgba(115,100,245,0.10); color: #6b5fd6; }

/* ══════════════════════════════════════════════════════════════════
   ATTACHMENT CARDS — ZIP/TXT/PY карточки под AI-сообщением.
   Стиль: то же что .hpc-attach в превью, но без preview-обёртки.
   Используется когда agent создал архив через package_files или когда
   из истории чата восстановлены attachments через metadata.
   ══════════════════════════════════════════════════════════════════ */
.msg-attachments {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}
.msg-attach {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 10px 9px 9px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    min-width: 200px;
    max-width: 280px;
    flex: 1 1 200px;
    transition: border-color 140ms, background 140ms, transform 140ms;
    cursor: pointer;
}
.msg-attach:hover {
    border-color: rgba(115, 100, 245, 0.42);
    background: rgba(255, 255, 255, 0.05);
    transform: translateY(-1px);
}
.msg-attach-ext {
    flex-shrink: 0;
    width: 40px; height: 46px;
    border-radius: 7px;
    display: flex; align-items: center; justify-content: center;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: #fff;
    position: relative;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.20);
}
.msg-attach-ext::after {
    content: '';
    position: absolute;
    top: 0; right: 0;
    border-style: solid;
    border-width: 0 8px 8px 0;
    border-color: transparent rgba(255, 255, 255, 0.20) transparent transparent;
    border-radius: 0 7px 0 0;
}
.msg-attach-info { flex: 1; min-width: 0; }
.msg-attach-name {
    font-size: 13px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.94);
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.25;
}
.msg-attach-meta {
    font-size: 11.5px;
    color: var(--text-muted);
    margin-top: 2px;
    line-height: 1.2;
}
.msg-attach-dl {
    flex-shrink: 0;
    width: 30px; height: 30px;
    background: rgba(255, 255, 255, 0.06);
    border: none;
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.6);
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background 140ms, color 140ms;
    padding: 0;
}
.msg-attach:hover .msg-attach-dl,
.msg-attach-dl:hover { background: rgba(115, 100, 245, 0.20); color: #c4b5fd; }

body.light-theme .msg-attach {
    background: #fafafe;
    border-color: #e0e0eb;
}
body.light-theme .msg-attach:hover {
    background: #f3f3fa;
    border-color: rgba(115, 100, 245, 0.40);
}
body.light-theme .msg-attach-name { color: #1a1a2e; }
body.light-theme .msg-attach-meta { color: #8888a8; }
body.light-theme .msg-attach-dl { background: #f0f0f7; color: #6b6b85; }
body.light-theme .msg-attach:hover .msg-attach-dl,
body.light-theme .msg-attach-dl:hover { background: rgba(115, 100, 245, 0.18); color: #6b5fd6; }

/* ── CSP utility classes — заменяют inline `style="..."` атрибуты в chat.html ──
 *
 * 2026-05-13: Часть статических inline-стилей в chat.html переведена на эти
 * классы, чтобы уменьшить count'у style-src-attr CSP violations. Не флипаем
 * директиву в `'none'` пока chat.js innerHTML-строки с inline-стилями не
 * подчищены — это отдельный рефакторинг chat.js (split + event delegation).
 *
 * Конвенция:
 *   .is-hidden            — display: none (БЕЗ !important чтобы JS мог
 *                            переопределить через `.style.display = 'flex'`
 *                            на динамически показываемых модалках; см.
 *                            enterChat(), showQueue() и т.п.)
 *   .u-relative           — position: relative
 *   .u-width-0            — width: 0% (для прогресс-баров до анимации)
 *   .u-flex-row           — display: flex; align-items: center; gap: 6px
 *   .u-mt-{12,8,6,10}     — margin-top
 *   .u-mb-10              — margin-bottom: 10px
 *
 * Source order гарантирует выигрыш над дефолтными display-правилами
 * (`.chat-screen { display: flex }` и т.п.) — этот блок в конце chat.css.
 */
.is-hidden          { display: none; }
.u-relative         { position: relative; }
.u-width-0          { width: 0%; }
.u-flex-1           { flex: 1; }
.u-flex-row         { display: flex; align-items: center; gap: 6px; }
.u-iflex-row        { display: inline-flex; align-items: center; gap: 6px; }
.u-flex-row-gap-10  { display: flex; gap: 10px; margin-top: 12px; }
.u-mt-12            { margin-top: 12px; }
.u-mt-10            { margin-top: 10px; }
.u-mt-8             { margin-top: 8px; }
.u-mt-6             { margin-top: 6px; }
.u-mt-4             { margin-top: 4px; }
.u-mt-1             { margin-top: 1px; }
.u-mb-10            { margin-bottom: 10px; }
.u-mb-6             { margin-bottom: 6px; }
.u-mb-2             { margin-bottom: 2px; }
.u-rounded-10       { border-radius: 10px; }
.u-rounded-50pct    { border-radius: 50%; }
.u-shrink-0         { flex-shrink: 0; }
.u-fs-18            { font-size: 18px; }
.u-fs-14            { font-size: 14px; }
.u-fs-13            { font-size: 13px; }
.u-fs-12            { font-size: 12px; }
.u-fs-11            { font-size: 11px; }
.u-fs-105           { font-size: 10.5px; }
.u-fw-700           { font-weight: 700; }
.u-fw-600           { font-weight: 600; }
.u-text-muted       { color: var(--text-muted); }
.u-text-accent      { color: var(--accent); }
.u-ellipsis         { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.u-justify-between  { display: flex; justify-content: space-between; }
.u-bar-track-3      { height: 3px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.u-iflex-1-min0     { flex: 1; min-width: 0; }

/* Component-ish classes for chat.js innerHTML строк (admin stats, model lists). */
.dyn-row            { padding: 4px 0; }
.dyn-row-divider    { border-bottom: 1px solid var(--border); }
.dyn-cell           { padding: 4px 8px 4px 0; }
.dyn-key            { padding: 4px 8px 4px 0; color: var(--accent); font-family: monospace; font-weight: 600; }
.dyn-chip           { background: var(--bg-input); border: 1px solid var(--border); border-radius: 4px; padding: 1px 5px; font-size: 11px; }
.dyn-section-hdr    { color: var(--accent); font-size: 14px; margin: 0 0 8px; }
.dyn-section-hint   { margin-top: 4px; font-size: 10.5px; color: var(--text-muted); }
.dyn-uppercase-cap  { margin: 0 0 2px; font-size: 11px; text-transform: uppercase; letter-spacing: .05em; }
.dyn-bigbar-track   { width: 100%; height: 6px; background: var(--bg-input); border-radius: 3px; overflow: hidden; }
.dyn-bar-track-tiny { height: 3px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.dyn-err-box        { display: flex; align-items: flex-start; gap: 8px; padding: 10px 12px; background: rgba(248,113,113,0.08); border: 1px solid rgba(248,113,113,0.3); border-radius: 10px; color: #fca5a5; }
.dyn-link-pill      { color: #a29cff; text-decoration: none; border: 1px solid rgba(162,156,255,0.3); padding: 4px 12px; border-radius: 8px; }
.dyn-tg-link        { color: #2AABEE; text-decoration: none; font-weight: 600; }

/* Avatar IMG inside .user-avatar / .acc-avatar / etc. — CSP-safe replacement
 * for inline style="width:32px;height:32px;object-fit:cover" pattern.
 * border-radius наследуется от контейнера, поэтому circle/square — оба ОК. */
.osc-avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
    display: block;
    opacity: 1;
    filter: none;
}

.user-avatar .osc-avatar-img,
.acc-avatar .osc-avatar-img,
.message-avatar .osc-avatar-img {
    opacity: 1 !important;
    filter: none !important;
}

/* Mobile fit pass: final source-order overrides for phone topbar, welcome and composer. */
@media (max-width: 768px) {
    html,
    body,
    .chat-screen,
    .chat-main {
        max-width: 100%;
        overflow-x: hidden;
    }

    .welcome-overlay {
        box-sizing: border-box;
        align-items: flex-start;
        justify-content: center;
        width: 100vw;
        max-width: 100vw;
        padding: max(12px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left)) !important;
        overflow-x: hidden;
        overflow-y: auto;
    }
    .welcome-modal {
        box-sizing: border-box;
        width: 100%;
        max-width: calc(100vw - 20px);
        min-width: 0;
        max-height: none;
        padding: 20px 16px !important;
        border-radius: 14px;
        overflow-x: hidden;
    }
    .welcome-title,
    .welcome-sub,
    .welcome-card-title,
    .welcome-card-desc {
        max-width: 100%;
        overflow-wrap: anywhere;
    }
    .welcome-grid {
        grid-template-columns: 1fr !important;
    }
    .welcome-card {
        min-width: 0;
        padding: 14px !important;
    }
    .welcome-actions {
        flex-wrap: wrap;
        justify-content: stretch;
    }
    .welcome-btn {
        width: 100%;
        min-height: 42px;
        white-space: normal;
    }

    .chat-topbar {
        box-sizing: border-box;
        width: 100%;
        max-width: 100vw;
        min-width: 0;
        gap: 6px !important;
        padding-left: max(10px, env(safe-area-inset-left)) !important;
        padding-right: max(10px, env(safe-area-inset-right)) !important;
        overflow: hidden;
    }
    .chat-topbar > [data-style*="flex:1"],
    .chat-topbar-brand,
    .chat-topbar-title,
    .resource-chips {
        display: none !important;
    }
    .sidebar-open-btn {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        flex: 0 0 auto;
    }
    .chat-topbar-logo {
        flex: 0 0 auto;
        min-width: 24px;
        gap: 0 !important;
    }
    .chat-topbar-logo img {
        width: 20px;
        height: 20px;
    }
    .chat-topbar-model {
        flex: 0 1 auto;
        min-width: 0;
        max-width: 108px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        padding: 7px 9px !important;
        font-size: 10.5px !important;
    }
    .topbar-controls {
        margin-left: auto !important;
        min-width: 0;
        flex: 0 1 auto;
        gap: 3px !important;
        overflow: visible;
    }
    .topbar-controls .topbar-btn,
    .topbar-lang-btn {
        box-sizing: border-box;
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
        padding: 0 !important;
        border-radius: 10px !important;
        flex: 0 0 auto;
    }
    .topbar-lang-btn {
        justify-content: center;
        gap: 0 !important;
    }
    .topbar-lang-btn .lang-code,
    .topbar-lang-btn .lang-chev {
        display: none !important;
    }
    /* 2026-06-02 fix: пустая чёрная капсула 38×38 рядом с флагом (содержимое
       скрыто выше). Юзер видел чёрный квадрат на который «нельзя нажать».
       Скрываем саму капсулу — клик-таргет — это .topbar-lang-trigger (button),
       флаг в .lang-flag-holder остаётся видимым и кликабельным. */
    .topbar-lang-btn {
        display: none !important;
    }
    .topbar-lang-trigger {
        padding: 4px !important;
        background: transparent !important;
        border: 0 !important;
    }
    .topbar-lang-dropdown {
        position: fixed !important;
        top: calc(max(50px, env(safe-area-inset-top) + 44px)) !important;
        left: 12px !important;
        right: 12px !important;
        width: auto !important;
        min-width: 0 !important;
        max-width: none !important;
    }

    .chat-welcome {
        box-sizing: border-box;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        padding-left: 14px !important;
        padding-right: 14px !important;
        overflow-x: hidden;
    }
    .chat-welcome h2,
    .chat-welcome p {
        max-width: 100%;
        overflow-wrap: anywhere;
    }
    .agent-switcher {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        width: min(100%, 440px);
        max-width: calc(100vw - 28px);
        gap: 5px !important;
        padding: 5px !important;
        overflow: hidden;
    }
    .agent-pill {
        width: 100%;
        min-width: 0 !important;
        padding: 10px 9px !important;
        gap: 8px !important;
    }
    .agent-pill-text {
        min-width: 0;
    }
    .agent-pill-name,
    .agent-pill-sub {
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .guest-cta {
        flex-wrap: wrap;
        align-items: stretch;
        gap: 10px;
        padding: 12px !important;
    }
    .guest-cta-text {
        flex: 1 1 100%;
    }
    .guest-cta .btn {
        width: 100%;
        justify-content: center;
        min-height: 44px;
    }

    .chat-input-wrapper {
        box-sizing: border-box;
        width: 100%;
        min-width: 0;
    }
    .chat-input-wrapper > .btn-attach,
    .chat-input-wrapper > .btn-send,
    .chat-input-wrapper > .btn-stop,
    .chat-input-wrapper > .btn-voice,
    .chat-input-wrapper > .btn-filesystem,
    .chat-input-wrapper > .btn-slash,
    .chat-input-wrapper > .context-meter,
    .chat-input-wrapper > #enhance-btn,
    .chat-input-wrapper > .btn-mode {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px;
        min-height: 38px;
    }
    .chat-input-wrapper > .btn-mode {
        padding: 0 !important;
        justify-content: center;
    }
    .btn-mode-chev {
        display: none !important;
    }
    #chat-input {
        min-width: 0;
    }
}

@media (max-width: 520px) {
    .topbar-controls .topbar-btn[data-act="exportChat"],
    .topbar-controls .topbar-btn[data-act="exportChatMarkdown"],
    .topbar-controls .topbar-btn[data-act="showShortcuts"],
    .topbar-controls .topbar-btn[data-act="searchMessages"],
    .topbar-controls .topbar-btn[title*="Экспорт"],
    .topbar-controls .topbar-btn[aria-label*="Экспорт"],
    .topbar-controls .topbar-btn[title*="Горячие"],
    .topbar-controls .topbar-btn[aria-label*="Горячие"],
    .topbar-controls .topbar-btn[title*="Поиск"],
    .topbar-controls .topbar-btn[aria-label*="Поиск"] {
        display: none !important;
    }
    .chat-topbar-model {
        max-width: 92px;
    }
    .agent-pill-ico {
        width: 28px !important;
        height: 28px !important;
        border-radius: 9px;
    }
    .agent-pill-name {
        font-size: 12.5px !important;
    }
    .agent-pill-sub {
        font-size: 9px !important;
        letter-spacing: 0.2px;
    }
}

@media (max-width: 430px) {
    .chat-topbar {
        padding-left: max(8px, env(safe-area-inset-left)) !important;
        padding-right: max(8px, env(safe-area-inset-right)) !important;
    }
    .sidebar-open-btn,
    .topbar-controls .topbar-btn,
    .topbar-lang-btn {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
    }
    .chat-topbar-model {
        max-width: 72px;
        padding-left: 7px !important;
        padding-right: 7px !important;
    }
    .chat-input-wrapper {
        gap: 5px !important;
        padding: 7px !important;
    }
    .chat-input-wrapper > .btn-attach,
    .chat-input-wrapper > .btn-send,
    .chat-input-wrapper > .btn-stop,
    .chat-input-wrapper > .btn-voice,
    .chat-input-wrapper > .btn-filesystem,
    .chat-input-wrapper > .btn-slash,
    .chat-input-wrapper > .context-meter,
    .chat-input-wrapper > #enhance-btn,
    .chat-input-wrapper > .btn-mode {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
    }
}

/* ══════════════════════════════════════════════════════════════════════
   Mobile topbar overflow («Основное + …»)
   ──────────────────────────────────────────────────────────────────────
   На десктопе вторичные кнопки лежат inline в .topbar-controls. На
   мобильном (≤640) .topbar-overflow становится скрытым popover'ом, а
   .topbar-more-btn — триггером. Существующее правило в @media (max-width:520)
   с display:none на отдельных кнопках больше не нужно — overflow покрывает
   тот же набор + добавляет реальный доступ к ним вместо «выкинули и забыли».
   ══════════════════════════════════════════════════════════════════════ */

/* По умолчанию (desktop) — overflow ведёт себя как обычная inline-группа,
   триггер скрыт. */
.topbar-overflow {
    display: contents; /* пробрасываем кнопки в flex-родителя, никаких лишних обёрток */
}
.topbar-more-btn {
    display: none !important;
}

.osc-action-sheet-backdrop {
    position: fixed;
    inset: 0;
    z-index: 10080;
    background: rgba(5, 7, 18, 0.42);
    backdrop-filter: blur(3px);
}

.osc-action-sheet {
    position: fixed;
    top: calc(58px + env(safe-area-inset-top));
    right: max(8px, env(safe-area-inset-right));
    z-index: 10081;
    display: grid;
    grid-template-columns: repeat(3, 44px);
    gap: 8px;
    padding: 10px;
    border-radius: 16px;
    background: rgba(18, 17, 31, 0.97);
    border: 1px solid rgba(139, 124, 246, 0.34);
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.46), 0 0 0 1px rgba(255,255,255,0.04) inset;
    backdrop-filter: blur(18px);
}

.osc-action-sheet-item {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 13px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.055);
    color: var(--text, #f7f4ff);
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}

.osc-action-sheet-item:active {
    transform: translateY(1px);
    background: rgba(139, 124, 246, 0.24);
}

.osc-action-sheet-item svg {
    width: 17px;
    height: 17px;
    flex: 0 0 auto;
}

@media (max-width: 640px) {
    /* На мобильных переводим overflow в popover и показываем триггер. */
    .topbar-overflow {
        display: none;
        position: fixed;
        top: calc(56px + env(safe-area-inset-top));
        right: max(8px, env(safe-area-inset-right));
        z-index: 10050;
        flex-direction: row;
        flex-wrap: wrap;
        gap: 4px;
        padding: 8px;
        background: var(--bg-card, #11111f);
        border: 1px solid var(--border, rgba(255,255,255,.08));
        border-radius: 12px;
        box-shadow: 0 12px 32px rgba(0,0,0,.4);
        max-width: min(280px, calc(100vw - 16px));
    }
    .topbar-overflow.is-open {
        display: flex;
    }
    .topbar-overflow .topbar-btn {
        width: 36px;
        height: 36px;
    }
    .topbar-more-btn {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
    }
    .topbar-more-btn[aria-expanded="true"] {
        background: rgba(115, 100, 245, 0.18);
        color: var(--primary-light, #b3a7ff);
    }
    /* Гарантируем что .chat-topbar — позиционирующий контейнер для popover'а. */
    .chat-topbar { position: relative; }
}

/* Старое правило @media (max-width:520){display:none} на этих же кнопках
   осталось активно для слотов с is-hidden / редко-используемых. Но раз они
   теперь в .topbar-overflow и доступ есть через «…», важно его НЕ
   ужесточать — иначе кнопки будут скрыты даже внутри popover'а. Перебиваем
   узким селектором повышенной специфичности. */
@media (max-width: 520px) {
    .topbar-overflow .topbar-btn[data-act="exportChat"],
    .topbar-overflow .topbar-btn[data-act="exportChatMarkdown"],
    .topbar-overflow .topbar-btn[data-act="showShortcuts"],
    .topbar-overflow .topbar-btn[data-act="searchMessages"] {
        display: inline-flex !important;
    }
}

/* Mobile UX hardening 2026-05-19: compact drawer, reliable chat taps,
   non-overflowing model picker, and no stray View Transition toggle ghosts. */
#btn-admin-panel,
.admin-sidebar-btn {
    text-decoration: none;
}

#btn-admin-panel {
    align-items: center;
    justify-content: center;
}

#btn-admin-panel:not(.is-hidden) {
    display: inline-flex;
}

.admin-sidebar-btn .sub-btn-ico {
    color: #fbbf24;
    filter: drop-shadow(0 0 6px rgba(251, 191, 36, 0.35));
}

#toggle-theme + .toggle-slider {
    view-transition-name: none;
}

@media (max-width: 820px) {
    .topbar-overflow {
        display: none;
        position: fixed;
        top: calc(56px + env(safe-area-inset-top));
        right: max(8px, env(safe-area-inset-right));
        z-index: 10050;
        flex-direction: row;
        flex-wrap: wrap;
        gap: 4px;
        padding: 8px;
        background: var(--bg-card, #11111f);
        border: 1px solid var(--border, rgba(255,255,255,.08));
        border-radius: 12px;
        box-shadow: 0 12px 32px rgba(0,0,0,.4);
        max-width: min(280px, calc(100vw - 16px));
    }
    .topbar-overflow.is-open { display: flex; }
    .topbar-overflow .topbar-btn {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
        padding: 0 !important;
    }
    .topbar-more-btn {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
    }
    .chat-topbar { position: relative; }
}

@media (max-width: 768px) {
    .chat-topbar {
        min-height: 52px;
        gap: 5px !important;
    }
    .chat-topbar-model {
        max-width: 74px !important;
        min-width: 58px;
    }
    .topbar-controls {
        gap: 2px !important;
    }
    .topbar-controls .topbar-btn,
    .topbar-lang-btn,
    .sidebar-open-btn {
        width: 34px !important;
        height: 34px !important;
        min-width: 34px !important;
        min-height: 34px !important;
        border-radius: 10px !important;
    }
    #btn-admin-panel:not(.is-hidden) {
        display: inline-flex !important;
        color: #fbbf24;
        background: rgba(251, 191, 36, 0.12);
        border-color: rgba(251, 191, 36, 0.28);
    }
    .sidebar {
        width: min(84vw, 330px) !important;
        max-width: calc(100vw - 34px);
    }
    .sidebar-header {
        padding: 12px 14px 10px !important;
    }
    .btn-new-chat {
        margin: 10px 12px 0 !important;
        min-height: 42px !important;
        padding: 9px 12px !important;
    }
    .sidebar-section {
        flex: 1 1 auto !important;
        min-height: 170px !important;
        max-height: none !important;
        overflow-y: auto !important;
        padding: 8px 12px 8px !important;
    }
    .sidebar-section-title,
    .chat-group-label {
        padding-top: 3px !important;
        padding-bottom: 5px !important;
    }
    .chat-list {
        gap: 1px !important;
    }
    .chat-list-item {
        min-height: 44px !important;
        padding: 10px 10px !important;
        gap: 8px !important;
        border-radius: 9px !important;
        touch-action: manipulation !important;
    }
    .chat-list-item .chat-item-icon {
        width: 16px;
        display: inline-flex;
        justify-content: center;
    }
    .chat-list-item .chat-item-title {
        font-size: 13px !important;
        line-height: 1.25;
    }
    .chat-list-item .chat-item-delete {
        opacity: .78;
        min-width: 28px;
        min-height: 28px;
    }
    .chat-list-item .chat-item-tokens {
        font-size: 10px;
        padding: 1px 6px;
    }
    .chat-list-item:hover .chat-item-tokens {
        opacity: 1;
    }
    .sidebar-bottom {
        flex: 0 0 auto !important;
        padding: 8px 12px !important;
        max-height: min(42dvh, 360px) !important;
        overflow-y: auto !important;
    }
    .model-selector {
        margin-bottom: 8px !important;
    }
    .model-selector-label {
        margin-bottom: 4px !important;
    }
    .model-selector-btn {
        min-height: 42px !important;
        padding: 9px 12px !important;
    }
    .sidebar-settings {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 6px 10px !important;
        margin-bottom: 8px !important;
    }
    .setting-toggle {
        min-height: 34px !important;
        padding: 5px 0 !important;
        gap: 8px;
    }
    .setting-toggle .tog-label {
        min-width: 0;
    }
    .setting-toggle .tog-label span:last-child {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .sidebar-footer {
        padding: 8px 12px calc(10px + env(safe-area-inset-bottom)) !important;
    }
    .token-bar,
    .proj-mem-bar {
        margin-top: 6px !important;
        padding: 7px 10px !important;
    }
    .sub-sidebar-btn,
    .admin-sidebar-btn,
    #servers-sidebar-btn,
    #vault-sidebar-btn {
        min-height: 38px !important;
        padding: 8px 10px !important;
        font-size: 13px !important;
    }
    .sidebar-user {
        min-height: 50px !important;
        padding: 8px 10px !important;
    }

    .pp-overlay {
        align-items: flex-start;
        justify-content: center;
        padding: max(12px, env(safe-area-inset-top)) 10px max(12px, env(safe-area-inset-bottom));
        overflow: hidden;
    }
    .pp-panel,
    .pp-panel.pp-wide {
        box-sizing: border-box;
        width: calc(100vw - 20px) !important;
        max-width: calc(100vw - 20px) !important;
        max-height: calc(100dvh - 24px) !important;
        border-radius: 16px;
    }
    .pp-head {
        padding: 14px 14px 12px !important;
        gap: 10px !important;
    }
    .pp-head-icon {
        width: 36px !important;
        height: 36px !important;
        border-radius: 11px !important;
    }
    .pp-title {
        font-size: 15px !important;
    }
    .pp-body {
        padding: 12px 12px 14px !important;
        overflow-x: hidden !important;
    }

    .mm-wrap-outer,
    .mm-wrap,
    .mm-twocol,
    .mm-col,
    .mm-list,
    .mm-detail,
    .mm-trial-hero {
        box-sizing: border-box;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }
    .mm-tabs {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px !important;
        width: 100% !important;
        overflow: visible !important;
        padding: 4px !important;
    }
    .mm-tab {
        min-width: 0 !important;
        width: 100% !important;
        padding: 8px 7px !important;
        font-size: 11.5px !important;
        white-space: normal !important;
        line-height: 1.15 !important;
    }
    .mm-tab svg {
        flex-shrink: 0;
    }
    .mm-twocol {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }
    .mm-col {
        padding: 12px !important;
        overflow: hidden !important;
    }
    .mm-col-list,
    .mm-list {
        max-height: none !important;
        overflow: visible !important;
        padding-right: 0 !important;
    }
    .mm-col-item,
    .mm-item {
        min-width: 0 !important;
        width: 100% !important;
        padding: 9px 8px !important;
        gap: 8px !important;
    }
    .mm-col-item-meta,
    .mm-item-meta {
        min-width: 0 !important;
    }
    .mm-col-item-name,
    .mm-item-name {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .mm-col-item-desc {
        display: -webkit-box !important;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        white-space: normal !important;
        overflow: hidden !important;
    }
    .mm-col-item-cost,
    .mm-item-cost,
    .mm-trial-card-cost {
        flex: 0 0 auto;
    }
    .mm-detail {
        margin-top: 4px !important;
        padding: 12px !important;
    }
    .mm-detail-head {
        align-items: flex-start !important;
    }
    .mm-detail-title {
        font-size: 16px !important;
        overflow-wrap: anywhere;
    }
    .mm-detail-desc,
    .mm-use-case {
        font-size: 12.5px !important;
        overflow-wrap: anywhere;
    }
    .mm-spec-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
    .mm-spark-banner {
        padding: 10px 11px !important;
        gap: 9px !important;
    }
    .mm-spark-switch {
        width: 40px !important;
        height: 22px !important;
    }
    .mm-spark-knob {
        width: 18px !important;
        height: 18px !important;
        left: 20px !important;
    }
    .mm-spark-banner.is-off .mm-spark-knob {
        left: 2px !important;
    }
}

@media (max-width: 380px) {
    .chat-topbar-model {
        max-width: 62px !important;
    }
    .topbar-controls .topbar-btn,
    .topbar-lang-btn,
    .sidebar-open-btn {
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        min-height: 32px !important;
    }
    .mm-tabs {
        grid-template-columns: 1fr !important;
    }
    .mm-spec-grid {
        grid-template-columns: 1fr !important;
    }
}


/* Chat file cards + plan approval */

@media (max-width: 768px) {
    .topbar-lang-trigger {
        gap: 7px !important;
        min-height: 38px !important;
    }
    .topbar-lang-btn {
        min-width: 38px !important;
        min-height: 38px !important;
        padding: 0 !important;
    }
}

@media (max-width: 430px) {
    .topbar-lang-trigger {
        gap: 6px !important;
        min-height: 36px !important;
    }
    .topbar-lang-btn {
        min-width: 36px !important;
        min-height: 36px !important;
    }
}

@media (max-width: 480px) {
    .topbar-lang-trigger {
        gap: 6px !important;
        min-height: 34px !important;
    }
    .topbar-lang-btn {
        min-width: 34px !important;
        min-height: 34px !important;
    }
}

@media (max-width: 380px) {
    .topbar-lang-trigger {
        gap: 5px !important;
        min-height: 32px !important;
    }
    .topbar-lang-btn {
        min-width: 32px !important;
        min-height: 32px !important;
    }
    .lang-flag-fixed {
        width: 20px;
        height: 15px;
    }
}
.msg-attach-actions {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-left: auto;
}
.msg-attach-act,
.msg-attach-dl {
    width: 28px;
    height: 28px;
    border: 1px solid rgba(139, 124, 246, 0.24);
    border-radius: 8px;
    background: rgba(12, 12, 28, 0.58);
    color: var(--muted, #8f96c5);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease;
}
.msg-attach-act:hover,
.msg-attach-dl:hover {
    color: #f4f1ff;
    border-color: rgba(139, 124, 246, 0.55);
    background: rgba(139, 124, 246, 0.18);
    transform: translateY(-1px);
}
.fm-reveal-pulse {
    outline: 2px solid rgba(94, 234, 212, 0.8);
    box-shadow: 0 0 0 6px rgba(94, 234, 212, 0.12);
}
.agent-plan-review {
    margin-top: 14px;
    padding: 14px;
    border-radius: 14px;
    border: 1px solid rgba(139, 124, 246, 0.26);
    background: linear-gradient(180deg, rgba(22, 22, 42, 0.94), rgba(13, 13, 28, 0.92));
    box-shadow: 0 18px 48px rgba(0,0,0,.22);
}
.apr-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 12px;
}
.apr-title {
    color: var(--text, #f4f1ff);
    font-weight: 800;
    font-size: 15px;
}
.apr-sub {
    color: var(--muted, #9298c8);
    font-size: 13px;
    margin-top: 3px;
}
.apr-badge {
    color: #a78bfa;
    background: rgba(139, 92, 246, 0.14);
    border: 1px solid rgba(167, 139, 250, 0.24);
    border-radius: 999px;
    padding: 4px 9px;
    font-size: 12px;
    white-space: nowrap;
}
.apr-actions {
    display: grid;
    gap: 8px;
}
.apr-option {
    width: 100%;
    display: grid;
    grid-template-columns: 26px 1fr;
    gap: 10px;
    text-align: left;
    padding: 10px;
    border-radius: 12px;
    border: 1px solid rgba(139, 124, 246, 0.22);
    background: rgba(255, 255, 255, 0.035);
    color: var(--text, #f4f1ff);
    cursor: pointer;
}
.apr-option:hover,
.apr-option.is-primary {
    border-color: rgba(94, 234, 212, 0.38);
    background: rgba(94, 234, 212, 0.08);
}
.apr-num {
    width: 24px;
    height: 24px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(139, 124, 246, 0.16);
    color: #c4b5fd;
    font-weight: 800;
}
.apr-option small {
    display: block;
    margin-top: 3px;
    color: var(--muted, #9298c8);
    line-height: 1.35;
}
.apr-note {
    width: 100%;
    margin-top: 10px;
    resize: vertical;
    border-radius: 10px;
    border: 1px solid rgba(139, 124, 246, 0.2);
    background: rgba(7, 8, 22, 0.72);
    color: var(--text, #f4f1ff);
    padding: 9px 10px;
}
.apr-foot {
    display: flex;
    justify-content: flex-end;
    margin-top: 8px;
}
.apr-cancel {
    border: 0;
    background: transparent;
    color: var(--muted, #9298c8);
    cursor: pointer;
}
.agent-plan-review.is-resolved .apr-actions,
.agent-plan-review.is-resolved .apr-note,
.agent-plan-review.is-resolved .apr-foot {
    opacity: 0.55;
}
body.light .agent-plan-review {
    background: rgba(255,255,255,0.96);
    border-color: rgba(99, 102, 241, 0.22);
}
body.light .msg-attach-act,
body.light .msg-attach-dl {
    background: rgba(255,255,255,0.82);
}
@media (max-width: 640px) {
    .msg-attach-actions { gap: 4px; }
    .msg-attach-act,
    .msg-attach-dl { width: 26px; height: 26px; }
    .agent-plan-review { padding: 12px; }
}

/* ════════════════════════════════════════════════════════════════════
   Vault icon skins — минималистичные дизайны иконки ТОЛЬКО для Vault-панели
   (перебираем по очереди; активный задаётся VAULT_SKIN в security_features.js)
   База: убираем градиент-подложку, рамку и радиальное «сияние» (::after).
   ════════════════════════════════════════════════════════════════════ */
.vault-skin .pp-head-icon { background: none; border: none; box-shadow: none; }
.vault-skin .pp-head-icon::after { display: none; }

/* Концепт 1 — «Контур»: тонкий штриховой замок, без подложки */
.vault-skin-outline .pp-head-icon { width: 40px; height: 40px; color: #9aa0bf; }
.vault-skin-outline .pp-head-icon svg { width: 30px; height: 30px; }
body.light-theme .vault-skin-outline .pp-head-icon { color: #5b6178; }

/* Концепт 2 — «Плитка»: плоская матовая подложка + тонкая рамка, монохромный замок */
.vault-skin-tile .pp-head-icon {
    width: 40px; height: 40px; border-radius: 10px;
    background: rgba(255, 255, 255, 0.045);
    border: 1px solid rgba(255, 255, 255, 0.10);
    color: #c3c8df;
}
.vault-skin-tile .pp-head-icon svg { width: 22px; height: 22px; }
body.light-theme .vault-skin-tile .pp-head-icon {
    background: rgba(15, 18, 40, 0.04);
    border-color: rgba(15, 18, 40, 0.12);
    color: #4b5168;
}

/* Концепт 3 — «Акцент-полоса»: без иконки, тонкая вертикальная полоса у заголовка */
.vault-skin-bar .pp-head-icon { display: none; }
.vault-skin-bar .pp-head-text { position: relative; padding-left: 14px; }
.vault-skin-bar .pp-head-text::before {
    content: ''; position: absolute; left: 0; top: 3px; bottom: 3px;
    width: 3px; border-radius: 3px; background: #7364f5;
}

/* Концепт 4 — «Кольцо» (финал): контурное кольцо + бренд-акцент, без заливки/свечения */
.vault-skin-ring .pp-head-icon {
    width: 40px; height: 40px; border-radius: 50%;
    background: none; border: 1px solid rgba(115, 100, 245, 0.45);
    color: #b9aeff;
}
.vault-skin-ring .pp-head-icon svg { width: 20px; height: 20px; }
body.light-theme .vault-skin-ring .pp-head-icon {
    border-color: rgba(115, 100, 245, 0.40); color: #6f5fe6;
}

/* ════════════════════════════════════════════════════════════════════
   Новинка-модель: NEW-бейдж + подсветка карточки + плавные анимации
   (Fable 5 launch 2026-06). Уважает prefers-reduced-motion.
   ════════════════════════════════════════════════════════════════════ */
.model-badge-new {
    display: inline-block; margin-left: 7px; padding: 1px 6px;
    font-size: 9px; font-weight: 800; letter-spacing: .6px; line-height: 1.55;
    border-radius: 5px; color: #fff; vertical-align: middle; user-select: none;
    background: linear-gradient(110deg, #7c3aed 0%, #db2777 45%, #7c3aed 90%);
    background-size: 220% 100%;
    box-shadow: 0 1px 7px rgba(124, 58, 237, .42);
    animation: badgeNewShimmer 3.4s ease-in-out infinite;
}
@keyframes badgeNewShimmer {
    0%, 100% { background-position: 0% 0; }
    50%      { background-position: 100% 0; }
}
/* Карточка-новинка в расширенном пикере — мягкая акцент-рамка + ореол (без !important) */
.mm-col-item.mm-col-item-new {
    border-color: rgba(124, 58, 237, .42);
    box-shadow: 0 0 0 1px rgba(124, 58, 237, .22), 0 6px 22px rgba(124, 58, 237, .12);
}
/* Плавный вход карточек пикера (stagger через nth-child) */
@keyframes mmCardIn { from { opacity: 0; transform: translateY(9px); } to { opacity: 1; transform: none; } }
.mm-col-item { animation: mmCardIn .34s cubic-bezier(.22, 1, .36, 1) both; }
.mm-col-item:nth-child(1) { animation-delay: .02s }
.mm-col-item:nth-child(2) { animation-delay: .05s }
.mm-col-item:nth-child(3) { animation-delay: .08s }
.mm-col-item:nth-child(4) { animation-delay: .11s }
.mm-col-item:nth-child(5) { animation-delay: .14s }
.mm-col-item:nth-child(6) { animation-delay: .17s }
.mm-col-item:nth-child(7) { animation-delay: .20s }
.mm-col-item:nth-child(n+8) { animation-delay: .23s }

/* Анонс-плашка новинки (floating, top-center, dismissible) */
.fable-announce {
    position: fixed; top: 16px; left: 50%; transform: translateX(-50%) translateY(-18px);
    z-index: 9000; max-width: min(540px, calc(100vw - 28px));
    display: flex; align-items: center; gap: 13px; padding: 13px 15px;
    border-radius: 15px; opacity: 0; pointer-events: none;
    background: linear-gradient(135deg, rgba(34, 28, 58, .96), rgba(24, 22, 44, .96));
    border: 1px solid rgba(124, 58, 237, .34);
    box-shadow: 0 14px 44px rgba(0, 0, 0, .5), 0 0 0 1px rgba(124, 58, 237, .12);
    backdrop-filter: blur(14px);
    transition: opacity .45s ease, transform .55s cubic-bezier(.22, 1, .36, 1);
}
.fable-announce.is-in { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }
.fable-announce-ico {
    flex-shrink: 0; width: 38px; height: 38px; border-radius: 11px;
    display: flex; align-items: center; justify-content: center; font-size: 0;
    background: linear-gradient(135deg, #D97757, #B76046);
    border: 1px solid rgba(255, 255, 255, .16);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .20),
        inset 0 -10px 16px rgba(0, 0, 0, .16);
    animation: fableIcoPulse 2.6s ease-in-out infinite;
}
.fable-announce-img {
    display: block;
    width: 74%;
    height: 74%;
    object-fit: contain;
    pointer-events: none;
}
@keyframes fableIcoPulse {
    0%, 100% {
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .20),
            inset 0 -10px 16px rgba(0, 0, 0, .16),
            0 0 0 0 rgba(217, 119, 87, .0);
    }
    50% {
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, .20),
            inset 0 -10px 16px rgba(0, 0, 0, .16),
            0 0 18px 2px rgba(217, 119, 87, .32);
    }
}
.fable-announce-body { flex: 1; min-width: 0; }
.fable-announce-title { font-weight: 700; font-size: 13.5px; color: #fff; margin-bottom: 2px; }
.fable-announce-text { font-size: 12px; color: rgba(226, 226, 240, .74); line-height: 1.4; }
.fable-announce-cta {
    flex-shrink: 0; padding: 7px 13px; border-radius: 9px; border: none; cursor: pointer;
    font-size: 12px; font-weight: 700; color: #fff;
    background: linear-gradient(135deg, #7c3aed, #db2777);
    transition: transform .18s ease, filter .18s ease;
}
.fable-announce-cta:hover { transform: translateY(-1px); filter: brightness(1.08); }
.fable-announce-close {
    flex-shrink: 0; width: 26px; height: 26px; border-radius: 8px; border: none; cursor: pointer;
    background: rgba(255, 255, 255, .06); color: rgba(226, 226, 240, .6);
    display: flex; align-items: center; justify-content: center; font-size: 16px; line-height: 1;
    transition: background .18s ease, color .18s ease;
}
.fable-announce-close:hover { background: rgba(255, 255, 255, .12); color: #fff; }

@media (prefers-reduced-motion: reduce) {
    .model-badge-new, .mm-col-item, .fable-announce-ico { animation: none; }
    .fable-announce { transition: opacity .2s ease; }
    .fable-announce.is-in { transform: translateX(-50%); }
}

/* Download-throttle: countdown-бейдж на кнопке скачивания при 429 (rate-limited).
   --dl-cd ставит JS (_disableBtn) через CSSOM; число секунд поверх дизейбленной кнопки. */
.dl-rate-limited { position: relative; opacity: .6; pointer-events: none; }
.dl-rate-limited::after {
    content: var(--dl-cd, ''); position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; font-weight: 800; color: #fbbf24;
    background: rgba(10, 12, 22, .72); border-radius: inherit; pointer-events: none;
}

/* 2026-06-17: cleaner "open in window" surface */
.fwin {
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(24, 25, 42, 0.98), rgba(10, 11, 24, 0.98));
    border-color: rgba(139, 124, 246, 0.26);
    box-shadow:
        0 28px 90px rgba(0, 0, 0, 0.48),
        0 0 0 1px rgba(139, 124, 246, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    overflow: hidden;
}
.fwin.focused {
    border-color: rgba(129, 140, 248, 0.58);
    box-shadow:
        0 34px 100px rgba(0, 0, 0, 0.54),
        0 0 0 1px rgba(129, 140, 248, 0.28),
        0 0 42px rgba(115, 100, 245, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
.fwin-head {
    min-height: 54px;
    padding: 0 12px 0 18px;
    gap: 12px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.025)),
        rgba(8, 9, 20, 0.58);
    border-bottom-color: rgba(139, 124, 246, 0.20);
}
.fwin-icon {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 9px;
    background: rgba(115, 100, 245, 0.14);
    color: var(--primary-light);
    font-size: 15px;
}
.fwin-title {
    font-size: 15px;
    font-weight: 750;
    letter-spacing: -0.01em;
}
.fwin-buttons {
    gap: 6px;
}
.fwin-btn {
    width: 32px;
    height: 30px;
    border-radius: 9px;
    color: var(--text-muted);
}
.fwin-btn:hover {
    background: rgba(139, 124, 246, 0.14);
    color: var(--text);
}
.fwin-body {
    background: var(--bg);
}
.fwin-toolbar {
    height: 56px;
    gap: 8px;
    padding: 9px 16px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012)),
        var(--bg-card);
    border-bottom-color: rgba(139, 124, 246, 0.18);
}
.fwin-tool-btn {
    min-height: 36px;
    padding: 0 13px;
    border-radius: 11px;
    border-color: rgba(139, 124, 246, 0.26);
    background: rgba(255, 255, 255, 0.035);
    font-size: 13px;
    font-weight: 700;
    gap: 8px;
}
.fwin-tool-btn:hover {
    background: rgba(139, 124, 246, 0.13);
    border-color: rgba(139, 124, 246, 0.48);
}
.fwin-tool-btn-primary {
    color: #60f0a2;
    background: rgba(34, 197, 94, 0.13);
    border-color: rgba(34, 197, 94, 0.42);
}
.fwin-tool-btn-primary:hover {
    background: rgba(34, 197, 94, 0.20);
    border-color: rgba(74, 222, 128, 0.66);
}
.fwin-tool-btn-icon {
    width: 38px;
    padding: 0;
}
.fwin-toolbar-hint {
    padding: 5px 9px;
    border: 1px solid rgba(139, 124, 246, 0.18);
    border-radius: 999px;
    background: rgba(139, 124, 246, 0.08);
    color: var(--text-secondary);
}
.fwin-code-pre,
.fwin-html-frame {
    height: calc(100% - 56px);
}
.fwin-pre {
    padding: 22px 24px;
    font-size: 14px;
    line-height: 1.72;
    background:
        radial-gradient(circle at 0 0, rgba(115, 100, 245, 0.08), transparent 34%),
        #060716;
}
.fwin-pre code {
    display: block;
    min-width: max-content;
}
.fwin-rsz-e,
.fwin-rsz-w {
    width: 10px;
}
.fwin-rsz-n,
.fwin-rsz-s {
    height: 10px;
}
body.light-theme .fwin {
    background: rgba(255, 255, 255, 0.98);
    border-color: rgba(99, 102, 241, 0.22);
    box-shadow:
        0 30px 90px rgba(15, 23, 42, 0.22),
        0 0 0 1px rgba(99, 102, 241, 0.10);
}
body.light-theme .fwin.focused {
    border-color: rgba(99, 102, 241, 0.45);
    box-shadow:
        0 34px 100px rgba(15, 23, 42, 0.30),
        0 0 0 1px rgba(99, 102, 241, 0.26),
        0 0 38px rgba(99, 102, 241, 0.16);
}
body.light-theme .fwin-head {
    background: linear-gradient(180deg, rgba(99,102,241,0.07), rgba(255,255,255,0.96));
    border-bottom-color: rgba(99, 102, 241, 0.16);
}
body.light-theme .fwin-icon {
    background: rgba(99, 102, 241, 0.10);
}
body.light-theme .fwin-toolbar {
    background: rgba(248, 250, 252, 0.96);
    border-bottom-color: rgba(99, 102, 241, 0.14);
}
body.light-theme .fwin-tool-btn {
    background: rgba(255, 255, 255, 0.72);
    border-color: rgba(15, 23, 42, 0.10);
}
body.light-theme .fwin-tool-btn:hover {
    background: rgba(99, 102, 241, 0.08);
    border-color: rgba(99, 102, 241, 0.24);
}
body.light-theme .fwin-pre {
    background: #f8fafc;
}
