/**
 * Tools4Web — единая дизайн-система (лендинг + формы + админка)
 */
:root {
    /* Midnight: тёмно-синий фон, серые блоки, ярко-белый текст, жёлтые кнопки и ссылки */
    --t4w-primary: #e8b84a;
    --t4w-primary-dark: #d4a017;
    --t4w-primary-light: #334155;
    --t4w-accent: #e8b84a;
    --t4w-link: #fde047;
    --t4w-link-hover: #fef08a;
    --t4w-text: #e2e8f0;
    --t4w-text-bright: #f8fafc;
    --t4w-placeholder: #64748b;
    --t4w-muted: #94a3b8;
    --t4w-muted-strong: #cbd5e1;
    --t4w-bg: #0f172a;
    --t4w-surface: #1e293b;
    --t4w-border: #334155;
    --t4w-radius: 8px;
    --t4w-shadow: 0 1px 3px rgba(0, 0, 0, 0.25), 0 4px 12px rgba(0, 0, 0, 0.2);
    --t4w-sidebar: #1e293b;
    --t4w-sidebar-hover: #334155;
    --t4w-sidebar-text: #cbd5e1;
    --t4w-status-ok: #22c55e;
    --t4w-status-warn: #eab308;
    --t4w-status-bad: #ef4444;
    /* Кнопки: жёлтый фон — чёрный текст; тёмный фон — белый */
    --t4w-on-primary: #0f172a;
    --t4w-on-dark: #ffffff;
    --bs-primary: #e8b84a;
    --bs-primary-rgb: 232, 184, 74;
    --bs-link-color: #fde047;
    --bs-link-hover-color: #fef08a;
    --bs-body-bg: #0f172a;
    --bs-body-color: #e2e8f0;
    /* Bootstrap: цвет тултипа = body-bg, фон = emphasis — без переопределения текст сливается с фоном */
    --bs-tooltip-bg: #334155;
    --bs-tooltip-color: #ffffff;
    --bs-tooltip-max-width: 18rem;
    --bs-tooltip-opacity: 1;
    --bs-focus-ring-color: rgba(232, 184, 74, 0.35);
    /* Единая сетка отступов админки */
    --t4w-pad-y: 1rem;
    --t4w-pad-x: 1.25rem;
    --t4w-gap-sm: 0.5rem;
    --t4w-gap-md: 0.75rem;
    --t4w-gap-lg: 1rem;
    --t4w-section-gap: 1.5rem;
    color-scheme: dark;
}

html {
    color-scheme: dark;
}

a:not(.btn):not(.btn-t4w-primary):not(.btn-t4w-outline):not(.sidebar-item):not(.nav-link):not(.landing-brand):not(.t4w-btn-block):not(.t4w-notif-action):not(.t4w-pagination__btn):not(.t4w-dropdown__item):not(.t4w-dropdown__menu-item):not(.contact-chip):not(.t4w-stat-card):not(.t4w-list__link) {
    color: var(--t4w-link);
}

a:not(.btn):not(.btn-t4w-primary):not(.btn-t4w-outline):not(.sidebar-item):not(.nav-link):not(.landing-brand):not(.t4w-btn-block):not(.t4w-notif-action):not(.t4w-pagination__btn):not(.t4w-dropdown__item):not(.t4w-dropdown__menu-item):not(.contact-chip):not(.t4w-stat-card):not(.t4w-list__link):hover {
    color: var(--t4w-link-hover);
}

/* ——— Общая типографика ——— */
body.landing-page {
    overflow-x: clip;
}

html:has(body.landing-page) {
    overflow-x: clip;
}

body.landing-page,
body.t4w-admin-body {
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: var(--t4w-text);
}

/* Админка: в панелях, формах и таблицах — белоснежный текст (не серый muted) */
body.t4w-admin-body {
    --t4w-text: #ffffff;
    --t4w-text-bright: #ffffff;
    --t4w-muted: #ffffff;
    --t4w-muted-strong: #ffffff;
    --bs-body-color: #ffffff;
    color: #ffffff;
}

/* ——— Кнопки (Bootstrap + кастом): жёлтые — чёрный текст, тёмные — белый ——— */
.btn-primary,
.btn-t4w-primary,
.btn-t4w-primary:hover,
.btn-t4w-primary:focus,
.btn-t4w-primary:active {
    background-color: var(--t4w-primary) !important;
    border-color: var(--t4w-primary) !important;
    color: var(--t4w-on-primary) !important;
    font-weight: 600;
    border-radius: 10px;
}

.btn-primary:hover,
.btn-t4w-primary:hover {
    background-color: var(--t4w-primary-dark) !important;
    border-color: var(--t4w-primary-dark) !important;
    color: var(--t4w-on-primary) !important;
}

.btn-primary i,
.btn-primary .fas,
.btn-primary .far,
.btn-t4w-primary i,
.btn-t4w-primary .fas,
.btn-t4w-primary .far {
    color: var(--t4w-on-primary) !important;
}

.btn-t4w-outline,
.btn-outline-primary,
.btn-t4w-outline:hover,
.btn-t4w-outline:focus,
.btn-outline-primary:hover {
    border: 2px solid var(--t4w-border) !important;
    color: var(--t4w-on-dark) !important;
    background: var(--t4w-surface) !important;
    font-weight: 600;
    border-radius: 10px;
}

.btn-t4w-outline:hover,
.btn-outline-primary:hover {
    border-color: var(--t4w-primary) !important;
    color: var(--t4w-on-dark) !important;
    background: var(--t4w-sidebar-hover) !important;
}

.btn-t4w-outline i,
.btn-t4w-outline .fas,
.btn-outline-primary i {
    color: var(--t4w-on-dark) !important;
}

.t4w-btn-block--primary,
.t4w-btn-block--primary:hover,
.t4w-btn-block--primary i {
    color: var(--t4w-on-primary) !important;
}

.text-primary {
    color: var(--t4w-primary) !important;
}

/* ——— Чекбоксы, радио, переключатели ——— */
.form-check-input {
    border-color: var(--t4w-border);
    background-color: var(--t4w-bg);
}

.form-check-input:checked,
.form-check-input[type="checkbox"]:checked,
.form-check-input[type="radio"]:checked {
    background-color: var(--t4w-primary) !important;
    border-color: var(--t4w-primary) !important;
}

.form-check-input:focus {
    border-color: var(--t4w-primary);
    box-shadow: 0 0 0 0.25rem var(--bs-focus-ring-color);
}

.form-check-input:active {
    filter: none;
    background-color: var(--t4w-primary-dark);
    border-color: var(--t4w-primary-dark);
}

.form-switch .form-check-input:checked {
    background-color: var(--t4w-primary) !important;
    border-color: var(--t4w-primary) !important;
    --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%230f172a'/%3e%3c/svg%3e");
}

.form-check-label {
    color: var(--t4w-text);
}

input[type="checkbox"]:not(.form-check-input),
input[type="radio"]:not(.form-check-input) {
    accent-color: var(--t4w-primary);
}

.form-range::-webkit-slider-thumb {
    background-color: var(--t4w-primary);
}

.form-range::-moz-range-thumb {
    background-color: var(--t4w-primary);
}

.form-range:focus::-webkit-slider-thumb {
    box-shadow: 0 0 0 1px var(--t4w-bg), 0 0 0 0.25rem var(--bs-focus-ring-color);
}

/* ——— Карусель ——— */
.t4w-carousel {
    position: relative;
}

.t4w-carousel__viewport {
    overflow: hidden;
    width: 100%;
    border-radius: var(--t4w-radius);
    isolation: isolate;
}

