/* Порядок загрузки: 1. main.css, 2. cabinet.css, 3. admin.css
   TASK-037 product cabinet layer. Loaded after main.css. */
:root {
    --font-display: "Russo One", "Arial Black", Impact, sans-serif;
    --font-mono: "PT Mono", "Cascadia Mono", "Consolas", monospace;
    --sidebar-width: 300px;
    --content-max: 1240px;
    --space-grid: 18px;
    --space-card: 18px;
    --radius-lg: 8px;
    --bg-void: #040810;
    --bg-deep: #060d1a;
    --bg-surface: #0a1628;
    --bg-panel: #0d1e35;
    --bg-card: #0f2340;
    --bg-elevated: #122848;
    --gradient-card: linear-gradient(180deg, rgba(13, 30, 53, 0.8), rgba(10, 22, 40, 0.92));
    --gradient-card-alt: linear-gradient(180deg, rgba(12, 31, 55, 0.78), rgba(7, 17, 31, 0.94));
    --border-faint: rgba(0, 140, 255, 0.08);
    --border-subtle: rgba(0, 160, 255, 0.15);
    --border-mid: rgba(0, 180, 255, 0.25);
    --border-active: rgba(0, 200, 255, 0.5);
    --border-glow: rgba(0, 220, 255, 0.8);
    --accent-primary: #00b4ff;
    --accent-bright: #00d4ff;
    --accent-pulse: #00eeff;
    --accent-amber: #ff8c00;
    --accent-action: #ff7a00;
    --accent-action-bright: #ffb12a;
    --accent-action-pulse: #ffd36a;
    --accent-warning: #a78bfa;
    --accent-warning-bright: #c4b5fd;
    --accent-warning-soft: rgba(167, 139, 250, 0.12);
    --accent-warning-border: rgba(167, 139, 250, 0.38);
    --accent-cost: #cbd5e1;
    --accent-cost-bright: #f1f5f9;
    --accent-cost-soft: rgba(203, 213, 225, 0.1);
    --accent-cost-border: rgba(203, 213, 225, 0.34);
    --accent-progress-bright: #ffd166;
    --accent-cyan: var(--accent-bright);
    --accent-green: #00ff9d;
    --accent-red: #ff4d6d;
    --text-primary: #e8f4ff;
    --text-secondary: #8ab4d4;
    --text-muted: #7e9db8;
    --text-disabled: #4a6a85;
    --shadow-panel: 0 0 0 1px rgba(0, 180, 255, 0.08), 0 14px 40px rgba(0, 0, 0, 0.45);
    --shadow-card: 0 0 0 1px rgba(0, 180, 255, 0.06), 0 12px 32px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 0 0 1px rgba(0, 200, 255, 0.1), 0 24px 64px rgba(0, 0, 0, 0.5);
    --glow-sm: 0 0 10px rgba(0, 180, 255, 0.3);
    --glow-md: 0 0 20px rgba(0, 180, 255, 0.4), 0 0 40px rgba(0, 120, 255, 0.2);
    --glow-lg: 0 0 30px rgba(0, 200, 255, 0.5), 0 0 60px rgba(0, 140, 255, 0.3);
    --glow-action: 0 0 15px rgba(255, 140, 0, 0.4), 0 0 30px rgba(255, 100, 0, 0.2);
    --glow-amber: 0 0 12px rgba(167, 139, 250, 0.32);
    --glow-cost: 0 0 12px rgba(203, 213, 225, 0.24);
    --radius-sm: 4px;
    --radius-md: 6px;
    --transition: 0.18s cubic-bezier(0.4, 0, 0.2, 1);
    --transition-interactive: background 120ms ease, border-color 120ms ease, color 120ms ease, opacity 120ms ease, transform 120ms ease, box-shadow 120ms ease;
    --color-error-text: #ffd6de;
    --color-success-text: #d6fff4;
    --bg-modal: #07111d;
    --bg-btn-primary: linear-gradient(135deg, #0a2a4a, #0d3560);
    --z-base: 1;
    --z-dropdown: 100;
    --z-sticky: 200;
    --z-modal-backdrop: 300;
    --z-modal: 400;
    --z-tooltip: 500;
    --z-notification: 600;
    --z-skip-link: 9999;
    --btn-secondary-border: #155174;
    --btn-secondary-bg: #082033;
    --btn-secondary-hover-bg: #0B2A42;
    --btn-secondary-hover-border: #1D75A3;
    --btn-secondary-text: #B8D8F2;
    --btn-secondary-hover-text: #E4F4FF;
}

.cabinet-body {
    font-size: 15px;
    background:
        radial-gradient(circle at top, rgba(0, 186, 255, 0.12), transparent 30%),
        radial-gradient(circle at 80% 20%, rgba(0, 238, 255, 0.08), transparent 18%),
        linear-gradient(180deg, #050914 0%, var(--bg-deep) 44%, #050a12 100%);
}

.cabinet-body.cabinet-v2 > .topbar,
.cabinet-body.cabinet-v2 > .page,
.cabinet-body.cabinet-v2 .hero {
    display: none;
}

.cabinet-body .app-shell {
    position: relative;
    z-index: var(--z-base);
    display: grid;
    grid-template-columns: var(--sidebar-width) minmax(0, 1fr);
    min-height: 100vh;
    width: 100%;
}

.cabinet-body .app-sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    padding: 22px 0 18px;
    border-right: 1px solid var(--border-subtle);
    background: linear-gradient(180deg, rgba(4, 8, 16, 0.98), rgba(6, 13, 26, 0.98));
    overflow: auto;
}

.cabinet-body .app-main {
    min-width: 0;
    width: min(var(--content-max), calc(100% - 56px));
    margin: 0 auto;
    padding: 0 0 84px;
}

.cabinet-body.history-page .app-main,
.cabinet-body .history-page.app-main {
    width: min(1360px, calc(100% - 56px));
}

.cabinet-body .brand {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    padding: 0 18px 22px;
    color: inherit;
    text-decoration: none;
}

.cabinet-body .brand-copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.cabinet-body .brand-title {
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 22px;
    line-height: 1;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.cabinet-body .brand-subtitle {
    color: var(--accent-action-bright);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 12px;
    letter-spacing: 0.24em;
    line-height: 1;
    text-transform: uppercase;
}

.cabinet-body .radar {
    position: relative;
    flex: 0 0 44px;
    width: 44px;
    height: 44px;
    border: 1.5px solid rgba(255, 122, 0, 0.72);
    border-radius: 50%;
    background: radial-gradient(circle at center, rgba(255, 186, 57, 0.2), rgba(4, 8, 16, 0.82) 52%, rgba(4, 8, 16, 0.98) 100%);
    box-shadow: inset 0 0 20px rgba(0, 200, 255, 0.12), 0 0 18px rgba(255, 122, 0, 0.22);
    overflow: hidden;
}

.cabinet-body .ring {
    position: absolute;
    top: 50%;
    left: 50%;
    border: 1.4px solid rgba(255, 147, 24, 0.76);
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.cabinet-body .r1 { width: 10px; height: 10px; }
.cabinet-body .r2 { width: 20px; height: 20px; opacity: 0.85; }
.cabinet-body .r3 { width: 32px; height: 32px; opacity: 0.62; border-style: dashed; animation: cabinet-ring-spin 12s linear infinite; }
.cabinet-body .r4 { width: 42px; height: 42px; opacity: 0.46; border-color: rgba(255, 122, 0, 0.62); }

.cabinet-body .sweep {
    position: absolute;
    inset: -6%;
    background: conic-gradient(from 0deg, rgba(0, 0, 0, 0) 0deg, rgba(255, 122, 0, 0) 286deg, rgba(255, 122, 0, 0.18) 314deg, rgba(255, 177, 38, 0.82) 334deg, rgba(255, 122, 0, 0.28) 350deg, rgba(255, 122, 0, 0) 360deg);
    animation: cabinet-spin 4.5s linear infinite;
    filter: blur(1px);
}

.cabinet-body .core {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--accent-action-pulse);
    transform: translate(-50%, -50%);
    box-shadow: 0 0 12px rgba(255, 189, 63, 0.95), 0 0 24px rgba(255, 122, 0, 0.42);
}

@keyframes cabinet-ring-spin {
    to { transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes cabinet-spin {
    to { transform: rotate(360deg); }
}

.cabinet-body .app-menu {
    display: flex;
    flex-direction: column;
}

.cabinet-body .nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 44px;
    padding: 0 18px;
    color: var(--text-muted);
    font-family: var(--font-body);
    font-size: 17px;
    text-decoration: none;
    transition: var(--transition-interactive);
}

.cabinet-body .nav-item:hover {
    color: var(--text-secondary);
    background: rgba(0, 180, 255, 0.035);
}

.cabinet-body .nav-item:focus-visible {
    color: var(--text-secondary);
    outline: 2px solid var(--accent-primary);
    outline-offset: -2px;
    background: rgba(0, 180, 255, 0.06);
}

.cabinet-body .nav-item.active {
    padding-left: 15px;
    border-left: 3px solid var(--accent-primary);
    color: var(--accent-bright);
    background: rgba(0, 180, 255, 0.06);
}

.cabinet-body .nav-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    opacity: 0.6;
    transition: opacity var(--transition-interactive);
}

.cabinet-body .nav-item:hover .nav-icon,
.cabinet-body .nav-item.active .nav-icon {
    opacity: 1;
}

.cabinet-body .support-menu-action {
    margin: 18px 18px 0;
    padding-top: 16px;
    border-top: 1px solid var(--border-subtle);
}

.cabinet-body .support-menu-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    min-height: 44px;
    padding: 0 16px;
    border: 1px solid rgba(255, 140, 0, 0.54);
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, #d96c00 0%, #9f4d00 100%);
    color: var(--text-primary);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: var(--glow-action), inset 0 1px 0 rgba(255, 255, 255, 0.16);
    cursor: pointer;
    transition: var(--transition-interactive);
}

.cabinet-body .support-menu-button:hover,
.cabinet-body .support-menu-button:focus-visible {
    border-color: rgba(255, 181, 71, 0.72);
    background: linear-gradient(180deg, #f07a00 0%, #b45600 100%);
    outline: none;
}

.cabinet-body .support-menu-icon {
    display: inline-grid;
    place-items: center;
    flex: 0 0 22px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: rgba(112, 49, 0, 0.28);
    color: var(--text-primary);
    font-weight: 700;
    line-height: 1;
}

.cabinet-body .referrals-dashboard {
    display: grid;
    gap: 18px;
}

.cabinet-body .referral-link-panel,
.cabinet-body .referral-rules-panel {
    gap: 16px;
}

.cabinet-body .referral-link-box {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
}

.cabinet-body .referral-link-input {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    background: transparent;
    font-family: var(--font-body);
}

.cabinet-body .referral-copy-button {
    min-height: 44px;
}

.cabinet-body .money-page .secondary {
    font-size: 15px;
}

.cabinet-body .money-page .tiny-label {
    font-size: 12px;
}

.cabinet-body .money-page .tariff-features li,
.cabinet-body .money-page .tariff-limits span {
    font-size: 15px;
}

.cabinet-body .referral-copy-feedback {
    margin: 0;
}

.cabinet-body .referral-stats .summary-card strong {
    font-size: 31px;
    line-height: 1.1;
}

.cabinet-body .referral-rules-list {
    display: grid;
    gap: 10px;
    margin: 0;
    padding-left: 20px;
    color: var(--text-secondary);
}

.cabinet-body .referral-rules-list li {
    font-size: 17px;
    line-height: 1.55;
}

.cabinet-body .muted-copy {
    margin: 0;
    color: var(--text-muted);
    line-height: 1.55;
}

.cabinet-body.news-page .news-main {
    width: min(1100px, calc(100% - 56px));
}

.cabinet-body .public-news-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    width: min(1100px, calc(100% - 32px));
    margin: 0 auto;
    padding: 22px 0;
}

.cabinet-body .public-news-main {
    width: min(1100px, calc(100% - 32px));
    margin: 0 auto;
    padding: 0 0 72px;
}

.cabinet-body .news-workspace,
.cabinet-body .news-article {
    display: grid;
    gap: 18px;
    padding-top: 18px;
}

.cabinet-body .news-list {
    columns: 2;
    column-gap: 20px;
}

.cabinet-body .news-card {
    break-inside: avoid;
    margin-bottom: 14px;
}

.cabinet-body .news-card,
.cabinet-body .news-empty,
.cabinet-body .news-article {
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: var(--gradient-card);
    box-shadow: var(--shadow-panel), inset 0 1px 0 rgba(0, 200, 255, 0.08);
}

.cabinet-body .news-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-self: start;
    min-height: 0;
    padding: var(--space-card);
}

.cabinet-body .news-card-no-cover {
    padding-top: 20px;
}

.cabinet-body .news-cover {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.04);
    color: var(--text-secondary);
    flex: 0 0 auto;
}

.cabinet-body .news-cover img,
.cabinet-body .news-cover video,
.cabinet-body .news-cover iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
    object-fit: cover;
}

.cabinet-body .news-cover-detail {
    max-width: 820px;
}

.cabinet-body .news-video-placeholder {
    display: grid;
    width: 100%;
    height: 100%;
    place-items: center;
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 21px;
    color: var(--text-primary);
    background: linear-gradient(135deg, rgba(0, 200, 255, 0.12), rgba(255, 255, 255, 0.04));
}

.cabinet-body .news-play-button {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 58px;
    height: 58px;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    background: rgba(7, 18, 28, 0.82);
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.32);
    pointer-events: none;
    opacity: 1;
    transition: var(--transition-interactive);
}

.cabinet-body [data-news-video-cover].is-playing .news-play-button {
    opacity: 0;
}

.cabinet-body .news-play-button::after {
    content: "";
    position: absolute;
    left: 23px;
    top: 18px;
    width: 0;
    height: 0;
    border-top: 11px solid transparent;
    border-bottom: 11px solid transparent;
    border-left: 16px solid #ffffff;
}

.cabinet-body .news-card h3 {
    margin: 0;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 22px;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.cabinet-body .news-card p {
    margin: 0;
    color: var(--text-secondary);
    line-height: 1.6;
}

.cabinet-body .news-card .btn {
    align-self: flex-start;
    flex: 0 0 auto;
    min-height: 36px;
    width: auto;
}

.cabinet-body .news-card-meta,
.cabinet-body .news-public-action {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.cabinet-body .news-card-meta time {
    color: var(--text-muted);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
}

.cabinet-body .news-article-head time {
    display: inline-flex;
    align-items: center;
    justify-self: start;
    min-height: 28px;
    padding: 4px 12px;
    border: 1px solid rgba(0, 180, 255, 0.28);
    border-radius: 100px;
    background: rgba(0, 160, 240, 0.10);
    color: var(--accent-primary);
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 500;
}

.cabinet-body .hashtag-filter,
.cabinet-body .hashtag-badges,
.cabinet-body .admin-hashtag-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    min-width: 0;
}

.cabinet-body .hashtag-filter {
    margin: 0 0 14px;
    padding: 10px 0;
}

.cabinet-body .hashtag-filter-label {
    color: var(--text-muted);
    font-size: 14px;
}

.cabinet-body .hashtag-pill,
.cabinet-body .hashtag-badge {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    max-width: 100%;
    padding: 6px 14px;
    border: 1px solid rgba(255, 122, 0, 0.35);
    border-radius: 100px;
    background: rgba(255, 122, 0, 0.15);
    color: #ffb74d;
    font-size: 14px;
    line-height: 1.2;
    text-decoration: none;
    overflow-wrap: anywhere;
}

.cabinet-body .hashtag-pill:hover,
.cabinet-body .hashtag-badge:hover {
    border-color: rgba(255, 122, 0, 0.6);
    background: rgba(255, 122, 0, 0.28);
    color: #ffcc80;
}

.cabinet-body .hashtag-pill.is-active {
    border-color: var(--accent-action);
    background: var(--accent-action);
    color: var(--text-primary);
}

.cabinet-body .admin-hashtag-picker-field {
    position: relative;
}

.cabinet-body .admin-hashtag-picker {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    min-width: 0;
}

.cabinet-body .admin-hashtag-picker > input {
    flex: 1 1 180px;
    min-width: 140px;
}

.cabinet-body .admin-hashtag-picker-chips {
    flex-wrap: wrap;
    gap: 6px;
    min-width: 0;
}

.cabinet-body .admin-hashtag-picker-chips:not([hidden]) {
    display: flex;
}

.cabinet-body .admin-hashtag-chip,
.cabinet-body .admin-hashtag-picker-option {
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    background: rgba(255, 122, 0, 0.1);
    color: var(--text-primary);
    cursor: pointer;
}

.cabinet-body .admin-hashtag-chip {
    min-height: 38px;
    padding: 6px 10px;
    font-size: 14px;
    overflow-wrap: anywhere;
}

.cabinet-body .admin-hashtag-picker-dropdown {
    position: absolute;
    z-index: var(--z-dropdown);
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    display: grid;
    gap: 4px;
    max-height: 220px;
    overflow-y: auto;
    padding: 8px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(4, 10, 18, 0.98);
    box-shadow: var(--shadow-card);
}

.cabinet-body .admin-hashtag-picker-dropdown[hidden] {
    display: none;
}

.cabinet-body .admin-hashtag-picker-option {
    min-height: 38px;
    padding: 8px 10px;
    text-align: left;
}

.cabinet-body .admin-hashtag-chip:hover,
.cabinet-body .admin-hashtag-picker-option:hover {
    border-color: rgba(0, 200, 255, 0.48);
    background: rgba(255, 122, 0, 0.18);
}

.cabinet-body .news-empty {
    padding: 18px;
}

.cabinet-body .news-article {
    padding: 22px;
}

.cabinet-body .news-back-link {
    text-decoration: none;
    color: var(--accent-primary);
    font-size: 16px;
}

.cabinet-body .news-back-link:hover {
    color: var(--accent-bright);
}

.cabinet-body .news-article-head {
    display: grid;
    gap: 10px;
    max-width: 820px;
}

.cabinet-body .news-article-head h2 {
    margin: 0;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 37px;
    line-height: 1.18;
    overflow-wrap: anywhere;
}

.cabinet-body .news-article-head p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 19px;
    line-height: 1.7;
}

.cabinet-body .news-content {
    max-width: 820px;
    color: var(--text-secondary);
    font-size: 19px;
    line-height: 1.75;
    overflow-wrap: anywhere;
}

.cabinet-body .news-content h1,
.cabinet-body .news-content h2,
.cabinet-body .news-content h3,
.cabinet-body .news-content h4 {
    margin: 1.4em 0 0.55em;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    line-height: 1.25;
}

.cabinet-body .news-content h1 { font-size: 31px; }
.cabinet-body .news-content h2 { font-size: 27px; }
.cabinet-body .news-content h3 { font-size: 22px; }
.cabinet-body .news-content h4 { font-size: 21px; }

.cabinet-body .news-content p,
.cabinet-body .news-content ul,
.cabinet-body .news-content ol,
.cabinet-body .news-content blockquote,
.cabinet-body .news-content pre {
    margin: 0 0 1em;
}

.cabinet-body .news-content a {
    color: var(--accent-bright);
}

.cabinet-body .news-content img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 14px 0;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
}

.cabinet-body .news-content blockquote {
    padding: 10px 14px;
    border-left: 3px solid var(--accent-primary);
    background: rgba(255, 122, 0, 0.04);
}

.cabinet-body .news-content code,
.cabinet-body .news-content pre {
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
}

.cabinet-body .news-content code {
    color: var(--accent-progress-bright);
}

.cabinet-body .news-content pre {
    max-width: 100%;
    overflow-x: auto;
    padding: 12px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(4, 8, 16, 0.66);
}

.cabinet-body.is-support-modal-open {
    overflow: hidden;
}

.cabinet-body .support-modal[hidden] {
    display: none;
}

.cabinet-body .support-modal {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-modal) + 1);
    display: grid;
    place-items: center;
    padding: 24px;
    overflow-y: auto;
}

.cabinet-body .support-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(2, 6, 14, 0.78);
    backdrop-filter: blur(8px);
}

.cabinet-body .support-modal-dialog {
    position: relative;
    z-index: var(--z-base);
    display: grid;
    gap: 16px;
    width: min(520px, 100%);
    padding: 22px;
    border: 1px solid var(--border-active);
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(13, 30, 53, 0.98), rgba(7, 17, 31, 0.98));
    box-shadow: var(--shadow-panel), 0 24px 80px rgba(0, 0, 0, 0.44), inset 0 1px 0 rgba(0, 200, 255, 0.08);
}

.cabinet-body .support-modal-dialog h2 {
    margin: 0;
    padding-right: 36px;
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 24px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.cabinet-body .support-modal-copy {
    margin: -4px 0 0;
    color: var(--text-muted);
    font-size: 15px;
    line-height: 1.6;
}

.cabinet-body .support-modal-close {
    position: absolute;
    top: 14px;
    right: 14px;
    display: inline-grid;
    place-items: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid var(--border-subtle);
    border-radius: 50%;
    background: rgba(255, 122, 0, 0.04);
    color: var(--text-secondary);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
}

.cabinet-body .support-modal-close:hover,
.cabinet-body .support-modal-close:focus-visible {
    color: var(--accent-bright);
    border-color: var(--border-active);
    outline: none;
}

.cabinet-body .support-channel-group {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: rgba(0, 200, 255, 0.025);
}

.cabinet-body .support-channel-group h3 {
    margin: 0;
    color: var(--accent-bright);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
    letter-spacing: 0.1em;
    line-height: 1.3;
    text-transform: uppercase;
}

.cabinet-body .support-channel-group-collapsible {
    padding: 0;
    overflow: hidden;
}

.cabinet-body .support-accordion-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    width: 100%;
    min-height: 50px;
    padding: 0 14px;
    border: 0;
    background: transparent;
    color: var(--accent-bright);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.3;
    text-align: left;
    text-transform: uppercase;
    cursor: pointer;
}

.cabinet-body .support-accordion-toggle:hover {
    background: rgba(255, 122, 0, 0.045);
}

.cabinet-body .support-accordion-toggle:focus-visible {
    outline: 2px solid var(--accent-primary);
    outline-offset: -1px;
    background: rgba(255, 122, 0, 0.06);
}

.cabinet-body .support-accordion-arrow {
    flex: 0 0 9px;
    width: 9px;
    height: 9px;
    border-right: 2px solid var(--accent-amber);
    border-bottom: 2px solid var(--accent-amber);
    transform: rotate(45deg) translateY(-2px);
    transition: var(--transition-interactive);
}