.t4w-carousel__track {
    display: flex;
    flex-wrap: nowrap;
    gap: 0;
    transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

.t4w-carousel--center .t4w-carousel__track,
.t4w-carousel--center .t4w-carousel__track--center {
    gap: var(--carousel-gap, 1rem);
}

.t4w-carousel__page {
    flex: 0 0 100%;
    width: 100%;
    min-width: 100%;
    box-sizing: border-box;
    display: grid;
    gap: 1rem;
    align-items: stretch;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.t4w-carousel__page[data-cols="2"] {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.t4w-carousel__page[data-cols="1"] {
    grid-template-columns: minmax(0, 1fr);
}

@media (max-width: 991.98px) {
    .t4w-carousel__page {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .t4w-carousel__page[data-cols="1"] {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 767.98px) {
    .t4w-carousel__page {
        grid-template-columns: minmax(0, 1fr);
    }
}

.t4w-carousel__slide {
    min-width: 0;
    box-sizing: border-box;
    display: flex;
    align-items: stretch;
}

.t4w-carousel__slide .monitor-type-card {
    flex: 1;
    width: 100%;
    min-height: 10.5rem;
}

.t4w-carousel__controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-top: 1.25rem;
}

.t4w-carousel__btn {
    width: 2.5rem;
    height: 2.5rem;
    border: 1px solid var(--t4w-border);
    border-radius: 10px;
    background: var(--t4w-surface);
    color: var(--t4w-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: border-color 0.2s, color 0.2s, background 0.2s;
}

.t4w-carousel__btn:hover:not(:disabled) {
    border-color: #d4d4d8;
    color: var(--t4w-text);
    background: var(--t4w-primary-light);
}

.t4w-carousel__btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.t4w-carousel__dots {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
    justify-content: center;
    min-height: 2.5rem;
}

.t4w-carousel__dot {
    width: 8px;
    height: 8px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: #cbd5e1;
    cursor: pointer;
    transition: transform 0.2s, background 0.2s;
}

.t4w-carousel__dot.is-active {
    background: var(--t4w-primary);
    transform: scale(1.2);
}

.t4w-carousel__dot:hover:not(.is-active) {
    background: #94a3b8;
}

/* ——— Админка ——— */
body.t4w-admin-body {
    background: var(--t4w-bg) !important;
}

.t4w-admin-shell {
    display: flex;
    min-height: 100vh;
    width: 100%;
    background: var(--t4w-bg) !important;
}

.t4w-admin-sidebar-col {
    display: none;
    width: 16rem;
    flex: 0 0 16rem;
}

@media (min-width: 1024px) {
    .t4w-admin-sidebar-col {
        display: block;
    }
}

.t4w-admin-main-col {
    display: flex;
    flex: 1 1 0%;
    flex-direction: column;
    min-width: 0;
    width: 100%;
}

.t4w-admin-header {
    position: sticky;
    top: 0;
    z-index: 30;
    flex-shrink: 0;
    width: 100%;
    background: color-mix(in srgb, var(--t4w-surface) 96%, transparent) !important;
    border-bottom: 1px solid var(--t4w-border) !important;
    backdrop-filter: blur(12px);
}

.t4w-admin-header__bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    height: 4rem;
    padding: 0 1.5rem;
    box-sizing: border-box;
}

.t4w-admin-header__start {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
    flex: 1 1 auto;
}

.t4w-admin-header__actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-shrink: 0;
    margin-left: auto;
}

.t4w-admin-header__actions > .relative {
    position: relative;
}

.t4w-admin-body .sidebar-glass,
.t4w-admin-body aside .sidebar-glass,
.t4w-admin-body .mobile-sidebar > div {
    background: var(--t4w-sidebar) !important;
    backdrop-filter: none !important;
    border-right: 1px solid var(--t4w-border) !important;
    box-shadow: none !important;
}

.t4w-admin-body .sidebar-glass .border-gray-200,
.t4w-admin-body .sidebar-glass .border-b,
.t4w-admin-body .mobile-sidebar .border-b {
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body .sidebar-glass .text-gray-900,
.t4w-admin-body .mobile-sidebar .text-gray-900 {
    color: var(--t4w-text) !important;
}

.t4w-admin-body .sidebar-glass .text-gray-700,
.t4w-admin-body .sidebar-glass .text-gray-600,
.t4w-admin-body .sidebar-glass .text-gray-500,
.t4w-admin-body .mobile-sidebar .text-gray-700,
.t4w-admin-body .mobile-sidebar .text-gray-600 {
    color: var(--t4w-sidebar-text) !important;
}

.t4w-admin-body .sidebar-item {
    color: var(--t4w-sidebar-text) !important;
    border-radius: 10px !important;
    transform: none !important;
}

.t4w-admin-body .sidebar-item:hover {
    background: var(--t4w-sidebar-hover) !important;
    color: #fff !important;
    transform: none !important;
}

.t4w-admin-body .sidebar-item.active {
    background: var(--t4w-primary) !important;
    color: var(--t4w-on-primary) !important;
    box-shadow: none;
}

.t4w-admin-body .sidebar-item.active i {
    color: var(--t4w-on-primary) !important;
}

.t4w-admin-body .section-header {
    color: var(--t4w-muted) !important;
}

.t4w-admin-body .section-header:hover {
    color: var(--t4w-muted-strong) !important;
}

.t4w-admin-body header.bg-white,
.t4w-admin-body .sticky.top-0 {
    background: color-mix(in srgb, var(--t4w-surface) 96%, transparent) !important;
    border-bottom: 1px solid var(--t4w-border) !important;
    backdrop-filter: blur(12px);
}

.t4w-admin-body .text-gray-900,
.t4w-admin-body .text-gray-800,
.t4w-admin-body h1.text-gray-800,
.t4w-admin-body .text-slate-900 {
    color: var(--t4w-text) !important;
}

.t4w-admin-body .text-gray-700,
.t4w-admin-body .text-slate-700 {
    color: var(--t4w-muted-strong) !important;
}

.t4w-admin-body .text-gray-600,
.t4w-admin-body .text-gray-500,
.t4w-admin-body .text-slate-600,
.t4w-admin-body .text-slate-500 {
    color: var(--t4w-muted) !important;
}

.t4w-admin-body .text-gray-400,
.t4w-admin-body .text-slate-400 {
    color: var(--t4w-placeholder) !important;
}

.t4w-admin-body .hover\:text-gray-700:hover,
.t4w-admin-body .hover\:text-blue-600:hover {
    color: var(--t4w-link) !important;
}

.t4w-admin-body .bg-gray-50,
.t4w-admin-body .bg-gray-100,
.t4w-admin-body .bg-slate-50,
.t4w-admin-body .bg-slate-100 {
    background-color: var(--t4w-primary-light) !important;
}

.t4w-admin-body .border-gray-200,
.t4w-admin-body .border-gray-300,
.t4w-admin-body .divide-gray-200 > :not([hidden]) ~ :not([hidden]) {
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body input[type="text"],
.t4w-admin-body input[type="email"],
.t4w-admin-body input[type="password"],
.t4w-admin-body input[type="number"],
.t4w-admin-body input[type="url"],
.t4w-admin-body input[type="tel"],
.t4w-admin-body input[type="search"],
.t4w-admin-body select,
.t4w-admin-body textarea {
    background-color: var(--t4w-bg) !important;
    color: var(--t4w-text) !important;
}

.t4w-admin-body input:focus,
.t4w-admin-body select:focus,
.t4w-admin-body textarea:focus {
    box-shadow: 0 0 0 0.2rem rgba(232, 184, 74, 0.35) !important;
}

.t4w-admin-body table thead {
    background-color: var(--t4w-primary-light) !important;
}

/* см. блок «Ховер блоков» ниже — таблицы только обводка */

.t4w-admin-body .modal-content {
    background: var(--t4w-surface) !important;
    color: var(--t4w-text) !important;
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body .modal-header,
.t4w-admin-body .modal-footer {
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body .dropdown-menu {
    background: var(--t4w-surface) !important;
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body .dropdown-item {
    color: var(--t4w-text) !important;
}

.t4w-admin-body .dropdown-item:hover {
    background: var(--t4w-sidebar-hover) !important;
    color: var(--t4w-text) !important;
}

.t4w-admin-body .bg-white,
.t4w-admin-body .bg-white.rounded-lg,
.t4w-admin-body .bg-white.rounded-xl,
.t4w-admin-body tbody.bg-white,
.t4w-admin-body .glass-card {
    background: var(--t4w-surface) !important;
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body .bg-white.rounded-lg,
.t4w-admin-body .bg-white.rounded-xl,
.t4w-admin-body .glass-card {
    border: 1px solid var(--t4w-border) !important;
    border-radius: var(--t4w-radius) !important;
    box-shadow: var(--t4w-shadow) !important;
    backdrop-filter: none !important;
}

.t4w-admin-body table thead.bg-gray-50,
.t4w-admin-body .bg-gray-50 {
    background-color: color-mix(in srgb, var(--t4w-bg) 45%, var(--t4w-surface)) !important;
}

.t4w-admin-body table tbody,
.t4w-admin-body table tbody.bg-white {
    background-color: transparent !important;
}

/* ——— Сайдбар админки ——— */
.t4w-sidebar-brand {
    min-height: 4.5rem;
    height: auto !important;
    overflow: visible;
    align-items: center !important;
}

.t4w-sidebar-user-card {
    padding: 0.75rem !important;
}

/* Sidebar user card (compact) */
.t4w-suc {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.t4w-suc__head {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    padding-bottom: 0.625rem;
    margin-bottom: 0.125rem;
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-suc__name {
    margin: 0;
    min-width: 0;
    flex: 1;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.25;
    color: var(--t4w-text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.t4w-suc__toggle {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--t4w-muted);
    cursor: pointer;
    transition: color 0.15s, background 0.15s, transform 0.2s;
}

.t4w-suc__toggle:hover {
    color: var(--t4w-text);
    background: color-mix(in srgb, var(--t4w-border) 55%, transparent);
}

.t4w-suc__toggle i {
    font-size: 0.7rem;
    transition: transform 0.2s ease;
}

.t4w-suc--collapsed .t4w-suc__toggle i {
    transform: rotate(-180deg);
}

.t4w-suc--collapsed .t4w-suc__head {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 0;
}

.t4w-suc__body {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.t4w-suc--collapsed .t4w-suc__body {
    display: none;
}

.t4w-suc__field {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    width: 100%;
}

.t4w-suc__field-label {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--t4w-muted);
    line-height: 1.25;
}

.t4w-suc__field-value {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--t4w-text);
    word-break: break-word;
}

.t4w-suc__field-value--link {
    text-decoration: none;
}

.t4w-suc__field-value--link:hover {
    color: var(--t4w-link);
}

.t4w-suc__field-value--balance {
    color: var(--t4w-primary);
}

.t4w-suc__field--tariff {
    margin-top: 0.25rem;
    padding-top: 0.625rem;
    border-top: 1px solid var(--t4w-border);
}

.t4w-suc__field-hint {
    font-size: 0.75rem;
    color: var(--t4w-muted);
    line-height: 1.25;
}

.t4w-suc__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: 100%;
    padding: 0.5rem 0.65rem;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1.2;
    color: var(--t4w-link);
    text-decoration: none;
    border-radius: 7px;
    border: 1px solid color-mix(in srgb, var(--t4w-primary) 35%, var(--t4w-border));
    background: transparent;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
}

.t4w-suc__btn:hover {
    color: var(--t4w-link-hover);
    border-color: var(--t4w-primary);
    background: color-mix(in srgb, var(--t4w-primary) 10%, transparent);
}

.t4w-suc__btn--warn {
    color: var(--t4w-primary);
    border: 2px solid var(--t4w-status-warn);
}

.t4w-suc__btn--warn:hover {
    background: color-mix(in srgb, var(--t4w-status-warn) 12%, transparent);
    border-color: var(--t4w-primary);
}

.t4w-suc__btn i {
    font-size: 0.65rem;
}

.t4w-suc__btn--muted {
    color: var(--t4w-muted);
    border-color: var(--t4w-border);
}

.t4w-suc__btn--muted:hover {
    color: var(--t4w-status-warn);
    border-color: color-mix(in srgb, var(--t4w-status-warn) 40%, var(--t4w-border));
}

/* Auth: подтверждение телефона — компактные кнопки по содержимому */
.t4w-phone-auth-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.t4w-phone-auth-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: auto;
    flex: 0 0 auto;
    min-height: 2rem;
    padding: 0.35rem 0.75rem !important;
    font-size: 0.8125rem !important;
    line-height: 1.2 !important;
    border-radius: 8px !important;
    white-space: nowrap;
}

.t4w-phone-auth-btn i {
    font-size: 0.75rem;
    flex-shrink: 0;
}

.t4w-panel--quick-actions {
    border: 2px solid var(--t4w-status-warn);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-status-warn) 25%, transparent);
}

.t4w-panel--quick-actions .t4w-panel__head {
    border-bottom-color: color-mix(in srgb, var(--t4w-status-warn) 35%, var(--t4w-border));
}


.t4w-sidebar-nav .sidebar-item {
    display: flex !important;
    align-items: center !important;
    padding: 0.5rem 0.75rem !important;
    margin-bottom: 0.15rem;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    line-height: 1.3 !important;
}

.t4w-sidebar-nav .sidebar-item i {
    width: 1.15rem !important;
    margin-right: 0.65rem !important;
    text-align: center;
    flex-shrink: 0;
}

.t4w-sidebar-nav .sidebar-item {
    width: 100%;
}

.t4w-sidebar-badge {
    margin-left: auto;
    background: var(--t4w-status-bad);
    color: #fff;
    font-size: 0.6875rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.2rem 0.45rem;
    border-radius: 999px;
    min-width: 1.25rem;
    text-align: center;
}

.t4w-sidebar-drawer__scroll {
    -webkit-overflow-scrolling: touch;
}

.t4w-sidebar-nav .space-y-1 > * + * {
    margin-top: 0.15rem !important;
}

.t4w-sidebar-nav .mb-6 {
    margin-bottom: 1rem !important;
}

.t4w-sidebar-nav .section-header {
    margin-bottom: 0.5rem !important;
    padding-left: 0.5rem !important;
}

.t4w-sidebar-nav .section-divider {
    margin: 0.75rem 0 !important;
}

.t4w-sidebar-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--t4w-muted);
    cursor: pointer;
}

.t4w-sidebar-close:hover {
    background: var(--t4w-sidebar-hover);
    color: #fff;
}

.t4w-probe-cards {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 0.75rem;
}

.t4w-probe-card {
    background: var(--t4w-bg);
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    overflow: hidden;
}

.t4w-probe-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1rem;
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-probe-card__name {
    margin: 0;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-probe-card__region {
    margin: 0.2rem 0 0;
    font-size: 0.75rem;
    color: var(--t4w-muted-strong);
}

.t4w-probe-card__body {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.t4w-probe-card__foot {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.75rem 1rem 1rem;
    border-top: 1px solid var(--t4w-border);
}

.t4w-form-panel {
    max-width: 40rem;
}

/* Карточки сайтов в списке */
.t4w-site-cards-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 640px) {
    .t4w-site-cards-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1280px) {
    .t4w-site-cards-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.t4w-site-card {
    background: var(--t4w-surface);
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    box-shadow: var(--t4w-shadow);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
}

/* hover: см. «Ховер блоков» */

.t4w-site-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1rem;
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-site-card__identity {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    min-width: 0;
    flex: 1;
}

.t4w-site-card__icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 8px;
    background: color-mix(in srgb, var(--t4w-primary) 18%, var(--t4w-bg));
    color: var(--t4w-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.t4w-site-card__titles {
    min-width: 0;
}

.t4w-site-card__name {
    margin: 0 0 0.2rem;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--t4w-text);
    word-break: break-word;
}

.t4w-site-card__url {
    font-size: 0.75rem;
    color: var(--t4w-link);
    word-break: break-all;
    text-decoration: none;
}

.t4w-site-card__url:hover {
    color: var(--t4w-link-hover);
    text-decoration: underline;
}

.t4w-site-card__body {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    flex: 1;
}

.t4w-site-card__foot {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.75rem 1rem 1rem;
    border-top: 1px solid var(--t4w-border);
}

.t4w-site-card__foot .btn {
    flex: 1 1 calc(50% - 0.25rem);
    justify-content: center;
}

.t4w-metric-pills {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem;
}

@media (min-width: 480px) {
    .t4w-metric-pills {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.t4w-metric-pill {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.5rem;
    font-size: 0.6875rem;
    font-weight: 500;
    line-height: 1.2;
    border-radius: 6px;
    border: 1px solid var(--t4w-border);
    background: var(--t4w-bg);
    color: var(--t4w-muted);
    min-width: 0;
}

.t4w-metric-pill span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.t4w-metric-pill i {
    flex-shrink: 0;
    opacity: 0.85;
}

.t4w-metric-pill--ok {
    border-color: color-mix(in srgb, var(--t4w-status-ok) 35%, var(--t4w-border));
    color: var(--t4w-status-ok);
    background: color-mix(in srgb, var(--t4w-status-ok) 10%, var(--t4w-bg));
}

.t4w-metric-pill--warn {
    border-color: color-mix(in srgb, var(--t4w-status-warn) 35%, var(--t4w-border));
    color: var(--t4w-status-warn);
    background: color-mix(in srgb, var(--t4w-status-warn) 10%, var(--t4w-bg));
}

.t4w-metric-pill--bad {
    border-color: color-mix(in srgb, var(--t4w-status-bad) 35%, var(--t4w-border));
    color: var(--t4w-status-bad);
    background: color-mix(in srgb, var(--t4w-status-bad) 10%, var(--t4w-bg));
}

.t4w-metric-pill--neutral {
    color: var(--t4w-muted);
}

.t4w-stat-card--filter .t4w-stat-card__body {
    padding: 1.25rem;
    cursor: pointer;
}

.t4w-admin-page .form-label {
    color: #ffffff;
    font-size: 0.875rem;
    font-weight: 500;
    margin-bottom: 0.35rem;
}

.t4w-admin-page .form-text {
    color: #ffffff;
    font-size: 0.75rem;
    margin-top: 0.25rem;
}

.t4w-check-row {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
    margin: 0;
}

.t4w-check-row .form-check-input {
    margin-top: 0.2rem;
    flex-shrink: 0;
    accent-color: var(--t4w-primary);
}

.t4w-check-row__text {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 0;
}

.t4w-check-row__title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-check-row__desc {
    font-size: 0.8125rem;
    line-height: 1.45;
    color: var(--t4w-muted);
}

/* Карточки выбора (виджеты дашборда, макет) */
.t4w-choice-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
}

@media (min-width: 768px) {
    .t4w-choice-grid--2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

.t4w-choice-card {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin: 0;
    padding: 1rem;
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    background: var(--t4w-bg);
    cursor: pointer;
    transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

/* hover: см. «Ховер блоков» */

.t4w-choice-card:has(.form-check-input:checked) {
    border-color: var(--t4w-primary);
    background: color-mix(in srgb, var(--t4w-primary) 14%, var(--t4w-bg));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-primary) 28%, transparent);
}

.t4w-choice-card .form-check-input {
    margin-top: 0.2rem;
    flex-shrink: 0;
    accent-color: var(--t4w-primary);
}

.t4w-choice-card__icon {
    flex-shrink: 0;
    width: 1.25rem;
    text-align: center;
    color: var(--t4w-primary);
    margin-top: 0.15rem;
}

.t4w-choice-card__text {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
}

.t4w-choice-card__title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-choice-card__desc {
    font-size: 0.75rem;
    color: var(--t4w-muted);
    line-height: 1.4;
}

.t4w-panel--warn .t4w-check-row__title,
.t4w-panel--warn .t4w-check-row__desc,
.t4w-panel--info p {
    color: #fff;
}

.t4w-panel--warn .t4w-check-row__desc {
    color: var(--t4w-muted);
}

.t4w-admin-body .t4w-admin-main .t4w-alert {
    margin-bottom: 0.75rem;
}

.t4w-admin-body .bg-blue-600,
.t4w-admin-body .bg-blue-500,
.t4w-admin-body .bg-indigo-600,
.t4w-admin-body .bg-green-600,
.t4w-admin-body .bg-teal-600,
.t4w-admin-body button.bg-blue-600,
.t4w-admin-body a.bg-blue-600,
.t4w-admin-body button.bg-blue-500,
.t4w-admin-body a.bg-blue-500,
.t4w-admin-body button.bg-green-600,
.t4w-admin-body a.bg-green-600 {
    background-color: var(--t4w-primary) !important;
    color: var(--t4w-on-primary) !important;
}

.t4w-admin-body .bg-blue-600 i,
.t4w-admin-body .bg-blue-500 i,
.t4w-admin-body .bg-green-600 i,
.t4w-admin-body .bg-teal-600 i,
.t4w-admin-body .bg-indigo-600 i,
.t4w-admin-body a.bg-blue-600 i,
.t4w-admin-body button.bg-blue-600 i {
    color: var(--t4w-on-primary) !important;
}

.t4w-admin-body .hover\:bg-blue-700:hover,
.t4w-admin-body .hover\:bg-blue-600:hover,
.t4w-admin-body .hover\:bg-indigo-700:hover,
.t4w-admin-body .hover\:bg-green-700:hover {
    background-color: var(--t4w-primary-dark) !important;
    color: var(--t4w-on-primary) !important;
}

.t4w-admin-body .text-blue-600,
.t4w-admin-body .text-indigo-600,
.t4w-admin-body a.text-blue-600 {
    color: var(--t4w-primary) !important;
}

.t4w-admin-body .bg-blue-50,
.t4w-admin-body .bg-blue-100,
.t4w-admin-body .bg-indigo-50 {
    background-color: var(--t4w-primary-light) !important;
}

.t4w-admin-body .border-blue-200,
.t4w-admin-body .border-blue-500,
.t4w-admin-body .border-indigo-100 {
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body .text-blue-600,
.t4w-admin-body .text-indigo-600,
.t4w-admin-body .text-purple-600,
.t4w-admin-body .text-teal-600,
.t4w-admin-body .text-violet-600 {
    color: var(--t4w-muted-strong) !important;
}

.t4w-admin-body .bg-purple-50,
.t4w-admin-body .bg-purple-100,
.t4w-admin-body .border-purple-500 {
    background-color: var(--t4w-primary-light) !important;
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body .text-purple-800,
.t4w-admin-body .text-purple-700 {
    color: var(--t4w-muted-strong) !important;
}

.t4w-admin-body a.bg-gradient-to-r,
.t4w-admin-body button.bg-gradient-to-r,
.t4w-admin-body .bg-gradient-to-br.from-teal-600,
.t4w-admin-body .bg-gradient-to-br[class*="from-teal"],
.t4w-admin-body .bg-gradient-to-br[class*="from-green"],
.t4w-admin-body .bg-gradient-to-br[class*="from-amber"]:not(.from-amber-50),
.t4w-admin-body .bg-gradient-to-r[class*="from-green"],
.t4w-admin-body .bg-gradient-to-r[class*="from-teal"] {
    background-image: none !important;
    background-color: var(--t4w-primary) !important;
    color: var(--t4w-on-primary) !important;
}

/* Тёмные кнопки в админке — белый текст */
.t4w-admin-body .bg-red-600,
.t4w-admin-body .bg-red-500,
.t4w-admin-body .bg-gray-500,
.t4w-admin-body .bg-gray-600,
.t4w-admin-body .bg-gray-700,
.t4w-admin-body .bg-gray-800,
.t4w-admin-body .bg-gray-900,
.t4w-admin-body .bg-black,
.t4w-admin-body .bg-slate-600,
.t4w-admin-body .bg-slate-700,
.t4w-admin-body .bg-slate-800,
.t4w-admin-body button.bg-red-600,
.t4w-admin-body button.bg-red-500,
.t4w-admin-body a.bg-red-600,
.t4w-admin-body .hover\:bg-red-600:hover,
.t4w-admin-body .hover\:bg-red-700:hover,
.t4w-admin-body .hover\:bg-gray-600:hover,
.t4w-admin-body .hover\:bg-gray-700:hover {
    color: var(--t4w-on-dark) !important;
}

.t4w-admin-body .bg-red-600 i,
.t4w-admin-body .bg-red-500 i,
.t4w-admin-body .bg-gray-500 i,
.t4w-admin-body .bg-gray-600 i,
.t4w-admin-body button.bg-red-600 i {
    color: var(--t4w-on-dark) !important;
}

.t4w-admin-body .from-amber-50,
.t4w-admin-body .from-indigo-50 {
    background: var(--t4w-primary-light) !important;
    border-color: #bfdbfe !important;
}

.t4w-avatar {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background: var(--t4w-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #0f172a;
    font-size: 0.875rem;
    font-weight: 600;
    flex-shrink: 0;
}

.t4w-admin-body input[type="text"],
.t4w-admin-body input[type="email"],
.t4w-admin-body input[type="password"],
.t4w-admin-body input[type="number"],
.t4w-admin-body input[type="url"],
.t4w-admin-body input[type="tel"],
.t4w-admin-body input[type="search"],
.t4w-admin-body select,
.t4w-admin-body textarea {
    border-radius: 10px !important;
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body input:focus,
.t4w-admin-body select:focus,
.t4w-admin-body textarea:focus {
    border-color: var(--t4w-primary) !important;
    box-shadow: 0 0 0 0.2rem rgba(24, 24, 27, 0.08) !important;
    outline: none;
}

.t4w-admin-body .rounded-lg,
.t4w-admin-body .rounded-xl {
    border-radius: var(--t4w-radius) !important;
}

.t4w-admin-body .gradient-bg,
.t4w-admin-body .gradient-bg-alt,
.t4w-admin-body .gradient-bg-success,
.t4w-admin-body .gradient-bg-warning,
.t4w-admin-body .gradient-bg-danger {
    background: var(--t4w-primary) !important;
}

.t4w-admin-main {
    background: transparent;
}

@media (max-width: 767.98px) {
    .t4w-admin-main {
        padding: 1rem !important;
    }
}

/* Логотип (лендинг + админка) — щит, beta на шнурке, Tools4Web с золотой «4» */
.landing-brand,
.landing-brand.navbar-brand,
.t4w-admin-body .landing-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-weight: 700;
    font-size: 1.25rem;
    color: #ffffff !important;
    text-decoration: none;
}

.landing-brand__text,
.t4w-admin-body .landing-brand__text {
    color: #ffffff;
}

.landing-brand__text span,
.t4w-admin-body .landing-brand__text span {
    color: var(--t4w-primary) !important;
}

.landing-brand__icon,
.t4w-admin-body .landing-brand__icon {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 1.65rem;
    height: 1.65rem;
}

.landing-brand__icon > i,
.t4w-admin-body .landing-brand__icon > i {
    font-size: 1.35rem;
    color: var(--t4w-primary);
    line-height: 1;
}

.landing-brand__text-wrap,
.t4w-admin-body .landing-brand__text-wrap {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.1;
    padding-top: 1.35rem;
}

.landing-brand__hanger,
.t4w-admin-body .landing-brand__hanger {
    position: absolute;
    top: 0;
    left: 0.85rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    transform-origin: top center;
    animation: landing-beta-swing 4.5s ease-in-out infinite;
    pointer-events: none;
}

.landing-brand__cord,
.t4w-admin-body .landing-brand__cord {
    display: block;
    width: 1px;
    height: 0.65rem;
    background: linear-gradient(180deg, color-mix(in srgb, var(--t4w-muted) 30%, transparent), var(--t4w-muted-strong));
}

.landing-brand__pin,
.t4w-admin-body .landing-brand__pin {
    display: block;
    width: 5px;
    height: 5px;
    margin-top: -1px;
    border-radius: 50%;
    background: var(--t4w-muted-strong);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}

.landing-brand__beta,
.t4w-admin-body .landing-brand__beta {
    margin-top: 2px;
    padding: 0.14rem 0.4rem;
    font-size: 0.5rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #0f172a;
    background: var(--t4w-primary);
    border-radius: 3px;
    box-shadow:
        0 2px 6px rgba(0, 0, 0, 0.35),
        inset 0 1px 0 rgba(255, 255, 255, 0.35);
    transform: rotate(-6deg);
}

@keyframes landing-beta-swing {
    0%,
    100% {
        transform: rotate(-4deg);
    }
    50% {
        transform: rotate(5deg);
    }
}

/* ——— Алерты (лендинг + формы + админка) ——— */
.t4w-alert,
body.landing-page .alert,
body.t4w-admin-body .alert {
    border-radius: var(--t4w-radius);
    font-size: 0.875rem;
    border-width: 1px;
    padding: 0.75rem 2.75rem 0.75rem 1rem;
}

.t4w-alert.alert-dismissible,
.alert.t4w-alert.alert-dismissible {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    min-height: 2.75rem;
}

.t4w-alert,
.alert.t4w-alert {
    background: var(--t4w-surface) !important;
    border-color: var(--t4w-border) !important;
    color: var(--t4w-text) !important;
}

.t4w-alert__text {
    color: inherit;
    flex: 1;
    min-width: 0;
}

.t4w-alert--success,
.alert.t4w-alert--success,
body.landing-page .alert-success,
body.t4w-admin-body .alert-success {
    background: color-mix(in srgb, var(--t4w-status-ok) 14%, var(--t4w-surface)) !important;
    border-color: var(--t4w-status-ok) !important;
    color: var(--t4w-text) !important;
}

.t4w-alert--success > i,
.t4w-alert--success .fas,
body.landing-page .alert-success > i {
    color: var(--t4w-status-ok) !important;
}

.t4w-alert--danger,
.alert.t4w-alert--danger,
body.landing-page .alert-danger,
body.t4w-admin-body .alert-danger {
    background: color-mix(in srgb, var(--t4w-status-bad) 16%, var(--t4w-surface)) !important;
    border-color: var(--t4w-status-bad) !important;
    color: var(--t4w-text) !important;
}

.t4w-alert--danger > i,
.t4w-alert--danger .fas,
body.landing-page .alert-danger > i {
    color: var(--t4w-status-bad) !important;
}

.t4w-alert--warning,
.alert.t4w-alert--warning,
body.landing-page .alert-warning,
body.t4w-admin-body .alert-warning {
    background: color-mix(in srgb, var(--t4w-status-warn) 16%, var(--t4w-surface)) !important;
    border-color: var(--t4w-status-warn) !important;
    color: var(--t4w-text) !important;
}

.t4w-alert--warning > i,
.t4w-alert--warning .fas {
    color: var(--t4w-status-warn) !important;
}

.t4w-alert--info,
.alert.t4w-alert--info,
body.landing-page .alert-info,
body.t4w-admin-body .alert-info {
    background: color-mix(in srgb, var(--t4w-primary) 14%, var(--t4w-surface)) !important;
    border-color: var(--t4w-primary) !important;
    color: #ffffff !important;
}

body.t4w-admin-body .alert-info p,
body.t4w-admin-body .alert-info li,
body.t4w-admin-body .alert-info code,
body.t4w-admin-body .alert-warning,
body.t4w-admin-body .alert-warning p,
body.t4w-admin-body .alert-success,
body.t4w-admin-body .alert-success p,
body.t4w-admin-body .alert-danger,
body.t4w-admin-body .alert-danger p {
    color: #ffffff !important;
}

.t4w-alert--info > i,
.t4w-alert--info .fas {
    color: var(--t4w-primary) !important;
}

.t4w-alert .btn-close,
.alert.t4w-alert .btn-close {
    position: absolute;
    top: 50%;
    right: 0.65rem;
    margin: 0;
    padding: 0.35rem;
    transform: translateY(-50%);
    filter: brightness(0) invert(1);
    opacity: 0.65;
    z-index: 2;
    cursor: pointer;
    pointer-events: auto;
}

.t4w-alert .btn-close:hover,
.alert.t4w-alert .btn-close:hover {
    transform: translateY(-50%);
    opacity: 1;
}

/* ——— Дашборд и панели админки ——— */
.t4w-panel {
    background: var(--t4w-surface);
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    box-shadow: var(--t4w-shadow);
    overflow: hidden;
}

.t4w-panel--accent {
    background: var(--t4w-primary);
    border-color: var(--t4w-primary-dark);
    color: #fff;
}

.t4w-panel__eyebrow {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    opacity: 0.85;
    margin: 0;
}

.t4w-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--t4w-gap-lg);
    padding: var(--t4w-pad-y) var(--t4w-pad-x);
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-panel__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-panel__body {
    padding: var(--t4w-pad-y) var(--t4w-pad-x);
}

.t4w-text-bright {
    color: var(--t4w-text-bright) !important;
}

/* Панели без __body: fallback-отступы (stat-card/onboarding — свои) */
.t4w-admin-page .t4w-dash-stats .t4w-panel:not(:has(.t4w-panel__body)):not(.t4w-onboarding-card) {
    padding: 0;
}

.t4w-admin-page .t4w-panel:not(:has(.t4w-panel__body)):not(:has(.t4w-stat-card__body)):not(.t4w-stat-card):not(.t4w-onboarding-card):not(.t4w-monitoring-card):not(.t4w-notif-grid__empty):not(.t4w-page-head-panel):not(.t4w-channel-hint):not([class*=" p-"]):not([class^="p-"]) {
    padding: 1rem 1.25rem;
}

.t4w-admin-page .t4w-panel:has(> .t4w-panel__head):not(:has(.t4w-panel__body)) {
    padding: 0;
}

.t4w-admin-page .t4w-panel:has(> .t4w-panel__head):not(:has(.t4w-panel__body)) > :not(.t4w-panel__head) {
    padding: 1rem 1.25rem;
}

.t4w-stat-card {
    display: block;
    text-decoration: none;
    color: inherit;
    transition: border-color 0.2s, box-shadow 0.2s;
}

/* hover: см. «Ховер блоков» */

.t4w-stat-card__body {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--t4w-gap-lg);
    padding: var(--t4w-pad-y) var(--t4w-pad-x);
}

/* Чекбокс + подпись в форме: не использовать space-between карточки статистики */
.t4w-stat-card__body:has(> input[type="checkbox"]),
.t4w-stat-card__body:has(> .form-check-input) {
    justify-content: flex-start;
    align-items: center;
    gap: 0.5rem;
    padding: 0;
}

.t4w-stat-card__body:has(> input[type="checkbox"]) > label,
.t4w-stat-card__body:has(> .form-check-input) > label {
    display: inline;
    margin: 0;
}

.t4w-stat-card__label {
    margin: 0 0 0.25rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--t4w-muted-strong);
}

body.t4w-admin-body .t4w-stat-card__label,
body.t4w-admin-body .t4w-stat-card__meta,
body.t4w-admin-body .t4w-stat-card__value,
body.t4w-admin-body .t4w-panel__title,
body.t4w-admin-body .t4w-panel__eyebrow,
body.t4w-admin-body .t4w-page-head__sub,
body.t4w-admin-body .t4w-empty,
body.t4w-admin-body .t4w-empty__title,
body.t4w-admin-body .t4w-check-row__desc,
body.t4w-admin-body .t4w-panel code,
body.t4w-admin-body .t4w-channel-hint code {
    color: #ffffff;
}

.t4w-stat-card__value {
    margin: 0;
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--t4w-text);
}

.t4w-stat-card__meta {
    margin: 0.35rem 0 0;
    font-size: 0.8125rem;
    color: var(--t4w-muted);
}

.t4w-stat-card__meta--alert {
    color: var(--t4w-primary);
    font-weight: 500;
}

.t4w-stat-card__icon {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 10px;
    background: var(--t4w-primary-light);
    color: var(--t4w-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    flex-shrink: 0;
}

.t4w-stat-card__icon--ok {
    color: var(--t4w-status-ok);
    background: color-mix(in srgb, var(--t4w-status-ok) 18%, var(--t4w-bg));
}

.t4w-stat-card__icon--warn {
    color: var(--t4w-status-warn);
    background: color-mix(in srgb, var(--t4w-status-warn) 18%, var(--t4w-bg));
}

.t4w-stat-card__icon--bad {
    color: var(--t4w-status-bad);
    background: color-mix(in srgb, var(--t4w-status-bad) 18%, var(--t4w-bg));
}

.t4w-stat-card__icon--muted {
    color: var(--t4w-muted);
    background: color-mix(in srgb, var(--t4w-muted) 15%, var(--t4w-bg));
}

.t4w-stat-card__icon--info {
    color: var(--t4w-link);
    background: color-mix(in srgb, var(--t4w-link) 18%, var(--t4w-bg));
}

.t4w-admin-body .btn-danger {
    background-color: var(--t4w-status-bad) !important;
    border-color: var(--t4w-status-bad) !important;
    color: var(--t4w-on-dark) !important;
}

.t4w-admin-body .btn-danger:hover {
    filter: brightness(1.08);
}

.t4w-stack {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.t4w-btn-block {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0.75rem 1rem;
    border-radius: 10px;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.t4w-btn-block--primary {
    background: var(--t4w-primary);
    color: var(--t4w-on-primary) !important;
    border: 1px solid var(--t4w-primary);
}

.t4w-btn-block--primary:hover {
    background: var(--t4w-primary-dark);
    border-color: var(--t4w-primary-dark);
    color: var(--t4w-on-primary) !important;
}

.t4w-btn-block--primary i {
    color: var(--t4w-on-primary) !important;
}

.t4w-btn-block--outline {
    background: var(--t4w-surface);
    color: var(--t4w-on-dark) !important;
    border: 1px solid var(--t4w-border);
}

.t4w-btn-block--outline:hover {
    background: var(--t4w-primary-light);
    color: var(--t4w-on-dark) !important;
    border-color: #d4d4d8;
}

.t4w-btn-block--outline i {
    color: var(--t4w-on-dark) !important;
}

.t4w-btn-block--warn-outline {
    background: transparent;
    color: var(--t4w-primary) !important;
    border: 2px solid var(--t4w-status-warn);
}

.t4w-btn-block--warn-outline:hover {
    background: color-mix(in srgb, var(--t4w-status-warn) 12%, transparent);
    border-color: var(--t4w-primary);
    color: var(--t4w-primary) !important;
}

.t4w-btn-block--warn-outline i {
    color: var(--t4w-primary) !important;
}

.t4w-btn-ghost {
    border: none;
    background: transparent;
    color: var(--t4w-muted);
    font-size: 0.8125rem;
    padding: 0.25rem 0.5rem;
    border-radius: 8px;
    cursor: pointer;
}

.t4w-btn-ghost:hover {
    background: var(--t4w-primary-light);
    color: var(--t4w-primary);
}

.t4w-activity-row {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-activity-row:last-child {
    border-bottom: none;
}

.t4w-activity-row__icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 8px;
    background: var(--t4w-primary-light);
    color: var(--t4w-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 0.875rem;
}

.t4w-activity-row__title {
    margin: 0;
    font-size: 0.875rem;
    font-weight: 500;
    color: #ffffff;
}

.t4w-activity-row__time {
    margin: 0.15rem 0 0;
    font-size: 0.75rem;
    color: #f8fafc;
}

.t4w-empty {
    text-align: center;
    padding: 2.5rem 1rem;
    color: var(--t4w-muted);
}

.t4w-empty > i {
    font-size: 2rem;
    margin-bottom: 0.5rem;
    opacity: 0.45;
    display: block;
}

.t4w-empty .btn {
    display: inline-flex;
    align-items: center;
    width: auto;
    margin-top: 0.25rem;
}

.t4w-empty--sm {
    padding: 1.5rem 1rem;
}

.t4w-link-sm {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--t4w-link);
    text-decoration: none;
}

.t4w-link-sm:hover {
    color: var(--t4w-link-hover);
    text-decoration: underline;
}

.t4w-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.t4w-list__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem 1.25rem;
    border-top: 1px solid var(--t4w-border);
}

.t4w-list__link {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--t4w-text);
    text-decoration: none;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.t4w-list__link:hover {
    color: var(--t4w-link);
}

.t4w-badge {
    font-size: 0.6875rem;
    font-weight: 600;
    padding: 0.2rem 0.5rem;
    border-radius: 6px;
    background: var(--t4w-primary-light);
    color: var(--t4w-muted-strong);
    border: 1px solid var(--t4w-border);
    white-space: nowrap;
}

.t4w-news-scroll {
    max-height: 320px;
    overflow-y: auto;
}

.t4w-news-item__link {
    color: var(--t4w-primary);
    text-decoration: none;
}

.t4w-news-item__link:hover {
    color: var(--t4w-link-hover);
}

.t4w-news-item__thumb-link {
    display: block;
    margin-bottom: 0.65rem;
}

.t4w-news-item__thumb {
    display: block;
    width: 100%;
    max-height: 140px;
    object-fit: cover;
    border-radius: 8px;
    border: 1px solid var(--t4w-border);
}

.t4w-news-pagination .t4w-pagination {
    flex-wrap: wrap;
    gap: 0.5rem;
}

.t4w-news-pagination .t4w-pagination__info {
    font-size: 0.75rem;
}

.t4w-news-detail {
    max-width: 52rem;
    overflow: hidden;
}

.t4w-news-detail__hero {
    margin: 0;
    border-bottom: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-bg) 75%, #000);
    aspect-ratio: 1200 / 630;
    overflow: hidden;
}

.t4w-news-detail__hero-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.t4w-news-detail__content {
    padding-top: 1.25rem;
    padding-bottom: 1.5rem;
}

.t4w-news-detail__prose {
    font-size: 0.9375rem;
    line-height: 1.7;
    color: #fff;
    word-break: break-word;
}

.t4w-news-detail__prose p,
.t4w-news-detail__prose li,
.t4w-news-detail__prose > p:first-child {
    color: #fff;
}

.t4w-news-detail__prose p {
    margin: 0 0 1rem;
}

.t4w-news-detail__prose > p:first-child {
    font-size: 1rem;
    line-height: 1.75;
}

.t4w-news-detail__prose p:last-child {
    margin-bottom: 0;
}

.t4w-news-detail__heading {
    margin: 1.5rem 0 0.65rem;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--t4w-primary) !important;
}

.t4w-news-detail__prose > .t4w-news-detail__heading:first-child,
.t4w-news-detail__prose > p:first-child + .t4w-news-detail__heading {
    margin-top: 0;
}

.t4w-news-detail__list {
    margin: 0 0 1.1rem;
    padding: 0 0 0 1.15rem;
    list-style: disc;
}

.t4w-news-detail__list li {
    margin: 0 0 0.55rem;
    padding-left: 0.15rem;
    line-height: 1.6;
}

.t4w-news-detail__list li::marker {
    color: var(--t4w-primary);
}

.t4w-news-detail__term {
    color: #fff;
    font-weight: 700;
}

.t4w-news-detail__meta {
    margin: 0 0 1rem;
    font-size: 0.8125rem;
    color: var(--t4w-muted);
}

.t4w-news-detail__figure {
    margin: 0 0 1.25rem;
}

.t4w-news-detail__image {
    display: block;
    width: 100%;
    max-height: 420px;
    object-fit: contain;
    border-radius: 10px;
    border: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-bg) 80%, #000);
}

.t4w-news-detail__body {
    font-size: 0.9375rem;
    line-height: 1.65;
    color: var(--t4w-text);
    white-space: pre-wrap;
    word-break: break-word;
}

.t4w-news-form-preview__img {
    display: block;
    max-width: 100%;
    max-height: 200px;
    border-radius: 8px;
    border: 1px solid var(--t4w-border);
}

.t4w-news-item {
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-news-item:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.t4w-news-item__title {
    margin: 0 0 0.25rem;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--t4w-primary);
}

.t4w-news-item__title .t4w-news-item__link {
    color: var(--t4w-primary);
}

.t4w-news-item__date {
    margin: 0 0 0.5rem;
    font-size: 0.75rem;
    color: #fff;
    opacity: 0.85;
}

.t4w-news-item__body {
    font-size: 0.8125rem;
    color: #fff;
    line-height: 1.5;
    margin-bottom: 0.5rem;
}

.t4w-news-item .t4w-link-sm {
    display: inline-block;
    margin-top: 0.15rem;
}

/* Страница новости: заголовок жёлтый, подзаголовок/дата — белые */
.t4w-admin-page .t4w-page-toolbar:has(+ .t4w-news-detail) .t4w-page-head__title {
    color: var(--t4w-primary) !important;
}

.t4w-admin-page .t4w-page-toolbar:has(+ .t4w-news-detail) .t4w-page-head__sub {
    color: #fff !important;
}

/* ——— Подсказки полей (Bootstrap Tooltip) ——— */
/* Плейсхолдеры форм — приглушённый серый, не как основной текст */
.t4w-control::placeholder,
.form-control.t4w-control::placeholder,
.t4w-order-modal .form-control::placeholder,
.modal .form-control::placeholder,
.pwd-field__input.t4w-control::placeholder,
.pwd-field__input::placeholder,
body.landing-page .form-control::placeholder,
body.t4w-admin-body .form-control::placeholder {
    color: var(--t4w-placeholder);
    opacity: 1;
}

.t4w-control::-webkit-input-placeholder,
.form-control.t4w-control::-webkit-input-placeholder,
body.landing-page .form-control::-webkit-input-placeholder,
body.t4w-admin-body .form-control::-webkit-input-placeholder {
    color: var(--t4w-placeholder);
}

.t4w-field-hint-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.125rem;
    height: 1.125rem;
    margin-left: 0.35rem;
    border-radius: 50%;
    border: 1px solid var(--t4w-border);
    background: var(--t4w-primary-light);
    color: var(--t4w-link);
    font-size: 0.7rem;
    cursor: help;
    vertical-align: middle;
    flex-shrink: 0;
}

.t4w-field-hint-icon:hover,
.t4w-field-hint-icon:focus-visible {
    border-color: var(--t4w-primary);
    color: var(--t4w-text);
}

.t4w-field-hint-icon:focus-visible {
    outline: 2px solid var(--t4w-primary);
    outline-offset: 2px;
}

/* Bootstrap на .tooltip задаёт --bs-tooltip-color: var(--bs-body-bg) — перебиваем */
.tooltip,
.tooltip.t4w-tooltip {
    --bs-tooltip-color: #ffffff;
    --bs-tooltip-bg: #334155;
}

.tooltip .tooltip-inner,
.tooltip.t4w-tooltip .tooltip-inner,
.t4w-tooltip .tooltip-inner {
    max-width: var(--bs-tooltip-max-width);
    padding: 0.5rem 0.75rem;
    color: #ffffff !important;
    background-color: #334155 !important;
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    box-shadow: var(--t4w-shadow);
    font-size: 0.8125rem;
    line-height: 1.45;
    text-align: left;
}

/* ——— Страница уведомлений ——— */
.t4w-page-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem;
}

.t4w-page-head__title {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--t4w-text);
}

.t4w-page-head__sub {
    margin: 0.25rem 0 0;
    font-size: 0.875rem;
    color: var(--t4w-muted);
}

.t4w-page-head__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.t4w-page-head--stack {
    flex-direction: column;
    align-items: stretch;
}

.t4w-page-head--stack .t4w-page-head__actions {
    width: 100%;
}

.t4w-stat-card--filter {
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s;
}

/* hover: см. «Ховер блоков» */

.t4w-stat-card--filter.t4w-stat-card--active {
    border-color: var(--t4w-primary);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-primary) 30%, transparent);
}

.t4w-search-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.t4w-search-bar__input {
    flex: 1 1 14rem;
    min-width: min(100%, 14rem);
    max-width: 100%;
    background: var(--t4w-bg) !important;
    border-color: var(--t4w-border) !important;
    color: var(--t4w-text) !important;
}

@media (min-width: 576px) {
    .t4w-search-bar__input {
        min-width: 16rem;
    }
}

.t4w-search-bar__hint {
    margin: 0.5rem 0 0;
    font-size: 0.8125rem;
    color: var(--t4w-text-bright);
}

.t4w-live-search-target--loading {
    opacity: 0.55;
    pointer-events: none;
    transition: opacity 0.15s ease;
}

.t4w-notif-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(20rem, 1fr));
    align-items: stretch;
    gap: 1.25rem;
}

.t4w-notif-grid__empty {
    grid-column: 1 / -1;
}

.t4w-notif-card {
    background: var(--t4w-surface);
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    box-shadow: var(--t4w-shadow);
    display: flex;
    flex-direction: column;
    height: 100%;
    min-width: 0;
    overflow: hidden;
    transition: border-color 0.2s;
}

.t4w-notif-card--unread {
    border-color: color-mix(in srgb, var(--t4w-primary) 45%, var(--t4w-border));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-primary) 12%, transparent), var(--t4w-shadow);
}

.t4w-notif-card--read {
    opacity: 0.92;
}

.t4w-notif-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.625rem;
    min-height: 8.5rem;
    padding: 1rem 1rem 0.875rem;
    background: color-mix(in srgb, var(--t4w-bg) 55%, var(--t4w-surface));
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-notif-card__head > .t4w-badge {
    flex-shrink: 0;
    margin-top: 0.125rem;
}

.t4w-notif-card__lead {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    min-width: 0;
    flex: 1;
}

.t4w-notif-card__icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 8px;
    background: var(--t4w-primary-light);
    color: var(--t4w-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1rem;
}

.t4w-notif-card--read .t4w-notif-card__icon {
    color: var(--t4w-muted);
}

.t4w-notif-card__titles {
    min-width: 0;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.t4w-notif-card__title {
    margin: 0;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--t4w-text);
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.7em;
}