.cabinet-body .support-accordion-toggle[aria-expanded="true"] .support-accordion-arrow {
    transform: rotate(225deg) translateY(-2px);
}

.cabinet-body .support-channel-list {
    display: grid;
    gap: 10px;
}

.cabinet-body .support-channel-list-collapsible {
    padding: 0 14px 14px;
}

.cabinet-body .support-channel-list-collapsible[hidden] {
    display: none;
}

.cabinet-body .support-channel {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
    min-height: 54px;
    padding: 12px 14px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: rgba(0, 180, 255, 0.035);
    color: var(--text-primary);
    font-size: 17px;
    font-weight: 700;
    text-decoration: none;
    transition: var(--transition-interactive);
}

.cabinet-body .support-channel:hover,
.cabinet-body .support-channel:focus-visible {
    border-color: var(--border-active);
    background: rgba(255, 122, 0, 0.07);
    box-shadow: var(--glow-sm);
    outline: none;
    transform: translateY(-1px);
}

.cabinet-body .support-channel span:last-child {
    min-width: 0;
    overflow-wrap: anywhere;
}

.cabinet-body .support-channel-icon,
.cabinet-body .support-channel-badge {
    flex: 0 0 36px;
    width: 36px;
    height: 36px;
}

.cabinet-body .support-channel-icon {
    display: block;
    object-fit: contain;
}

.cabinet-body .support-channel-badge {
    display: inline-grid;
    place-items: center;
    border: 1px solid rgba(255, 122, 0, 0.34);
    border-radius: 50%;
    background: rgba(255, 122, 0, 0.12);
    color: var(--accent-amber);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1;
}

.cabinet-body .support-phone-status {
    margin: 0;
    padding: 10px 12px;
    border: 1px solid rgba(0, 255, 157, 0.34);
    border-radius: var(--radius-lg);
    background: rgba(0, 255, 157, 0.08);
    color: var(--color-success-text);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.5;
    opacity: 1;
    transition: var(--transition-interactive);
}

.cabinet-body .support-phone-status[hidden] {
    display: none;
}

.cabinet-body .support-phone-status.is-hiding {
    opacity: 0;
}

.cabinet-body .sidebar-card {
    display: grid;
    gap: 12px;
    margin: 28px 18px 0;
    padding: var(--space-card);
}

.cabinet-body .sidebar-card strong {
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 21px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.cabinet-body .sidebar-card p {
    margin: 0;
    color: var(--text-muted);
    font-size: 12px;
    line-height: 1.7;
}

.cabinet-body .mobile-user-card {
    display: none;
}

.cabinet-body .app-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    min-height: 66px;
    padding: 12px 0 10px;
    border-bottom: 1px solid var(--border-subtle);
    background: rgba(4, 8, 16, 0.42);
    backdrop-filter: blur(10px);
}

.cabinet-body .app-topbar h1 {
    margin: 3px 0 0;
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 27px;
    letter-spacing: 0.08em;
    line-height: 1.08;
    text-transform: uppercase;
}

.cabinet-body .topbar-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.cabinet-body .topbar-actions form {
    margin: 0;
}

.cabinet-body .auth-chip {
    max-width: 260px;
    overflow: hidden;
    padding: 8px 10px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cabinet-body .workspace-section {
    margin-top: 24px;
    scroll-margin-top: 24px;
}

.cabinet-body .workspace-section:first-of-type {
    margin-top: 16px;
}

.cabinet-body .cabinet-section-head {
    align-items: center;
    justify-content: space-between;
}

.cabinet-body .cabinet-section-head .section-title {
    margin-top: 7px;
    font-size: 21px;
}

.cabinet-body .processing-grid,
.cabinet-body .history-layout {
    display: grid;
    grid-template-columns: minmax(320px, 430px) minmax(0, 1fr);
    gap: var(--space-grid);
    align-items: start;
}

.cabinet-body .processing-panel,
.cabinet-body .history-list-panel {
    position: sticky;
    top: 84px;
}

.cabinet-body .panel,
.cabinet-body .card,
.cabinet-body .summary-card,
.cabinet-body .state-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
    padding: var(--space-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: var(--gradient-card);
    box-shadow: var(--shadow-panel), inset 0 1px 0 rgba(0, 200, 255, 0.08);
    overflow: visible;
}

.cabinet-body .result-card,
.cabinet-body .empty-state {
    min-width: 0;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: var(--gradient-card);
    box-shadow: var(--shadow-panel), inset 0 1px 0 rgba(0, 200, 255, 0.08);
    overflow: visible;
}

.cabinet-body .protocol-list-panel,
.cabinet-body .protocol-form-panel {
    max-width: 100%;
}

.cabinet-body .panel-actions,
.cabinet-body .protocol-card-badges,
.cabinet-body .protocol-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.cabinet-body .protocol-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.cabinet-body .protocol-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
    padding: var(--space-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: var(--gradient-card);
    box-shadow: var(--shadow-panel), inset 0 1px 0 rgba(255,177,42,0.08);
}

.cabinet-body .protocol-card-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
}

.cabinet-body .protocol-card-head h4 {
    margin: 4px 0 0;
    font-size: 19px;
    line-height: 1.25;
    word-break: break-word;
    overflow-wrap: anywhere;
    max-width: 100%;
}

.cabinet-body .protocol-card-meta {
    color: var(--text-muted);
    font-size: 12px;
    line-height: 1.5;
}

.cabinet-body .protocol-card-actions {
    margin-top: auto;
}

.cabinet-body .protocol-form-panel textarea {
    min-height: 260px;
    resize: vertical;
}

.cabinet-body .admin-form-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

.cabinet-body .protocol-form-panel {
    gap: 22px;
    padding: 24px;
}

.cabinet-body .protocol-form-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
}

.cabinet-body .protocol-field {
    gap: 10px;
    color: var(--text-secondary);
    font-size: 14px;
}

.cabinet-body .protocol-input,
.cabinet-body .protocol-textarea {
    width: 100%;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(4, 8, 16, 0.78);
    color: var(--text-primary);
    font-size: 17px;
    line-height: 1.55;
    outline: none;
    transition: var(--transition-interactive);
}

.cabinet-body .protocol-input {
    min-height: 48px;
    padding: 12px 14px;
}

.cabinet-body .protocol-textarea {
    min-height: 380px;
    padding: 14px;
    resize: vertical;
}

.cabinet-body .protocol-input:focus,
.cabinet-body .protocol-textarea:focus {
    border-color: rgba(0, 200, 255, 0.58);
    box-shadow: var(--glow-sm), inset 0 1px 0 rgba(0, 200, 255, 0.1);
}

.cabinet-body .admin-feature-toggle,
.cabinet-body .protocol-availability-toggle {
    display: flex;
    min-height: 58px;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: rgba(4, 8, 16, 0.35);
    color: var(--text-secondary);
}
.cabinet-body .protocol-availability-toggle {
    width: min(100%, 420px);
}

.cabinet-body .protocol-delete-modal {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-dropdown) + 4);
    place-items: center;
    padding: 24px;
    background: rgba(2, 6, 12, 0.72);
    backdrop-filter: blur(8px);
}

.cabinet-body .protocol-delete-modal:not([hidden]) {
    display: grid;
}

.cabinet-body .protocol-delete-dialog {
    display: grid;
    gap: 14px;
    width: min(100%, 460px);
    padding: 22px;
    border: 1px solid var(--border-mid);
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(13, 30, 53, 0.98), rgba(7, 17, 31, 0.98));
    box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(0, 200, 255, 0.08);
}

.cabinet-body .protocol-delete-dialog h3 {
    margin: 0;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 21px;
    line-height: 1.2;
}

.cabinet-body .protocol-delete-dialog p {
    margin: 0;
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.65;
}

.cabinet-body .protocol-delete-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    flex-wrap: wrap;
}

@media (max-width: 980px) {
    .cabinet-body .protocol-cards {
        grid-template-columns: 1fr;
    }
}

.cabinet-body .panel::before,
.cabinet-body .result-card::before,
.cabinet-body .empty-state::before {
    display: none;
}

.cabinet-body .panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.cabinet-body .panel-head h3,
.cabinet-body .card h3,
.cabinet-body .summary-card h3,
.cabinet-body .empty-state h3,
.cabinet-body .history-result-section-head h3 {
    margin: 0;
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 15px;
    line-height: 1.08;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.cabinet-body .tiny-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-muted);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.cabinet-body .secondary,
.cabinet-body .field-help,
.cabinet-body .hint {
    color: var(--text-muted);
    font-size: 12px;
    line-height: 1.65;
}

.cabinet-body .grid-3 {
    display: grid;
    gap: var(--space-grid);
}

.cabinet-body .grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

.cabinet-body .badge {
    align-items: center;
    gap: 6px;
    min-height: 24px;
    padding: 4px 13px;
    border: 1px solid var(--border-subtle);
    color: var(--text-muted);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.15em;
    line-height: 1.25;
    text-transform: uppercase;
    white-space: nowrap;
}

.cabinet-body .badge:not([hidden]) {
    display: inline-flex;
}

.cabinet-body .badge::before {
    content: "";
    flex: 0 0 6px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
}

.cabinet-body .badge-warning { color: var(--accent-amber); border-color: rgba(255, 140, 0, 0.25); background: rgba(255, 140, 0, 0.07); }
.cabinet-body .badge-neutral,
.cabinet-body .badge-disabled { color: var(--text-muted); background: transparent; border-color: var(--border-subtle); }
.cabinet-body .status-published { border-color: rgba(0, 255, 157, 0.34); background: rgba(0, 255, 157, 0.10); color: var(--accent-green); }
.cabinet-body .status-draft { border-color: rgba(0, 180, 255, 0.34); background: rgba(0, 180, 255, 0.10); color: var(--accent-primary); }
.cabinet-body .status-archived { border-color: rgba(255, 77, 109, 0.34); background: rgba(255, 77, 109, 0.10); color: var(--accent-red); }

.cabinet-body .btn {
    position: relative;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 10px 23px;
    border: 1px solid transparent;
    border-radius: 0;
    background: transparent;
    color: var(--text-secondary);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 12px;
    letter-spacing: 0.12em;
    line-height: 1.2;
    text-decoration: none;
    text-transform: uppercase;
    white-space: nowrap;
    clip-path: polygon(13px 0, 100% 0, calc(100% - 13px) 100%, 0 100%);
    transition: var(--transition-interactive);
}

.cabinet-body .btn:not([hidden]):not(.is-hidden) {
    display: inline-flex;
}

.cabinet-body .btn-primary,
.cabinet-body button.btn-primary,
.cabinet-body .submit-button {
    color: var(--accent-bright);
    border-color: var(--border-active);
    background: var(--bg-btn-primary);
    box-shadow: var(--glow-sm), inset 0 1px 0 rgba(0, 200, 255, 0.1);
}

.cabinet-body .btn-secondary,
.cabinet-body .secondary-button {
    color: var(--text-secondary);
    border-color: var(--border-mid);
    background: transparent;
}

.cabinet-body .btn-danger {
    color: var(--accent-red);
    border-color: rgba(255, 51, 85, 0.3);
    background: rgba(255, 51, 85, 0.08);
}

.cabinet-body .btn-sm {
    min-height: 32px;
    padding: 7px 14px;
    font-size: 10px;
}

.cabinet-body .btn-wide {
    width: 100%;
}

.cabinet-body .submit-cost-hint {
    display: block;
    text-align: center;
    font-size: 12px;
    color: var(--text-muted);
    margin-top: 6px;
}

.cabinet-body .btn[disabled],
.cabinet-body button[disabled] {
    opacity: 0.65;
    cursor: not-allowed;
    box-shadow: none;
}

.cabinet-body form {
    display: grid;
    gap: 16px;
}

.cabinet-body .field-group {
    flex-direction: column;
    gap: 8px;
}

.cabinet-body .field-group:not([hidden]) {
    display: flex;
}

.cabinet-body .input-shell,
.cabinet-body .file-input,
.cabinet-body .text-input-wrapper,
.cabinet-body textarea,
.cabinet-body select {
    width: 100%;
    min-height: 41px;
    padding: 10px 15px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    background: var(--bg-surface);
    color: var(--text-primary);
    outline: none;
    transition: var(--transition-interactive);
}

.cabinet-body .text-input {
    min-height: auto;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--text-primary);
}

.cabinet-body .file-input input[type="file"] {
    width: 100%;
    color: var(--text-primary);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 12px;
    letter-spacing: 0.04em;
}

.cabinet-body .file-input input[type="file"]::file-selector-button {
    min-height: 30px;
    margin-right: 12px;
    padding: 7px 13px;
    border: 1px solid var(--border-active);
    border-radius: 0;
    background: var(--bg-btn-primary);
    color: var(--accent-bright);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    clip-path: polygon(9px 0, 100% 0, calc(100% - 9px) 100%, 0 100%);
    cursor: pointer;
    box-shadow: var(--glow-sm), inset 0 1px 0 rgba(0, 200, 255, 0.1);
    transition: var(--transition-interactive);
}

.cabinet-body .file-input input[type="file"]::file-selector-button:hover {
    color: var(--text-primary);
    border-color: rgba(0, 200, 255, 0.74);
    box-shadow: var(--glow-md);
}

/* File drop zone */
.cabinet-body .file-drop-zone {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 32px 24px;
    border: 2px dashed var(--border-mid);
    border-radius: var(--radius-lg);
    background: rgba(4, 8, 16, 0.24);
    cursor: pointer;
    text-align: center;
    transition: var(--transition-interactive);
}

.cabinet-body .file-drop-zone:hover,
.cabinet-body .file-drop-zone:focus-visible {
    border-color: var(--accent-primary);
    background: rgba(0, 180, 255, 0.04);
    outline: none;
}

.cabinet-body .file-drop-zone.drag-over {
    border-color: var(--accent-primary);
    background: rgba(0, 180, 255, 0.08);
    box-shadow: 0 0 0 4px rgba(0, 180, 255, 0.08);
}

.cabinet-body .file-drop-zone-icon {
    width: 48px;
    height: 48px;
    color: var(--text-muted);
    transition: var(--transition-interactive);
}

.cabinet-body .file-drop-zone:hover .file-drop-zone-icon,
.cabinet-body .file-drop-zone.drag-over .file-drop-zone-icon {
    color: var(--accent-primary);
}

.cabinet-body .file-drop-zone-text {
    color: var(--text-secondary);
    font-size: 17px;
    margin: 0;
}

.cabinet-body .file-drop-zone-admin {
    padding: 14px 18px;
    font-size: 14px;
    margin-top: 4px;
}
.cabinet-body .file-drop-zone-admin .file-drop-zone-text {
    font-size: 14px;
}

.cabinet-body .file-drop-zone-hint {
    color: var(--text-muted);
    font-size: 14px;
    margin: 0;
}

.cabinet-body .file-drop-zone-name:not([hidden]) {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    margin-top: 8px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(0, 180, 255, 0.04);
    color: var(--accent-bright);
    font-size: 15px;
}

.cabinet-body textarea {
    min-height: 96px;
    resize: vertical;
}

.cabinet-body .source-tabs,
.cabinet-body .admin-section-switch.source-tabs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px;
    padding: 5px;
    border: 1px solid var(--border-mid);
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(2, 16, 32, 0.82), rgba(1, 10, 22, 0.9));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04), inset 0 -14px 22px rgba(0, 0, 0, 0.28);
}

.cabinet-body .money-page .admin-section-switch.source-tabs {
    display: flex;
    flex-wrap: nowrap;
    max-width: none;
}

.cabinet-body .money-page .admin-section-tab {
    flex: 1 1 0;
    min-width: 0;
    min-height: 46px;
    white-space: nowrap;
    flex-direction: row;
    text-transform: none;
    letter-spacing: 0;
    font-size: 15px;
    font-family: var(--font-body);
    align-items: center;
    justify-content: center;
}

.cabinet-body .source-tab-icon {
    display: grid;
    place-items: center;
    width: 30px;
    height: 30px;
    color: currentColor;
}

.cabinet-body .icon-stroke {
    width: 100%;
    height: 100%;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.cabinet-body .source-panel[hidden] {
    display: none;
}

.cabinet-body .source-panel {
    padding: var(--space-card);
    border: 1px solid var(--border-mid);
    border-radius: var(--radius-lg);
    background: rgba(0, 180, 255, 0.035);
}

.cabinet-body .notice,
.cabinet-body .flash {
    padding: 14px 16px;
    border: 1px solid var(--border-mid);
    border-left-width: 3px;
    border-radius: var(--radius-md);
    background: linear-gradient(135deg, rgba(255, 122, 0, 0.12), rgba(8, 24, 43, 0.92));
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.65;
}

.cabinet-body .history-paywall {
    border-color: rgba(0, 255, 157, 0.24);
    border-left-color: var(--accent-green);
    background: linear-gradient(135deg, rgba(0, 255, 157, 0.1), rgba(8, 24, 43, 0.92));
}

.cabinet-body .storage-breakdown,
.cabinet-body .storage-purchase-summary {
    display: grid;
    gap: 6px;
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.5;
}

.cabinet-body .storage-breakdown strong,
.cabinet-body .storage-purchase-summary strong {
    color: var(--text-primary);
}

.cabinet-body .error {
    display: none;
    border-color: rgba(255, 51, 85, 0.35);
    background: rgba(255, 51, 85, 0.08);
    color: var(--color-error-text);
}
.cabinet-body .error.is-visible { display: block; }
.cabinet-body .flash-error {
    border-color: rgba(255, 51, 85, 0.35);
    background: rgba(255, 51, 85, 0.08);
    color: var(--color-error-text);
}

/* --- Progress Stepper (P1.1 unified processing flow) --- */

.cabinet-body .progress-stepper {
    display: none;
    gap: 14px;
}

.cabinet-body .progress-stepper:not(.is-hidden) {
    display: grid;
}

.cabinet-body .progress-stepper-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
}

.cabinet-body .progress-stepper-title {
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 19px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.cabinet-body .progress-stepper-percent {
    color: var(--accent-bright);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 17px;
}

.cabinet-body .progress-steps {
    display: flex;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cabinet-body .progress-step {
    position: relative;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding-top: 14px;
    color: var(--text-muted);
    font-size: 10px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-align: center;
}

.cabinet-body .progress-step::before {
    content: "";
    position: absolute;
    top: 7px;
    left: 0;
    right: calc(50% + 7px);
    height: 1px;
    background: var(--border-subtle);
}

.cabinet-body .progress-step::after {
    content: "";
    position: absolute;
    top: 7px;
    left: calc(50% + 7px);
    right: 0;
    height: 1px;
    background: var(--border-subtle);
}

.cabinet-body .progress-step:first-child::before,
.cabinet-body .progress-step:last-child::after {
    display: none;
}

.cabinet-body .progress-step-marker {
    position: relative;
    z-index: var(--z-base);
    width: 14px;
    height: 14px;
    border: 2px solid var(--border-mid);
    border-radius: 50%;
    background: var(--bg-deep);
    flex-shrink: 0;
}

.cabinet-body .progress-step-label {
    line-height: 1.3;
}

/* Active step */
.cabinet-body .progress-step.is-active {
    color: var(--accent-bright);
}

.cabinet-body .progress-step.is-active .progress-step-marker {
    border-color: var(--accent-bright);
    background: var(--accent-bright);
    box-shadow: 0 0 10px rgba(0, 180, 255, 0.5);
}

/* Completed step */
.cabinet-body .progress-step.is-completed {
    color: var(--accent-green);
}

.cabinet-body .progress-step.is-completed .progress-step-marker {
    border-color: var(--accent-green);
    background: var(--accent-green);
}

.cabinet-body .progress-step.is-completed::after,
.cabinet-body .progress-step.is-completed + .progress-step.is-completed::before,
.cabinet-body .progress-step.is-active::before,
.cabinet-body .progress-step.is-completed::before {
    background: var(--accent-green);
}

/* Error step */
.cabinet-body .progress-step.is-error {
    color: var(--accent-red);
}

.cabinet-body .progress-step.is-error .progress-step-marker {
    border-color: var(--accent-red);
    background: var(--accent-red);
    box-shadow: 0 0 10px rgba(255, 77, 109, 0.5);
}

.cabinet-body .progress-stepper-detail {
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.5;
}

/* UTILITY: .is-hidden — programmatic hide via CSS class.
   ВАЖНО: JS который скрывает через этот класс должен использовать classList.add/remove('is-hidden'),
   НЕ element.hidden и НЕ element.style.display.
   Смешивать с атрибутом hidden — НЕЛЬЗЯ. */
.cabinet-body .is-hidden { display: none; }

.cabinet-body .loading-progress {
    height: 10px;
    border: 1px solid rgba(255, 122, 0, 0.28);
    border-radius: 999px;
    background: rgba(2, 10, 20, 0.78);
    overflow: hidden;
}

.cabinet-body .loading-progress-fill {
    width: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--accent-primary), var(--accent-green));
}

.cabinet-body .processing-actions,
.cabinet-body .record-controls,
.cabinet-body .record-debug-actions,
.cabinet-body .record-preview-actions {
    flex-wrap: wrap;
    gap: 14px;
}

.cabinet-body .processing-actions:not([hidden]),
.cabinet-body .record-controls:not([hidden]),
.cabinet-body .record-debug-actions:not([hidden]),
.cabinet-body .record-preview-actions:not([hidden]) {
    display: flex;
}

/* --- Processing page modes (P1.2) --- */

.cabinet-body .processing-workspace[data-processing-mode="idle"] .results {
    display: flex;
    align-items: center;
    justify-content: center;
}

.cabinet-body .processing-workspace[data-processing-mode="idle"] .result-card {
    display: none;
}

.cabinet-body .processing-workspace[data-processing-mode="idle"] .empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 12px;
    padding: 40px 24px;
}

/* Configuring: normal layout, submit visible, stepper hidden, empty-state hidden, result cards visible */
.cabinet-body .processing-workspace[data-processing-mode="configuring"] .progress-stepper {
    display: none;
}

.cabinet-body .processing-workspace[data-processing-mode="configuring"] .submit-button {
    display: inline-flex;
}

.cabinet-body .processing-workspace[data-processing-mode="configuring"] .empty-state {
    display: none;
}

.cabinet-body .processing-workspace[data-processing-mode="configuring"] .result-card {
    display: block;
}

/* Processing: left panel dimmed, stepper visible, submit hidden */
.cabinet-body .processing-workspace[data-processing-mode="processing"] .processing-panel {
    opacity: 0.55;
    pointer-events: none;
}

.cabinet-body .processing-workspace[data-processing-mode="processing"] .processing-panel .processing-actions,
.cabinet-body .processing-workspace[data-processing-mode="processing"] .processing-panel .cancel-processing-button,
.cabinet-body .processing-workspace[data-processing-mode="processing"] .processing-panel .processing-action-button {
    opacity: 1;
    pointer-events: auto;
}

.cabinet-body .processing-workspace[data-processing-mode="processing"] .submit-button {
    display: none;
}

.cabinet-body .processing-workspace[data-processing-mode="processing"] .progress-stepper {
    display: grid;
}

.cabinet-body .processing-workspace[data-processing-mode="processing"] .processing-complete-block {
    display: none;
}

/* Completed: results prominent, complete block visible, stepper hidden */
.cabinet-body .processing-workspace[data-processing-mode="completed"] .progress-stepper {
    display: none;
}

.cabinet-body .processing-workspace[data-processing-mode="completed"] .submit-button {
    display: none;
}
.cabinet-body .processing-workspace[data-processing-mode="processing"] .empty-state,
.cabinet-body .processing-workspace[data-processing-mode="completed"] .empty-state {
    display: none;
}


.cabinet-body .processing-workspace[data-processing-mode="completed"] .processing-complete-block {
    display: block;
}

.cabinet-body .processing-complete-block {
    padding: 16px 0;
}

.cabinet-body .processing-complete-title {
    margin: 0 0 6px;
    color: var(--accent-green);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 19px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.cabinet-body .processing-complete-copy {
    margin: 0;
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.55;
}

.cabinet-body .more-settings {
    padding: 0;
    overflow: hidden;
}

.cabinet-body .more-settings-summary {
    padding: 14px 16px;
}

.cabinet-body .more-settings-body {
    display: grid;
    gap: 16px;
    padding: 0 16px 16px;
}

.cabinet-body .toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.cabinet-body .toggle-switch {
    position: relative;
    flex: 0 0 54px;
    width: 54px;
    height: 30px;
    cursor: pointer;
}

.cabinet-body .toggle-switch input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.cabinet-body .toggle-slider {
    position: absolute;
    inset: 0;
    border: 1px solid var(--border-mid);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(6, 16, 30, 0.96), rgba(12, 27, 47, 0.94));
    box-shadow: inset 0 2px 8px rgba(0, 0, 0, 0.45);
    transition: var(--transition-interactive);
}

.cabinet-body .toggle-slider::before {
    content: "";
    position: absolute;
    top: 4px;
    left: 4px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--text-muted);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.45);
    transition: var(--transition-interactive);
}

.cabinet-body .toggle-switch input:checked + .toggle-slider::before {
    background: var(--accent-green);
    box-shadow: 0 0 14px rgba(0, 255, 157, 0.5);
    transform: translateX(24px);
}

.cabinet-body .result-card.is-visible { display: block; }
.cabinet-body .result-card:not(.is-visible) { display: none; }

/* --- Content collapse for long texts --- */

.cabinet-body .content-collapsed {
    overflow: hidden;
}

.cabinet-body .content-expand-inline {
    display: inline-block;
    text-align: center;
    color: var(--accent-primary);
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    user-select: none;
    padding: 8px 0 12px 0;
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color var(--transition-interactive), text-decoration-color var(--transition-interactive);
    background: none;
    border: 0;
}

.cabinet-body .content-expand-inline:hover {
    color: var(--accent-bright);
    text-decoration-color: var(--accent-bright);
}

/* Align with content padding on New Processing page (button is a sibling, not child) */
.cabinet-body .result-card .content + .content-expand-inline {
    margin-left: 24px;
    margin-bottom: 12px;
}

.cabinet-body .result-card.is-reading-mode {
    position: fixed !important;
    inset: 0;
    z-index: calc(var(--z-dropdown) + 5);
    margin: 0 !important;
    border-radius: 0;
    border: 0;
    background: var(--bg-void);
    overflow-y: auto;
}

.cabinet-body .result-card.is-reading-mode .content,
.cabinet-body .result-card.is-reading-mode .transcription-content,
.cabinet-body .result-card.is-reading-mode .protocol-content {
    max-height: none !important;
    max-width: 860px;
    margin: 0 auto;
    padding: 32px 24px 120px;
    font-size: 19px;
    line-height: 1.8;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    overflow: visible;
    white-space: pre-wrap;
}

.cabinet-body .result-card.is-reading-mode .result-head,
.cabinet-body .result-card.is-reading-mode .result-toolbar {
    position: sticky;
    z-index: calc(var(--z-base) + 1);
    background: var(--bg-deep);
    border-bottom: 1px solid var(--border-subtle);
}

.cabinet-body .result-card.is-reading-mode .result-head {
    top: 0;
    padding: 16px 24px;
}

.cabinet-body .result-card.is-reading-mode .result-toolbar {
    top: 56px;
    padding: 12px 24px;
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.cabinet-body .result-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 18px;
    border-bottom: 1px solid var(--border-subtle);
    background: rgba(4, 8, 16, 0.32);
}

.cabinet-body .result-head h2,
.cabinet-body .result-head h3 {
    margin: 0;
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 19px;
    letter-spacing: 0.06em;
}

.cabinet-body .result-toolbar:not(.is-hidden) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 18px;
    border-bottom: 1px solid var(--border-faint);
    background: rgba(7, 17, 31, 0.72);
}

.cabinet-body .result-actions,
.cabinet-body .history-result-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.cabinet-body .download-menu:not([hidden]) { position: relative; display: inline-flex; }
.cabinet-body .download-menu-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: calc(var(--z-dropdown) + 3);
    width: 252px;
    flex-direction: column;
    gap: 10px;
    padding: 12px;
    border: 1px solid rgba(0, 188, 255, 0.34);
    border-radius: var(--radius-lg);
    background: var(--bg-modal);
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.62);
    visibility: hidden;
    opacity: 0;
    transform: translateY(-6px) scale(0.98);
    pointer-events: none;
    transition: var(--transition-interactive);
}

.cabinet-body .download-menu-panel:not([hidden]) {
    display: flex;
}

.cabinet-body .download-menu.is-open .download-menu-panel {
    visibility: visible;
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

.cabinet-body .download-option {
    min-height: 42px;
    padding: 10px 12px;
    border: 1px solid rgba(255, 122, 0, 0.24);
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, #10233a 0%, #0b1a2c 100%);
    color: var(--text-primary);
    text-align: left;
}

.cabinet-body .content {
    padding: 18px;
    max-height: min(58vh, 680px);
    color: var(--text-primary);
    line-height: 1.8;
    white-space: pre-wrap;
}




.cabinet-body .transcription-player {
    margin: 16px 18px 0;
    padding: 14px;
    border: 1px solid rgba(255, 122, 0, 0.18);
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, rgba(8, 24, 43, 0.92), rgba(4, 14, 26, 0.86));
}

.cabinet-body .transcription-player-main {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    align-items: center;
}

.cabinet-body .transcription-segments:not([hidden]) {
    display: grid;
    gap: 10px;
    white-space: normal;
}

.cabinet-body .transcription-segment {
    padding: 13px 14px;
    border: 1px solid rgba(0, 200, 255, 0.12);
    border-radius: var(--radius-lg);
    background: rgba(4, 14, 26, 0.58);
}

.cabinet-body .transcription-segment.is-active {
    border-color: rgba(0, 255, 157, 0.42);
    background: linear-gradient(135deg, rgba(0, 84, 72, 0.32), rgba(4, 14, 26, 0.74));
}

.cabinet-body .protocol-version-controls:not([hidden]) {
    display: grid;
}

.cabinet-body .empty-state {
    gap: 12px;
    padding: var(--space-card);
    color: var(--text-secondary);
}

.cabinet-body .empty-state:not([hidden]) {
    display: grid;
}

.cabinet-body .onboarding-list {
    margin: 0;
    padding: 0 0 0 20px;
    list-style: disc;
    display: grid;
    gap: 8px;
    text-align: left;
}

.cabinet-body .onboarding-list li {
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.55;
}

.cabinet-body .onboarding-list li::marker {
    color: var(--accent-bright);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 15px;
}

.cabinet-body .onboarding-content {
    text-align: left;
}

.cabinet-body .onboarding-content p {
    margin: 0 0 10px;
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.55;
}

.cabinet-body .onboarding-content strong {
    color: var(--text-primary);
}

.cabinet-body .onboarding-steps {
    margin: 0;
    padding: 0 0 0 28px;
    list-style: none;
    counter-reset: onboarding-counter;
    display: grid;
    gap: 14px;
}

.cabinet-body .onboarding-steps li {
    counter-increment: onboarding-counter;
    color: var(--text-secondary);
    font-size: 16px;
    line-height: 1.6;
    position: relative;
}

.cabinet-body .onboarding-steps li::marker {
    content: counter(onboarding-counter) ".\00a0";
    color: var(--accent-bright);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 17px;
    font-weight: 700;
}

.cabinet-body .record-panel,
.cabinet-body .record-panel-copy,
.cabinet-body .record-debug {
    display: grid;
    gap: 10px;
}

.cabinet-body .record-primary-button {
    display: grid;
    place-items: center;
    width: 84px;
    height: 84px;
    min-height: 84px;
    padding: 0;
    border: 1px solid rgba(0, 200, 255, 0.48);
    border-radius: 50%;
    background: radial-gradient(circle at 36% 28%, rgba(255, 211, 106, 0.34), rgba(0, 88, 132, 0.86) 48%, rgba(6, 18, 34, 0.98) 100%);
    color: var(--accent-bright);
    box-shadow: var(--glow-md), inset 0 2px 0 rgba(255, 255, 255, 0.08), inset 0 -12px 24px rgba(0, 0, 0, 0.34);
    cursor: pointer;
    transition: var(--transition-interactive);
}

.cabinet-body .record-primary-button.is-recording {
    border-color: rgba(255, 77, 109, 0.74);
    background: radial-gradient(circle at 36% 28%, rgba(255, 119, 140, 0.9), rgba(142, 19, 45, 0.96) 52%, rgba(42, 6, 16, 0.98) 100%);
    color: var(--text-primary);
    box-shadow: 0 0 22px rgba(255, 77, 109, 0.4), inset 0 2px 0 rgba(255, 255, 255, 0.12), inset 0 -12px 24px rgba(0, 0, 0, 0.34);
}

.cabinet-body .record-primary-button[disabled] {
    opacity: 0.65;
    cursor: not-allowed;
}

.cabinet-body .record-button-icon {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
}

.cabinet-body .record-stop-shape {
    width: 23px;
    height: 23px;
    border-radius: 3px;
    background: currentColor;
}

.cabinet-body .visually-hidden,
.cabinet-body .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.cabinet-body .record-panel-head,
.cabinet-body .record-panel-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.cabinet-body .record-mode-switch {
    width: fit-content;
    margin-bottom: 14px;
}

.cabinet-body .sync-recording-locked.field-help {
    padding: 10px 14px 10px 20px;
    border: 1px solid rgba(0, 200, 255, 0.22);
    border-radius: var(--radius-lg);
    background: rgba(0, 200, 255, 0.08);
    color: var(--text-primary);
    font-size: 15px;
    line-height: 1.35;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cabinet-body .sync-recording-locked.field-help a {
    color: #00b4e4;
}

@media (max-width: 480px) {
    .cabinet-body .sync-recording-locked.field-help {
        font-size: 13px;
        padding: 10px 10px 10px 14px;
    }
}

.cabinet-body .record-preview-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.cabinet-body .balance-value,
.cabinet-body .limit-value,
.cabinet-body .profile-status {
    color: var(--accent-bright);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 37px;
    line-height: 1;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-shadow: var(--glow-sm);
}

.cabinet-body .history-list:not([hidden]) {
    display: grid;
}

.cabinet-body .history-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: start;
    padding: 14px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: rgba(0, 180, 255, 0.035);
    transition: var(--transition-interactive);
}

.cabinet-body .history-title {
    overflow-wrap: anywhere;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 15px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.cabinet-body .history-meta {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}

.cabinet-body .history-result-section {
    padding: 18px;
    border-top: 1px solid var(--border-faint);
}

.cabinet-body .history-result-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}

.cabinet-body .confirm-modal {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-dropdown) + 10);
    place-items: center;
    padding: 20px;
}

.cabinet-body .confirm-modal:not([hidden]) {
    display: grid;
}

.cabinet-body .confirm-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.62);
    backdrop-filter: blur(8px);
}

.cabinet-body .confirm-modal-dialog {
    position: relative;
    z-index: var(--z-base);
    width: min(420px, 100%);
    display: grid;
    gap: 14px;
    padding: 22px;
    border: 1px solid var(--border-mid);
    border-radius: var(--radius-lg);
    background: var(--bg-modal);
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.62);
}

.cabinet-body .confirm-modal-title {
    margin: 0;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 21px;
    letter-spacing: 0.04em;
    line-height: 1.3;
}

.cabinet-body .confirm-modal-copy {
    margin: 0;
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.55;
}

.cabinet-body .confirm-modal-actions,
.cabinet-body .money-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.cabinet-body .money-grid {
    display: grid;
    grid-template-columns: minmax(280px, 0.9fr) minmax(320px, 1.1fr);
    gap: var(--space-grid);
    align-items: stretch;
}

.cabinet-body .money-balance-grid {
    align-items: start;
}

.cabinet-body .money-balance-column {
    display: grid;
    gap: var(--space-grid);
    align-content: start;
}

.cabinet-body .money-dashboard {
    display: grid;
    gap: var(--space-grid);
}

.cabinet-body .money-flash {
    padding: 12px 14px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(4, 14, 26, 0.64);
    color: var(--text-primary);
}

.cabinet-body .money-flash[data-mode="error"] {
    border-color: rgba(255, 92, 92, 0.42);
    color: #ffb0b0;
    background: rgba(68, 16, 24, 0.42);
}

.cabinet-body .money-flash[data-mode="success"] {
    border-color: rgba(0, 255, 157, 0.32);
    color: #aaffdc;
    background: rgba(0, 75, 71, 0.32);
}

.cabinet-body .money-renewal-warning {
    margin: 12px 0;
    padding: 12px 14px;
    border: 1px solid rgba(255, 51, 85, 0.34);
    border-radius: var(--radius-md);
    color: #ffb0b0;
    background: rgba(68, 16, 24, 0.44);
}

.cabinet-body .money-renewal-warning[hidden] {
    display: none;
}

.cabinet-body .tariff-period-summary {
    display: grid;
    gap: 8px;
    margin: 12px 0 16px;
    color: var(--text-secondary);
    font-size: 1.10rem;
}

.cabinet-body .tariff-period-summary strong {
    color: var(--text-primary);
}

.cabinet-body .subscription-status-failed {
    color: #ffb0b0;
}

.cabinet-body .money-view[hidden] {
    display: none;
}

.cabinet-body .tariff-card-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-grid);
}

.cabinet-body .tariff-plan-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
    min-height: 360px;
    padding: var(--space-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: var(--gradient-card);
    box-shadow: var(--shadow-panel), inset 0 1px 0 rgba(0, 200, 255, 0.08);
    position: relative;
}

.cabinet-body .tariff-plan-card.is-selected {
    border-color: rgba(0, 255, 157, 0.34);
    background: linear-gradient(180deg, rgba(0, 75, 71, 0.42), rgba(10, 22, 40, 0.92));
}

.cabinet-body .tariff-plan-head,
.cabinet-body .limit-meter-head {
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
}

.cabinet-body .tariff-plan-head h3 {
    margin: 5px 0 0;
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 21px;
}

.cabinet-body .tariff-plan-head .badge {
    order: -1;
    align-self: flex-end;
}

.cabinet-body .tariff-price {
    display: flex;
    align-items: baseline;
    gap: 8px;
}

.cabinet-body .tariff-price strong {
    color: var(--accent-bright);
    font-size: 31px;
}

.cabinet-body .tariff-limits {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
}

.cabinet-body .tariff-limits span,
.cabinet-body .tariff-features li {
    padding: 8px 9px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    background: rgba(4, 14, 26, 0.48);
    color: var(--text-secondary);
    font-size: 12px;
}

.cabinet-body .tariff-features {
    display: grid;
    gap: 7px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cabinet-body .tariff-features li::before {
    content: "";
    display: inline-block;
    width: 7px;
    height: 7px;
    margin-right: 8px;
    border-radius: 999px;
    background: var(--accent-bright);
}

.cabinet-body .tariff-features li.is-muted {
    opacity: 0.58;
}

.cabinet-body .tariff-features li.is-muted::before {
    background: rgba(255, 255, 255, 0.28);
}

.cabinet-body .tariff-actions {
    display: grid;
    gap: 8px;
    margin-top: auto;
}

/* money-action-button: layout only — visual style comes from .btn / .btn-secondary premium system */
.cabinet-body .money-action-button {
    min-height: 44px;
}

.cabinet-body .tariff-select-button {
    width: 100%;
}

.cabinet-body .tariff-actions .btn[disabled],
.cabinet-body .topup-box .btn[disabled] {
    cursor: not-allowed;
    opacity: 0.55;
}

.cabinet-body .topup-box {
    display: grid;
    gap: 12px;
    margin-top: 4px;
}

.cabinet-body .money-balance-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.cabinet-body .money-balance-actions .money-action-button {
    width: auto;
    min-width: 180px;
}

.cabinet-body .topup-box label {
    display: grid;
    gap: 6px;
}

.cabinet-body .topup-box input {
    min-height: 40px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(4, 14, 26, 0.82);
    color: var(--text-primary);
    padding: 0 12px;
}

.cabinet-body .quick-amounts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}

.cabinet-body .quick-amounts button {
    min-height: 34px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    background: rgba(4, 14, 26, 0.64);
    color: var(--text-secondary);
    cursor: pointer;
}

.cabinet-body .quick-amounts button:hover,
.cabinet-body .quick-amounts button.is-active {
    border-color: rgba(0, 200, 255, 0.32);
    color: var(--text-primary);
    background: rgba(0, 200, 255, 0.12);
}

.cabinet-body .tariff-list,
.cabinet-body .operation-list {
    display: grid;
    gap: 10px;
}

.cabinet-body .tariff-row,
.cabinet-body .operation-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 13px 14px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(4, 14, 26, 0.58);
}

.cabinet-body .operation-row {
    grid-template-columns: 150px minmax(0, 1fr) auto;
}

.cabinet-body .tariff-row.is-featured {
    border-color: rgba(0, 255, 157, 0.28);
    background: linear-gradient(135deg, rgba(0, 84, 72, 0.32), rgba(4, 14, 26, 0.74));
}

.cabinet-body .operation-kind,
.cabinet-body .operation-amount,
.cabinet-body .tariff-row strong {
    color: var(--accent-bright);
}

.cabinet-body .limit-meter {
    gap: 8px;
}

.cabinet-body .limit-meter:not([hidden]) {
    display: grid;
}

.cabinet-body .storage-usage-meter {
    padding-top: 10px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.cabinet-body .storage-usage-meter strong {
    color: var(--accent-bright);
}

.cabinet-body .limit-track {
    height: 10px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
}

.cabinet-body .limit-track span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--accent-action), var(--accent-action-bright));
}

.cabinet-body .limit-track[data-limit-tone="green"] span {
    background: linear-gradient(90deg, var(--accent-green), var(--accent-green));
}

.cabinet-body .limit-track[data-limit-tone="blue"] span {
    background: linear-gradient(90deg, var(--accent-action), var(--accent-action-bright));
}

.cabinet-body .limit-track[data-limit-tone="orange"] span {
    background: linear-gradient(90deg, var(--accent-cost), var(--accent-cost-bright));
}

.cabinet-body .limit-track[data-limit-tone="red"] span {
    background: linear-gradient(90deg, var(--accent-primary), var(--accent-warning-bright));
}

.cabinet-body .money-filters {
    display: grid;
    grid-template-columns: repeat(2, minmax(180px, 240px));
    gap: 12px;
}

.cabinet-body .money-filters label {
    display: grid;
    gap: 6px;
    color: var(--text-muted);
    font-size: 12px;
}

.cabinet-body .money-filters input,
.cabinet-body .money-filters select {
    min-height: 38px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(4, 14, 26, 0.82);
    color: var(--text-primary);
    padding: 0 11px;
}

.cabinet-body .operation-table {
    display: grid;
    overflow-x: auto;
    margin-top: 6px;
}

.cabinet-body .operation-table-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    align-items: center;
    min-width: 520px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border-subtle);
    color: var(--text-secondary);
    font-size: 14px;
}

.cabinet-body .operation-table-row.operation-table-row-finance {
    grid-template-columns: minmax(110px, 0.8fr) minmax(90px, 0.7fr) minmax(180px, 1.4fr) minmax(100px, 0.7fr);
    min-width: 680px;
}