.t4w-notif-card__preview-block {
    margin: 0.5rem 0 0;
    min-height: 2.75rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

.t4w-notif-card__preview-site {
    margin: 0;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--t4w-muted);
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.t4w-notif-card__status-flow {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.35rem;
    margin: 0.4rem 0 0;
}

.t4w-notif-card__status-arrow {
    flex-shrink: 0;
    font-size: 0.75rem;
    color: var(--t4w-muted);
}

.t4w-notif-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 5.25rem;
    padding: 0.2rem 0.5rem;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1.2;
    border-radius: 5px;
    border: 1px solid var(--t4w-border);
    white-space: nowrap;
    box-sizing: border-box;
}

.t4w-notif-status--ok {
    color: var(--t4w-status-ok);
    border-color: color-mix(in srgb, var(--t4w-status-ok) 40%, var(--t4w-border));
    background: color-mix(in srgb, var(--t4w-status-ok) 12%, transparent);
}

.t4w-notif-status--warn {
    color: var(--t4w-status-warn);
    border-color: color-mix(in srgb, var(--t4w-status-warn) 40%, var(--t4w-border));
    background: color-mix(in srgb, var(--t4w-status-warn) 12%, transparent);
}

.t4w-notif-status--bad {
    color: var(--t4w-status-bad);
    border-color: color-mix(in srgb, var(--t4w-status-bad) 40%, var(--t4w-border));
    background: color-mix(in srgb, var(--t4w-status-bad) 12%, transparent);
}

.t4w-notif-status--muted {
    color: var(--t4w-muted);
    background: color-mix(in srgb, var(--t4w-muted) 10%, transparent);
}

.t4w-notif-card__preview-text {
    margin: 0.5rem 0 0;
    min-height: 2.75rem;
    font-size: 0.8125rem;
    color: color-mix(in srgb, var(--t4w-text) 85%, var(--t4w-muted));
    line-height: 1.45;
    word-break: break-word;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.t4w-notif-card__body {
    padding: 0.875rem 1rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.875rem;
    flex: 1;
}

.t4w-notif-card__meta-box {
    padding: 0.625rem 0.75rem;
    min-height: 8.25rem;
    background: var(--t4w-bg);
    border: 1px solid var(--t4w-border);
    border-radius: 8px;
    box-sizing: border-box;
}

.t4w-notif-card__placeholder {
    color: var(--t4w-muted);
    font-weight: 500;
}

.t4w-notif-card__meta {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.t4w-notif-card__row {
    display: grid;
    grid-template-columns: 4.75rem 1fr;
    align-items: center;
    gap: 0.5rem 0.75rem;
    min-height: 1.75rem;
    padding: 0.35rem 0;
    font-size: 0.8125rem;
    border-bottom: 1px solid color-mix(in srgb, var(--t4w-border) 65%, transparent);
}

.t4w-notif-card__row:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.t4w-notif-card__row:first-child {
    padding-top: 0;
}

.t4w-notif-card__row dt {
    margin: 0;
    color: var(--t4w-muted);
    font-weight: 500;
    font-size: 0.75rem;
}

.t4w-notif-card__row dd {
    margin: 0;
    color: var(--t4w-text);
    text-align: right;
    min-width: 0;
}

.t4w-notif-card__mono {
    font-variant-numeric: tabular-nums;
    font-size: 0.75rem;
    color: color-mix(in srgb, var(--t4w-text) 90%, var(--t4w-muted));
}

.t4w-notif-card__site-link {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--t4w-link);
    text-decoration: none;
}

.t4w-notif-card__site-link:hover {
    text-decoration: underline;
}

.t4w-badge--new {
    background: color-mix(in srgb, var(--t4w-primary) 16%, var(--t4w-surface));
    border-color: color-mix(in srgb, var(--t4w-primary) 40%, var(--t4w-border));
    color: var(--t4w-primary);
}

.t4w-badge--read {
    color: var(--t4w-muted);
}

.t4w-badge--ok {
    background: color-mix(in srgb, var(--t4w-status-ok) 16%, var(--t4w-bg));
    border-color: color-mix(in srgb, var(--t4w-status-ok) 35%, var(--t4w-border));
    color: var(--t4w-status-ok);
}

.t4w-badge--warn {
    background: color-mix(in srgb, var(--t4w-status-warn) 16%, var(--t4w-bg));
    border-color: color-mix(in srgb, var(--t4w-status-warn) 35%, var(--t4w-border));
    color: var(--t4w-status-warn);
}

.t4w-badge--bad {
    background: color-mix(in srgb, var(--t4w-status-bad) 16%, var(--t4w-bg));
    border-color: color-mix(in srgb, var(--t4w-status-bad) 35%, var(--t4w-border));
    color: var(--t4w-status-bad);
}

.t4w-badge--info {
    background: color-mix(in srgb, var(--t4w-primary) 18%, var(--t4w-bg));
    border-color: color-mix(in srgb, var(--t4w-primary) 40%, var(--t4w-border));
    color: var(--t4w-primary);
}

.t4w-badge--neutral {
    background: color-mix(in srgb, var(--t4w-muted) 12%, var(--t4w-bg));
    color: var(--t4w-muted-strong);
}

.t4w-badge--priority-support {
    background: color-mix(in srgb, var(--t4w-primary) 22%, var(--t4w-bg));
    border-color: color-mix(in srgb, var(--t4w-primary) 55%, var(--t4w-border));
    color: var(--t4w-primary);
}

.t4w-admin-page tr.t4w-ticket-row--priority-support > td {
    background: color-mix(in srgb, var(--t4w-primary) 8%, var(--t4w-surface));
    box-shadow: inset 3px 0 0 var(--t4w-primary);
}

.t4w-list-row.t4w-ticket-row--priority-support {
    background: color-mix(in srgb, var(--t4w-primary) 8%, var(--t4w-surface));
    box-shadow: inset 3px 0 0 var(--t4w-primary);
}

.t4w-notif-card__actions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.4rem;
    margin-top: auto;
}

.t4w-notif-action,
.t4w-notif-card__actions .t4w-notif-action {
    min-height: 2.125rem;
}

.t4w-notif-card__action-form {
    display: contents;
}

.t4w-notif-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: 100%;
    padding: 0.45rem 0.35rem;
    font-size: 0.6875rem;
    font-weight: 600;
    line-height: 1.2;
    border-radius: 7px;
    border: 1px solid color-mix(in srgb, var(--t4w-border) 90%, transparent);
    background: color-mix(in srgb, var(--t4w-surface) 80%, var(--t4w-bg));
    color: var(--t4w-muted-strong, var(--t4w-text));
    text-decoration: none;
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.t4w-notif-action i {
    color: inherit;
    opacity: 0.85;
}

.t4w-notif-action:hover {
    border-color: color-mix(in srgb, var(--t4w-primary) 50%, var(--t4w-border));
    color: var(--t4w-text);
    background: color-mix(in srgb, var(--t4w-primary) 8%, var(--t4w-bg));
}

.t4w-notif-action--ok:hover {
    border-color: var(--t4w-status-ok);
    color: var(--t4w-status-ok);
}

.t4w-notif-action--danger:hover {
    border-color: var(--t4w-status-bad);
    color: var(--t4w-status-bad);
}

.t4w-notif-action--muted {
    opacity: 0.55;
    cursor: default;
    pointer-events: none;
}

.t4w-notif-action span {
    display: none;
}

@media (min-width: 480px) {
    .t4w-notif-action span {
        display: inline;
    }
}

.t4w-empty__title {
    margin: 0 0 0.35rem;
    font-size: 1rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.t4w-pagination__info {
    font-size: 0.8125rem;
    color: var(--t4w-muted);
}

.t4w-pagination__nav {
    display: flex;
    gap: 0.5rem;
}

.t4w-pagination__btn {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 500;
    border-radius: 8px;
    border: 1px solid var(--t4w-border);
    background: var(--t4w-bg);
    color: var(--t4w-text);
    text-decoration: none;
    transition: border-color 0.15s, background 0.15s;
}

.t4w-pagination__btn:hover:not(.t4w-pagination__btn--disabled) {
    border-color: var(--t4w-primary);
    color: var(--t4w-text);
    background: var(--t4w-primary-light);
}

.t4w-pagination__btn--disabled {
    opacity: 0.45;
    cursor: default;
    pointer-events: none;
}

.t4w-pagination__btn--active {
    background: var(--t4w-primary) !important;
    border-color: var(--t4w-primary) !important;
    color: var(--t4w-on-primary) !important;
    font-weight: 600;
}

.t4w-pagination__dots {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.35rem;
    font-size: 0.8125rem;
    color: var(--t4w-muted);
}

/* Запасной вариант: светлые tailwind-кнопки в пагинации → Midnight */
.t4w-admin-body .t4w-pagination a.bg-white,
.t4w-admin-body .t4w-admin-page a.bg-white.border,
.t4w-admin-body .pagination .page-link {
    background: var(--t4w-bg) !important;
    border-color: var(--t4w-border) !important;
    color: var(--t4w-text) !important;
}

.t4w-admin-body .t4w-pagination a.bg-white:hover,
.t4w-admin-body .t4w-admin-page a.bg-white.border:hover,
.t4w-admin-body .pagination .page-link:hover {
    background: var(--t4w-primary-light) !important;
    border-color: var(--t4w-primary) !important;
    color: var(--t4w-text) !important;
}

.t4w-admin-body .pagination .page-item.active .page-link {
    background: var(--t4w-primary) !important;
    border-color: var(--t4w-primary) !important;
    color: var(--t4w-on-primary) !important;
}

/* Сетка метрик (карточка сайта, дашборд) */
.t4w-dash-stats {
    display: grid;
    gap: 1rem;
    width: 100%;
    margin-bottom: 1.5rem;
}

.t4w-dash-stats--4 {
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .t4w-dash-stats--4 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .t4w-dash-stats--4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.t4w-dash-stats--3 {
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .t4w-dash-stats--3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.t4w-form-narrow {
    max-width: 48rem;
    margin-left: auto;
    margin-right: auto;
}

.t4w-form-panel {
    max-width: 56rem;
}

.t4w-status-item-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem;
    padding: 1rem;
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    background: color-mix(in srgb, var(--t4w-muted) 6%, var(--t4w-surface));
}

.t4w-status-item-row__field {
    flex: 0 1 auto;
    min-width: 7rem;
}

.t4w-status-item-row__field--grow {
    flex: 1 1 12rem;
    min-width: 10rem;
}

.form-label-sm {
    font-size: 0.75rem;
    margin-bottom: 0.25rem;
}

.t4w-embed-panel {
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    background: var(--t4w-surface);
    overflow: hidden;
}

.t4w-embed-panel__head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem;
    border-bottom: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-primary) 8%, var(--t4w-surface));
}