.cabinet-body .operation-table-head {
    color: var(--text-muted);
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cabinet-body .operation-table-row strong {
    color: var(--accent-bright);
}

.cabinet-body .operation-table-row .operation-value,
.cabinet-body .operation-table-row .operation-status,
.cabinet-body .operation-table-row .operation-description {
    color: inherit;
}

.cabinet-body .operation-table-row .operation-description {
    min-width: 0;
    overflow-wrap: anywhere;
}

.cabinet-body .operation-table-row.operation-tone-spent {
    color: var(--accent-red);
}

.cabinet-body .operation-table-row.operation-tone-reserved {
    color: var(--accent-cost-bright);
}

.cabinet-body .operation-table-row.operation-tone-credited {
    color: var(--accent-green);
}

.cabinet-body .operation-table-row.is-empty {
    grid-template-columns: 1fr;
    min-width: 0;
}

.cabinet-body .money-operations {
    gap: 18px;
}

@media (max-width: 1180px) {
    .cabinet-body .processing-grid,
    .cabinet-body .history-layout {
        grid-template-columns: 1fr;
    }

    .cabinet-body .processing-panel,
    .cabinet-body .history-list-panel {
        position: static;
    }

    .cabinet-body .grid-3 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .cabinet-body .tariff-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    .cabinet-body .app-shell {
        grid-template-columns: 1fr;
    }

    .cabinet-body .app-sidebar {
        position: relative;
        height: auto;
        border-right: 0;
        border-bottom: 1px solid var(--border-subtle);
    }

    .cabinet-body .app-main,
    .cabinet-body.history-page .app-main,
    .cabinet-body .history-page.app-main {
        width: min(100% - 24px, var(--content-max));
    }

    .cabinet-body .app-topbar {
        position: static;
        align-items: flex-start;
        flex-direction: column;
    }

    .cabinet-body .app-menu {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        padding: 0 12px;
        gap: 6px;
    }

    .cabinet-body .nav-item,
    .cabinet-body .nav-item.active {
        min-height: 38px;
        padding: 0 12px;
        border: 1px solid var(--border-faint);
    }

    .cabinet-body .support-menu-action {
        margin: 12px;
        padding-top: 12px;
    }

    .cabinet-body .grid-3,
    .cabinet-body .history-meta,
    .cabinet-body .history-result-meta {
        grid-template-columns: 1fr;
    }

    .cabinet-body .result-toolbar,
    .cabinet-body .history-result-section-head,
    .cabinet-body .record-panel-head,
    .cabinet-body .record-panel-meta {
        align-items: flex-start;
        flex-direction: column;
    }

    .cabinet-body .transcription-player-main {
        grid-template-columns: 1fr;
    }

    .cabinet-body .tariff-card-grid,
    .cabinet-body .money-grid,
    .cabinet-body .money-filters {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 560px) {
    .cabinet-body .source-tabs,
    .cabinet-body .record-preview-stats {
        grid-template-columns: 1fr;
    }

    .cabinet-body .history-item {
        grid-template-columns: 1fr;
    }

    .cabinet-body .tariff-limits {
        grid-template-columns: 1fr;
    }

    .cabinet-body .support-modal {
        padding: 16px;
    }

    .cabinet-body .support-modal-dialog {
        padding: 18px;
    }

    .cabinet-body .support-channel {
        min-height: 58px;
    }

    .cabinet-body .quick-amounts {
        grid-template-columns: 1fr;
    }
}

.cabinet-body .badge-online {
    color: var(--accent-amber);
    border-color: var(--accent-amber-border);
    background: var(--accent-amber-soft);
}

.cabinet-body .more-settings-summary {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 48px;
    padding: 14px 16px;
    color: var(--accent-warning-bright);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    list-style: none;
    background: linear-gradient(135deg, rgba(255, 140, 0, 0.14), rgba(6, 18, 34, 0.94));
    box-shadow: inset 0 1px 0 rgba(255, 190, 110, 0.14);
}

.cabinet-body .more-settings-summary::-webkit-details-marker {
    display: none;
}

.cabinet-body .more-settings-summary-indicator {
    flex: 0 0 11px;
    width: 11px;
    height: 11px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg) translateY(-2px);
}

.cabinet-body .more-settings[open] .more-settings-summary-indicator {
    transform: rotate(225deg) translateY(-2px);
}

.cabinet-body .history-list {
    gap: 8px;
}

.cabinet-body .history-item-main {
    display: grid;
    gap: 8px;
}

.cabinet-body .history-title-actions:not([hidden]) {
    display: flex;
    gap: 6px;
    align-items: center;
}

.cabinet-body .history-icon-button {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border: 1px solid rgba(255, 122, 0, 0.25);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
    background: rgba(255, 122, 0, 0.04);
    cursor: pointer;
}

.cabinet-body .history-icon-button:hover {
    color: var(--accent-bright);
    border-color: rgba(0, 200, 255, 0.48);
}

.cabinet-body .history-title-edit-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 6px;
    align-items: center;
}

.cabinet-body .history-title-input {
    min-width: 0;
    min-height: 34px;
    padding: 7px 9px;
    border: 1px solid rgba(255, 122, 0, 0.32);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    background: rgba(2, 10, 20, 0.82);
}

.cabinet-body .history-title-input:focus {
    outline: none;
    border-color: rgba(0, 200, 255, 0.62);
    box-shadow: var(--glow-sm);
}

.cabinet-body .history-title-stack {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.cabinet-body .history-title-label,
.cabinet-body .history-meta-label,
.cabinet-body .record-preview-label,
.cabinet-body .download-menu-label {
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 12px;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.cabinet-body .history-filename,
.cabinet-body .history-title {
    margin: 0;
    overflow-wrap: anywhere;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 15px;
    line-height: 1.35;
    letter-spacing: 0;
    text-transform: none;
}

.cabinet-body .history-meta {
    grid-template-columns: 1fr;
    gap: 6px;
}

.cabinet-body .history-meta-item {
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    padding: 7px 9px;
    border: 1px solid rgba(255, 122, 0, 0.12);
    border-radius: var(--radius-sm);
    background: rgba(4, 14, 26, 0.54);
}

.cabinet-body .history-meta-value {
    min-width: 0;
    color: var(--text-primary);
    overflow-wrap: anywhere;
}

.cabinet-body .history-worktime-value {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.cabinet-body .history-worktime-block {
    display: inline-flex;
    flex-wrap: wrap;
    column-gap: 4px;
    align-items: baseline;
}

.cabinet-body .history-worktime-prefix {
    color: var(--text-secondary);
    font-weight: 600;
}

.cabinet-body .history-worktime-separator {
    color: var(--text-muted);
}

.cabinet-body .history-meta-time {
    display: block;
    color: var(--text-secondary);
}

.cabinet-body .history-flags,
.cabinet-body .history-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.cabinet-body .history-flag,
.cabinet-body .history-status-badge {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    width: fit-content;
    padding: 4px 8px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
    background: rgba(255, 122, 0, 0.04);
}

.cabinet-body .history-status-badge.is-completed {
    color: var(--accent-green);
    border-color: rgba(0, 255, 157, 0.3);
    background: rgba(0, 255, 157, 0.08);
}

.cabinet-body .history-status-badge.is-failed {
    color: var(--accent-red);
    border-color: rgba(255, 77, 109, 0.34);
    background: rgba(255, 77, 109, 0.08);
}

.cabinet-body .history-delete-confirm-button {
    min-height: 34px;
    color: #ffd6de;
    border-color: rgba(255, 77, 109, 0.34);
    background: rgba(90, 18, 34, 0.35);
}

.cabinet-body .history-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-dropdown) + 1);
    display: grid;
    place-items: center;
    padding: 24px;
    background: rgba(0, 6, 14, 0.72);
}

.cabinet-body .history-modal {
    width: min(100%, 420px);
    padding: 18px;
    border: 1px solid rgba(255, 122, 0, 0.24);
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, rgba(10, 27, 48, 0.98), rgba(5, 14, 27, 0.98));
    box-shadow: var(--shadow-panel);
}

.cabinet-body .history-modal p {
    margin: 0 0 14px;
    color: var(--text-primary);
}

.cabinet-body .history-modal-title {
    margin: 0 0 10px;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 19px;
    letter-spacing: 0.04em;
    line-height: 1.3;
}

.cabinet-body .history-modal-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

@media (max-width: 560px) {
    .cabinet-body .history-meta-item {
        grid-template-columns: 1fr;
    }

    .cabinet-body .history-title-edit-form {
        grid-template-columns: 1fr;
    }
}

/* TASK-037 balance pass: return nav active to blue cabinet tone. */
.cabinet-body .nav-item.active {
    border-left-color: var(--accent-primary);
    color: var(--accent-bright);
    background: rgba(0, 180, 255, 0.06);
}

.cabinet-body .tiny-label,
.cabinet-body label,
.cabinet-body .history-title-label,
.cabinet-body .history-meta-label,
.cabinet-body .record-preview-label,
.cabinet-body .download-menu-label {
    color: var(--text-muted);
}

.cabinet-body .field-help,
.cabinet-body .record-panel-description,
.cabinet-body .record-helper,
.cabinet-body .protocol-description {
    padding-left: 0;
    border-left: 0;
    color: var(--text-muted);
}

.cabinet-body .notice,
.cabinet-body .flash {
    border-color: var(--border-mid);
    background: linear-gradient(135deg, rgba(255, 122, 0, 0.12), rgba(8, 24, 43, 0.92));
}

.cabinet-body .loading-progress {
    border-color: rgba(255, 122, 0, 0.28);
}

.cabinet-body .loading-progress-fill {
    background: linear-gradient(90deg, var(--accent-primary), var(--accent-green));
}

.cabinet-body .more-settings {
    border-color: var(--border-subtle);
    background: var(--gradient-card);
}

.cabinet-body .more-settings-summary {
    color: var(--text-secondary);
    background: linear-gradient(135deg, rgba(0, 180, 255, 0.08), rgba(6, 18, 34, 0.94));
    box-shadow: inset 0 1px 0 rgba(0, 212, 255, 0.12);
}

.cabinet-body .more-settings-body {
    border-top-color: var(--border-subtle);
}

.cabinet-body .toggle-switch input:checked + .toggle-slider {
    border-color: rgba(0, 255, 157, 0.48);
    background: linear-gradient(135deg, rgba(0, 116, 104, 0.78), rgba(0, 72, 110, 0.78));
    box-shadow: var(--glow-sm), inset 0 1px 0 rgba(0, 255, 157, 0.16);
}

.cabinet-body .toggle-switch input:checked + .toggle-slider::before {
    background: var(--accent-green);
    box-shadow: 0 0 14px rgba(0, 255, 157, 0.5);
}

.cabinet-body .history-title-label,
.cabinet-body .history-meta-label {
    color: var(--text-muted);
}

.cabinet-body .history-flag.is-ready,
.cabinet-body .history-status-badge.is-completed {
    color: var(--accent-green);
    border-color: rgba(0, 255, 157, 0.25);
    background: rgba(0, 255, 157, 0.07);
}

.cabinet-body .cancel-processing-button,
.cabinet-body .btn-danger {
    color: #ffe4e9;
    border-color: rgba(255, 77, 109, 0.62);
    background: linear-gradient(135deg, rgba(125, 18, 42, 0.96), rgba(63, 10, 25, 0.96));
    box-shadow: 0 0 14px rgba(255, 77, 109, 0.28), inset 0 1px 0 rgba(255, 150, 170, 0.18);
}

.cabinet-body .flash-error,
.cabinet-body .error,
.cabinet-body .error-message,
.cabinet-body .history-result-error {
    border-color: rgba(255, 77, 109, 0.58);
    border-left-color: var(--accent-red);
    background: linear-gradient(135deg, rgba(125, 18, 42, 0.36), rgba(42, 8, 18, 0.92));
    color: #ffe4e9;
    box-shadow: 0 0 0 1px rgba(255, 77, 109, 0.08), 0 14px 30px rgba(0, 0, 0, 0.28);
}

/* Ordinary action buttons — now primary orange for strong accent */
.cabinet-body .action-button,
.cabinet-body .download-trigger,
.cabinet-body .history-copy-button,
.cabinet-body .transcription-copy,
.cabinet-body .protocol-copy {
    border: 1px solid var(--accent-action-bright);
    background: linear-gradient(180deg, var(--accent-action) 0%, var(--accent-action) 100%);
    color: #FFF7F0;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
}

.cabinet-body .action-button:hover,
.cabinet-body .download-trigger:hover {
    border-color: var(--accent-action-bright);
    background: linear-gradient(180deg, var(--accent-action-bright) 0%, var(--accent-action) 100%);
    color: var(--text-primary);
    transform: translateY(-1px);
}

.cabinet-body .new-transcription-button {
    border: 1px solid var(--accent-action-bright) !important;
    background: linear-gradient(180deg, var(--accent-action) 0%, var(--accent-action) 100%) !important;
    color: #FFF7F0 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
}

.cabinet-body .history-title-row .history-open-button {
    flex: 0 0 auto;
    width: auto;
    min-width: 112px;
}

.cabinet-body .history-title-stack {
    width: 100%;
}