.t4w-embed-panel__lead {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}

.t4w-embed-panel__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 10px;
    background: var(--t4w-primary);
    color: var(--t4w-on-primary);
    flex-shrink: 0;
}

.t4w-embed-panel__body {
    padding: 1.25rem;
}

.t4w-embed-panel__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 992px) {
    .t4w-embed-panel__grid {
        grid-template-columns: 1fr 1fr;
    }
}

.t4w-embed-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    padding: 0.35rem;
    border-radius: var(--t4w-radius);
    background: color-mix(in srgb, var(--t4w-bg) 50%, var(--t4w-surface));
    border: 1px solid var(--t4w-border);
}

.t4w-embed-tabs__btn {
    flex: 1 1 auto;
    min-width: 5rem;
    padding: 0.5rem 0.75rem;
    border: 1px solid transparent;
    border-radius: 8px;
    background: transparent;
    color: var(--t4w-muted);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s, color 0.2s, border-color 0.2s;
}

.t4w-embed-tabs__btn.is-active,
.t4w-embed-tabs__btn.status-embed-tab.is-active {
    background: var(--t4w-surface);
    color: var(--t4w-text);
    border-color: var(--t4w-primary);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-primary) 40%, transparent);
}

.t4w-embed-preview {
    padding: 0.75rem;
    border-radius: var(--t4w-radius);
    border: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-bg) 60%, var(--t4w-surface));
}

.t4w-code-block {
    margin: 0;
    padding: 1rem;
    max-height: 12rem;
    overflow: auto;
    border-radius: var(--t4w-radius);
    border: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-bg) 80%, #0f172a);
}

.t4w-code-block code {
    font-size: 0.75rem;
    color: #e2e8f0;
    white-space: pre-wrap;
    word-break: break-all;
}

.t4w-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

.t4w-page-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.t4w-page-toolbar .btn {
    flex-shrink: 0;
}

.t4w-onboarding-card {
    padding: 1.5rem;
}

.t4w-onboarding-card .t4w-panel__title {
    font-size: 1.125rem;
    margin-top: 0.25rem;
}

.t4w-onboarding-steps .t4w-onboarding-card {
    color: var(--t4w-text);
    min-width: 0;
}

.t4w-onboarding-steps .t4w-onboarding-card .t4w-panel__eyebrow,
.t4w-onboarding-steps .t4w-onboarding-card .t4w-panel__title,
.t4w-onboarding-steps .t4w-onboarding-card .t4w-stat-card__meta,
.t4w-onboarding-steps .t4w-onboarding-card p {
    color: #fff;
}

.t4w-onboarding-steps .t4w-onboarding-card.is-active {
    border: 2px solid var(--t4w-primary);
    background: color-mix(in srgb, var(--t4w-bg) 55%, var(--t4w-surface));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-primary) 35%, transparent);
}

.t4w-onboarding-steps .t4w-onboarding-card.is-active .t4w-panel__eyebrow,
.t4w-onboarding-steps .t4w-onboarding-card.is-active .t4w-panel__title,
.t4w-onboarding-steps .t4w-onboarding-card.is-active .t4w-stat-card__meta {
    color: #fff;
}

.t4w-onboarding-steps .t4w-panel--accent.is-active {
    border: 2px solid var(--t4w-primary-dark);
}

.t4w-service-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.t4w-service-tabs__item {
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 1rem;
    border-radius: var(--t4w-radius);
    border: 1px solid var(--t4w-border);
    background: var(--t4w-surface);
    color: var(--t4w-text) !important;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition: border-color 0.2s, background 0.2s, color 0.2s;
}

.t4w-service-tabs__item:hover {
    border-color: var(--t4w-primary) !important;
    box-shadow: 0 0 0 1px var(--t4w-primary);
    color: var(--t4w-text) !important;
    background: var(--t4w-surface) !important;
}

.t4w-service-tabs__item.is-active {
    border-color: var(--t4w-primary);
    background: color-mix(in srgb, var(--t4w-primary) 18%, var(--t4w-surface));
    color: #fff !important;
    box-shadow: 0 0 0 1px var(--t4w-primary);
}

.t4w-dash-stats--2 {
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .t4w-dash-stats--2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.t4w-metric-tile {
    height: 100%;
}

.t4w-metric-tile .t4w-stat-card__body {
    align-items: center;
}

.t4w-metric-tile .t4w-stat-card__value {
    font-size: 1.35rem;
    text-transform: capitalize;
}

.t4w-uptime-panel {
    padding: 1.25rem;
}

.t4w-uptime-panel__title {
    margin: 0 0 1rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-uptime-panel__percent {
    margin: 0;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
    color: var(--t4w-text);
}

.t4w-panel__head--toolbar-below {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
}

.t4w-panel__head--toolbar-below .t4w-panel__actions {
    margin-left: 0;
    width: 100%;
    justify-content: flex-start;
}

.t4w-panel__head--clickable {
    cursor: pointer;
    user-select: none;
}

.t4w-panel__title--truncate {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.t4w-panel__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    margin-left: auto;
    flex-shrink: 0;
}

.t4w-page-back {
    margin-bottom: 1rem;
}

.t4w-detail-cols {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .t4w-detail-cols {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.t4w-detail-cols__full {
    grid-column: 1 / -1;
}

/* Двухколоночная страница (main + sidebar): не смешивать Bootstrap .row с Tailwind lg:col-span-* */
.t4w-page-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

@media (min-width: 992px) {
    .t4w-page-layout--sidebar {
        grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    }
}

.t4w-page-layout__main {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    min-width: 0;
}

.t4w-page-layout__aside {
    min-width: 0;
}

.t4w-page-layout__aside .t4w-panel > * + * {
    margin-top: 0;
}

/* Кнопки админки: ~200px, не «простыни» на всю колонку (w-100 / w-full) */
.t4w-admin-page .btn.w-100:not(.t4w-btn--wide):not(.btn-lg),
.t4w-admin-page .btn.w-full:not(.t4w-btn--wide):not(.btn-lg),
.t4w-actions-stack .btn,
.t4w-agent-install-actions .btn {
    box-sizing: border-box;
    flex: 0 0 12.5rem !important;
    width: 12.5rem !important;
    max-width: 100%;
    height: 2.25rem;
    min-height: 2.25rem;
    max-height: 2.25rem;
    padding: 0 0.65rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 0.8125rem;
    line-height: 1;
}

.t4w-admin-page form.w-full:has(.btn.w-100),
.t4w-admin-page form.w-full:has(.btn.w-full) {
    width: auto !important;
    max-width: 100%;
}

.t4w-actions-stack {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
}

.t4w-actions-stack form {
    width: auto;
    margin: 0;
}

.t4w-page-layout__aside .t4w-actions-stack .btn.t4w-btn--wide {
    width: 100% !important;
    max-width: 100%;
    flex: none;
    height: auto;
    min-height: 2.25rem;
    max-height: none;
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
}

.t4w-panel__section {
    padding-top: 2rem;
    margin-top: 2rem;
    border-top: 1px solid var(--t4w-border);
}

.t4w-panel__section:first-child,
.t4w-panel__body > .t4w-panel__section:first-child {
    padding-top: 0;
    margin-top: 0;
    border-top: none;
}

.t4w-health-banner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-radius: var(--t4w-radius);
    border: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-primary) 10%, var(--t4w-surface));
    margin-bottom: 1.5rem;
}

.t4w-health-banner--ok {
    border-color: color-mix(in srgb, var(--t4w-status-ok) 45%, var(--t4w-border));
    background: color-mix(in srgb, var(--t4w-status-ok) 12%, var(--t4w-surface));
}

.t4w-health-banner--warn {
    border-color: color-mix(in srgb, var(--t4w-status-warn) 45%, var(--t4w-border));
    background: color-mix(in srgb, var(--t4w-status-warn) 12%, var(--t4w-surface));
}

.t4w-health-banner--bad {
    border-color: color-mix(in srgb, var(--t4w-status-bad) 45%, var(--t4w-border));
    background: color-mix(in srgb, var(--t4w-status-bad) 12%, var(--t4w-surface));
}

.t4w-health-banner--muted {
    background: color-mix(in srgb, var(--t4w-muted) 10%, var(--t4w-surface));
}

.t4w-health-banner__title {
    margin: 0;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-health-banner__hint {
    margin: 0.25rem 0 0;
    font-size: 0.875rem;
    color: var(--t4w-muted);
}

.t4w-callout {
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
    border-radius: var(--t4w-radius);
    border: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-status-warn) 10%, var(--t4w-surface));
}

.t4w-callout__title {
    margin: 0 0 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: #fff;
}

.t4w-callout__text {
    margin: 0;
    font-size: 0.875rem;
    color: #fff;
}

.t4w-callout--info {
    background: color-mix(in srgb, var(--t4w-muted) 8%, var(--t4w-surface));
}

.t4w-finding-type {
    font-weight: 600;
}

.t4w-finding-type--integrity {
    color: var(--t4w-status-ok);
}

.t4w-finding-type--content {
    color: var(--t4w-status-bad);
}

.t4w-finding-type--path {
    color: #a78bfa;
}

.t4w-finding-item--ignored .t4w-finding-item__path {
    color: var(--t4w-muted);
}

.t4w-copy-row {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: stretch;
}

@media (min-width: 640px) {
    .t4w-copy-row {
        flex-direction: row;
        align-items: center;
    }
}

.t4w-copy-row__code {
    flex: 1;
    min-width: 0;
    margin: 0;
    padding: 0.75rem;
    font-size: 0.75rem;
    line-height: 1.4;
    word-break: break-all;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    color: var(--t4w-text);
    background: color-mix(in srgb, var(--t4w-bg) 60%, var(--t4w-surface));
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
}

.t4w-dl-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem 1.5rem;
}