.cabinet-body .history-title-line {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.cabinet-body .history-title-line .history-filename {
    min-width: 0;
}

.cabinet-body .history-title-actions {
    flex: 0 0 auto;
}

.cabinet-body .history-title-edit-form {
    flex: 1 1 auto;
    width: 100%;
}

.cabinet-body .history-status-badge {
    gap: 7px;
    min-height: 22px;
    padding: 3px 9px;
    font-size: 10px;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cabinet-body .history-status-badge::before {
    content: "";
    width: 5px;
    height: 5px;
    flex: 0 0 auto;
    border-radius: 999px;
    background: currentColor;
    box-shadow: 0 0 8px currentColor;
}

.cabinet-body .history-meta {
    grid-template-columns: 1fr;
    gap: 6px;
    align-items: stretch;
}

.cabinet-body .history-meta-item {
    min-width: 0;
    padding: 8px 10px;
}

.cabinet-body .history-worktime-item {
    grid-template-columns: 96px minmax(0, 1fr);
}

.cabinet-body .history-worktime-value {
    display: grid;
    gap: 4px;
    align-content: center;
}

.cabinet-body .history-worktime-line {
    display: block;
    white-space: nowrap;
}

.cabinet-body .history-duration-item {
    grid-template-columns: 96px minmax(0, 1fr);
    min-width: 0;
    align-content: center;
}

.cabinet-body .history-duration-item .history-meta-label {
    margin-bottom: 3px;
}

.cabinet-body .history-actions {
    justify-content: space-between;
    align-items: center;
}


.cabinet-body .history-open-button,
.cabinet-body .history-icon-button,
.cabinet-body .history-copy-button,
.cabinet-body .download-trigger {
    transition: var(--transition-interactive);
}

.cabinet-body .history-open-button:hover,
.cabinet-body .history-icon-button:hover,
.cabinet-body .history-copy-button:hover,
.cabinet-body .download-trigger:hover {
    transform: translateY(-1px);
}

.cabinet-body .history-open-button:active,
.cabinet-body .history-icon-button:active,
.cabinet-body .history-copy-button:active,
.cabinet-body .download-trigger:active {
    transform: translateY(1px) scale(0.98);
}

.cabinet-body .history-result-meta .history-status-badge {
    justify-self: start;
}

.cabinet-body .history-result-meta .history-meta-item {
    border: 0;
    background: transparent;
}

.cabinet-body .history-result-meta .history-worktime-item {
    grid-template-columns: 88px minmax(0, 1fr);
    justify-self: center;
    width: min(100%, 460px);
    padding: 0;
}

.cabinet-body .history-result-meta .history-duration-item {
    grid-template-columns: 1fr;
    justify-self: end;
    min-width: 124px;
    padding: 0;
}

.cabinet-body .history-result-section {
    padding-top: 10px;
}

.cabinet-body .history-result-section-head {
    align-items: flex-start;
    justify-content: flex-end;
    margin-bottom: 10px;
}

.cabinet-body .history-result-actions {
    margin-left: auto;
}

.cabinet-body .history-edit-button {
    transform: scaleX(-1);
}

.cabinet-body .history-edit-button:hover {
    transform: scaleX(-1) translateY(-1px);
}

.cabinet-body .history-edit-button:active {
    transform: scaleX(-1) translateY(1px) scale(0.98);
}

@media (max-width: 860px) {
    .cabinet-body .history-result-meta {
        grid-template-columns: 1fr;
    }

    .cabinet-body .history-result-meta {
        margin: 0 12px 10px;
    }

    .cabinet-body .history-result-section-head {
        align-items: stretch;
        flex-direction: row;
        justify-content: flex-end;
    }
}

@media (max-width: 560px) {
    .cabinet-body .history-worktime-item {
        grid-template-columns: 1fr;
    }

    .cabinet-body .history-worktime-line {
        white-space: normal;
    }

    .cabinet-body .history-result-section-head {
        align-items: flex-start;
        flex-direction: column;
    }
}

.cabinet-body .history-flags {
    margin-top: 2px;
    padding-top: 2px;
}

.cabinet-body .record-preview-stats {
    grid-template-columns: 1fr;
    gap: 10px;
}

.cabinet-body .record-preview-stat:not([hidden]) {
    display: grid;
    grid-template-columns: minmax(110px, 0.42fr) minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    min-width: 0;
    padding: 10px 12px;
    border: 1px solid rgba(255, 122, 0, 0.14);
    border-radius: var(--radius-md);
    background: rgba(4, 14, 26, 0.58);
}

.cabinet-body .record-preview-value {
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.cabinet-body .send-recording-button {
    color: var(--text-primary);
    border-color: rgba(0, 200, 255, 0.52);
    background: linear-gradient(135deg, rgba(0, 78, 122, 0.94), rgba(8, 34, 58, 0.96));
    box-shadow: var(--glow-sm), inset 0 1px 0 rgba(0, 200, 255, 0.16);
}

.cabinet-body .reset-recording-button {
    color: var(--color-error-text);
    border-color: rgba(255, 77, 109, 0.34);
    background: linear-gradient(135deg, rgba(14, 48, 82, 0.82), rgba(8, 24, 43, 0.94));
    box-shadow: inset 0 1px 0 rgba(0, 200, 255, 0.1);
}

@media (max-width: 560px) {
    .cabinet-body .record-preview-stat:not([hidden]) {
        grid-template-columns: 1fr;
    }
}

/* Result text containment: keep long transcripts/protocols inside their panels. */
.cabinet-body .results,
.cabinet-body .history-result-shell,
.cabinet-body .history-result-card,
.cabinet-body .history-result-section,
.cabinet-body .result-card {
    min-width: 0;
}

.cabinet-body .history-result-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    min-width: 44px;
    height: 44px;
    min-height: 44px;
    padding: 0;
    border: 1px solid rgba(255, 51, 85, 0.28);
    border-radius: var(--radius-md);
    background: rgba(255, 51, 85, 0.08);
    cursor: pointer;
    flex-shrink: 0;
}

.cabinet-body .history-result-close:hover,
.cabinet-body .history-result-close:focus-visible {
    border-color: rgba(255, 51, 85, 0.55);
    background: rgba(255, 51, 85, 0.18);
    outline: none;
}

.cabinet-body .history-result-close:active {
    background: rgba(255, 51, 85, 0.24);
}

.cabinet-body .result-head,
.cabinet-body .result-toolbar,
.cabinet-body .history-result-section-head {
    position: relative;
    z-index: calc(var(--z-base) + 1);
    flex-shrink: 0;
}

.cabinet-body .transcription-content,
.cabinet-body .protocol-content,
.cabinet-body .history-transcription-content,
.cabinet-body .history-protocol-content,
.cabinet-body .transcription-segments,
.cabinet-body .history-transcription-segments {
    max-width: calc(100% - 36px);
    max-height: min(52vh, 560px);
    margin: 14px 18px 18px;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    border: 1px solid rgba(0, 200, 255, 0.12);
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(3, 12, 24, 0.66), rgba(6, 18, 34, 0.86));
    box-shadow: inset 0 1px 0 rgba(0, 200, 255, 0.08);
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    word-break: break-word;
    scrollbar-color: rgba(255, 122, 0, 0.46) rgba(3, 12, 24, 0.72);
}

.cabinet-body .history-transcription-content,
.cabinet-body .history-protocol-content,
.cabinet-body .history-transcription-segments {
    max-width: 100%;
    margin: 12px 0 0;
}

.cabinet-body .transcription-segments,
.cabinet-body .history-transcription-segments {
    align-content: start;
    white-space: normal;
}

.cabinet-body .transcription-segments:not([hidden]),
.cabinet-body .history-transcription-segments:not([hidden]) {
    display: grid;
}

.cabinet-body .transcription-segment {
    min-width: 0;
    overflow: hidden;
}

.cabinet-body .transcription-segment-text,
.cabinet-body .segment-text,
.cabinet-body .segment-content {
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.cabinet-body .transcription-segment-time,
.cabinet-body .segment-time {
    white-space: nowrap;
}



.cabinet-body .processing-workspace {
    display: grid;
    gap: 18px;
}

.cabinet-body .processing-panel {
    gap: 18px;
}

.cabinet-body .upload-form,
.cabinet-body .upload-form .auth-gated-fieldset,
.cabinet-body .source-panels,
.cabinet-body .results {
    display: grid;
    gap: 18px;
}

.cabinet-body .upload-form .auth-gated-fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0;
}

.cabinet-body .source-panel,
.cabinet-body .more-settings-body {
    gap: 14px;
}

.cabinet-body .protocol-toolbar {
    justify-content: flex-end;
}

.cabinet-body .protocol-version-controls {
    gap: 10px;
    padding: 16px 26px 0;
}

.cabinet-body .protocol-version-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.cabinet-body .protocol-version-title {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    color: var(--text-primary);
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    font-size: 14px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* [REMOVED] .protocol-version-meta { display: none; } — dead code, permanently hidden */

.cabinet-body .protocol-versions-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    overflow-x: visible;
}

.cabinet-body .protocol-version-name {
    color: var(--text-primary);
    font-size: 12px;
    line-height: 1.25;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.cabinet-body .protocol-version-meta-line {
    display: flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
    color: var(--text-muted);
    font-size: 12px;
    letter-spacing: 0.04em;
    line-height: 1.2;
}

.cabinet-body.history-page .cabinet-section-head,
.cabinet-body .history-page .cabinet-section-head {
    margin-bottom: 22px;
}

.cabinet-body.history-page .cabinet-section-head .badge-info,
.cabinet-body .history-page .cabinet-section-head .badge-info {
    margin-top: 12px;
}

.cabinet-body .operation-table-row {
    color: var(--text-primary);
}

.cabinet-body .operation-table-head {
    color: var(--text-muted);
}

.cabinet-body .operation-table-row.operation-tone-spent,
.cabinet-body .operation-table-row.operation-tone-reserved,
.cabinet-body .operation-table-row.operation-tone-credited {
    color: var(--text-primary);
}

.cabinet-body .operation-table-row.operation-tone-spent .operation-value {
    color: var(--accent-red);
}

.cabinet-body .operation-table-row.operation-tone-reserved .operation-value {
    color: var(--accent-cost-bright);
}

.cabinet-body .operation-table-row.operation-tone-credited .operation-value {
    color: var(--accent-green);
}

.cabinet-body .operation-table-row.operation-is-error {
    color: var(--accent-red);
}

.cabinet-body .operation-table-row.operation-is-error .operation-value,
.cabinet-body .operation-table-row.operation-is-error .operation-status,
.cabinet-body .operation-table-row.operation-is-error .operation-description {
    color: inherit;
}
.cabinet-body .user-menu {
    position: relative;
    z-index: var(--z-dropdown);
}

.cabinet-body .user-menu-toggle {
    border: 1px solid var(--border-subtle);
    cursor: pointer;
}

.cabinet-body .user-menu-panel {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    width: min(320px, calc(100vw - 32px));
    padding: 14px;
    border: 1px solid;
    border-radius: var(--radius-lg);
}

.cabinet-body .user-menu-row {
    display: grid;
    gap: 4px;
    padding: 8px 0;
}

.cabinet-body .user-menu-row span {
    color: var(--text-muted);
    font-size: 14px;
}

.cabinet-body .user-menu-row strong {
    color: var(--text-primary);
    font-size: 17px;
    overflow-wrap: anywhere;
}

.cabinet-body .user-menu-id-link {
    width: 100%;
    margin-top: 10px;
}

.cabinet-body .user-menu-panel form,
.cabinet-body .user-menu-logout {
    width: 100%;
}

.cabinet-body .auth-required-card {
    display: grid;
    gap: 12px;
    margin-bottom: 16px;
    padding: var(--space-card);
}

.cabinet-body .auth-gated-fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0;
}

/* TASK-056 phone visual mode. Desktop/tablet keep the existing cabinet layout. */
.cabinet-body .mobile-only {
    display: none;
}

.cabinet-body .mobile-sheet {
    display: contents;
}

.cabinet-body .mobile-nav-toggle,
.cabinet-body .mobile-sheet-close,
.cabinet-body .mobile-menu-backdrop {
    display: none;
}

@media (max-width: 767px) {
    html,
    body,
    .cabinet-body {
        width: 100%;
        max-width: 100%;
        overflow-x: hidden;
    }

    body::before {
        display: none;
    }

    .cabinet-body {
        --space-card: 14px;
        --space-grid: 14px;
        font-size: 10px;
        background: #050914;
    }

    html {
        scroll-behavior: auto;
    }

    .cabinet-body .desktop-only {
        display: none;
    }

    .cabinet-body .mobile-only {
        display: inline-flex;
    }

    .cabinet-body.news-page .news-main,
    .cabinet-body .public-news-main,
    .cabinet-body .public-news-header {
        width: min(100% - 24px, 430px);
    }

    .cabinet-body .public-news-header {
        padding: 14px 0;
    }

    .cabinet-body .news-list {
        columns: 1;
        column-gap: 0;
    }

    .cabinet-body .news-card {
        break-inside: avoid;
        margin-bottom: 14px;
    }

    .cabinet-body .news-article {
        padding: 16px;
    }

    .cabinet-body .news-article-head h2 {
        font-size: 22px;
    }

    .cabinet-body .news-content {
        font-size: 12px;
    }

    .cabinet-body .news-back-link {
        display: inline-flex;
        align-items: center;
        min-height: 44px;
        padding: 8px 0;
    }

    .cabinet-body .app-shell {
        display: block;
        min-width: 0;
    }

    .cabinet-body .app-sidebar {
        position: sticky;
        top: 0;
        z-index: calc(var(--z-tooltip) + 1);
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 10px;
        height: auto;
        min-height: 58px;
        padding: 8px 10px;
        overflow: visible;
        border-right: 0;
        border-bottom: 1px solid rgba(255, 122, 0, 0.18);
        background: rgba(4, 8, 16, 0.96);
        backdrop-filter: none;
    }

    .cabinet-body .brand {
        min-width: 0;
        min-height: 48px;
        gap: 9px;
        padding: 5px 0;
    }

    .cabinet-body .radar {
        width: 42px;
        height: 42px;
        flex: 0 0 42px;
        box-shadow: none;
    }

    .cabinet-body .ring,
    .cabinet-body .sweep {
        filter: none;
        box-shadow: none;
    }

    .cabinet-body .r3 {
        animation: cabinet-ring-spin 12s linear infinite;
    }

    .cabinet-body .sweep {
        animation: cabinet-spin 4.5s linear infinite;
    }

    .cabinet-body .core {
        animation: none !important;
        filter: none;
        box-shadow: none;
    }

    .cabinet-body .brand-title,
    .cabinet-body .brand-subtitle {
        font-size: 14px;
        line-height: 1.05;
    }

    .cabinet-body .mobile-nav-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        min-width: 92px;
        min-height: 44px;
        padding: 0 12px;
        border: 1px solid rgba(0, 200, 255, 0.36);
        border-radius: var(--radius-md);
        background: linear-gradient(180deg, rgba(15, 34, 58, 0.9), rgba(7, 16, 29, 0.96));
        color: var(--text-primary);
        cursor: pointer;
    }

    .cabinet-body .mobile-nav-icon,
    .cabinet-body .mobile-nav-icon::before,
    .cabinet-body .mobile-nav-icon::after {
        display: block;
        width: 18px;
        height: 2px;
        border-radius: 2px;
        background: var(--accent-bright);
        content: "";
    }

    .cabinet-body .mobile-nav-icon {
        position: relative;
    }

    .cabinet-body .mobile-nav-icon::before,
    .cabinet-body .mobile-nav-icon::after {
        position: absolute;
        left: 0;
    }

    .cabinet-body .mobile-nav-icon::before {
        top: -6px;
    }

    .cabinet-body .mobile-nav-icon::after {
        top: 6px;
    }

    .cabinet-body .mobile-menu-backdrop {
        position: fixed;
        inset: 0;
        z-index: calc(var(--z-tooltip) + 2);
        display: block;
        background: rgba(0, 0, 0, 0.48);
    }

    .cabinet-body .mobile-menu-backdrop[hidden] {
        display: none;
    }

    .cabinet-body .mobile-sheet {
        position: fixed;
        top: 0;
        right: 0;
        z-index: calc(var(--z-tooltip) + 3);
        display: grid;
        width: min(318px, calc(100vw - 28px));
        max-width: calc(100vw - 28px);
        max-height: 100dvh;
        gap: 12px;
        padding: 16px;
        overflow-y: auto;
        transform: translateX(110%);
        border-left: 1px solid rgba(0, 200, 255, 0.22);
        background: linear-gradient(180deg, rgba(6, 13, 26, 0.99), rgba(4, 8, 16, 0.99));
        box-shadow: none;
        transition: none;
    }

    .cabinet-body.is-mobile-menu-open .mobile-sheet {
        transform: translateX(0);
    }

    .cabinet-body .app-menu {
        display: grid;
        grid-template-columns: 1fr !important;
        gap: 8px;
        padding: 0;
    }

    .cabinet-body .nav-item {
        width: 100%;
        min-height: 44px;
        padding: 12px 14px;
        border: 1px solid var(--border-faint);
        border-radius: var(--radius-md);
        background: rgba(0, 180, 255, 0.035);
    }

    .cabinet-body .nav-item.active {
        border-color: var(--border-active);
        background: rgba(0, 180, 255, 0.08);
        color: var(--accent-bright);
    }

    .cabinet-body .support-menu-action {
        margin: 2px 0 0;
        padding: 0;
    }

    .cabinet-body .support-menu-button {
        width: 100%;
        min-height: 44px;
    }

    .cabinet-body .support-menu-icon {
        width: 28px;
        height: 28px;
        flex: 0 0 28px;
    }

    .cabinet-body .mobile-sheet-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-height: 44px;
        border: 1px solid rgba(255, 122, 0, 0.22);
        border-radius: var(--radius-md);
        background: rgba(4, 14, 26, 0.72);
        color: var(--text-secondary);
        cursor: pointer;
    }

    .cabinet-body .app-main,
    .cabinet-body.history-page .app-main,
    .cabinet-body .history-page.app-main {
        width: 100%;
        padding: 0 10px 48px;
    }

    .cabinet-body .app-topbar {
        position: static;
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        gap: 10px;
        min-height: 0;
        padding: 16px 0 8px;
        border-bottom: 0;
    }

    .cabinet-body .app-topbar h1 {
        font-size: 19px;
        line-height: 1.18;
        overflow-wrap: anywhere;
    }

    .cabinet-body .topbar-actions,
    .cabinet-body .topbar-actions form {
        width: 100%;
        justify-content: stretch;
    }

    .cabinet-body .topbar-actions {
        display: none;
    }

    .cabinet-body .user-menu,
    .cabinet-body .user-menu-toggle,
    .cabinet-body .auth-chip,
    .cabinet-body .topbar-actions .btn {
        width: 100%;
        min-width: 0;
    }

    .cabinet-body .user-menu-panel {
        left: 0;
        right: auto;
        width: min(100%, calc(100vw - 20px));
        background: #06111f;
    }

    .cabinet-body .mobile-user-card {
        display: flex;
        flex-direction: column;
        gap: 6px;
        padding: 12px;
        border: 1px solid var(--border-subtle);
        border-radius: var(--radius-md);
        background: rgba(0, 180, 255, 0.04);
    }
    .cabinet-body .mobile-user-name {
        color: var(--text-primary);
        font-size: 12px;
        font-weight: 600;
    }
    .cabinet-body .mobile-user-email {
        color: var(--text-muted);
        font-size: 10px;
        word-break: break-all;
    }
    .cabinet-body .mobile-logout-button {
        width: 100%;
        min-height: 44px;
        padding: 8px 14px;
        border: 1px solid rgba(255, 51, 85, 0.28);
        border-radius: var(--radius-sm);
        background: rgba(255, 51, 85, 0.08);
        color: #ff5470;
        font: inherit;
        font-size: 11px;
        cursor: pointer;
    }

    .cabinet-body .workspace-section {
        margin-top: 12px;
    }

    .cabinet-body.history-page .workspace-section,
    .cabinet-body .history-page .workspace-section {
        margin-top: 10px;
    }

    .cabinet-body.history-page .cabinet-section-head,
    .cabinet-body .history-page .cabinet-section-head {
        margin-bottom: 14px;
    }

    .cabinet-body .section-head,
    .cabinet-body .cabinet-section-head,
    .cabinet-body .panel-head,
    .cabinet-body .result-head,
    .cabinet-body .tariff-plan-head,
    .cabinet-body .protocol-card-head,
    .cabinet-body .history-title-row,
    .cabinet-body .money-balance-actions,
    .cabinet-body .admin-form-actions {
        align-items: stretch;
        flex-direction: column;
        gap: 10px;
    }

    .cabinet-body .section-title,
    .cabinet-body .empty-state-title,
    .cabinet-body .result-head h2,
    .cabinet-body .result-head h3 {
        font-size: 17px;
        line-height: 1.25;
    }

    .cabinet-body .panel,
    .cabinet-body .card,
    .cabinet-body .summary-card,
    .cabinet-body .state-card,
    .cabinet-body .result-card,
    .cabinet-body .empty-state,
    .cabinet-body .responsive-card {
        width: 100%;
        min-width: 0;
        padding: 14px;
        border-radius: var(--radius-md);
    }

    .cabinet-body.history-page .panel,
    .cabinet-body.history-page .result-card,
    .cabinet-body .history-page .panel,
    .cabinet-body .history-page .result-card,
    .cabinet-body .money-page .summary-card,
    .cabinet-body .money-page .tariff-plan-card {
        box-shadow: none;
    }

    .cabinet-body .money-page .admin-section-switch {
        position: relative;
        flex-wrap: nowrap;
    }

    .cabinet-body .panel,
    .cabinet-body .card,
    .cabinet-body .summary-card,
    .cabinet-body .state-card,
    .cabinet-body .result-card,
    .cabinet-body .empty-state,
    .cabinet-body .source-tab,
    .cabinet-body .btn,
    .cabinet-body .admin-section-tab,
    .cabinet-body .toggle-slider,
    .cabinet-body .toggle-slider::before {
        box-shadow: none !important;
        transition-property: background, border-color, color, opacity, transform;
        transition-duration: 80ms;
    }

    .cabinet-body .processing-grid,
    .cabinet-body .history-layout,
    .cabinet-body .money-grid,
    .cabinet-body .money-balance-grid,
    .cabinet-body .grid-3,
    .cabinet-body .protocol-cards,
    .cabinet-body .protocol-form-grid,
    .cabinet-body .record-preview-stats,
    .cabinet-body .cost-estimate-details,
    .cabinet-body .tariff-period-summary,
    .cabinet-body .storage-breakdown {
        grid-template-columns: 1fr !important;
    }

    .cabinet-body .money-view {
        max-width: 100%;
        overflow: hidden;
    }

    .cabinet-body .tariff-card-grid {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        gap: 14px;
        padding-bottom: 4px;
    }
    .cabinet-body .tariff-card-grid::-webkit-scrollbar {
        height: 8px;
    }
    .cabinet-body .tariff-card-grid::-webkit-scrollbar-thumb {
        background: rgba(0, 200, 255, 0.6);
        border-radius: 4px;
    }
    .cabinet-body .tariff-card-grid::-webkit-scrollbar-track {
        background: rgba(255, 255, 255, 0.06);
    }
    .cabinet-body .tariff-plan-card {
        flex: 0 0 auto;
        width: min(85vw, 320px);
    }

    .cabinet-body .processing-panel,
    .cabinet-body .history-list-panel,
    .cabinet-body .protocol-list-panel,
    .cabinet-body .protocol-form-panel {
        position: static;
    }

    .cabinet-body .source-tabs,
    .cabinet-body .admin-section-switch.source-tabs {
        display: grid;
        grid-template-columns: 1fr !important;
        gap: 8px;
        max-width: none;
        width: 100%;
        padding: 6px;
    }

    /* Примечание: !important на display в @media ниже — вынужденная мера для переопределения
       высокоспецифичных десктопных селекторов кабинета. Без !important мобильная вёрстка ломается. */
    .cabinet-body .record-mode-switch.source-tabs:not([hidden]) {
        display: flex !important;
        flex-wrap: nowrap;
        gap: 0;
        padding: 0;
        width: 100%;
    }

    .cabinet-body .processing-grid .source-tabs,
    .cabinet-body .processing-panel .source-tabs {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 6px;
    }
    .cabinet-body .processing-grid .source-tab,
    .cabinet-body .processing-panel .source-tab {
        justify-content: center;
        text-align: center;
    }
    .cabinet-body .processing-grid .source-tab-icon,
    .cabinet-body .processing-panel .source-tab-icon {
        width: 20px;
        height: 20px;
        flex: 0 0 20px;
    }

    .cabinet-body .money-page .source-tabs,
    .cabinet-body .money-page .admin-section-switch.source-tabs,
    .cabinet-body .money-page .cabinet-tabs {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }
    .cabinet-body .money-page .source-tabs::-webkit-scrollbar,
    .cabinet-body .money-page .admin-section-switch.source-tabs::-webkit-scrollbar,
    .cabinet-body .money-page .cabinet-tabs::-webkit-scrollbar {
        height: 4px;
    }
    .cabinet-body .money-page .source-tabs::-webkit-scrollbar-thumb,
    .cabinet-body .money-page .admin-section-switch.source-tabs::-webkit-scrollbar-thumb,
    .cabinet-body .money-page .cabinet-tabs::-webkit-scrollbar-thumb {
        background: rgba(0, 200, 255, 0.4);
        border-radius: 2px;
    }
    .cabinet-body .money-page .source-tab,
    .cabinet-body .money-page .cabinet-tab {
        flex: 0 0 auto;
        white-space: nowrap;
    }

    .cabinet-body .money-operations .source-tabs:not([hidden]) {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 6px;
    }
    .cabinet-body .money-operations .source-tab {
        justify-content: center;
        text-align: center;
    }

    .cabinet-body .source-tab,
    .cabinet-body .admin-section-tab {
        min-height: 44px;
        padding: 10px 12px;
        font-size: 10px;
        letter-spacing: 0.04em;
    }

    .cabinet-body .source-tab {
        flex-direction: row;
        justify-content: flex-start;
        text-align: left;
    }

    .cabinet-body .source-tab-icon {
        width: 24px;
        height: 24px;
        flex: 0 0 24px;
    }

    .cabinet-body .record-panel-head,
    .cabinet-body .record-panel-meta,
    .cabinet-body .record-controls,
    .cabinet-body .result-toolbar:not(.is-hidden),
    .cabinet-body .result-actions,
    .cabinet-body .history-result-actions,
    .cabinet-body .protocol-card-actions,
    .cabinet-body .panel-actions,
    .cabinet-body .tariff-actions,
    .cabinet-body .quick-amounts {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
        gap: 8px;
    }

    .cabinet-body .money-balance-card .quick-amounts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .cabinet-body .money-balance-grid {
        display: flex;
        flex-direction: column;
        gap: var(--space-grid, 14px);
    }
    .cabinet-body .money-balance-column {
        display: flex;
        flex-direction: column;
        gap: var(--space-grid, 14px);
    }
    .cabinet-body .topup-box {
        width: 100%;
    }
    .cabinet-body .quick-amounts {
        flex-wrap: wrap;
    }

    .cabinet-body .record-panel-icon {
        width: 42px;
        height: 42px;
    }

    .cabinet-body .record-primary-button {
        width: 76px;
        height: 76px;
        min-height: 76px;
        justify-self: center;
    }

    .cabinet-body .record-panel {
        gap: 10px;
    }
    .cabinet-body .record-panel-head {
        gap: 6px;
        padding: 0;
    }
    .cabinet-body .record-panel-copy {
        gap: 4px;
    }
    .cabinet-body .record-panel-description {
        font-size: 11px;
        margin: 0;
    }
    .cabinet-body .record-panel-meta {
        gap: 6px;
        padding: 0;
    }
    .cabinet-body .processing-panel .record-mode-switch,
    .cabinet-body .processing-grid .record-mode-switch {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        width: 100%;
        gap: 6px;
    }
    .cabinet-body .record-controls {
        gap: 8px;
    }
    .cabinet-body .record-helper {
        margin: 4px 0 0;
        font-size: 10px;
    }
    .cabinet-body .record-state {
        font-size: 11px;
    }
    .cabinet-body .record-timer {
        font-size: 12px;
    }

    .cabinet-body .btn {
        min-height: 44px;
        width: 100%;
        max-width: 100%;
        white-space: normal;
    }

    .cabinet-body input,
    .cabinet-body select,
    .cabinet-body textarea,
    .cabinet-body .select-input,
    .cabinet-body .text-input {
        width: 100%;
        max-width: 100%;
        min-height: 44px;
        font-size: 15px;
    }

    .cabinet-body textarea,
    .cabinet-body .protocol-textarea {
        min-height: 220px;
    }

    .cabinet-body .toggle-row,
    .cabinet-body .admin-feature-toggle,
    .cabinet-body .protocol-availability-toggle {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 12px;
        min-height: 44px;
    }

    .cabinet-body .history-item,
    .cabinet-body .history-meta,
    .cabinet-body .history-result-meta,
    .cabinet-body .record-preview-stat:not([hidden]) {
        grid-template-columns: 1fr !important;
    }

    .cabinet-body .history-actions:not([hidden]) {
        display: flex !important;
        flex-direction: row;
        flex-wrap: nowrap;
        gap: 10px;
        width: 100%;
        align-items: center;
        justify-content: space-between;
    }
    .cabinet-body .history-open-button {
        flex: 0 0 auto;
        min-width: 0;
        width: auto;
    }
    .cabinet-body .history-title-actions {
        display: flex;
        align-items: center;
        gap: 6px;
    }

    .cabinet-body .history-item-main,
    .cabinet-body .history-title-stack,
    .cabinet-body .history-title-line {
        min-width: 0;
        width: 100%;
    }

    .cabinet-body .history-title-row {
        display: grid;
        grid-template-columns: 1fr;
        min-width: 0;
        width: 100%;
    }

    .cabinet-body .history-title-line:not([hidden]) {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        gap: 8px;
    }

    .cabinet-body .history-title-line .history-filename,
    .cabinet-body .history-title-line .history-title-actions {
        grid-area: auto;
    }

    .cabinet-body .history-filename,
    .cabinet-body .history-title {
        display: block;
        min-width: 0;
        max-width: 100%;
        white-space: normal;
        word-break: normal;
        overflow-wrap: anywhere;
    }

    .cabinet-body .history-title-edit-form {
        grid-template-columns: 1fr;
    }

    .cabinet-body .history-icon-button {
        width: 44px;
        min-width: 44px;
        justify-self: end;
        align-self: center;
    }

    .cabinet-body .download-menu,
    .cabinet-body .download-trigger {
        width: 100%;
    }

    .cabinet-body .download-menu-panel {
        left: 0;
        right: auto;
        width: 100%;
        min-width: 0;
    }

    .cabinet-body .transcription-content,
    .cabinet-body .protocol-content,
    .cabinet-body .transcription-segments,
    .cabinet-body .content {
        max-width: 100%;
        max-height: none;
        margin: 10px 0 0;
        padding: 12px;
        overflow-x: hidden;
        overflow-y: visible;
        font-size: 10px;
        line-height: 1.62;
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .cabinet-body .history-transcription-content,
    .cabinet-body .history-protocol-content,
    .cabinet-body .history-transcription-segments {
        max-width: 100%;
        max-height: min(42dvh, 270px);
        margin: 10px 0 0;
        padding: 12px;
        overflow-x: hidden;
        overflow-y: auto;
        font-size: 10px;
        line-height: 1.62;
        overflow-wrap: anywhere;
        word-break: break-word;
        overscroll-behavior: contain;
    }

    .cabinet-body .history-page:not(.is-history-result-focused) .history-result-shell {
        display: none;
    }

    .cabinet-body .history-page.is-history-result-focused .history-list-panel {
        display: none;
    }

    .cabinet-body .history-page.is-history-result-focused .history-result-shell {
        display: block;
        width: 100%;
    }

    .cabinet-body .history-result-card .result-head {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: start;
        gap: 10px;
        margin: 0;
        padding-right: 12px;
    }

    .cabinet-body .history-result-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 46px;
        min-width: 46px;
        max-width: 46px;
        height: 44px;
        min-height: 44px;
        padding: 0;
        border: 1px solid rgba(255, 51, 85, 0.28);
        border-radius: var(--radius-md);
        background: rgba(255, 51, 85, 0.08);
        cursor: pointer;
    }

    .cabinet-body .history-result-close:hover,
    .cabinet-body .history-result-close:focus-visible {
        border-color: rgba(255, 51, 85, 0.55);
        background: rgba(255, 51, 85, 0.18);
        outline: none;
    }

    .cabinet-body .history-result-close:active {
        background: rgba(255, 51, 85, 0.24);
    }

    .cabinet-body .history-result-card .history-result-meta {
        margin: 0;
        padding: 12px;
        gap: 10px;
    }

    .cabinet-body .history-result-card .history-result-section:not([hidden]) {
        display: grid;
        gap: 10px;
        padding: 2px 0 0;
    }

    .cabinet-body .history-result-card .history-result-section-head {
        margin: 0;
    }

    .cabinet-body .history-result-card .history-result-actions {
        gap: 8px;
        margin: 0;
    }

    .cabinet-body .history-status[aria-busy="true"] {
        padding: 12px;
        min-height: 48px;
        align-content: center;
    }

    .cabinet-body .history-result-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        gap: 0;
    }
    .cabinet-body .history-result-tabs::-webkit-scrollbar {
        height: 4px;
    }
    .cabinet-body .history-result-tabs::-webkit-scrollbar-thumb {
        background: rgba(0, 200, 255, 0.4);
        border-radius: 2px;
    }
    .cabinet-body .history-result-tab {
        flex: 0 0 auto;
        white-space: nowrap;
        min-height: 44px;
        padding: 10px 16px;
    }

    .cabinet-body .result-head,
    .cabinet-body .result-toolbar,
    .cabinet-body .protocol-version-controls {
        padding: 12px;
    }

    .cabinet-body .result-title-wrap {
        min-width: 0;
    }

    .cabinet-body .result-index {
        width: auto;
        min-width: 42px;
    }

    .cabinet-body .tariff-plan-card,
    .cabinet-body .protocol-card {
        min-width: 0;
        padding: 14px;
    }

    .cabinet-body .tariff-features {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        padding-left: 0;
    }
    .cabinet-body .tariff-features li:nth-child(n+5) {
        grid-column: 1 / -1;
    }

    .cabinet-body .operation-table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        max-width: 100%;
    }

    .cabinet-body .money-operations {
        max-width: 100%;
        overflow-x: hidden;
    }

    .cabinet-body .operation-table-head {
        display: grid;
    }

    .cabinet-body .operation-table-row,
    .cabinet-body .operation-table-row.operation-table-row-finance {
        min-width: 520px;
        padding: 13px 6px;
        border: 0;
        border-bottom: 1px solid var(--border-subtle);
        border-radius: 0;
        background: transparent;
    }

    .cabinet-body .operation-table-row.operation-table-row-finance {
        min-width: 680px;
    }

    .cabinet-body .operation-table-row span,
    .cabinet-body .operation-table-row strong {
        min-width: 0;
        overflow-wrap: anywhere;
        text-align: left;
    }

    .cabinet-body .referral-link-box {
        grid-template-columns: 1fr;
    }

    .cabinet-body .referral-copy-button {
        width: 100%;
    }

    .cabinet-body .support-modal {
        align-items: stretch;
        padding: 10px;
    }

    .cabinet-body .support-modal-dialog,
    .cabinet-body .confirm-modal-dialog,
    .cabinet-body .history-modal,
    .cabinet-body .protocol-delete-dialog {
        width: 100%;
        max-width: calc(100vw - 20px);
        max-height: calc(100dvh - 20px);
        padding: 16px;
        overflow-y: auto;
        border-radius: var(--radius-md);
    }

    .cabinet-body .support-modal-close {
        width: 44px;
        height: 44px;
    }

    .cabinet-body .confirm-modal,
    .cabinet-body .history-modal-overlay,
    .cabinet-body .protocol-delete-modal {
        padding: 10px;
    }

    .cabinet-body .confirm-modal-actions,
    .cabinet-body .history-modal-actions,
    .cabinet-body .protocol-delete-actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .cabinet-body .tiny-label,
    .cabinet-body .badge {
        font-size: 11px;
    }

    .cabinet-body .more-settings-summary {
        font-size: 11px;
        cursor: pointer;
    }

    .cabinet-body .file-drop-zone {
        cursor: pointer;
    }
}

/* TASK-063 UI/UX audit cleanup: font-family moved to SpeechKit UI-Kit alignment section (line 5304). */

/* Оверрайд .app-topbar для sticky-режима */
.cabinet-body .app-topbar {
    position: static;
    top: auto;
    z-index: auto;
    border-bottom-color: rgba(255, 255, 255, 0.08);
    background: transparent;
    backdrop-filter: none;
}

.cabinet-body .field-help,
.cabinet-body .hint,
.cabinet-body .secondary,
.cabinet-body input,
.cabinet-body textarea,
.cabinet-body select,
.cabinet-body .text-input,
.cabinet-body .content,
.cabinet-body .history-document-meta,
.cabinet-body .history-meta-label,
.cabinet-body .history-meta-value {
    font-family: var(--font-body);
}

.cabinet-body .field-help,
.cabinet-body .hint,
.cabinet-body .secondary {
    font-size: 14px;
}

.cabinet-body .panel,
.cabinet-body .state-card,
.cabinet-body .result-card,
.cabinet-body .empty-state,
.cabinet-body .history-item {
    border-color: rgba(255, 255, 255, 0.09);
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.36), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}


.cabinet-body .record-mode-switch {
    width: 100%;
}

.cabinet-body .record-preview-ready {
    color: var(--text-primary);
    font-size: 19px;
}

.cabinet-body .record-preview-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cabinet-body .record-preview-file-name {
    grid-column: 1 / -1;
}

.cabinet-body .content {
    font-size: 19px;
    line-height: 1.78;
    letter-spacing: 0;
    font-family: "Segoe UI", system-ui, -apple-system, sans-serif;
}

.cabinet-body .transcription-segment {
    border-color: rgba(255, 255, 255, 0.08);
}

.cabinet-body .history-document-meta {
    margin-top: 6px;
    color: var(--text-muted);
    font-size: 14px;
    line-height: 1.45;
}

.cabinet-body .protocol-select-trigger,
.cabinet-body .protocol-select-option {
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.45;
    white-space: normal;
    overflow-wrap: anywhere;
}

.cabinet-body .protocol-select-option {
    align-items: flex-start;
    min-height: 44px;
    padding: 10px 12px;
}

.cabinet-body .download-trigger,
.cabinet-body .history-copy-button,
.cabinet-body .transcription-copy,
.cabinet-body .protocol-copy {
    border-color: rgba(255, 255, 255, 0.12);
    background: rgba(9, 23, 42, 0.9);
    color: var(--text-secondary);
    box-shadow: none;
}

/* TASK-063 audit #2: stronger controls and document-like results. */
/* [REMOVED] .app-topbar .tiny-label { display: none; } — dead code, permanently hidden */

.cabinet-body label,
.cabinet-body .history-details-label,
.cabinet-body .record-preview-label {
    color: #b9d4ea;
    font-size: 15px;
}