@media (min-width: 640px) {
    .t4w-dl-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.t4w-dl-grid__full {
    grid-column: 1 / -1;
}

.t4w-stack {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.t4w-stack--md {
    gap: 0.75rem;
}

.t4w-stack--lg {
    gap: 1rem;
}

.t4w-remote-scan {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-top: 0.75rem;
    width: 100%;
}

.t4w-remote-scan__url {
    width: 100%;
}

.t4w-remote-scan__url .t4w-copy-row__code {
    display: block;
    width: 100%;
    box-sizing: border-box;
}

.t4w-remote-scan-summary {
    width: 100%;
    padding: 0.85rem 1rem;
    border: 1px solid color-mix(in srgb, var(--t4w-ok, #22c55e) 35%, var(--t4w-border));
    border-radius: var(--t4w-radius);
    background: color-mix(in srgb, var(--t4w-ok, #22c55e) 8%, var(--t4w-surface));
}

.t4w-remote-scan-summary__head {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    margin-bottom: 0.65rem;
}

.t4w-remote-scan-summary__icon {
    color: var(--t4w-ok, #22c55e);
    font-size: 1.125rem;
    margin-top: 0.1rem;
    flex-shrink: 0;
}

.t4w-remote-scan-summary__title {
    margin: 0 0 0.15rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--t4w-text, #e8eaed);
}

.t4w-remote-scan-summary__meta {
    font-size: 0.75rem;
    color: var(--t4w-muted);
}

.t4w-remote-scan-summary__url {
    display: block;
    width: 100%;
    box-sizing: border-box;
    margin: 0 0 0.5rem;
    padding: 0.55rem 0.65rem;
    font-size: 0.6875rem;
    line-height: 1.35;
    word-break: break-all;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    color: var(--t4w-text);
    background: color-mix(in srgb, var(--t4w-bg) 60%, var(--t4w-surface));
    border: 1px solid var(--t4w-border);
    border-radius: calc(var(--t4w-radius) - 2px);
}

.t4w-remote-scan-summary__toggle {
    font-size: 0.8125rem;
    text-decoration: none;
}

.t4w-remote-scan-summary__toggle:hover {
    text-decoration: underline;
}

.t4w-remote-scan-setup {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.t4w-remote-scan-setup > * {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.t4w-remote-scan__agent-label {
    margin: 0.75rem 0 0.35rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--t4w-text, #e8eaed);
}

.t4w-btn--danger-text {
    color: #f87171 !important;
    border-color: rgba(248, 113, 113, 0.45) !important;
}

.t4w-btn--danger-text:hover {
    color: #fca5a5 !important;
    border-color: rgba(248, 113, 113, 0.65) !important;
    background: rgba(248, 113, 113, 0.08);
}

.t4w-page-layout__aside .t4w-actions-stack {
    align-items: flex-start;
}

.t4w-remote-scan__url-label {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 0.8125rem;
    color: var(--t4w-muted);
}

.t4w-remote-scan__form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    width: 100%;
    padding-top: 0.75rem;
    border-top: 1px solid var(--t4w-border);
}

.t4w-remote-scan__switch {
    margin-bottom: 0;
}

.t4w-remote-scan__custom-wrap {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    align-self: stretch;
}

.t4w-remote-scan__custom-wrap > .btn {
    width: 100%;
    max-width: 100%;
    justify-content: center;
}

.t4w-remote-scan__custom {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    width: 100%;
    max-width: 100%;
    min-width: 0;
    align-self: stretch;
    box-sizing: border-box;
    padding: 0.85rem;
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    background: color-mix(in srgb, var(--t4w-bg) 55%, var(--t4w-surface));
}

.t4w-remote-scan__custom .form-label {
    display: block;
    width: 100%;
}

.t4w-remote-scan__custom .form-control,
.t4w-remote-scan__custom-input,
.t4w-remote-scan__custom input[type="url"] {
    display: block;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0;
    box-sizing: border-box;
}

.t4w-remote-scan__toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.25rem;
}

.t4w-remote-scan__save {
    margin-left: auto;
}

.t4w-event-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.t4w-event-item {
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--t4w-border);
    font-size: 0.875rem;
}

.t4w-event-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.t4w-event-item__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.35rem;
}

.t4w-event-item__title {
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-event-item__time {
    font-size: 0.8125rem;
    color: var(--t4w-muted);
    white-space: nowrap;
}

.t4w-finding-list {
    margin: 0.5rem 0 0;
    padding: 0;
    list-style: none;
}

.t4w-finding-item {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid color-mix(in srgb, var(--t4w-status-bad) 25%, var(--t4w-border));
    font-size: 0.75rem;
    color: var(--t4w-status-bad);
}

.t4w-finding-item:last-child {
    border-bottom: none;
}

.t4w-finding-item__path {
    flex: 1;
    min-width: 0;
    word-break: break-all;
}

.t4w-finding-item__path code {
    font-size: 0.7rem;
    color: inherit;
}

.t4w-finding-item__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: center;
    flex-shrink: 0;
}

.t4w-btn-block--danger {
    background: transparent;
    color: var(--t4w-status-bad) !important;
    border: 1px solid color-mix(in srgb, var(--t4w-status-bad) 50%, var(--t4w-border));
}

.t4w-btn-block--danger:hover {
    background: color-mix(in srgb, var(--t4w-status-bad) 12%, var(--t4w-surface));
    border-color: var(--t4w-status-bad);
    color: var(--t4w-status-bad) !important;
}

.t4w-btn-xs {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    font-size: 0.65rem;
    font-weight: 600;
    line-height: 1.2;
    border-radius: 6px;
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none;
}

.t4w-btn-xs--danger {
    background: var(--t4w-status-bad);
    color: #fff !important;
    border-color: var(--t4w-status-bad);
}

.t4w-btn-xs--muted {
    background: var(--t4w-sidebar-hover);
    color: var(--t4w-text) !important;
    border-color: var(--t4w-border);
}

.t4w-status-on {
    color: var(--t4w-status-ok);
}

.t4w-status-off {
    color: var(--t4w-placeholder);
}

.t4w-dl {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.t4w-dl__row dt {
    margin: 0 0 0.25rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--t4w-muted);
}

.t4w-dl__row dd {
    margin: 0;
    font-size: 0.875rem;
    color: var(--t4w-text);
    word-break: break-word;
}

.t4w-section-divider {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--t4w-border);
}

.t4w-section-title {
    margin: 0 0 1rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-info-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    font-size: 0.875rem;
    color: var(--t4w-muted);
}

.t4w-info-list li i {
    width: 1.25rem;
    color: var(--t4w-primary);
}

.t4w-check-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 640px) {
    .t4w-check-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .t4w-check-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.t4w-check-card {
    background: var(--t4w-bg);
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    overflow: hidden;
}

.t4w-check-card__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1rem;
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-check-card__when {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.t4w-check-card__icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.t4w-check-card__icon--ok {
    color: var(--t4w-status-ok);
    background: color-mix(in srgb, var(--t4w-status-ok) 18%, var(--t4w-surface));
}

.t4w-check-card__icon--warn {
    color: var(--t4w-status-warn);
    background: color-mix(in srgb, var(--t4w-status-warn) 18%, var(--t4w-surface));
}

.t4w-check-card__icon--bad {
    color: var(--t4w-status-bad);
    background: color-mix(in srgb, var(--t4w-status-bad) 18%, var(--t4w-surface));
}

.t4w-check-card__date {
    margin: 0;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-check-card__ago {
    margin: 0.15rem 0 0;
    font-size: 0.75rem;
    color: var(--t4w-muted);
}

.t4w-check-card__body {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.t4w-kv {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    font-size: 0.8125rem;
}

.t4w-kv__label {
    color: var(--t4w-muted-strong);
}

.t4w-kv__empty {
    color: var(--t4w-muted);
}

.t4w-check-card__error {
    display: flex;
    gap: 0.5rem;
    padding-top: 0.65rem;
    margin-top: 0.25rem;
    border-top: 1px solid var(--t4w-border);
    color: var(--t4w-status-bad);
    font-size: 0.8125rem;
}

.t4w-check-card__error p {
    margin: 0.25rem 0 0;
    color: var(--t4w-muted);
}

.t4w-empty {
    text-align: center;
    padding: 2.5rem 1rem;
    color: var(--t4w-muted);
}

.t4w-empty > i {
    font-size: 2.5rem;
    opacity: 0.45;
    margin-bottom: 1rem;
    display: block;
}

.t4w-empty .btn {
    display: inline-flex;
    align-items: center;
    width: auto;
    margin-top: 0.25rem;
}

.t4w-metric-tile--row .t4w-stat-card__body {
    flex-wrap: wrap;
}

.t4w-metric-tile--row .t4w-stat-card__extra {
    flex: 1 1 100%;
    text-align: right;
}

@media (min-width: 768px) {
    .t4w-metric-tile--row .t4w-stat-card__extra {
        flex: 0 0 auto;
        margin-left: auto;
        text-align: right;
    }
}


/* ——— Шапка админки: иконки, выпадающие меню (Midnight) ——— */
.t4w-admin-header__menu-btn {
    display: inline-flex;
}

@media (min-width: 1024px) {
    .t4w-admin-header__start {
        display: none !important;
    }

    .t4w-admin-header__bar {
        justify-content: flex-end;
    }
}

[x-cloak] {
    display: none !important;
}

@media (max-width: 639px) {
    .t4w-admin-header__title-wrap {
        display: none;
    }
}

.t4w-admin-header__title-wrap {
    min-width: 0;
}

.t4w-admin-header__title {
    margin: 0;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-header-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border: 1px solid transparent;
    border-radius: 10px;
    background: transparent;
    color: var(--t4w-muted);
    cursor: pointer;
    transition: color 0.15s, background 0.15s, border-color 0.15s;
}

.t4w-header-icon-btn:hover {
    color: var(--t4w-primary);
    background: var(--t4w-primary-light);
    border-color: var(--t4w-border);
}

.t4w-header-icon-btn--sm {
    width: 1.75rem;
    height: 1.75rem;
    font-size: 0.75rem;
}

.t4w-header-badge {
    position: absolute;
    top: -0.15rem;
    right: -0.15rem;
    min-width: 1rem;
    height: 1.15rem;
    padding: 0 0.25rem;
    border-radius: 999px;
    background: var(--t4w-status-bad);
    border: 1px solid color-mix(in srgb, var(--t4w-status-bad) 80%, #000);
    color: var(--t4w-on-dark);
    font-size: 0.625rem;
    font-weight: 700;
    line-height: 1.15rem;
    text-align: center;
}

.t4w-header-badge--wide {
    min-width: 1.35rem;
}

.t4w-header-badge--wider {
    min-width: 1.65rem;
}

.t4w-header-profile {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.25rem 0.35rem;
    border: none;
    border-radius: 10px;
    background: transparent;
    color: var(--t4w-text);
    cursor: pointer;
    transition: background 0.15s;
}

.t4w-header-profile:hover {
    background: var(--t4w-primary-light);
}

.t4w-header-profile__name {
    font-size: 0.875rem;
    font-weight: 500;
}

.t4w-header-profile__caret {
    font-size: 0.65rem;
    color: var(--t4w-muted);
}

.t4w-dropdown {
    width: 24rem;
    max-width: calc(100vw - 1.5rem);
    background: var(--t4w-surface);
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    box-shadow: var(--t4w-shadow);
    overflow: hidden;
}

.t4w-dropdown--prompt {
    width: 20rem;
}

.t4w-profile-dropdown {
    width: 12.5rem;
}

.t4w-dropdown__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-bg) 40%, var(--t4w-surface));
}

.t4w-dropdown__title {
    margin: 0;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--t4w-text);
}

.t4w-dropdown__head-actions {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.t4w-dropdown__link-btn {
    border: none;
    background: transparent;
    padding: 0.2rem 0.45rem;
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--t4w-muted);
    border-radius: 6px;
    cursor: pointer;
    transition: color 0.15s, background 0.15s;
}

.t4w-dropdown__link-btn:hover {
    color: var(--t4w-link);
    background: var(--t4w-primary-light);
}

.t4w-dropdown__scroll {
    max-height: 20rem;
    overflow-y: auto;
}

.t4w-dropdown__scroll::-webkit-scrollbar {
    width: 6px;
}

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

.t4w-dropdown__item {
    display: block;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid var(--t4w-border);
    text-decoration: none;
    color: inherit;
    transition: background 0.15s;
}

.t4w-dropdown__item:last-child {
    border-bottom: none;
}

.t4w-dropdown__item:hover {
    background: color-mix(in srgb, var(--t4w-primary-light) 65%, var(--t4w-surface));
    color: inherit;
    text-decoration: none;
}

.t4w-dropdown__item--unread {
    border-left: 3px solid var(--t4w-primary);
    padding-left: calc(1rem - 3px);
    background: color-mix(in srgb, var(--t4w-primary) 10%, var(--t4w-surface));
}

.t4w-dropdown__item-inner {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
}

.t4w-dropdown__item-main {
    flex: 1;
    min-width: 0;
}

.t4w-dropdown__item-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.35rem;
}

.t4w-dropdown__item-title {
    margin: 0;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--t4w-text);
    line-height: 1.3;
}

.t4w-dropdown__item-time {
    flex-shrink: 0;
    font-size: 0.6875rem;
    color: var(--t4w-muted);
    white-space: nowrap;
}

.t4w-dropdown__item-text {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.45;
    color: var(--t4w-muted);
}

.t4w-dropdown__item-arrow {
    flex-shrink: 0;
    margin-top: 0.15rem;
    font-size: 0.65rem;
    color: var(--t4w-muted);
    opacity: 0.7;
}

.t4w-dropdown__empty {
    padding: 2rem 1rem;
    text-align: center;
    color: var(--t4w-muted);
}

.t4w-dropdown__empty i {
    display: block;
    font-size: 1.35rem;
    margin-bottom: 0.5rem;
    opacity: 0.45;
}

.t4w-dropdown__empty p {
    margin: 0;
    font-size: 0.8125rem;
}

.t4w-dropdown__spinner {
    width: 1.5rem;
    height: 1.5rem;
    margin: 0 auto 0.5rem;
    border: 2px solid var(--t4w-border);
    border-top-color: var(--t4w-primary);
    border-radius: 50%;
    animation: t4w-spin 0.7s linear infinite;
}

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

.t4w-dropdown__foot {
    padding: 0.65rem 1rem;
    text-align: center;
    border-top: 1px solid var(--t4w-border);
    background: color-mix(in srgb, var(--t4w-bg) 40%, var(--t4w-surface));
}

.t4w-dropdown__menu-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.55rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--t4w-text) !important;
    text-decoration: none;
    transition: background 0.15s;
}

.t4w-dropdown__menu-item:hover {
    background: var(--t4w-primary-light);
    color: var(--t4w-text) !important;
}

.t4w-dropdown__menu-item i {
    width: 1rem;
    text-align: center;
    color: var(--t4w-muted);
}

.t4w-dropdown__divider {
    margin: 0.35rem 0;
    border: none;
    border-top: 1px solid var(--t4w-border);
    opacity: 1;
}

/* Футер админки — тот же блок, что на главной (landing.partials.footer) */
.t4w-admin-body .landing-footer {
    background: var(--t4w-surface);
    color: var(--t4w-muted);
    padding: 3rem 0 1.5rem;
    border-top: 1px solid var(--t4w-border);
    flex-shrink: 0;
    width: 100%;
}

.t4w-admin-body .landing-footer .brand {
    color: var(--t4w-text);
    font-weight: 700;
}

.t4w-admin-body .landing-footer a {
    color: var(--t4w-link);
    text-decoration: none;
}

.t4w-admin-body .landing-footer a:hover {
    color: var(--t4w-link-hover);
}

.t4w-admin-body .landing-footer .disclaimer-text {
    font-size: 0.75rem;
    color: var(--t4w-muted);
    line-height: 1.5;
}

.t4w-admin-body .landing-footer .text-white-50 {
    color: var(--t4w-muted) !important;
}

.t4w-admin-body .landing-footer hr.border-secondary {
    border-color: var(--t4w-border) !important;
    opacity: 0.25;
}

.t4w-admin-page {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
    max-width: none;
    margin: 0;
    box-sizing: border-box;
}

/* Агент на карточке сервера: две колонки без «разъезда» */
.t4w-agent-status-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    align-items: start;
}

@media (min-width: 768px) {
    .t4w-agent-status-row {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    }
}

.t4w-agent-status-row__hint {
    margin: 0.5rem 0 0;
    font-size: 0.8125rem;
    line-height: 1.45;
    color: var(--t4w-muted);
}

.t4w-admin-page .min-w-0 {
    min-width: 0;
}

.t4w-page-head-panel {
    margin-bottom: 0 !important;
}

/* Карточка объекта мониторинга: название + действия на первом экране */
.t4w-monitoring-show-hero {
    margin-bottom: 1.25rem;
}

.t4w-monitoring-show-hero .t4w-page-head {
    padding: 1.25rem 1.5rem;
}

.t4w-monitoring-show-hero .t4w-page-head__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    width: 100%;
}

.t4w-monitoring-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
}

.t4w-monitoring-actions form {
    display: inline-flex;
    margin: 0;
    align-items: center;
}

.t4w-monitoring-actions .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    min-height: 2.25rem;
    padding: 0.4375rem 0.875rem;
    line-height: 1.2;
    font-size: 0.8125rem;
    font-weight: 600;
    white-space: nowrap;
    vertical-align: middle;
    box-sizing: border-box;
    border-width: 2px;
    border-style: solid;
}

.t4w-monitoring-actions .btn i,
.t4w-monitoring-actions .btn .fas,
.t4w-monitoring-actions .btn .far {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.875rem;
    font-size: 0.875rem;
    line-height: 1;
    flex-shrink: 0;
    margin: 0 !important;
}

.t4w-monitoring-actions .btn-t4w-primary {
    border-color: var(--t4w-primary) !important;
}

.t4w-monitoring-actions .btn-danger {
    border-color: transparent;
}

.t4w-monitoring-show-stats .t4w-stat-card__value {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--t4w-text);
}

.t4w-monitoring-show-stats .t4w-stat-card__unit {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--t4w-muted);
    margin-left: 0.15rem;
}

.t4w-monitoring-stat-status.t4w-status-on,
.t4w-monitoring-show-stats .t4w-status-on {
    color: var(--t4w-status-ok);
}

@media (max-width: 575.98px) {
    .t4w-monitoring-actions .btn {
        flex: 1 1 calc(50% - 0.25rem);
    }
}

/* Фильтры по статусу (список и история проверок) */
.t4w-status-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.t4w-status-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.75rem;
    border-radius: var(--t4w-radius, 0.5rem);
    border: 1px solid var(--t4w-border);
    background: var(--t4w-surface-elevated, var(--t4w-surface));
    color: var(--t4w-text);
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.t4w-status-filter-btn:hover {
    border-color: color-mix(in srgb, var(--t4w-primary) 45%, var(--t4w-border));
    color: var(--t4w-text-bright);
    text-decoration: none;
}

.t4w-status-filter-btn--active {
    border-color: var(--t4w-primary);
    background: color-mix(in srgb, var(--t4w-primary) 14%, var(--t4w-surface));
    color: var(--t4w-text-bright);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-primary) 25%, transparent);
}

.t4w-status-filter-btn__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.35rem;
    padding: 0 0.35rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: color-mix(in srgb, var(--t4w-muted) 20%, transparent);
    color: var(--t4w-muted);
}

.t4w-status-filter-btn--active .t4w-status-filter-btn__count {
    background: color-mix(in srgb, var(--t4w-primary) 25%, transparent);
    color: var(--t4w-text-bright);
}

.t4w-status-filter-btn--ok .fa-check-circle { color: var(--t4w-status-ok); }
.t4w-status-filter-btn--warn .fa-exclamation-triangle { color: var(--t4w-status-warn); }
.t4w-status-filter-btn--bad .fa-times-circle { color: var(--t4w-status-bad, #dc3545); }

.t4w-check-history-pagination {
    border-color: var(--t4w-border) !important;
}

.t4w-panel--info {
    padding: 0.75rem 1rem;
    background: color-mix(in srgb, var(--t4w-primary) 10%, var(--t4w-surface));
    border-color: color-mix(in srgb, var(--t4w-primary) 35%, var(--t4w-border));
}

.t4w-panel--info .t4w-panel__body,
.t4w-panel--info p,
.t4w-panel--info strong,
.t4w-panel--info a:not(.btn) {
    color: #fff;
}

.t4w-panel--info .fas,
.t4w-panel--info .fa {
    color: var(--t4w-primary);
}

.t4w-panel--warn .t4w-panel__body,
.t4w-panel--warn p,
.t4w-panel--warn strong,
.t4w-panel--warn a:not(.btn) {
    color: #fff;
}

.t4w-panel--warn {
    padding: 0.75rem 1rem;
    background: color-mix(in srgb, var(--t4w-status-warn) 12%, var(--t4w-surface));
    border-color: var(--t4w-status-warn);
}

.t4w-panel--warn p {
    color: #fff;
}

.t4w-admin-page .tariff-card,
body.landing-page .tariff-extra-note {
    color: var(--t4w-muted);
}

body.landing-page .tariff-extra-note {
    max-width: 42rem;
    margin-left: auto;
    margin-right: auto;
    padding: 0.75rem 1rem;
    background: color-mix(in srgb, var(--t4w-primary) 8%, var(--t4w-surface));
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
}

body.landing-page .tariff-extra-note strong {
    color: var(--t4w-text);
}

.t4w-tariff-pick {
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.t4w-tariff-pick--current {
    border-color: var(--t4w-primary) !important;
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-primary) 35%, transparent);
}

.t4w-admin-page .row.g-4 > [class*="col-"] {
    overflow: visible;
}

.t4w-admin-body .t4w-tariff-pick:hover:not(.t4w-tariff-pick--disabled) {
    border-color: var(--t4w-primary) !important;
    box-shadow: 0 0 0 1px var(--t4w-primary), var(--t4w-shadow) !important;
}

.t4w-admin-body .t4w-tariff-pick--current:hover {
    box-shadow:
        0 0 0 1px var(--t4w-primary),
        0 4px 16px color-mix(in srgb, var(--t4w-primary) 22%, transparent) !important;
}

.t4w-tariff-pick .btn-t4w-primary,
.t4w-tariff-pick .btn-t4w-outline {
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.t4w-tariff-pick .btn-t4w-primary:hover:not(:disabled) {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px color-mix(in srgb, var(--t4w-primary) 35%, transparent);
}

.t4w-tariff-features {
    color: var(--t4w-muted);
}

/* ——— Админка: унификация форм, таблиц, карточек (legacy Tailwind внутри .t4w-admin-page) ——— */
.t4w-admin-page h1,
.t4w-admin-page .t4w-page-head__title {
    color: var(--t4w-text);
}

.t4w-admin-page h2,
.t4w-admin-page h3,
.t4w-admin-page .t4w-panel__title {
    color: var(--t4w-text);
}

.t4w-admin-page p,
.t4w-admin-page .text-muted,
.t4w-admin-page .text-gray-500,
.t4w-admin-page .text-gray-600,
.t4w-admin-page .small,
.t4w-admin-page small {
    color: #ffffff;
}

/* Info/callout/onboarding: белый текст поверх общего правила для p */
.t4w-admin-page .t4w-panel--info,
.t4w-admin-page .t4w-panel--info p,
.t4w-admin-page .t4w-panel--info .small,
.t4w-admin-page .t4w-panel--info strong:not(.btn),
.t4w-admin-page .t4w-panel--warn p,
.t4w-admin-page .t4w-panel--warn .small,
.t4w-admin-page .t4w-panel--warn strong:not(.btn),
.t4w-admin-page .t4w-callout,
.t4w-admin-page .t4w-callout p,
.t4w-admin-page .t4w-callout__text,
.t4w-admin-page .t4w-callout__title,
.t4w-admin-page .t4w-callout strong,
.t4w-admin-page .t4w-channel-hint,
.t4w-admin-page .t4w-channel-hint p,
.t4w-admin-page .t4w-channel-hint .small,
.t4w-onboarding-steps .t4w-onboarding-card,
.t4w-onboarding-steps .t4w-onboarding-card p,
.t4w-onboarding-steps .t4w-onboarding-card .t4w-stat-card__meta {
    color: #fff;
}

.t4w-admin-page label,
.t4w-admin-page .text-gray-700,
.t4w-admin-page .text-gray-800,
.t4w-admin-page fieldset legend {
    color: #ffffff !important;
}

.t4w-admin-page .form-control,
.t4w-admin-page input[type="text"]:not([type="checkbox"]):not([type="radio"]),
.t4w-admin-page input[type="email"],
.t4w-admin-page input[type="password"],
.t4w-admin-page input[type="number"],
.t4w-admin-page input[type="url"],
.t4w-admin-page input[type="tel"],
.t4w-admin-page input[type="search"],
.t4w-admin-page select,
.t4w-admin-page textarea,
.t4w-admin-page .w-full.px-3.py-2.border {
    padding: 0.5rem 0.75rem !important;
    min-height: 2.375rem;
    font-size: 0.875rem;
    line-height: 1.4;
    background-color: var(--t4w-bg) !important;
    color: var(--t4w-text) !important;
    border-color: var(--t4w-border) !important;
    border-radius: 10px !important;
}

.t4w-admin-page .form-control:focus,
.t4w-admin-page input:focus,
.t4w-admin-page select:focus,
.t4w-admin-page textarea:focus {
    border-color: var(--t4w-primary) !important;
    box-shadow: 0 0 0 0.2rem rgba(232, 184, 74, 0.25) !important;
}

.t4w-admin-page select,
.t4w-admin-body select,
.t4w-admin-page .form-select,
.t4w-admin-body .form-select {
    accent-color: var(--t4w-primary);
}

.t4w-admin-page select option,
.t4w-admin-body select option,
.t4w-admin-page .form-select option,
.t4w-admin-body .form-select option {
    background-color: var(--t4w-bg);
    color: var(--t4w-text);
}

.t4w-admin-page select option:checked,
.t4w-admin-body select option:checked,
.t4w-admin-page select option:hover,
.t4w-admin-body select option:hover,
.t4w-admin-page select option:focus,
.t4w-admin-body select option:focus,
.t4w-admin-page select:focus option:checked,
.t4w-admin-body select:focus option:checked {
    background: var(--t4w-primary) linear-gradient(0deg, var(--t4w-primary) 0%, var(--t4w-primary) 100%);
    background-color: var(--t4w-primary) !important;
    color: var(--t4w-on-primary) !important;
}

.t4w-admin-body .input-group-text,
.t4w-admin-page .input-group-text {
    background-color: var(--t4w-surface) !important;
    color: #ffffff !important;
    border-color: var(--t4w-border) !important;
}

.t4w-admin-body .input-group > .input-group-text,
.t4w-admin-page .input-group > .input-group-text {
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    font-size: 0.8125rem;
}

.t4w-admin-body .input-group > .input-group-text + .form-control,
.t4w-admin-page .input-group > .input-group-text + .form-control {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.t4w-admin-body .input-group:focus-within .input-group-text,
.t4w-admin-page .input-group:focus-within .input-group-text {
    border-color: var(--t4w-primary) !important;
    color: var(--t4w-text) !important;
}

.t4w-admin-page .table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--t4w-text);
    --bs-table-border-color: var(--t4w-border);
    color: var(--t4w-text);
}

.t4w-admin-page .table thead th,
.t4w-admin-page table thead,
.t4w-admin-body table thead th {
    background: var(--t4w-primary-light) !important;
    color: #ffffff !important;
    border-color: var(--t4w-border) !important;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.t4w-admin-page .table td,
.t4w-admin-page .table th {
    border-color: var(--t4w-border) !important;
    vertical-align: middle;
    padding: 0.75rem var(--t4w-pad-x) !important;
}

/* Таблицы без Bootstrap-класса .table */
.t4w-admin-page .t4w-panel table th,
.t4w-admin-page .t4w-panel table td {
    padding: 0.75rem var(--t4w-pad-x) !important;
    border-color: var(--t4w-border);
    color: var(--t4w-text);
    vertical-align: middle;
}

.t4w-admin-page .t4w-panel table thead th {
    background: var(--t4w-primary-light) !important;
    color: #ffffff !important;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.t4w-table-col-actions {
    width: 11rem;
    white-space: nowrap;
}

/* Ячейка пользователя в таблицах (не использовать t4w-stat-card__body — space-between) */
.t4w-user-table-cell {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.t4w-user-table-cell__meta {
    min-width: 0;
}

.t4w-user-table-cell__name {
    margin: 0;
    font-weight: 600;
    color: #ffffff;
    line-height: 1.3;
}

.t4w-user-table-cell__sub {
    margin: 0.15rem 0 0;
    font-size: 0.75rem;
    color: #ffffff;
}

/* Формы в блоке «Управление тикетом» и похожих панелях */
.t4w-inline-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: stretch;
}

.t4w-inline-form-actions .form-control,
.t4w-inline-form-actions select {
    flex: 1 1 10rem;
    min-width: 0;
}

.t4w-inline-form-actions .btn {
    flex: 0 0 auto;
    align-self: stretch;
    white-space: nowrap;
}

.t4w-support-meta-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 768px) {
    .t4w-support-meta-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1200px) {
    .t4w-support-meta-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

.t4w-support-meta-grid .t4w-panel__body {
    padding: 1rem 1.25rem;
}

.t4w-support-manage-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
    align-items: end;
}

@media (min-width: 992px) {
    .t4w-support-manage-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.t4w-table-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    flex-wrap: nowrap;
}

.t4w-table-actions a,
.t4w-table-actions button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: none;
    background: transparent;
    border-radius: 8px;
    color: var(--t4w-primary);
    line-height: 1;
}

.t4w-table-actions a:hover,
.t4w-table-actions button:hover {
    background: var(--t4w-primary-light);
    color: var(--t4w-primary-hover, var(--t4w-primary));
}

.t4w-table-actions .text-danger,
.t4w-table-actions button.text-danger {
    color: #f87171;
}

.t4w-dash-stat-inline {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: var(--t4w-pad-y) var(--t4w-pad-x);
}

.t4w-users-table .t4w-text-email {
    color: #f8fafc;
}

.t4w-users-table .t4w-text-date {
    color: var(--t4w-muted-strong);
}

/* Подсказки и info-панели без __body */
.t4w-admin-page .t4w-panel.t4w-channel-hint,
.t4w-admin-page .t4w-panel--info:not(:has(.t4w-panel__body)):not(:has(.t4w-panel__head)),
.t4w-admin-page .t4w-panel--warn:not(:has(.t4w-panel__body)):not(:has(.t4w-panel__head)) {
    padding: var(--t4w-pad-y) var(--t4w-pad-x);
}

.t4w-admin-page .t4w-page-toolbar {
    margin-bottom: var(--t4w-section-gap);
}

.t4w-admin-page > .t4w-panel + .t4w-panel,
.t4w-admin-page > .mb-6 + .t4w-panel,
.t4w-admin-page > .t4w-panel + .mb-6 {
    margin-top: var(--t4w-section-gap);
}

.t4w-admin-page p {
    line-height: 1.6;
}

.t4w-admin-page .text-muted {
    color: var(--t4w-muted) !important;
}

.t4w-admin-page h1,
.t4w-admin-page h2,
.t4w-admin-page h3,
.t4w-admin-page h4,
.t4w-admin-page .fw-semibold:not(.badge):not(.btn) {
    color: var(--t4w-text-bright);
}

.t4w-admin-page .t4w-page-head__title {
    color: var(--t4w-text-bright);
}

/* hover таблиц: см. «Ховер блоков» */

.t4w-admin-page .t4w-stat-card--filter {
    cursor: pointer;
    padding: 0 !important;
}

.t4w-admin-page .t4w-stat-card--filter .flex.items-center {
    padding: 1.25rem;
}

.t4w-admin-page .t4w-stat-card--filter .text-2xl {
    color: var(--t4w-primary) !important;
}

.t4w-admin-page .t4w-stat-card--filter .text-2xl.font-bold,
.t4w-admin-page .t4w-stat-card--filter .font-bold {
    color: var(--t4w-text) !important;
}

.t4w-admin-page .t4w-panel__body {
    padding: 1rem 1.25rem;
}

.t4w-admin-page .t4w-panel__head .text-sm {
    margin: 0.25rem 0 0;
    color: var(--t4w-muted);
}

.t4w-admin-page .bg-gray-50,
.t4w-admin-page .bg-gray-100,
.t4w-admin-page .divide-gray-200 > :not([hidden]) ~ :not([hidden]) {
    background-color: color-mix(in srgb, var(--t4w-bg) 35%, var(--t4w-surface)) !important;
    border-color: var(--t4w-border) !important;
}

/* tailwind hover:bg-gray — см. «Ховер блоков» */

.t4w-admin-page .text-red-600,
.t4w-admin-page .text-red-800 {
    color: var(--t4w-status-bad) !important;
}

.t4w-admin-page .text-green-600,
.t4w-admin-page .text-green-700 {
    color: var(--t4w-status-ok) !important;
}

.t4w-admin-page .modal-content {
    background: var(--t4w-surface);
    color: var(--t4w-text);
    border-color: var(--t4w-border);
}

.t4w-admin-page .card,
.t4w-admin-page .max-w-2xl.bg-white,
.t4w-admin-page .max-w-5xl {
    max-width: 100%;
}

.t4w-admin-page code {
    background: var(--t4w-bg);
    color: var(--t4w-link);
    padding: 0.1rem 0.35rem;
    border-radius: 4px;
}

.t4w-tariff-warnings {
    list-style: none;
    margin: 0 0 0.75rem;
    padding: 0;
}

.t4w-tariff-warnings li {
    font-size: 0.75rem;
    color: var(--t4w-status-warn);
    margin-bottom: 0.35rem;
    padding-left: 1rem;
    position: relative;
}

.t4w-tariff-warnings li::before {
    content: "!";
    position: absolute;
    left: 0;
    font-weight: 700;
}

.t4w-code-block {
    background: var(--t4w-bg);
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    padding: 0.75rem 1rem;
}

.t4w-code-block code {
    color: var(--t4w-text);
}

.t4w-code-inline,
code.t4w-code-inline {
    display: inline-block;
    padding: 0.1rem 0.35rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.8125rem;
    line-height: 1.4;
    color: var(--t4w-text);
    background: color-mix(in srgb, var(--t4w-muted) 12%, var(--t4w-bg));
    border: 1px solid var(--t4w-border);
    border-radius: 4px;
}

.t4w-text {
    color: var(--t4w-text);
}

/* Пути, имена файлов в тексте (не ссылки) */
code.t4w-text,
.t4w-text--mono,
.t4w-admin-page code.t4w-text {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.8125rem;
    color: var(--t4w-muted-strong);
    background: color-mix(in srgb, var(--t4w-muted) 10%, var(--t4w-bg));
    border: 1px solid var(--t4w-border);
    border-radius: 4px;
    padding: 0.1rem 0.35rem;
}

/* Иконки в заголовках блоков — золотой акцент, не «ссылочный» жёлтый */
.t4w-icon-accent,
.t4w-admin-page .t4w-panel__title .fas,
.t4w-admin-page .t4w-panel__title .far,
.t4w-admin-page h3 .fas.t4w-icon-accent,
.t4w-admin-page h4 .fas.t4w-icon-accent {
    color: var(--t4w-primary);
}

.t4w-hint,
.t4w-admin-page .text-amber-700,
.t4w-admin-body .text-amber-700 {
    margin: 0;
    font-size: 0.75rem;
    line-height: 1.45;
    color: var(--t4w-muted) !important;
}

.t4w-instructions {
    margin: 0 0 1rem;
    padding-left: 1.25rem;
    font-size: 0.875rem;
    line-height: 1.55;
    color: var(--t4w-muted-strong);
}

.t4w-instructions li + li {
    margin-top: 0.5rem;
}

.t4w-instructions strong {
    color: var(--t4w-text);
    font-weight: 600;
}

.t4w-admin-body button.bg-white,
.t4w-admin-body a.bg-white.border,
.t4w-admin-body .inline-flex.bg-white {
    background: var(--t4w-surface) !important;
    border-color: var(--t4w-border) !important;
    color: var(--t4w-text) !important;
}

.t4w-admin-body button.text-red-700.bg-white,
.t4w-admin-body button.text-red-700.bg-white:hover,
.t4w-admin-body .hover\:bg-red-50:hover {
    color: var(--t4w-status-bad) !important;
    border-color: color-mix(in srgb, var(--t4w-status-bad) 50%, var(--t4w-border)) !important;
    background: color-mix(in srgb, var(--t4w-status-bad) 8%, var(--t4w-surface)) !important;
}

.t4w-admin-body .text-gray-900,
.t4w-admin-body .text-gray-800 {
    color: var(--t4w-text-bright) !important;
}

.t4w-admin-body .text-gray-600,
.t4w-admin-body .text-gray-700 {
    color: var(--t4w-muted-strong) !important;
}

.t4w-admin-body .text-blue-800,
.t4w-admin-body .text-indigo-900,
.t4w-admin-body .text-indigo-950 {
    color: var(--t4w-text) !important;
}

.t4w-code-block--install {
    max-height: none;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
    margin-bottom: 0;
    padding: 0.75rem 0.85rem;
    background: color-mix(in srgb, var(--t4w-bg) 78%, #000);
    border: 1px solid var(--t4w-border);
    border-radius: 8px;
}

.t4w-code-block--install code {
    display: block;
    white-space: pre;
    word-break: break-all;
    overflow-wrap: anywhere;
    font-size: 0.75rem;
    line-height: 1.5;
    min-width: 0;
    color: var(--t4w-text-bright);
}

.t4w-panel--content-visible {
    overflow: visible;
}

.t4w-agent-install-section {
    padding-bottom: 1.35rem;
}

.t4w-instructions--agent {
    padding-left: 1.1rem;
}

.t4w-instructions__step-token {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
}

.t4w-instructions__step-note {
    font-size: 0.8125rem;
    color: var(--t4w-muted-strong);
    line-height: 1.45;
    max-width: 36rem;
}

.t4w-instructions__step-label {
    display: block;
    font-weight: 600;
    color: var(--t4w-text);
    margin-bottom: 0.25rem;
}

.t4w-agent-install-actions {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.t4w-agent-install-divider {
    margin-top: 1rem;
    padding-top: 1.25rem;
}

.t4w-install-filename {
    display: block;
    width: fit-content;
    max-width: 100%;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.8125rem;
    color: var(--t4w-muted-strong);
    background: color-mix(in srgb, var(--t4w-muted) 10%, var(--t4w-bg));
    border: 1px solid var(--t4w-border);
    border-radius: 6px;
    padding: 0.35rem 0.55rem;
    word-break: break-all;
}

.t4w-btn-wrap {
    white-space: normal !important;
    text-align: left;
    word-break: break-word;
    max-width: 100%;
    line-height: 1.35;
    padding-top: 0.55rem;
    padding-bottom: 0.55rem;
}

@media (max-width: 575.98px) {
    .t4w-code-block--install {
        overflow-x: auto;
        padding-bottom: 0.5rem;
    }

    .t4w-code-block--install code {
        white-space: pre;
        word-break: normal;
        overflow-wrap: normal;
        font-size: 0.52rem;
        line-height: 1.45;
    }

    .t4w-install-filename {
        width: 100%;
    }

    .t4w-agent-install-actions {
        gap: 0.65rem;
        margin-bottom: 0.25rem;
    }
}

@media (min-width: 576px) {
    .t4w-code-block--install code {
        font-size: 0.8125rem;
    }
}

/* ——— Ховер блоков: только жёлтая обводка, без светлой заливки ——— */
.t4w-admin-body .t4w-site-card,
.t4w-admin-body .t4w-choice-card,
.t4w-admin-body .t4w-onboarding-card,
.t4w-admin-body .t4w-status-item-row,
.t4w-admin-body .t4w-notif-card,
.t4w-admin-body .t4w-embed-panel,
.t4w-admin-body .t4w-stat-card.t4w-panel,
.t4w-admin-body .t4w-tariff-pick,
.t4w-admin-body .t4w-metric-tile,
.t4w-admin-body .t4w-list__item {
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.t4w-admin-body .t4w-site-card:hover,
.t4w-admin-body .t4w-choice-card:hover,
.t4w-admin-body .t4w-onboarding-card:hover,
.t4w-admin-body .t4w-status-item-row:hover,
.t4w-admin-body .t4w-notif-card:hover,
.t4w-admin-body .t4w-embed-panel:hover,
.t4w-admin-body .t4w-stat-card.t4w-panel:hover,
.t4w-admin-body .t4w-tariff-pick:hover:not(.t4w-tariff-pick--disabled),
.t4w-admin-body .t4w-metric-tile:hover,
.t4w-admin-body .t4w-stat-card--filter:hover,
.t4w-admin-body a.t4w-stat-card:hover,
.t4w-admin-body .t4w-list__item:hover {
    border-color: var(--t4w-primary) !important;
    box-shadow: 0 0 0 1px var(--t4w-primary), var(--t4w-shadow) !important;
    color: inherit;
    text-decoration: none;
}

.t4w-admin-body .t4w-choice-card:hover {
    background: var(--t4w-bg) !important;
}

.t4w-admin-body .t4w-choice-card:has(.form-check-input:checked) {
    border-color: var(--t4w-primary) !important;
    background: color-mix(in srgb, var(--t4w-primary) 14%, var(--t4w-bg)) !important;
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--t4w-primary) 28%, transparent) !important;
}

.t4w-admin-body .t4w-onboarding-card.is-active:hover,
.t4w-admin-body .t4w-panel--accent.is-active:hover {
    border-color: var(--t4w-primary) !important;
}

.t4w-admin-body .table,
.t4w-admin-body table.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--t4w-text);
    --bs-table-hover-bg: transparent;
    --bs-table-hover-color: var(--t4w-text);
    --bs-table-active-bg: transparent;
    --bs-table-active-color: var(--t4w-text);
    --bs-table-striped-bg: transparent;
    --bs-table-striped-color: var(--t4w-text);
}