.cabinet-body .toggle-row {
    min-height: 46px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.cabinet-body .protocol-select-trigger {
    min-height: 48px;
    border: 1px solid var(--btn-secondary-border);
    background: var(--btn-secondary-bg);
    box-shadow: none;
}

.cabinet-body .protocol-select-trigger:hover,
.cabinet-body .protocol-select-trigger:focus-visible,
.cabinet-body .protocol-select.is-open .protocol-select-trigger {
    border-color: var(--btn-secondary-hover-border);
    background: var(--btn-secondary-hover-bg);
}

.cabinet-body .protocol-select-option {
    height: auto;
    min-height: 48px;
}

.cabinet-body .record-panel-icon {
    width: 30px;
    height: 30px;
    flex: 0 0 30px;
}

.cabinet-body .record-panel-head {
    align-items: flex-start;
}

.cabinet-body .btn {
    border-radius: var(--radius-md);
    clip-path: none;
    font-family: var(--font-body);
    letter-spacing: 0;
    text-transform: none;
}

.cabinet-body .btn-primary,
.cabinet-body button.btn-primary,
.cabinet-body .submit-button {
    border: 1px solid var(--accent-action-bright);
    background: linear-gradient(180deg, var(--accent-action) 0%, var(--accent-action) 100%);
    color: #FFF7F0;
}

.cabinet-body .btn-secondary,
.cabinet-body .secondary-button,
.cabinet-body .history-copy-button,
.cabinet-body .download-trigger,
.cabinet-body .transcription-copy,
.cabinet-body .protocol-copy {
    border: 1px solid rgba(242, 106, 0, 0.55);
    background: rgba(242, 106, 0, 0.12);
    color: var(--accent-action-bright);
}

.cabinet-body .btn-secondary:hover,
.cabinet-body .secondary-button:hover,
.cabinet-body .history-copy-button:hover,
.cabinet-body .download-trigger:hover,
.cabinet-body .transcription-copy:hover,
.cabinet-body .protocol-copy:hover {
    border-color: rgba(242, 106, 0, 0.72);
    background: rgba(242, 106, 0, 0.22);
    color: var(--text-primary);
    transform: translateY(-1px);
}

.cabinet-body .history-open-button {
    border: 1px solid var(--accent-action-bright) !important;
    background: linear-gradient(180deg, var(--accent-action) 0%, var(--accent-action) 100%) !important;
    color: #FFF7F0 !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
}

.cabinet-body .history-open-button:hover {
    border-color: var(--accent-action-bright) !important;
    background: linear-gradient(180deg, var(--accent-action-bright) 0%, var(--accent-action) 100%) !important;
    color: var(--text-primary) !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
    transform: translateY(-1px);
}


.cabinet-body .history-item {
    background: linear-gradient(180deg, rgba(17, 37, 66, 0.82), rgba(9, 22, 40, 0.92));
}

.cabinet-body .history-document-meta {
    color: #a7c3dc;
}

.cabinet-body .history-details-item {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 14px;
    border: 1px solid rgba(128, 166, 204, 0.16);
    border-radius: var(--radius-md);
    background: rgba(16, 35, 63, 0.66);
}

.cabinet-body .history-details-value {
    color: #edf7ff;
    font-size: 19px;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.cabinet-body .markdown-document {
    display: grid;
    gap: 12px;
    color: #edf7ff;
    white-space: normal;
}

.cabinet-body .markdown-document h2,
.cabinet-body .markdown-document h3,
.cabinet-body .markdown-document h4 {
    margin: 10px 0 2px;
    color: var(--text-primary);
    font-family: var(--font-body);
    letter-spacing: 0;
    line-height: 1.25;
    text-transform: none;
}

.cabinet-body .markdown-document p {
    margin: 0;
}

.cabinet-body .markdown-document ul,
.cabinet-body .markdown-document ol {
    margin: 0;
    padding-left: 22px;
}

.cabinet-body .markdown-document li {
    margin: 4px 0;
}

.cabinet-body .transcription-segment {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4px;
    align-items: start;
    padding: 9px 12px;
    border-radius: var(--radius-md);
    background: rgba(10, 24, 43, 0.56);
}

.cabinet-body .transcription-segment-time {
    font-size: 12px;
}

@media (max-width: 767px) {
    .cabinet-body .history-result-meta,
    .cabinet-body .transcription-segment {
        grid-template-columns: 1fr;
    }
}

/* SpeechKit UI-Kit alignment: cyan system base with orange action accents. */
.cabinet-body {
    --font-body: var(--font-mono);
    --accent-amber-soft: rgba(255, 140, 0, 0.1);
    --accent-amber-border: rgba(255, 140, 0, 0.3);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    color: var(--text-primary);
}

.cabinet-body .panel,
.cabinet-body .card,
.cabinet-body .summary-card,
.cabinet-body .state-card,
.cabinet-body .record-panel,
.cabinet-body .record-preview,
.cabinet-body .result-card,
.cabinet-body .empty-state,
.cabinet-body .history-item,
.cabinet-body .history-details-item,
.cabinet-body .download-menu,
.cabinet-body .sidebar-card,
.cabinet-body .auth-required-card {
    border-color: var(--border-subtle);
    border-radius: var(--radius-lg);
    background: var(--gradient-card);
    box-shadow: var(--shadow-panel), inset 0 1px 0 rgba(0, 200, 255, 0.08);
}

/* .state-card and .history-item now use canonical values from the mega-selector above.
   Hover/focus states below still apply the active border + glow. */

.cabinet-body .card:hover,
.cabinet-body .state-card:hover,
.cabinet-body .history-item:hover,
.cabinet-body .history-item:focus-within {
    border-color: var(--border-active);
    box-shadow: var(--glow-sm), var(--shadow-panel);
}

.cabinet-body .panel-head h3,
.cabinet-body .section-title,
.cabinet-body .empty-state-title,
.cabinet-body .record-panel-title,
.cabinet-body .history-filename {
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    letter-spacing: 0.06em;
    margin: 0;
}

.cabinet-body .brand-title {
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.cabinet-body .field-help,
.cabinet-body .hint,
.cabinet-body .secondary,
.cabinet-body .history-document-meta,
.cabinet-body .history-meta-label,
.cabinet-body .history-meta-value,
.cabinet-body .history-details-label,
.cabinet-body .record-preview-label {
    color: var(--text-muted);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
    line-height: 1.6;
}

.cabinet-body label {
    color: var(--text-secondary);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 12px;
    letter-spacing: 0.08em;
}

.cabinet-body input,
.cabinet-body textarea,
.cabinet-body select,
.cabinet-body .text-input,
.cabinet-body .input-shell,
.cabinet-body .file-input {
    border-color: var(--border-subtle);
    border-radius: var(--radius-sm);
    background: var(--bg-surface);
    color: var(--text-primary);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    box-shadow: none;
}

.cabinet-body input:focus,
.cabinet-body textarea:focus,
.cabinet-body select:focus,
.cabinet-body .text-input:focus,
.cabinet-body .input-shell:focus-within,
.cabinet-body .file-input:focus-within {
    border-color: var(--border-active);
    background: var(--bg-panel);
    box-shadow: var(--glow-sm);
}


.cabinet-body .btn:hover,
.cabinet-body .btn:focus-visible,
.cabinet-body .download-trigger:hover,
.cabinet-body .download-trigger:focus-visible,
.cabinet-body .history-copy-button:hover,
.cabinet-body .history-copy-button:focus-visible,
.cabinet-body .protocol-select-trigger:hover,
.cabinet-body .protocol-select-trigger:focus-visible,
.cabinet-body .user-menu-toggle:hover,
.cabinet-body .user-menu-toggle:focus-visible {
    border-color: var(--btn-secondary-hover-border);
    background: var(--btn-secondary-hover-bg);
    color: var(--btn-secondary-hover-text);
    transform: translateY(-1px);
}

/* Primary button — bright pure orange */
.cabinet-body .btn-primary,
.cabinet-body button.btn-primary,
.cabinet-body .submit-button,
.cabinet-body .new-transcription-button,
.cabinet-body .send-recording-button,
.cabinet-body .file-input input[type="file"]::file-selector-button {
    border: 1px solid var(--accent-action-bright);
    background: linear-gradient(180deg, var(--accent-action) 0%, var(--accent-action) 100%);
    color: #FFF7F0;
    box-shadow: 0 8px 18px rgba(242, 106, 0, 0.24);
}

.cabinet-body .btn-primary:not(.is-success):not(.is-copied):hover,
.cabinet-body .btn-primary:not(.is-success):not(.is-copied):focus-visible,
.cabinet-body button.btn-primary:not(.is-success):not(.is-copied):hover,
.cabinet-body button.btn-primary:not(.is-success):not(.is-copied):focus-visible,
.cabinet-body .submit-button:not(.is-success):not(.is-copied):hover,
.cabinet-body .submit-button:not(.is-success):not(.is-copied):focus-visible,
.cabinet-body .new-transcription-button:not(.is-success):not(.is-copied):hover,
.cabinet-body .new-transcription-button:not(.is-success):not(.is-copied):focus-visible,
.cabinet-body .send-recording-button:not(.is-success):not(.is-copied):hover,
.cabinet-body .send-recording-button:not(.is-success):not(.is-copied):focus-visible {
    border-color: var(--accent-action-bright);
    background: linear-gradient(180deg, var(--accent-action-bright) 0%, var(--accent-action) 100%);
    color: var(--text-primary);
    box-shadow: 0 10px 22px rgba(242, 106, 0, 0.32);
    transform: translateY(-1px);
}

.cabinet-body .btn-danger,
.cabinet-body .history-delete-confirm-button,
.cabinet-body .user-menu-logout {
    border-color: rgba(255, 51, 85, 0.34);
    background: rgba(255, 51, 85, 0.08);
    color: #ffd8df;
}

.cabinet-body .btn-danger:hover,
.cabinet-body .btn-danger:focus-visible,
.cabinet-body .history-delete-confirm-button:hover,
.cabinet-body .history-delete-confirm-button:focus-visible,
.cabinet-body .user-menu-logout:hover,
.cabinet-body .user-menu-logout:focus-visible {
    border-color: rgba(255, 94, 120, 0.72);
    background: rgba(255, 51, 85, 0.18);
    color: var(--text-primary);
}

/* Auto-renew toggle — green when off (enable), red when on (disable) */
.cabinet-body .auto-renew-toggle[data-auto-renew-enabled="false"] {
    border-color: var(--accent-green);
    background: linear-gradient(180deg, var(--accent-green) 0%, var(--accent-green) 100%);
    color: var(--text-primary);
}
.cabinet-body .auto-renew-toggle[data-auto-renew-enabled="false"]:hover,
.cabinet-body .auto-renew-toggle[data-auto-renew-enabled="false"]:focus-visible {
    border-color: #00E673;
    background: linear-gradient(180deg, #00E673 0%, #00B84D 100%);
    color: var(--text-primary);
    transform: translateY(-1px);
}
.cabinet-body .auto-renew-toggle[data-auto-renew-enabled="true"] {
    border-color: #E63A50;
    background: linear-gradient(180deg, #E63A50 0%, #B8223C 100%);
    color: var(--text-primary);
}
.cabinet-body .auto-renew-toggle[data-auto-renew-enabled="true"]:hover,
.cabinet-body .auto-renew-toggle[data-auto-renew-enabled="true"]:focus-visible {
    border-color: #F04C62;
    background: linear-gradient(180deg, #F04C62 0%, #CC2A44 100%);
    color: var(--text-primary);
    transform: translateY(-1px);
}

.cabinet-body .btn:disabled,
.cabinet-body button:disabled,
.cabinet-body .btn.is-disabled,
.cabinet-body .submit-button.is-disabled {
    border-color: var(--border-faint);
    background: rgba(10, 22, 40, 0.72);
    color: var(--text-disabled);
    box-shadow: none;
    cursor: not-allowed;
    opacity: 1;
    transform: none;
}


.cabinet-body .protocol-select {
    position: relative;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.cabinet-body .more-settings {
    overflow: visible;
}

.cabinet-body .protocol-native-select {
    position: absolute;
    width: 1px;
    height: 1px;
    min-height: 0;
    margin: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
}

.cabinet-body .protocol-select-trigger {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: start;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    height: auto;
    min-height: 46px;
    padding: 11px 14px;
    text-align: left;
    box-sizing: border-box;
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    border-radius: var(--radius-md);
}

.cabinet-body .protocol-select-arrow {
    justify-self: end;
    width: 9px;
    height: 9px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg) translateY(2px);
}

.cabinet-body .protocol-select.is-open .protocol-select-arrow {
    transform: rotate(225deg) translateY(-2px);
}

.cabinet-body .protocol-select-trigger,
.cabinet-body .protocol-select-option {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.cabinet-body .protocol-select-value,
.cabinet-body [data-custom-select-value] {
    display: block;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: left;
    line-height: 1.45;
}

.cabinet-body .protocol-select-list {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    left: 0;
    z-index: var(--z-modal-backdrop);
    display: grid;
    width: 100%;
    min-width: 100%;
    max-width: 100%;
    max-height: min(400px, 60vh);
    padding: 4px 0;
    overflow-x: hidden;
    overflow-y: auto;
    border: 1px solid var(--border-mid);
    border-radius: var(--radius-sm);
    background: rgba(4, 12, 24, 0.99);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.5), var(--glow-sm);
    scrollbar-color: rgba(0, 200, 255, 0.48) rgba(7, 17, 31, 0.96);
}

.cabinet-body .protocol-select-list[hidden] {
    display: none;
}

.cabinet-body .protocol-select-option {
    width: 100%;
    height: auto;
    min-height: 0;
    padding: 12px 16px;
    border: 0;
    border-bottom: 1px solid rgba(0, 180, 255, 0.12);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    color: var(--text-primary);
    text-align: left;
    line-height: 1.45;
    box-sizing: border-box;
    appearance: none;
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.cabinet-body .protocol-select-option + .protocol-select-option {
    margin-top: 0;
}

.cabinet-body .protocol-select-option:hover,
.cabinet-body .protocol-select-option:focus-visible {
    background: rgba(0, 180, 255, 0.07);
    color: var(--accent-pulse);
}

.cabinet-body .protocol-select-option.is-selected {
    border-left: 3px solid var(--accent-primary);
    background: rgba(0, 180, 255, 0.11);
    color: var(--text-primary);
}

.cabinet-body .protocol-select-option.custom-option--current {
    outline: 2px solid var(--accent-primary);
    outline-offset: -2px;
    background: rgba(0, 200, 255, 0.13);
}

.cabinet-body .history-layout,
.cabinet-body .processing-grid {
    gap: var(--space-grid);
}

.cabinet-body .history-item {
    position: relative;
    border-color: var(--border-subtle);
    background: linear-gradient(180deg, rgba(13, 30, 53, 0.78), rgba(7, 17, 31, 0.94));
}

.cabinet-body .history-item.is-selected,
.cabinet-body .history-item:hover,
.cabinet-body .history-item:focus-within {
    border-color: var(--border-active);
    background: linear-gradient(180deg, rgba(13, 48, 78, 0.86), rgba(7, 21, 38, 0.98));
}

.cabinet-body .history-item-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 42px;
    grid-template-areas:
        "title edit"
        "duration duration"
        "open delete";
    gap: 12px;
    align-items: end;
}

.cabinet-body .history-title-row,
.cabinet-body .history-title-stack,
.cabinet-body .history-title-line,
.cabinet-body .history-actions {
    display: contents;
}

.cabinet-body .history-filename {
    grid-area: title;
    min-width: 0;
    margin: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.cabinet-body .history-title-actions {
    grid-area: edit;
    justify-self: end;
    align-self: start;
}

.cabinet-body .history-document-meta {
    grid-area: duration;
    color: var(--text-secondary);
    font-size: 15px;
    line-height: 1.4;
}

.cabinet-body .history-open-button {
    grid-area: open;
    justify-self: start;
}

.cabinet-body .history-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    min-width: 42px;
    height: 42px;
    min-height: 42px;
    padding: 0;
}


.cabinet-body .history-result-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    padding: 0;
    border-bottom: 0;
    background: transparent;
}

.cabinet-body .history-details-item {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 14px;
}

.cabinet-body .history-details-value {
    min-width: 0;
    color: var(--text-primary);
    font-size: 17px;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.cabinet-body .record-panel {
    padding: 18px;
}

/* [REMOVED] .record-panel-icon { display: none; } — dead code, permanently hidden */

.cabinet-body .record-panel-head {
    display: block;
}

.cabinet-body .record-mode-switch {
    display: inline-flex;
    flex-wrap: nowrap;
    width: auto;
    gap: 0;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.cabinet-body .record-mode-switch .source-tab {
    flex: 1 1 0;
    min-width: 0;
    min-height: 32px;
    padding: 4px 14px;
    white-space: normal;
    text-align: center;
    justify-content: center;
    border-radius: 0;
    font-size: 13px;
}

.cabinet-body .record-mode-switch .source-tab:first-child {
    border-radius: 100px 0 0 100px;
    border-right-width: 0;
}

.cabinet-body .record-mode-switch .source-tab:last-child {
    border-radius: 0 100px 100px 0;
    border-left-width: 0;
}

.cabinet-body .record-primary-button {
    border-color: rgba(255, 170, 60, 0.55);
    background: radial-gradient(circle at 35% 28%, #ffb84d 0%, #e07814 40%, #b85500 74%, #7a3800 100%);
    color: var(--text-primary);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35), inset 0 2px 3px rgba(255, 238, 205, 0.28), inset 0 -8px 14px rgba(50, 20, 0, 0.32);
}

.cabinet-body .record-primary-button:hover,
.cabinet-body .record-primary-button:focus-visible {
    border-color: rgba(255, 196, 84, 0.72);
    background: radial-gradient(circle at 35% 28%, #ffcc66 0%, #f0881c 40%, #cc6600 74%, #8a4200 100%);
}

.cabinet-body .record-primary-button .icon-stroke,
.cabinet-body .record-button-icon {
    color: #ffffff;
    stroke: currentColor;
}

.cabinet-body .record-preview {
    gap: 14px;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.cabinet-body .record-preview:not([hidden]) {
    display: grid;
}

.cabinet-body .record-preview-stats {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
}

.cabinet-body .record-preview-stat:not([hidden]) {
    display: grid;
    grid-template-columns: minmax(120px, max-content) minmax(0, 1fr);
    gap: 12px;
    min-width: 0;
    padding: 0;
    border: 0;
    background: transparent;
}

.cabinet-body .record-preview-file-name,
.cabinet-body .record-preview-actions {
    grid-template-columns: 1fr;
}

.cabinet-body .record-preview-value {
    min-width: 0;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.cabinet-body .badge-info {
    color: var(--accent-bright);
    border-color: var(--border-mid);
    background: rgba(0, 180, 255, 0.07);
}

.cabinet-body .history-flag.is-processing,
.cabinet-body .history-status-badge.is-processing {
    color: var(--accent-warning-bright);
    border-color: var(--accent-warning-border);
    background: var(--accent-warning-soft);
}

.cabinet-body .limit-stat-value,
.cabinet-body .operation-table-row.operation-tone-reserved,
.cabinet-body .operation-table-row.operation-tone-reserved .operation-value {
    color: var(--accent-cost-bright);
}

.cabinet-body .limit-track[data-limit-tone="orange"] span {
    background: linear-gradient(90deg, var(--accent-cost), var(--accent-cost-bright));
    box-shadow: var(--glow-cost);
}

.cabinet-body .limit-track[data-limit-tone="blue"] span,
.cabinet-body .loading-progress-fill {
    background: linear-gradient(90deg, var(--accent-primary), var(--accent-bright));
}

.cabinet-body .markdown-document {
    display: grid;
    gap: 12px;
    color: var(--text-primary);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 17px;
    line-height: 1.62;
    white-space: normal;
}

.cabinet-body .markdown-document h2,
.cabinet-body .markdown-document h3,
.cabinet-body .markdown-document h4 {
    margin: 8px 0 0;
    font-family: var(--font-display, "Arial Black", Impact, sans-serif);
    letter-spacing: 0.04em;
    line-height: 1.25;
}

.cabinet-body .markdown-table {
    width: 100%;
    border-collapse: collapse;
    overflow: hidden;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    background: rgba(8, 22, 40, 0.66);
    font-size: 15px;
    line-height: 1.5;
}

.cabinet-body .markdown-table td {
    padding: 9px 10px;
    border: 1px solid rgba(0, 180, 255, 0.14);
    vertical-align: top;
    overflow-wrap: anywhere;
}

.cabinet-body .transcription-segment {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4px;
    align-items: start;
}

.cabinet-body .user-menu-panel,
.cabinet-body .support-modal,
.cabinet-body .download-menu-panel {
    border-color: var(--border-mid);
    background: rgba(4, 12, 24, 0.99);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.5), var(--glow-sm);
}

.cabinet-body .user-menu-panel[hidden] {
    display: none;
}

.cabinet-body .user-menu-id-link,
.cabinet-body .user-menu-logout,
.cabinet-body .user-menu-panel form {
    width: 100%;
}

.cabinet-body .field-group,
.cabinet-body .compact-field,
.cabinet-body .more-settings-body {
    min-width: 0;
}


.cabinet-body .protocol-version-controls {
    width: 100%;
}

.cabinet-body .protocol-versions-list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    overflow-x: visible;
}

.cabinet-body .result-toolbar,
.cabinet-body .result-actions,
.cabinet-body .history-result-actions,
.cabinet-body .protocol-card-actions,
.cabinet-body .panel-actions,
.cabinet-body .processing-actions,
.cabinet-body .record-debug-actions,
.cabinet-body .record-preview-actions,
.cabinet-body .protocol-delete-actions,
.cabinet-body .tariff-actions,
.cabinet-body .topbar-actions {
    gap: 14px;
}

.cabinet-body .history-result-actions,
.cabinet-body .result-toolbar:not(.is-hidden),
.cabinet-body .protocol-card-actions {
    display: flex;
    flex-wrap: wrap;
}


.cabinet-body .user-menu {
    z-index: var(--z-modal);
}

.cabinet-body .app-topbar,
.cabinet-body .topbar-actions {
    overflow: visible;
}

/* z-index для .app-topbar в контексте модальных окон */
.cabinet-body .app-topbar {
    position: relative;
    z-index: var(--z-tooltip);
}

.cabinet-body .user-menu-panel {
    z-index: var(--z-notification);
}

.cabinet-body .support-menu-button {
    border-color: rgba(255, 188, 82, 0.72);
    background: linear-gradient(180deg, #ff9a24 0%, #d96b00 100%);
    color: #fffaf0;
    box-shadow: 0 0 18px rgba(255, 140, 0, 0.48), 0 0 34px rgba(255, 111, 0, 0.24), inset 0 1px 0 rgba(255, 245, 225, 0.28);
}

.cabinet-body .support-menu-button:hover,
.cabinet-body .support-menu-button:focus-visible {
    background: linear-gradient(180deg, #ffb04a 0%, #ef7a00 100%);
}

.cabinet-body .record-controls {
    justify-content: center;
    margin-bottom: 12px;
}

.cabinet-body .record-mode-switch {
    display: flex;
    flex-wrap: nowrap;
    width: 100%;
}

.cabinet-body .record-primary-button,
.cabinet-body .record-button-icon,
.cabinet-body .record-primary-button .icon-stroke {
    place-items: center;
}

.cabinet-body .record-primary-button .icon-stroke {
    display: block;
    width: 30px;
    height: 30px;
    margin: auto;
}

@media (max-width: 767px) {
    .cabinet-body .mobile-nav-toggle {
        border-color: var(--border-active);
        background: linear-gradient(180deg, rgba(10, 42, 72, 0.92), rgba(7, 16, 29, 0.96));
    }

    .cabinet-body .mobile-nav-icon,
    .cabinet-body .mobile-nav-icon::before,
    .cabinet-body .mobile-nav-icon::after {
        background: var(--accent-bright);
    }

    .cabinet-body .mobile-sheet {
        border-left-color: var(--border-subtle);
    }

    .cabinet-body .nav-item {
        border-color: var(--border-faint);
        background: rgba(0, 180, 255, 0.035);
    }

    .cabinet-body .nav-item.active {
        border-color: var(--border-active);
        background: rgba(0, 180, 255, 0.08);
        color: var(--accent-bright);
    }

    .cabinet-body .history-result-meta,
    .cabinet-body .transcription-segment,
    .cabinet-body .record-preview-stat:not([hidden]) {
        grid-template-columns: 1fr;
    }


    .cabinet-body .processing-panel .record-mode-switch,
    .cabinet-body .processing-grid .record-mode-switch {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        width: 100%;
        gap: 6px;
    }

    .cabinet-body .record-mode-switch .source-tab {
        justify-content: center;
        text-align: center;
    }

    .cabinet-body .history-item-main {
        grid-template-columns: minmax(0, 1fr) 42px;
    }

    .cabinet-body .protocol-select-trigger {
        align-items: center;
    }
}

/* TASK-063 follow-up: source-tabs container styling. */
.cabinet-body .source-tabs,
.cabinet-body .admin-section-switch.source-tabs {
    color: var(--text-secondary);
    transition: var(--transition-interactive);
}

.cabinet-body .record-mode-switch {
    gap: 0;
}

.cabinet-body .record-mode-switch .source-tab {
    min-height: 32px;
}

.cabinet-body .protocol-version-controls,
.cabinet-body .history-protocol-version-controls {
    gap: 10px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.cabinet-body .protocol-version-head {
    padding: 0;
}

.cabinet-body .protocol-versions-list {
    gap: 8px;
}

.cabinet-body .history-result-actions,
.cabinet-body .result-actions,
.cabinet-body .record-preview-actions,
.cabinet-body .processing-actions,
.cabinet-body .history-modal-actions,
.cabinet-body .protocol-delete-actions,
.cabinet-body .user-menu-panel {
    gap: 14px;
}

.cabinet-body .user-menu-panel {
    display: grid;
}


.cabinet-body .history-title-edit-form {
    grid-column: 1 / -1;
    grid-row: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 40px 40px;
    gap: 8px;
    align-items: center;
    width: 100%;
}

.cabinet-body .history-title-input {
    width: 100%;
    min-height: 40px;
}

.cabinet-body .history-title-action-button {
    display: inline-grid;
    place-items: center;
    width: 40px;
    min-width: 40px;
    height: 40px;
    min-height: 40px;
    padding: 0;
    border: 1px solid var(--border-mid);
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, rgba(13, 37, 65, 0.94), rgba(7, 18, 34, 0.98));
    box-shadow: inset 0 1px 0 rgba(0, 200, 255, 0.08);
    cursor: pointer;
    transition: var(--transition-interactive);
}

.cabinet-body .history-title-save-button {
    color: #8ff0a4;
    border-color: rgba(82, 211, 126, 0.42);
}

.cabinet-body .history-title-cancel-button {
    color: #ff8ba0;
    border-color: rgba(255, 77, 109, 0.42);
}

.cabinet-body .history-title-action-button:hover,
.cabinet-body .history-title-action-button:focus-visible {
    background: linear-gradient(180deg, rgba(16, 52, 86, 0.98), rgba(8, 27, 48, 0.98));
    box-shadow: var(--glow-sm), inset 0 1px 0 rgba(0, 200, 255, 0.12);
    transform: translateY(-1px);
}

.cabinet-body .history-title-save-button:hover,
.cabinet-body .history-title-save-button:focus-visible {
    border-color: rgba(116, 242, 157, 0.76);
    color: #c8ffd4;
}

.cabinet-body .history-title-cancel-button:hover,
.cabinet-body .history-title-cancel-button:focus-visible {
    border-color: rgba(255, 112, 138, 0.82);
    color: #fff1f4;
}

.cabinet-body .history-title-action-icon {
    width: 18px;
    height: 18px;
}

@media (max-width: 560px) {
    .cabinet-body .history-title-edit-form {
        grid-template-columns: minmax(0, 1fr) 40px 40px;
    }
}

/* TASK-063 icon-only history actions: keep touch area, remove button plates. */

/* === Icon buttons (shared base) === */
.cabinet-body .history-icon-button,
.cabinet-body .history-title-action-button {
    display: inline-grid;
    place-items: center;
    width: 40px;
    min-width: 40px;
    height: 40px;
    min-height: 40px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    clip-path: none;
    cursor: pointer;
    transition: var(--transition-interactive);
}

.cabinet-body .history-icon-button,
.cabinet-body .history-edit-button {
    color: var(--text-secondary);
}

.cabinet-body .history-title-save-button {
    color: #8ff0a4;
}

.cabinet-body .history-title-cancel-button {
    color: #ff8ba0;
}

.cabinet-body .history-icon-button:hover,
.cabinet-body .history-icon-button:focus-visible,
.cabinet-body .history-edit-button:hover,
.cabinet-body .history-edit-button:focus-visible {
    color: var(--accent-pulse);
    background: transparent;
    box-shadow: none;
    transform: translateY(-1px);
}

.cabinet-body .history-title-cancel-button:hover,
.cabinet-body .history-title-cancel-button:focus-visible {
    color: #fff1f4;
    background: transparent;
    box-shadow: none;
    transform: translateY(-1px);
}

.cabinet-body .history-title-save-button:hover,
.cabinet-body .history-title-save-button:focus-visible {
    color: #c8ffd4;
    background: transparent;
    box-shadow: none;
    transform: translateY(-1px);
}

/* === History Delete Button --- consolidated (was ~20 scattered blocks) === */

/* Grid placement (parent grid .history-item-main defines "delete" area) */
.cabinet-body .history-delete-button {
    grid-area: delete;
    justify-self: end;
    align-self: end;
    cursor: pointer;
    clip-path: none;
    transition: var(--transition-interactive);
    border-radius: 0;
}

/* Button-element overrides --- beats .btn/.btn-secondary (0,2,0) */
.cabinet-body button.history-delete-button {
    width: 40px;
    min-width: 40px;
    max-width: 40px;
    height: 40px;
    min-height: 40px;
    padding: 0;
    border: 0;
    background: transparent;
    background-image: none;
    box-shadow: none;
    color: #ff8ba0;
}

.cabinet-body button.history-delete-button:hover,
.cabinet-body button.history-delete-button:focus-visible {
    color: #ff3355;
    background: transparent;
    background-image: none;
    box-shadow: none;
    transform: translateY(-1px);
}

.cabinet-body button.history-delete-button:active {
    transform: translateY(1px) scale(0.98);
}

/* Hide pseudo-element (was used for mask-based trash icon) */
.cabinet-body .history-delete-button::before {
    content: none;
    display: none;
}

/* Delete icon inside the button */
.cabinet-body .history-delete-button .history-delete-icon,
.cabinet-body .history-delete-button .history-delete-icon path {
    display: block;
    width: 19px;
    height: 19px;
    color: currentColor;
    stroke: currentColor;
    opacity: 1;
    visibility: visible;
    pointer-events: none;
}

/* === Button-element overrides (shared) === */
.cabinet-body button.history-icon-button,
.cabinet-body button.history-title-action-button {
    width: 40px !important;
    min-width: 40px !important;
    max-width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0;
    background: transparent !important;
    background-image: none !important;
    box-shadow: none !important;
}

.cabinet-body button.history-edit-button {
    color: var(--text-secondary) !important;
}

.cabinet-body button.history-title-cancel-button {
    color: #ff8ba0 !important;
}

.cabinet-body button.history-title-save-button {
    color: #8ff0a4 !important;
}

.cabinet-body button.history-icon-button:hover,
.cabinet-body button.history-icon-button:focus-visible,
.cabinet-body button.history-title-action-button:hover,
.cabinet-body button.history-title-action-button:focus-visible {
    border: 0;
    background: transparent !important;
    background-image: none !important;
    box-shadow: none !important;
}

/* === Icon styling (shared) === */
.cabinet-body .history-title-action-icon,
.cabinet-body .history-delete-icon {
    display: block;
    width: 19px;
    height: 19px;
    color: currentColor;
    stroke: currentColor;
    opacity: 1;
    visibility: visible;
    pointer-events: none;
}



/* ── Premium button system: no neon, clean depth (task079-v4) ── */

/* Secondary / default — blue auxiliary */
.cabinet-body .btn,
.cabinet-body .btn-secondary,
.cabinet-body .secondary-button,
.cabinet-body .download-trigger,
.cabinet-body .history-copy-button,
.cabinet-body .history-open-button,
.cabinet-body .transcription-copy,
.cabinet-body .protocol-copy,
.cabinet-body .regenerate-protocol-button,
.cabinet-body .user-menu-toggle,
.cabinet-body .user-menu-id-link,
.cabinet-body .id-login-button,
.cabinet-body .file-input input[type="file"]::file-selector-button {
    min-height: 44px;
    border: 1px solid var(--btn-secondary-border);
    border-radius: var(--radius-md);
    background: var(--btn-secondary-bg);
    color: var(--btn-secondary-text);
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    clip-path: none;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.22);
}

.cabinet-body .btn:hover,
.cabinet-body .btn:focus-visible,
.cabinet-body .btn-secondary:hover,
.cabinet-body .btn-secondary:focus-visible,
.cabinet-body .secondary-button:hover,
.cabinet-body .secondary-button:focus-visible,
.cabinet-body .download-trigger:hover,
.cabinet-body .download-trigger:focus-visible,
.cabinet-body .history-copy-button:hover,
.cabinet-body .history-copy-button:focus-visible,
.cabinet-body .history-open-button:hover,
.cabinet-body .history-open-button:focus-visible,
.cabinet-body .transcription-copy:hover,
.cabinet-body .transcription-copy:focus-visible,
.cabinet-body .protocol-copy:hover,
.cabinet-body .protocol-copy:focus-visible,
.cabinet-body .regenerate-protocol-button:hover,
.cabinet-body .regenerate-protocol-button:focus-visible,
.cabinet-body .id-login-button:hover,
.cabinet-body .id-login-button:focus-visible,
.cabinet-body .file-input input[type="file"]::file-selector-button:hover {
    border-color: var(--btn-secondary-hover-border);
    background: var(--btn-secondary-hover-bg);
    color: var(--btn-secondary-hover-text);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.28);
    transform: translateY(-1px);
}

.cabinet-body .btn:focus-visible,
.cabinet-body .btn-secondary:focus-visible,
.cabinet-body .secondary-button:focus-visible,
.cabinet-body .download-trigger:focus-visible,
.cabinet-body .history-copy-button:focus-visible,
.cabinet-body .history-open-button:focus-visible,
.cabinet-body .transcription-copy:focus-visible,
.cabinet-body .protocol-copy:focus-visible,
.cabinet-body .regenerate-protocol-button:focus-visible,
.cabinet-body .id-login-button:focus-visible {
    outline: 2px solid var(--btn-secondary-hover-border);
    outline-offset: 1px;
}

/* Success — green action (moved after .btn base so cascade wins without !important) */
.cabinet-body .btn-success {
    border-color: rgba(0, 255, 157, 0.45);
    background: linear-gradient(180deg, #0d6b3d 0%, #094a2a 100%);
    color: #e0ffe8;
    box-shadow: 0 0 14px rgba(0, 255, 157, 0.18), inset 0 0 10px rgba(0, 255, 180, 0.08);
}

.cabinet-body .btn-success:hover,
.cabinet-body .btn-success:focus-visible {
    border-color: rgba(0, 255, 157, 0.68);
    background: linear-gradient(180deg, #108548 0%, #0b5e34 100%);
    color: #f0fff4;
    box-shadow: 0 0 18px rgba(0, 255, 157, 0.28), inset 0 0 14px rgba(0, 255, 180, 0.12);
}

.cabinet-body .user-menu-id-link:hover,
.cabinet-body .user-menu-id-link:focus-visible {
    border-color: rgba(30, 70, 140, 0.7);
    background: linear-gradient(180deg, #0d2d52 0%, #061830 100%);
    color: #c8daff;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
    outline: 2px solid rgba(30, 70, 140, 0.7);
    outline-offset: 2px;
}

/* Primary — orange accent, no neon */
.cabinet-body .submit-button,
.cabinet-body .new-transcription-button,
.cabinet-body .send-recording-button,
.cabinet-body .support-menu-button {
    border-color: rgba(232, 128, 28, 0.55);
    background: linear-gradient(180deg, #e07814 0%, #b85500 100%);
    color: var(--text-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.28);
}

.cabinet-body .submit-button:hover,
.cabinet-body .new-transcription-button:hover,
.cabinet-body .send-recording-button:hover,
.cabinet-body .support-menu-button:hover {
    border-color: rgba(245, 150, 42, 0.72);
    background: linear-gradient(180deg, #f0881c 0%, #cc6600 100%);
    color: var(--text-primary);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.32);
}

.cabinet-body .submit-button:focus-visible,
.cabinet-body .new-transcription-button:focus-visible,
.cabinet-body .send-recording-button:focus-visible,
.cabinet-body .support-menu-button:focus-visible {
    outline: 2px solid rgba(245, 150, 42, 0.8);
    outline-offset: 2px;
    border-color: rgba(245, 150, 42, 0.72);
    background: linear-gradient(180deg, #f0881c 0%, #cc6600 100%);
    color: var(--text-primary);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.32);
}

/* ── Disabled ── */
.cabinet-body .btn:disabled,
.cabinet-body button:disabled,
.cabinet-body .btn.is-disabled,
.cabinet-body .submit-button:disabled,
.cabinet-body .submit-button.is-disabled {
    border-color: rgba(95, 120, 145, 0.26) !important;
    background: linear-gradient(180deg, rgba(12, 26, 43, 0.78), rgba(7, 16, 29, 0.88)) !important;
    color: #667f96 !important;
    box-shadow: none !important;
    cursor: not-allowed;
    opacity: 1;
    transform: none;
}

/* ── Danger ── */
.cabinet-body .btn-danger,
.cabinet-body .history-delete-confirm-button,
.cabinet-body .user-menu-logout:hover,
.cabinet-body .user-menu-logout:focus-visible {
    border-color: rgba(255, 83, 116, 0.72);
    background: linear-gradient(180deg, rgba(143, 28, 56, 0.96), rgba(82, 15, 34, 0.98));
    color: #fff1f4;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.28);
}

.cabinet-body .btn-danger:hover,
.cabinet-body .btn-danger:focus-visible,
.cabinet-body .history-delete-confirm-button:hover,
.cabinet-body .history-delete-confirm-button:focus-visible {
    border-color: rgba(255, 124, 148, 0.88);
    background: linear-gradient(180deg, rgba(181, 38, 72, 0.98), rgba(105, 20, 44, 1));
    color: var(--text-primary);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
}

/* ── Consolidated .source-tab base (Group 1) ── */
.cabinet-body .source-tab {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-height: 42px;
    min-width: 92px;
    padding: 9px 16px;
    border: 1px solid rgba(0, 154, 220, 0.42);
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, rgba(7, 27, 48, 0.98), rgba(3, 13, 28, 0.99));
    color: #acc9df;
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    box-shadow: inset 0 1px 0 rgba(117, 220, 255, 0.08), inset 0 -10px 18px rgba(0, 0, 0, 0.18);
    clip-path: none;
    transition: var(--transition-interactive);
}

/* ── Consolidated .source-tab hover (Group 2) ── */
.cabinet-body .source-tab:hover,
.cabinet-body .source-tab:focus-visible {
    border-color: rgba(66, 166, 230, 0.62);
    background: linear-gradient(180deg, rgba(10, 40, 68, 0.98), rgba(4, 20, 40, 0.99));
    color: #dceeff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.22);
    transform: translateY(-1px);
}

/* ── Consolidated .protocol-version-button base (Group 1) ── */
.cabinet-body .protocol-version-button {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    min-height: 42px;
    min-width: 92px;
    padding: 9px 16px;
    border: 1px solid rgba(0, 154, 220, 0.42);
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, rgba(7, 27, 48, 0.98), rgba(3, 13, 28, 0.99));
    color: #acc9df;
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
    font-size: 14px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    box-shadow: inset 0 1px 0 rgba(117, 220, 255, 0.08), inset 0 -10px 18px rgba(0, 0, 0, 0.18);
    clip-path: none;
    transition: var(--transition-interactive);
    flex: 0 0 auto;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    cursor: pointer;
}

/* ── Consolidated .protocol-version-button hover (Group 2) ── */
.cabinet-body .protocol-version-button:hover,
.cabinet-body .protocol-version-button:focus-visible {
    border-color: rgba(66, 166, 230, 0.62);
    background: linear-gradient(180deg, rgba(10, 40, 68, 0.98), rgba(4, 20, 40, 0.99));
    color: #dceeff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.22);
    transform: translateY(-1px);
}

/* --- Browser-style history tabs (consolidated) --- */

.cabinet-body .history-result-tabs {
    display: flex;
    gap: 0;
    flex-wrap: wrap;
    padding: 0 18px;
    border-bottom: 0;
    background: transparent;
}

.cabinet-body .history-result-tab {
    position: relative !important;
    min-height: 36px !important;
    padding: 8px 20px !important;
    border: 0 !important;
    border-bottom: 0 !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    color: var(--text-muted) !important;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif !important;
    font-size: 18px !important;
    letter-spacing: 0.02em !important;
    text-transform: none !important;
    clip-path: polygon(0 0, 100% 0, calc(100% - 10px) 100%, 10px 100%) !important;
    margin-bottom: -2px !important;
    cursor: pointer !important;
    width: auto !important;
}

.cabinet-body .history-result-tab::before,
.cabinet-body .history-result-tab::after {
    display: none;
}

.cabinet-body .history-result-tab:hover {
    color: var(--text-secondary) !important;
    background: rgba(255, 255, 255, 0.05) !important;
}

.cabinet-body .history-result-tab:focus-visible {
    color: var(--text-secondary) !important;
    outline: 2px solid var(--accent-primary);
    outline-offset: -2px;
    background: rgba(255, 255, 255, 0.07) !important;
}

.cabinet-body .history-result-tab.is-active,
.cabinet-body .history-result-tab[aria-selected="true"] {
    border-color: rgba(0, 200, 255, 0.55) !important;
    border-bottom-color: var(--bg-surface) !important;
    background: linear-gradient(180deg, rgba(18, 40, 72, 0.96), var(--bg-surface)) !important;
    color: var(--accent-bright) !important;
    font-weight: 600 !important;
}

.cabinet-body .source-tab.is-active,
.cabinet-body .source-tab.active {
    border-color: rgba(77, 175, 240, 0.72);
    background: linear-gradient(180deg, #0e4a78 0%, #083050 48%, #041c30 100%);
    color: #eef6ff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.22);
}

/* Selected protocol version — slightly lighter pure orange */
.cabinet-body .protocol-version-button.is-selected,
.cabinet-body .protocol-version-button[aria-selected="true"] {
    border-color: var(--accent-action-bright);
    background: linear-gradient(180deg, var(--accent-action) 0%, var(--accent-action) 100%);
    color: #FFF7F0;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 154, 61, 0.22);
}

.cabinet-body .protocol-version-button.is-selected .protocol-version-name,
.cabinet-body .protocol-version-button.is-selected .protocol-version-meta-line {
    color: var(--text-primary);
}


.cabinet-body .record-mode-switch.source-tabs {
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    padding: 0;
}

.cabinet-body .source-tab .source-tab-icon {
    color: #7fb8d6;
}

.cabinet-body .source-tab:hover .source-tab-icon,
.cabinet-body .source-tab:focus-visible .source-tab-icon,
.cabinet-body .source-tab.is-active .source-tab-icon,
.cabinet-body .source-tab.active .source-tab-icon {
    color: #b8e0f8;
}

.cabinet-body .cost-estimate {
    flex-direction: column;
    gap: 8px;
    padding: 14px 18px;
    border: 1px solid rgba(0, 184, 255, 0.15);
    border-left: 4px solid rgba(0, 184, 255, 0.7);
    background: linear-gradient(135deg, rgba(0, 184, 255, 0.06), var(--bg-panel, #0d1b2e));
    box-shadow: 0 0 0 1px rgba(0, 184, 255, 0.06), 0 8px 24px rgba(0, 0, 0, 0.25);
    border-radius: var(--radius-md);
    color: var(--text-primary, #e0e8f0);
}

.cabinet-body .cost-estimate:not([hidden]) {
    display: flex;
}

.cabinet-body .cost-estimate-title {
    color: var(--accent-primary);
    font-family: var(--font-display, system-ui);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.04em;
    margin-bottom: 2px;
}

.cabinet-body .cost-estimate-status {
    color: #8ab4d0;
    font-size: 15px;
    line-height: 1.5;
}

.cabinet-body .cost-estimate-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
    padding: 3px 0;
    color: var(--text-primary, #e0e8f0);
}

.cabinet-body .cost-estimate-label {
    color: var(--text-secondary, #8899aa);
    font-size: 15px;
}

.cabinet-body .cost-estimate-value {
    color: #e0e8f0;
    font-family: var(--font-mono, monospace);
    font-size: 15px;
    font-weight: 600;
}

.cabinet-body .cost-estimate-total {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    margin-top: 8px;
    padding-top: 10px;
}

.cabinet-body .cost-estimate-total .cost-estimate-label {
    color: #e0e8f0;
    font-weight: 700;
}

.cabinet-body .cost-estimate-total .cost-estimate-value {
    color: var(--accent-green);
    font-weight: 700;
}

.cabinet-body .cost-estimate-note {
    color: rgba(255, 255, 255, 0.4);
    font-size: 12px;
    line-height: 1.45;
    margin-top: 4px;
}

.cabinet-body .cost-estimate-details {
    flex-wrap: wrap;
    gap: 8px 14px;
    margin: 6px 0 0;
}

.cabinet-body .cost-estimate-details:not([hidden]) {
    display: flex;
}

.cabinet-body .cost-estimate-details div {
    display: inline-flex;
    gap: 6px;
    align-items: baseline;
    min-width: auto;
    padding: 0;
    border: 0;
    background: transparent;
}

.cabinet-body .cost-estimate-details dt {
    color: #6a8aaa;
    font-size: 14px;
}

.cabinet-body .cost-estimate-details dd {
    color: #c8d8e8;
    font-size: 15px;
}

.cabinet-body .cost-estimate-total dd {
    color: var(--accent-green);
}

.cabinet-body .more-settings-body label,
.cabinet-body .field-group > label,
.cabinet-body .toggle-row label,
.cabinet-body .record-preview-label,
.cabinet-body .history-details-label {
    color: #c4d8ea;
    font-size: 17px;
    letter-spacing: 0.01em;
    text-transform: none;
}

.cabinet-body .protocol-select-trigger {
    min-height: 48px;
    border: 1px solid var(--btn-secondary-border);
    background: var(--btn-secondary-bg);
    color: var(--btn-secondary-text);
    font-size: 15px;
    letter-spacing: 0.02em;
    text-transform: none;
    box-shadow: none;
}

.cabinet-body .protocol-select-trigger:hover,
.cabinet-body .protocol-select-trigger:focus-visible {
    border-color: var(--btn-secondary-hover-border);
    background: var(--btn-secondary-hover-bg);
    color: var(--btn-secondary-hover-text);
}

.cabinet-body .history-modal {
    width: min(440px, calc(100vw - 32px));
    max-width: calc(100vw - 32px);
}

.cabinet-body .history-modal-actions {
    justify-content: flex-end;
}

.cabinet-body .user-menu-logout:hover,
.cabinet-body .user-menu-logout:focus-visible {
    border-color: rgba(255, 83, 116, 0.72) !important;
    background: linear-gradient(180deg, rgba(143, 28, 56, 0.96), rgba(82, 15, 34, 0.98)) !important;
    color: #fff1f4 !important;
}

/* =====================================================================
   P2.11 + P2.13: Visual softening — reduced CAPS, better fonts, cleaner tabs
   ===================================================================== */

/* Reduce CAPS on action buttons to normal case */
.cabinet-body .btn:not(.brand-title):not(.section-title):not(.progress-stepper-title):not(.processing-complete-title) {
    text-transform: none;
    letter-spacing: 0.02em;
}

/* Result card content — use readable font for transcription/protocol */
.cabinet-body .result-card .content,
.cabinet-body .transcription-content,
.cabinet-body .protocol-content,
.cabinet-body .history-transcription-content,
.cabinet-body .history-protocol-content {
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    font-size: 17px;
    line-height: 1.7;
}

/* Preserve monospace for timestamps and technical values */
.cabinet-body .transcription-segments .segment-timestamp,
.cabinet-body .transcription-segment-timestamp,
.cabinet-body .history-meta-time,
.cabinet-body .record-timer {
    font-family: var(--font-mono, "PT Mono", "Cascadia Mono", "Consolas", monospace);
}

/* --- Issue 6: Stronger contrast for secondary buttons and user name --- */

.cabinet-body .btn-secondary:not(.user-menu-logout):not(.user-menu-id-link):not(.history-delete-button):not(.is-success):not(.is-copied),
.cabinet-body .secondary-button:not(.btn-danger):not(.processing-action-button):not(.is-success):not(.is-copied) {
    border: 1px solid var(--btn-secondary-border);
    background: var(--btn-secondary-bg);
    color: var(--btn-secondary-text);
}

.cabinet-body .btn-secondary:not(.user-menu-logout):not(.user-menu-id-link):not(.history-delete-button):not(.is-success):not(.is-copied):hover,
.cabinet-body .secondary-button:not(.btn-danger):not(.processing-action-button):not(.is-success):not(.is-copied):hover,
.cabinet-body .btn-secondary:not(.user-menu-logout):not(.user-menu-id-link):not(.history-delete-button):not(.is-success):not(.is-copied):focus-visible,
.cabinet-body .secondary-button:not(.btn-danger):not(.processing-action-button):not(.is-success):not(.is-copied):focus-visible {
    border-color: var(--btn-secondary-hover-border);
    background: var(--btn-secondary-hover-bg);
    color: var(--btn-secondary-hover-text);
    transform: translateY(-1px);
}

.cabinet-body .topbar-actions,
.cabinet-body .app-topbar strong,
.cabinet-body .app-topbar .user-menu-trigger {
    color: #d0e4f7;
}

/* --- Issue 7: Link input container fills the field background --- */

.cabinet-body .text-input-wrapper.input-shell {
    width: 100%;
    box-sizing: border-box;
}

.cabinet-body .text-input-wrapper.input-shell .text-input {
    width: 100%;
    box-sizing: border-box;
    padding: 12px 14px;
}

.cabinet-body .history-result-section-head {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    padding: 8px 0 8px;
    border-bottom: 0;
}

.cabinet-body .history-result-section-head .history-result-actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
}

/* Reduce excessive borders on inner containers */
.cabinet-body .result-card .content,
.cabinet-body .placeholder-card .content,
.cabinet-body .empty-state .content,
.cabinet-body .transcription-content,
.cabinet-body .protocol-content,
.cabinet-body .history-transcription-content,
.cabinet-body .history-protocol-content {
    border: 0;
    background: transparent;
    box-shadow: none;
    border-radius: 0;
}

.cabinet-body .history-result-card,
.cabinet-body .history-result-shell {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
    padding: var(--space-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: var(--gradient-card);
    box-shadow: var(--shadow-panel), inset 0 1px 0 rgba(255,177,42,0.08);
}

.cabinet-body .history-result-section {
    border-top: 0;
}

/* More breathing room for content areas */
.cabinet-body .result-card .content,
.cabinet-body .transcription-content,
.cabinet-body .protocol-content {
    padding: 20px 24px;
}

.cabinet-body .text-input:focus {
    border-color: rgba(0, 200, 255, 0.48) !important;
    background: rgba(10, 22, 40, 0.95) !important;
    box-shadow: none !important;
}

.cabinet-body .new-transcription-button {
    border-color: rgba(255, 122, 0, 0.58) !important;
    background: linear-gradient(180deg, #ff8a1f 0%, #f16a00 100%) !important;
    color: var(--text-primary) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.24), 0 8px 20px rgba(255,122,0,0.22) !important;
}
.cabinet-body .new-transcription-button:not(.is-success):not(.is-copied):hover,
.cabinet-body .new-transcription-button:not(.is-success):not(.is-copied):focus-visible {
    border-color: rgba(255, 190, 110, 0.76) !important;
    background: linear-gradient(180deg, #ff982f 0%, #ff7400 100%) !important;
}

/* Audit v2: New Processing button — subdued state (COMPLETED) */
.cabinet-body .new-transcription-button.is-subtle {
    border-color: rgba(95, 120, 145, 0.32) !important;
    background: linear-gradient(180deg, rgba(13, 37, 65, 0.7), rgba(7, 18, 34, 0.8)) !important;
    color: var(--text-secondary) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2) !important;
}
.cabinet-body .new-transcription-button.is-subtle:hover,
.cabinet-body .new-transcription-button.is-subtle:focus-visible {
    border-color: rgba(120, 145, 170, 0.42) !important;
    background: linear-gradient(180deg, rgba(20, 50, 80, 0.78), rgba(10, 25, 45, 0.88)) !important;
    color: #c8d8e8 !important;
}

/* Audit v2: New Processing button — recovery state (CANCELLED / ERROR) */
.cabinet-body .new-transcription-button.is-recovery {
    border-color: rgba(66, 166, 230, 0.52) !important;
    background: linear-gradient(180deg, rgba(16, 52, 86, 0.9), rgba(8, 27, 48, 0.95)) !important;
    color: #d0e4f7 !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.25), 0 0 12px rgba(0, 180, 255, 0.15) !important;
}
.cabinet-body .new-transcription-button.is-recovery:hover,
.cabinet-body .new-transcription-button.is-recovery:focus-visible {
    border-color: rgba(100, 190, 245, 0.68) !important;
    background: linear-gradient(180deg, rgba(25, 62, 100, 0.94), rgba(10, 35, 58, 0.98)) !important;
    color: #eaf4ff !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3), 0 0 18px rgba(0, 190, 255, 0.22) !important;
}

/* --- Issue 4: Copy button success feedback --- */
.cabinet-body .btn.is-copied,
.cabinet-body .action-button.is-copied,
.cabinet-body .btn.is-success,
.cabinet-body .action-button.is-success,
.cabinet-body .btn-primary.is-success,
.cabinet-body .btn-secondary.is-success,
.cabinet-body .secondary-button.is-success,
.cabinet-body .transcription-copy.is-success,
.cabinet-body .protocol-copy.is-success,
.cabinet-body .history-copy-button.is-success,
.cabinet-body .referral-copy-button.is-success {
    background: rgba(0, 255, 157, 0.18);
    background-color: rgba(0, 255, 157, 0.18);
    border-color: rgba(0, 255, 157, 0.55);
    color: var(--accent-green);
    transition: var(--transition-interactive);
}

.cabinet-body .new-processing-hint {
    display: block;
    color: var(--text-muted, #7e9db8);
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.45;
    margin-top: 6px;
}

/* =====================================================================
   TASK-063 post-audit: background calming (history page)
   ===================================================================== */

.cabinet-body.history-page .app-main,
.cabinet-body .history-page.app-main {
    background: linear-gradient(180deg, rgba(5, 9, 20, 0.35), rgba(6, 13, 26, 0.42));
}

.cabinet-body.history-page .history-item,
.cabinet-body .history-page .history-item {
    background: linear-gradient(180deg, rgba(10, 24, 44, 0.42), rgba(6, 14, 26, 0.6));
}

.cabinet-body.history-page .ring {
    border-color: rgba(255, 147, 24, 0.32);
}

/* =====================================================================
   TASK-063 post-audit: thin custom scrollbars on scrollable containers
   ===================================================================== */

.cabinet-body .app-sidebar,
.cabinet-body .protocol-select-list,
.cabinet-body .history-transcription-segments,
.cabinet-body .transcription-segments,
.cabinet-body .result-card.is-reading-mode,
.cabinet-body .result-card .content,
.cabinet-body .transcription-content,
.cabinet-body .protocol-content,
.cabinet-body .history-transcription-content,
.cabinet-body .history-protocol-content,
.cabinet-body .admin-hashtag-picker-dropdown,
.cabinet-body .support-modal,
.cabinet-body .history-list,
.cabinet-body .history-result-shell {
    scrollbar-width: thin;
    scrollbar-color: var(--text-muted, #7e9db8) transparent;
}

/* =====================================================================
   TASK-063 audit v2: mobile 360–430px
   Right panel full-width, version chips full-width, 44px touch targets,
   vertical onboarding, no horizontal scroll.
   ===================================================================== */

@media (max-width: 430px) {
    .cabinet-body {
        overflow-x: hidden;
    }

    .cabinet-body .app-shell {
        overflow-x: hidden;
    }

    /* Right panel full-width in all states */
    .cabinet-body .app-main {
        width: 100%;
        padding: 0 10px 24px;
    }

    .cabinet-body .result-card,
    .cabinet-body .panel,
    .cabinet-body .workspace-section {
        width: 100%;
        margin-left: 0;
        margin-right: 0;
    }

    /* Version chips — full width, wrap */
    .cabinet-body .protocol-version-button {
        flex: 0 0 auto;
        width: auto;
        max-width: 85vw;
        white-space: nowrap;
        min-height: 44px;
        padding: 8px 14px;
    }

    .cabinet-body .protocol-versions-list {
        flex-direction: row;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        gap: 8px;
    }

    .cabinet-body .protocol-version-controls {
        max-width: 100%;
        overflow: hidden;
        gap: 8px;
    }

    .cabinet-body .protocol-version-meta-line {
        flex-wrap: wrap;
    }

    .cabinet-body .protocol-version-head {
        padding: 8px 0;
        gap: 6px;
    }
    .cabinet-body .protocol-version-copy {
        gap: 4px;
    }
    .cabinet-body .protocol-version-title {
        font-size: 11px;
    }

    .cabinet-body .history-result-tab {
        min-height: 44px !important;
        padding: 10px 16px !important;
        font-size: 14px !important;
    }

    .cabinet-body .history-result-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        gap: 0;
    }
    .cabinet-body .history-result-tabs::-webkit-scrollbar {
        height: 4px;
    }
    .cabinet-body .history-result-tabs::-webkit-scrollbar-thumb {
        background: rgba(0, 200, 255, 0.4);
        border-radius: 2px;
    }

    /* Onboarding — vertical list */
    .cabinet-body .onboarding-steps {
        display: flex;
        flex-direction: column;
        gap: 14px;
    }

    .cabinet-body .onboarding-steps li {
        width: 100%;
        font-size: 10px;
        line-height: 1.5;
    }

    /* Reading zones — full width on mobile */
    .cabinet-body .transcription-content,
    .cabinet-body .protocol-content,
    .cabinet-body .history-transcription-content,
    .cabinet-body .history-protocol-content,
    .cabinet-body .result-card .content {
        font-size: 11px;
    }

    /* No horizontal scroll anywhere */
    .cabinet-body .app-sidebar,
    .cabinet-body .app-topbar,
    .cabinet-body .history-item,
    .cabinet-body .history-result-card {
        overflow-x: hidden;
        max-width: 100%;
    }

    /* History items — clean full-width */
    .cabinet-body .history-item {
        width: 100%;
        padding: 8px;
    }

    .cabinet-body .history-item-main {
        display: flex;
        flex-direction: column;
        gap: 6px;
    }
}

/* =====================================================================
   NOTE: blanket .cabinet-body [hidden] rule removed (TASK-XXX).
   Component-scoped [hidden] rules use :not([hidden]) qualifiers instead.
   ===================================================================== */

/* =====================================================================
   TASK-079: Base component classes
   ===================================================================== */

/* --- Input --- */
.cabinet-input {
    width: 100%;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    padding: 10px 15px;
    background: var(--bg-surface);
    color: var(--text-primary);
    outline: none;
    transition: var(--transition-interactive);
}

.cabinet-input:focus {
    border-color: rgba(0, 200, 255, 0.48);
    background: rgba(10, 22, 40, 0.95);
    box-shadow: none;
}

/* --- Modal Backdrop --- */
.cabinet-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: calc(var(--z-dropdown) + 1);
    background: rgba(0, 0, 0, 0.62);
    backdrop-filter: blur(8px);
}

/* --- Modal Dialog --- */
.cabinet-modal-dialog {
    position: relative;
    z-index: var(--z-base);
    width: min(420px, 100%);
    border: 1px solid var(--border-mid);
    border-radius: var(--radius-lg);
    padding: 22px;
    background: linear-gradient(180deg, rgba(13, 30, 53, 0.98), rgba(7, 17, 31, 0.98));
    box-shadow: var(--shadow-panel);
}

/* ── TASK-081 FE-4: phone touch targets ≥44px ── */
@media (max-width: 767px) {
    .cabinet-body .btn,
    .cabinet-body .nav-item,
    .cabinet-body .source-tab,
    .cabinet-body .history-result-tab,
    .cabinet-body button {
        min-height: 44px;
    }
}

@media (max-width: 767px) {
    .cabinet-body .history-actions:not([hidden]) {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        gap: 10px;
        width: 100%;
        align-items: center;
        justify-content: space-between;
    }
    .cabinet-body .history-open-button {
        flex: 0 0 auto !important;
        min-width: 0 !important;
        width: auto !important;
    }
}

/* [hidden] enforcement — must be LAST in file to override component display rules.
   Without this, component display:grid/flex/block rules (0,2,0 specificity)
   override the browser's native [hidden] rule (0,1,0 user-agent origin),
   making element.hidden = false ineffective. No !important — cascade order wins. */
.cabinet-body [hidden] { display: none; }