.t4w-admin-body .table-hover tbody tr,
.t4w-admin-body table tbody tr {
    transition: box-shadow 0.15s ease;
}

.t4w-admin-body .table-hover tbody tr:hover,
.t4w-admin-body table.table-hover tbody tr:hover,
.t4w-admin-body table tbody tr:hover,
.t4w-admin-page .table-hover tbody tr:hover {
    background-color: transparent !important;
    --bs-table-bg-state: transparent;
    --bs-table-color-state: var(--t4w-text);
    box-shadow: inset 0 0 0 2px var(--t4w-primary);
}

.t4w-admin-body .table-hover tbody tr.t4w-table-row--empty:hover,
.t4w-admin-body .table-hover tbody tr:hover:has(.t4w-empty),
.t4w-admin-page .table-hover tbody tr.t4w-table-row--empty:hover,
.t4w-admin-page .table-hover tbody tr:hover:has(.t4w-empty) {
    box-shadow: none !important;
}

.t4w-service-security-table {
    table-layout: fixed;
    width: 100%;
}

.t4w-admin-body .table-hover tbody tr:hover > *,
.t4w-admin-body table tbody tr:hover > td,
.t4w-admin-body table tbody tr:hover > th,
.t4w-admin-page .table-hover tbody tr:hover > * {
    color: var(--t4w-text) !important;
    background-color: transparent !important;
    --bs-table-bg-state: transparent;
    --bs-table-color-state: var(--t4w-text);
    box-shadow: none;
}

.t4w-admin-body .table-hover tbody tr:hover .fw-semibold,
.t4w-admin-body .table-hover tbody tr:hover .t4w-link-sm,
.t4w-admin-body .table-hover tbody tr:hover a:not(.btn) {
    color: var(--t4w-link) !important;
}

.t4w-admin-body .table-hover tbody tr:hover .btn-link.text-danger,
.t4w-admin-body .table-hover tbody tr:hover .text-danger {
    color: var(--t4w-status-bad) !important;
}

.t4w-admin-body .table-hover tbody tr:hover .t4w-status-off {
    color: var(--t4w-placeholder) !important;
}

/* tailwind hover:bg-* на блоках — обводка вместо заливки */
.t4w-admin-page tr.hover\:bg-gray-50:hover,
.t4w-admin-page tr.hover\:bg-gray-100:hover,
.t4w-admin-page .hover\:bg-gray-50:hover:not(.btn):not(.sidebar-item):not(.dropdown-item),
.t4w-admin-page .hover\:bg-gray-100:hover:not(.btn):not(.sidebar-item):not(.dropdown-item) {
    background-color: transparent !important;
    border-color: var(--t4w-primary) !important;
    box-shadow: inset 0 0 0 2px var(--t4w-primary);
}

.t4w-admin-page a.hover\:bg-gray-50:hover,
.t4w-admin-page a.bg-white.hover\:bg-gray-50:hover {
    background: var(--t4w-surface) !important;
    border-color: var(--t4w-primary) !important;
    box-shadow: 0 0 0 1px var(--t4w-primary) !important;
    color: var(--t4w-text) !important;
}

/* ——— Модальные окна (JS вставляет в body, вне .t4w-admin-page) ——— */
.t4w-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 1050;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 2rem 1rem;
    overflow-y: auto;
    background: rgba(15, 23, 42, 0.78);
}

.t4w-modal-overlay--wide .t4w-modal__dialog {
    max-width: 48rem;
}

.t4w-modal__dialog {
    width: 100%;
    max-width: 28rem;
    margin: 0 auto;
}

.t4w-modal__box {
    background: var(--t4w-surface);
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    box-shadow: var(--t4w-shadow);
    padding: 1.5rem;
    color: var(--t4w-text);
}

.t4w-modal__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    margin: 0 auto 1rem;
    border-radius: 999px;
    font-size: 1.35rem;
}

.t4w-modal__icon--ok {
    background: color-mix(in srgb, var(--t4w-status-ok) 22%, var(--t4w-surface));
    color: var(--t4w-status-ok);
}

.t4w-modal__icon--bad {
    background: color-mix(in srgb, var(--t4w-status-bad) 22%, var(--t4w-surface));
    color: var(--t4w-status-bad);
}

.t4w-modal__title {
    margin: 0 0 1rem;
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--t4w-text-bright);
    text-align: center;
}

.t4w-modal__rows {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    font-size: 0.9375rem;
}

.t4w-modal__row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: baseline;
}

.t4w-modal__row dt,
.t4w-modal__row-label {
    font-weight: 600;
    color: var(--t4w-muted-strong);
    flex-shrink: 0;
}

.t4w-modal__row dd,
.t4w-modal__row-value {
    margin: 0;
    text-align: right;
    color: var(--t4w-text);
    word-break: break-word;
}

.t4w-modal__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 1.5rem;
}

.t4w-modal-overlay--confirm {
    align-items: center;
    padding: 1.5rem 1rem;
    opacity: 0;
    transition: opacity 0.18s ease;
}

.t4w-modal-overlay--confirm.t4w-modal-overlay--visible {
    opacity: 1;
}

.t4w-modal-overlay--confirm.t4w-modal-overlay--closing {
    opacity: 0;
}

.t4w-modal-overlay--confirm .t4w-modal__dialog {
    transform: translateY(12px) scale(0.98);
    opacity: 0;
    transition: transform 0.22s ease, opacity 0.22s ease;
}

.t4w-modal-overlay--confirm.t4w-modal-overlay--visible .t4w-modal__dialog {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.t4w-modal-overlay--confirm.t4w-modal-overlay--closing .t4w-modal__dialog {
    transform: translateY(8px) scale(0.98);
    opacity: 0;
}

.t4w-modal__box--confirm {
    padding: 1.75rem 1.5rem 1.5rem;
}

.t4w-modal__icon--ask {
    background: color-mix(in srgb, var(--t4w-primary) 22%, var(--t4w-surface));
    color: var(--t4w-primary);
}

.t4w-modal__icon--warn {
    background: color-mix(in srgb, var(--t4w-status-bad) 22%, var(--t4w-surface));
    color: var(--t4w-status-bad);
}

.t4w-modal__message-wrap {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.t4w-modal__message {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.55;
    color: var(--t4w-muted-strong);
    text-align: center;
}

.t4w-modal__message--lead {
    color: var(--t4w-text-bright);
    font-size: 1rem;
    font-weight: 600;
}

.t4w-modal__actions--confirm {
    justify-content: stretch;
    gap: 0.75rem;
    margin-top: 1.75rem;
}

.t4w-modal__actions--confirm .btn {
    flex: 1 1 0;
    min-height: 2.75rem;
    padding-inline: 1rem;
}

body.t4w-modal-open {
    overflow: hidden;
}

.t4w-callout {
    border-radius: var(--t4w-radius);
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    line-height: 1.45;
    border: 1px solid var(--t4w-border);
    color: var(--t4w-text);
}

.t4w-callout--info {
    background: color-mix(in srgb, var(--t4w-primary) 14%, var(--t4w-surface));
    border-color: color-mix(in srgb, var(--t4w-primary) 55%, var(--t4w-border));
}

.t4w-callout--info strong {
    color: #fff;
}

.t4w-callout--danger {
    background: color-mix(in srgb, var(--t4w-status-bad) 16%, var(--t4w-surface));
    border-color: var(--t4w-status-bad);
}

.t4w-callout--danger strong {
    color: var(--t4w-text-bright);
}

.t4w-security-feed__table-wrap {
    max-height: 28rem;
    overflow: auto;
}

.t4w-security-feed__table thead th {
    position: sticky;
    top: 0;
    z-index: 1;
    background: var(--t4w-surface);
    font-size: 0.75rem;
    white-space: nowrap;
}

.t4w-security-feed__table td {
    vertical-align: top;
    border-color: var(--t4w-border);
}

.t4w-security-feed__row--new {
    animation: t4w-security-feed-flash 1.2s ease-out;
}

@keyframes t4w-security-feed-flash {
    from {
        background: color-mix(in srgb, var(--t4w-status-warn) 35%, transparent);
    }
    to {
        background: transparent;
    }
}

.t4w-security-feed__status--live {
    color: var(--t4w-status-ok);
}

.t4w-doc-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.8125rem;
    margin-bottom: 0;
}

.t4w-doc-breadcrumb__link {
    color: var(--t4w-muted);
    text-decoration: none;
}

.t4w-doc-breadcrumb__link:hover {
    color: var(--t4w-accent);
}

.t4w-doc-breadcrumb__sep {
    color: var(--t4w-border);
    user-select: none;
}

.t4w-doc-nav__link {
    display: block;
    padding: 0.45rem 0.65rem;
    border-radius: 0.375rem;
    font-size: 0.875rem;
    color: var(--t4w-muted);
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

.t4w-doc-nav__link:hover {
    color: var(--t4w-text);
    background: color-mix(in srgb, var(--t4w-accent) 12%, transparent);
}

.t4w-doc-nav__link--active {
    color: var(--t4w-text-bright);
    background: color-mix(in srgb, var(--t4w-accent) 22%, transparent);
}

.t4w-doc-prose h2 {
    font-size: 1.15rem;
    margin: 1.5rem 0 0.75rem;
    color: var(--t4w-text-bright);
}

.t4w-doc-prose h2:first-child {
    margin-top: 0;
}

.t4w-doc-prose h3 {
    font-size: 1rem;
    margin: 1.25rem 0 0.5rem;
    color: var(--t4w-text);
}

.t4w-doc-prose p,
.t4w-doc-prose li {
    font-size: 0.9rem;
    color: var(--t4w-muted);
    line-height: 1.55;
}

.t4w-doc-prose a {
    color: var(--t4w-accent);
}

.t4w-doc-prose ul,
.t4w-doc-prose ol {
    padding-left: 1.25rem;
    margin-bottom: 1rem;
}

.t4w-doc-section {
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-doc-section:last-child {
    border-bottom: none;
}

.t4w-doc-faq h3 {
    font-size: 0.95rem;
    margin-top: 1rem;
}

/* Legacy Tailwind (светлая тема) — читаемо на Midnight, в т.ч. модалки на body */
body.t4w-admin-body .text-gray-900,
body.t4w-admin-body .text-gray-800 {
    color: var(--t4w-text-bright) !important;
}

body.t4w-admin-body .text-gray-700,
body.t4w-admin-body .text-gray-600,
body.t4w-admin-body .text-gray-500 {
    color: var(--t4w-muted) !important;
}

body.t4w-admin-body .text-blue-800,
body.t4w-admin-body .text-blue-700,
body.t4w-admin-body .text-indigo-800,
body.t4w-admin-body .text-indigo-700 {
    color: var(--t4w-text) !important;
}

body.t4w-admin-body .text-red-800,
body.t4w-admin-body .text-red-700 {
    color: var(--t4w-status-bad) !important;
}

body.t4w-admin-body .text-green-800,
body.t4w-admin-body .text-green-700 {
    color: var(--t4w-status-ok) !important;
}

body.t4w-admin-body .bg-red-50,
body.t4w-admin-body .bg-red-100 {
    background: color-mix(in srgb, var(--t4w-status-bad) 16%, var(--t4w-surface)) !important;
    border-color: var(--t4w-status-bad) !important;
}

body.t4w-admin-body .bg-blue-50,
body.t4w-admin-body .bg-blue-100,
body.t4w-admin-body .bg-indigo-50 {
    background: color-mix(in srgb, var(--t4w-primary) 14%, var(--t4w-surface)) !important;
}

body.t4w-admin-body .border-blue-200,
body.t4w-admin-body .border-red-200,
body.t4w-admin-body .border-indigo-200 {
    border-color: var(--t4w-border) !important;
}

body.t4w-admin-body .bg-blue-600,
body.t4w-admin-body .bg-blue-600:hover,
body.t4w-admin-body .hover\:bg-blue-700:hover {
    background-color: var(--t4w-primary) !important;
    color: var(--t4w-on-primary) !important;
    border: none;
}

body.t4w-admin-body .fixed.inset-0.bg-gray-600,
body.t4w-admin-body .t4w-modal-overlay {
    background: rgba(15, 23, 42, 0.78) !important;
}

body.t4w-admin-body .fixed .bg-white,
body.t4w-admin-body .t4w-modal__box {
    background: var(--t4w-surface) !important;
    border-color: var(--t4w-border) !important;
    color: var(--t4w-text) !important;
}

.t4w-drop-zone--active {
    border-color: var(--t4w-primary) !important;
    background: color-mix(in srgb, var(--t4w-primary) 12%, var(--t4w-surface)) !important;
}

.t4w-mini-stat {
    padding: 0.75rem 1rem;
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    background: color-mix(in srgb, var(--t4w-bg) 40%, var(--t4w-surface));
}

.t4w-mini-stat__value {
    margin-top: 0.35rem;
    font-size: 1rem;
    font-weight: 600;
    color: var(--t4w-text-bright);
}

.t4w-feed-list__item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.25rem 0;
    font-size: 0.8125rem;
}

.t4w-monitoring-list-results > .t4w-panel--info {
    margin-bottom: 1rem;
}

.t4w-monitoring-list-results > .t4w-panel--info + [data-t4w-monitoring-grid] {
    margin-top: 0;
}

.t4w-monitoring-card__head {
    align-items: flex-start;
    border-color: var(--t4w-border) !important;
}

.t4w-monitoring-card__head-inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
    min-width: 0;
}

.t4w-monitoring-card__identity {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
    flex: 1 1 auto;
}

.t4w-monitoring-card__title {
    margin: 0 0 0.25rem;
    font-size: 0.9375rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--t4w-text-bright);
    word-break: break-word;
}

.t4w-monitoring-card__details {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
}

.t4w-monitoring-card__row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
    font-size: 0.875rem;
}

.t4w-monitoring-card__actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
    border-top: 1px solid var(--t4w-border);
}

.t4w-monitoring-card__open {
    flex: 0 1 auto;
    min-width: 8rem;
    max-width: 12.5rem;
}

.t4w-mobile-detail-card {
    background: color-mix(in srgb, var(--t4w-muted) 8%, var(--t4w-surface));
    border: 1px solid var(--t4w-border);
    border-radius: var(--t4w-radius);
    padding: 1rem;
}

.t4w-code-chip {
    display: inline-block;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-size: 0.75rem;
    padding: 0.2rem 0.45rem;
    border-radius: 6px;
    background: color-mix(in srgb, var(--t4w-muted) 14%, var(--t4w-bg));
    border: 1px solid var(--t4w-border);
    color: var(--t4w-text);
}

.t4w-status-warn {
    color: var(--t4w-status-warn);
}

.t4w-incident-row {
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-incident-row:last-child {
    border-bottom: none;
}

.t4w-border-subtle {
    border-color: var(--t4w-border) !important;
}

.t4w-surface-muted {
    background: color-mix(in srgb, var(--t4w-muted) 12%, var(--t4w-surface)) !important;
}

.t4w-support-msg {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--t4w-border);
}

.t4w-support-msg--user {
    background: color-mix(in srgb, var(--t4w-primary) 6%, var(--t4w-surface));
}

.t4w-support-msg--staff {
    background: var(--t4w-surface);
}

.t4w-code-block--terminal {
    background: color-mix(in srgb, var(--t4w-bg) 90%, #000);
    color: #4ade80;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    padding: 1rem;
    border-radius: var(--t4w-radius);
    border: 1px solid var(--t4w-border);
}

.t4w-admin-page .border-t.t4w-border-subtle,
.t4w-admin-page .border.t4w-border-subtle {
    border-color: var(--t4w-border) !important;
}

