/* =========================================================
   ЛЕБІГОЛЯНДІЯ — INDUSTRIAL UI
   Полная замена старого css/style.css
   ========================================================= */

/* ---------- TOKENS ---------- */
:root {
    --bg-primary: #0d0f11;
    --bg-secondary: #131619;
    --bg-card: #1b1e22;
    --bg-elevated: #22262a;
    --bg-input: #101316;

    --border: #3c4146;
    --border-soft: #2b3035;
    --border-strong: #676c71;

    --accent: #c92a20;
    --accent-hover: #e13a30;
    --accent-dark: #79110c;
    --accent-soft: rgba(201, 42, 32, 0.14);

    --danger: #e3483f;
    --warning: #d9a41b;
    --success: #3aa66b;
    --twitch: #9146ff;

    --text-primary: #f1efe9;
    --text-secondary: #c0c3c5;
    --text-muted: #8d9296;
    --text-inverse: #17191b;

    --industrial-yellow: #e0aa18;
    --industrial-steel: #353a3f;

    --radius-sm: 0;
    --radius-md: 0;
    --radius-lg: 0;

    --shadow-sm: 3px 3px 0 rgba(0, 0, 0, 0.24);
    --shadow-md: 5px 5px 0 rgba(0, 0, 0, 0.29);
    --shadow-lg: 9px 9px 0 rgba(0, 0, 0, 0.34);
    --shadow-glow: none;

    --gradient-primary: linear-gradient(180deg, #df3b31 0%, #a91610 100%);
    --gradient-panel: linear-gradient(180deg, #1d2024 0%, #111315 100%);
    --transition: 0.16s ease;
}

body.light {
    --bg-primary: #d6d3cb;
    --bg-secondary: #e1ded6;
    --bg-card: #e9e6de;
    --bg-elevated: #f0ede5;
    --bg-input: #f4f1e9;

    --border: #8d8c86;
    --border-soft: #b5b2aa;
    --border-strong: #666863;

    --text-primary: #191b1d;
    --text-secondary: #44484b;
    --text-muted: #6f7374;
    --text-inverse: #f3f1ea;

    --shadow-sm: 3px 3px 0 rgba(0, 0, 0, 0.13);
    --shadow-md: 5px 5px 0 rgba(0, 0, 0, 0.16);
    --shadow-lg: 9px 9px 0 rgba(0, 0, 0, 0.2);

    background-image:
        linear-gradient(rgba(255, 255, 255, 0.11), rgba(0, 0, 0, 0.028)),
        repeating-linear-gradient(0deg, transparent 0 3px, rgba(0, 0, 0, 0.014) 4px),
        radial-gradient(circle at 18% 22%, rgba(0, 0, 0, 0.045) 0 1px, transparent 2px);
}

/* ---------- RESET ---------- */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    min-height: 100%;
    overflow-y: scroll;
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    margin: 0;
    overflow-x: hidden;
    color: var(--text-primary);
    background-color: var(--bg-primary);
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.012), rgba(0, 0, 0, 0.045)),
        repeating-linear-gradient(0deg, transparent 0 3px, rgba(255, 255, 255, 0.008) 4px),
        radial-gradient(circle at 18% 22%, rgba(255, 255, 255, 0.025) 0 1px, transparent 2px);
    background-size: auto, auto, 41px 41px;
    font-family: "Roboto Condensed", "Inter Tight", Inter, system-ui, sans-serif;
    letter-spacing: 0.01em;
}


button,
input,
textarea,
select {
    font: inherit;
}

button {
    color: inherit;
}

img {
    display: block;
    max-width: 100%;
}

a {
    color: inherit;
}

.hidden {
    display: none !important;
}

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

::selection {
    color: #fff;
    background: var(--accent);
}

/* ---------- FOCUS / NO PURPLE GLOW ---------- */
button,
a,
input,
textarea,
select,
[role="button"] {
    text-shadow: none;
    filter: none;
}

button:focus,
a:focus,
input:focus,
textarea:focus,
select:focus {
    outline: none;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[role="button"]:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    box-shadow: none;
}

input[type="checkbox"],
input[type="radio"] {
    accent-color: var(--accent);
}

/* ---------- SCROLLBAR ---------- */
* {
    scrollbar-color: var(--industrial-steel) var(--bg-primary);
    scrollbar-width: thin;
}

::-webkit-scrollbar {
    width: 11px;
    height: 11px;
}

::-webkit-scrollbar-track {
    background: var(--bg-primary);
    border-left: 1px solid var(--border-soft);
}

::-webkit-scrollbar-thumb {
    background: repeating-linear-gradient(135deg, #3c4146 0 6px, #24282c 6px 12px);
    border: 1px solid #111315;
}

::-webkit-scrollbar-thumb:hover {
    background: repeating-linear-gradient(135deg, var(--accent) 0 6px, var(--accent-dark) 6px 12px);
}

/* ---------- LOADER ---------- */
.app-loader {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    color: var(--text-primary);
    background: var(--bg-primary);
    transition: opacity 0.25s ease;
}

.app-loader.hidden {
    opacity: 0;
    pointer-events: none;
}

.loader-logo {
    font-size: 3.4rem;
    animation: pulse 1.25s infinite;
}

.loader-title {
    font-family: "Russo One", sans-serif;
    font-size: 1.05rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* =========================================================
   HEADER
   ========================================================= */
.header {
    position: sticky;
    top: 0;
    z-index: 1000;
    width: 100%;
    overflow: visible;
    color: #f2f0e9;
    background: linear-gradient(180deg, #191c1f 0%, #0d0f11 100%);
    border-bottom: 3px solid var(--accent);
    box-shadow: 0 5px 0 rgba(0, 0, 0, 0.2);
}

.header::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -3px;
    height: 3px;
    pointer-events: none;
    background: repeating-linear-gradient(135deg, var(--accent) 0 12px, #71100b 12px 18px);
}

.header-inner {
    width: 100%;
    max-width: 1580px;
    min-height: 94px;
    margin: 0 auto;
    padding: 12px 28px 8px;
    display: grid;
    grid-template-columns: 235px minmax(280px, 1fr) auto;
    grid-template-rows: 44px 34px;
    align-items: center;
    gap: 7px 22px;
    overflow: visible;
}

.header-center {
    min-width: 0;
}

/* Logo: supports the current industrial markup and old fallback markup. */
.logo,
.logo.industrial-logo {
    grid-column: 1;
    grid-row: 1;
    position: relative;
    top: 2px;
    width: fit-content;
    max-width: 230px;
    min-height: 40px;
    margin: 0;
    padding: 0;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    overflow: visible;
    color: #f2f0e9 !important;
    background: none !important;
    border: 0 !important;
    box-shadow: none !important;
    text-decoration: none;
    transform: none !important;
}

.logo::before,
.logo::after,
.logo.industrial-logo::before,
.logo.industrial-logo::after {
    content: none !important;
    display: none !important;
}

.logo-avatar,
.logo > img {
    width: 36px;
    height: 36px;
    flex: 0 0 36px;
    object-fit: cover;
    border: 2px solid #70757a;
    border-radius: 50%;
    box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.45);
}

.industrial-logo-signal {
    width: 8px;
    height: 32px;
    flex: 0 0 8px;
    background: repeating-linear-gradient(0deg, #e43b31 0 7px, #93130d 7px 12px);
    box-shadow: 3px 0 0 rgba(0, 0, 0, 0.28);
    transform: skewX(-8deg);
}

.industrial-logo-copy {
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 3px;
}

.industrial-logo-name,
.industrial-logo-text,
.logo-text,
.logo > span {
    display: block;
    color: #f2f0e9 !important;
    -webkit-text-fill-color: #f2f0e9 !important;
    background: none !important;
    font-family: "Russo One", Impact, sans-serif;
    font-size: 1.04rem;
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.035em;
    white-space: nowrap;
    text-shadow: 2px 2px 0 #000 !important;
}

.industrial-logo-subtitle {
    display: block;
    color: #90959a !important;
    font-size: 0.53rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    white-space: nowrap;
}

/* Search */
.search-section {
    grid-column: 2;
    grid-row: 1;
    width: 100%;
    max-width: 620px;
    min-height: 40px;
    justify-self: center;
    display: flex;
    align-items: center;
    overflow: hidden;
    color: #f3f1eb;
    background: #090b0c;
    border: 1px solid #44494e;
    border-left: 4px solid #666b70;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.search-section:focus-within {
    border-color: var(--accent);
    border-left-color: var(--accent);
    box-shadow: inset 4px 0 0 var(--accent);
}

.search-icon {
    padding: 0 11px;
    color: #8c9195;
    font-size: 0.88rem;
}

.search-section input {
    min-width: 0;
    flex: 1;
    margin: 0;
    padding: 9px 10px 9px 0;
    color: #f3f1eb;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.search-section input::placeholder {
    color: #6f7478;
}

.clear-search-btn {
    width: 40px;
    height: 38px;
    padding: 0;
    color: #8f9498;
    background: transparent;
    border: 0;
    cursor: pointer;
}

.clear-search-btn:hover {
    color: #fff;
    background: var(--accent-soft);
}

/* User area */
.user-area,
.header-user-panel {
    grid-column: 3;
    grid-row: 1;
    min-width: 0;
    justify-self: end;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: nowrap;
    white-space: nowrap;
}

.header-profile,
.user-pill {
    min-height: 38px;
    padding: 4px 9px 4px 4px;
    display: inline-flex;
    align-items: center;
    gap: 9px;
    color: #f1efe8;
    background: #171a1d;
    border: 1px solid #3c4146;
    border-left: 3px solid var(--accent);
    cursor: pointer;
}

.header-profile .feed-card-avatar,
.header-profile img {
    width: 29px !important;
    height: 29px !important;
    min-width: 29px;
    object-fit: cover;
    border: 1px solid #74787c;
    border-radius: 50%;
}

.header-profile-name {
    max-width: 130px;
    overflow: hidden;
    color: #f1efe8;
    font-size: 0.9rem;
    font-weight: 800;
    text-overflow: ellipsis;
}

.header-role-badge {
    font-size: 0.78rem;
}

.header-actions-group {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0 9px;
    border-left: 1px solid #393d41;
    border-right: 1px solid #393d41;
}

.header-icon-btn,
.header-theme-btn,
.theme-btn,
.icon-action-btn,
.notification-btn {
    position: relative;
    width: 38px;
    height: 38px;
    min-width: 38px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #b5b8ba;
    background: linear-gradient(180deg, #22262a, #121416);
    border: 1px solid #464b50;
    box-shadow: none;
    cursor: pointer;
    transition: color var(--transition), border-color var(--transition), background var(--transition), transform var(--transition);
}

.header-icon-btn:hover,
.header-theme-btn:hover,
.theme-btn:hover,
.icon-action-btn:hover,
.notification-btn:hover {
    color: #fff;
    background: #2a2f34;
    border-color: var(--accent);
    transform: translateY(-1px);
}

.header-icon-btn .fa-star,
.icon-action-btn .fa-star {
    color: var(--industrial-yellow);
}

.header-icon-btn .fa-bell {
    color: #e0e1de;
}

.header-icon-btn.active,
.header-icon-btn.is-active {
    color: #fff;
    background: var(--accent);
    border-color: #ef4d43;
}

.header-admin-btn {
    min-height: 38px;
    padding: 0 15px;
    color: #f1efe8;
    background: #171a1d;
    border: 1px solid #464b50;
    font-weight: 900;
    cursor: pointer;
}

.header-admin-btn:hover {
    color: #fff;
    background: #282d31;
    border-color: var(--accent);
}

.notification-badge,
.header-notification-badge,
.notifications-badge,
.unread-badge {
    position: absolute;
    top: -5px;
    right: -5px;
    min-width: 17px;
    height: 17px;
    padding: 0 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--danger);
    border: 2px solid #111315;
    font-family: Arial, sans-serif;
    font-size: 9px;
    font-weight: 900;
}

/* Main tabs / navigation: separate second line */
.header-nav,
.header-tabs,
.main-tabs,
.site-tabs {
    grid-column: 1 / -1;
    grid-row: 2;
    align-self: end;
    justify-self: center;
    min-height: 32px;
    margin: 0;
    display: inline-flex;
    align-items: stretch;
    justify-content: center;
    gap: 2px;
    background: #0b0d0f;
    border: 1px solid #363a3e;
}

.nav-tab,
.header-tab,
.main-tab,
.site-tab {
    min-width: 110px;
    min-height: 30px;
    padding: 6px 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    color: #adb1b4;
    background: #191c1f;
    border: 0;
    border-right: 1px solid #383c40;
    box-shadow: none;
    font-size: 0.79rem;
    font-weight: 900;
    letter-spacing: 0.075em;
    text-transform: uppercase;
    cursor: pointer;
}

.nav-tab:last-child,
.header-tab:last-child,
.main-tab:last-child,
.site-tab:last-child {
    border-right: 0;
}

.nav-tab:hover,
.header-tab:hover,
.main-tab:hover,
.site-tab:hover {
    color: #fff;
    background: #292d31;
}

.nav-tab.active,
.header-tab.active,
.main-tab.active,
.site-tab.active {
    color: #fff;
    background: var(--accent);
    border-color: var(--accent);
    box-shadow: inset 0 -3px 0 var(--accent-dark);
}

/* =========================================================
   LAYOUT / CONTROLS
   ========================================================= */
.container {
    width: 100%;
    max-width: 1580px;
    margin: 0 auto;
    padding: 22px 28px 55px;
}

.stats-bar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 18px;
}

.stat-card,
.admin-metric-card {
    padding: 17px;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 4px solid var(--industrial-steel);
    box-shadow: var(--shadow-sm);
}

.stat-value,
.admin-metric-card strong {
    display: block;
    color: var(--accent);
    font-size: 1.55rem;
    font-weight: 900;
}

.stat-label,
.admin-metric-card span {
    margin-top: 5px;
    color: var(--text-muted);
}

.controls {
    position: relative;
    width: 100%;
    margin-bottom: 20px;
    padding: 9px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    background: var(--gradient-panel);
    border: 1px solid #3e4348;
    border-left: 5px solid var(--accent);
    box-shadow: var(--shadow-sm);
}

.controls::before,
.controls::after {
    content: "";
    position: absolute;
    top: 5px;
    width: 5px;
    height: 5px;
    background: #6f7478;
    border: 1px solid #08090a;
}

.controls::before { left: 5px; }
.controls::after { right: 5px; }

.controls-row {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.filters {
    min-width: 0;
    display: flex;
    align-items: stretch;
    gap: 2px;
    flex-wrap: wrap;
}

.filter-btn,
.cat-btn,
.notif-filter,
.activity-legend-item {
    min-height: 34px;
    padding: 7px 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    color: #b2b5b7;
    background: #202428;
    border: 1px solid #3b4045;
    box-shadow: none;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.035em;
    text-transform: uppercase;
    cursor: pointer;
}

body.light .filter-btn,
body.light .cat-btn,
body.light .notif-filter,
body.light .activity-legend-item {
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

.filter-btn:hover,
.cat-btn:hover,
.notif-filter:hover,
.activity-legend-item:hover {
    color: #fff;
    background: #30353a;
    border-color: #6f7478;
}

.filter-btn.active,
.cat-btn.active,
.notif-filter.active {
    color: #fff;
    background: var(--gradient-primary);
    border-color: #ef4d43;
    box-shadow: inset 0 -3px 0 var(--accent-dark);
}

.filter-btn .count,
.count {
    min-width: 18px;
    padding: 0 4px;
    color: #d4d6d7;
    background: #111315;
    border: 1px solid #4b5055;
    font-family: Arial, sans-serif;
    font-size: 0.66rem;
    line-height: 16px;
    text-align: center;
}

.filter-btn.active .count {
    color: #fff;
    background: rgba(0, 0, 0, 0.28);
    border-color: rgba(255, 255, 255, 0.22);
}

.filter-my {
    position: relative;
    padding-left: 22px;
}

.filter-my::before {
    content: "";
    position: absolute;
    left: 10px;
    top: 50%;
    width: 6px;
    height: 6px;
    background: var(--accent);
    transform: translateY(-50%);
}

.filter-my.active::before {
    background: #fff;
}

.approved-filter-icon {
    color: var(--industrial-yellow);
    font-size: 0.8rem;
}

.filter-btn.active .approved-filter-icon {
    color: #fff;
}

#sortSelect,
.sort-select,
.sort-pill,
.controls select,
.compact-input {
    width: auto;
    min-width: 130px;
    min-height: 34px;
    margin: 0;
    padding: 6px 34px 6px 11px;
    color: #d3d5d6;
    background: #171a1d;
    border: 1px solid #494e53;
    box-shadow: none;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
}

body.light #sortSelect,
body.light .sort-select,
body.light .sort-pill,
body.light .controls select,
body.light .compact-input {
    color: var(--text-primary);
    background: var(--bg-input);
    border-color: var(--border);
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn,
.add-video-btn,
.btn-add-video,
#openAddModal,
.donate-add-btn,
.donate-participate-btn,
.my-videos-btn,
.twitch-login-btn {
    min-height: 38px;
    padding: 8px 15px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: #fff;
    background: var(--gradient-primary);
    border: 1px solid #ed4b41;
    border-left: 5px solid var(--accent-dark);
    box-shadow: var(--shadow-sm);
    font-size: 0.8rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-decoration: none;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform var(--transition), background var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.btn:hover,
.add-video-btn:hover,
.btn-add-video:hover,
#openAddModal:hover,
.donate-add-btn:hover,
.donate-participate-btn:hover,
.my-videos-btn:hover,
.twitch-login-btn:hover {
    color: #fff;
    background: linear-gradient(180deg, #ed473d, #bd1a13);
    border-color: #f45a50;
    transform: translate(-1px, -1px);
    box-shadow: var(--shadow-md);
}

.btn:active,
.add-video-btn:active,
.btn-add-video:active,
#openAddModal:active,
.donate-add-btn:active,
.donate-participate-btn:active {
    transform: translate(0, 0);
    box-shadow: 2px 2px 0 rgba(0, 0, 0, 0.24);
}

.btn.outline {
    color: var(--text-secondary);
    background: transparent;
    border: 1px solid var(--border);
    box-shadow: none;
}

.btn.outline:hover {
    color: #fff;
    background: #292d31;
    border-color: var(--accent);
    transform: none;
}

.btn.danger {
    background: linear-gradient(180deg, #ef5148, #aa1812);
    border-color: #f36b63;
    border-left-color: #73100b;
}

.small-btn {
    min-height: 29px;
    padding: 4px 9px;
    font-size: 0.7rem;
}

.add-video-btn,
.add-video-btn::before {
    overflow: hidden;
}

.add-video-btn::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.22) 45%, transparent 70%);
    transform: translateX(-120%);
    transition: transform 0.45s ease;
}

.add-video-btn:hover::before {
    transform: translateX(120%);
}

.add-video-btn {
    position: relative;
    margin-left: auto;
}

.my-videos-btn.active {
    background: linear-gradient(180deg, #45b779, #25744d);
    border-color: #63c58e;
    border-left-color: #174a31;
}

/* Twitch retains brand color, without glow. */
.twitch-login-btn {
    background: linear-gradient(180deg, #9146ff, #6e2bd8);
    border-color: #aa72ff;
    border-left-color: #43158f;
    box-shadow: var(--shadow-sm);
}

/* =========================================================
   VIDEO GRID / CARDS
   ========================================================= */
.video-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
    align-items: stretch;
    gap: 15px;
}

.feed-card {
    position: relative;
    min-width: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-top: 4px solid var(--industrial-steel);
    box-shadow: var(--shadow-md);
    animation: fadeUp 0.25s ease;
    transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.feed-card:hover {
    transform: translate(-2px, -2px);
    border-color: var(--border-strong);
    border-top-color: var(--accent);
    box-shadow: var(--shadow-lg);
}

.feed-card::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 18px;
    height: 18px;
    pointer-events: none;
    background: linear-gradient(135deg, transparent 0 50%, var(--border) 51% 100%);
}

.feed-card-preview,
.feed-card-preview-link {
    position: relative;
    flex: 0 0 auto;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: #08090a;
    border-bottom: 2px solid #23272a;
}

.feed-card-preview::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 48px;
    pointer-events: none;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.78));
}

.video-thumb-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(0.84) contrast(1.06);
    transition: transform 0.18s ease, filter 0.18s ease;
}

.feed-card:hover .video-thumb-image {
    transform: scale(1.025);
    filter: saturate(1) contrast(1.08);
}

.preview-iframe {
    position: absolute;
    inset: 0;
    z-index: 3;
    width: 100%;
    height: 100%;
    border: 0;
}

.video-thumb-duration,
.video-thumb-date {
    position: absolute;
    bottom: 7px;
    z-index: 4;
    padding: 3px 6px;
    color: #fff;
    background: rgba(8, 9, 10, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.18);
    font-size: 0.71rem;
    font-weight: 800;
}

.video-thumb-duration { left: 7px; }
.video-thumb-date { right: 7px; }

.video-card-pin-badge {
    position: absolute;
    top: 7px;
    left: 7px;
    z-index: 5;
    padding: 4px 7px;
    color: #fff;
    background: rgba(18, 20, 22, 0.94);
    border: 1px solid #555a5f;
    border-left: 4px solid var(--industrial-yellow);
    font-size: 0.69rem;
    font-weight: 800;
}

.feed-card-info {
    min-height: 0;
    padding: 11px 12px 13px;
    display: flex;
    flex: 1;
    flex-direction: column;
}

.video-card-top {
    min-height: 32px;
    margin-bottom: 8px;
    padding-bottom: 7px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    border-bottom: 1px solid var(--border-soft);
}

.video-author,
.comment-user {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.feed-card-avatar,
.user-avatar,
.profile-avatar {
    flex: 0 0 auto;
    object-fit: cover;
    color: #fff;
    background: var(--accent);
    border: 1px solid #25282b;
    border-radius: 50%;
    box-shadow: 2px 2px 0 rgba(0, 0, 0, 0.2);
}

.feed-card-avatar {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.profile-avatar {
    width: 96px;
    height: 96px;
}

.feed-card-username {
    max-width: 145px;
    overflow: hidden;
    color: var(--accent-hover);
    font-size: 0.83rem;
    font-weight: 900;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.feed-card-title {
    height: 2.55em;
    min-height: 2.55em;
    max-height: 2.55em;
    margin-bottom: 7px;
    display: -webkit-box;
    overflow: hidden;
    color: var(--text-primary);
    font-size: 0.97rem;
    font-weight: 900;
    line-height: 1.27;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.feed-card-title a {
    color: inherit;
    text-decoration: none;
}

.feed-card-title a:hover {
    color: var(--accent-hover);
}

.video-card-meta {
    min-height: 22px;
    max-height: 22px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
    overflow: hidden;
    color: var(--text-muted);
    font-size: 0.76rem;
}

.video-channel-link {
    min-width: 0;
    overflow: hidden;
    color: var(--text-muted);
    font-weight: 800;
    text-decoration: none;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.video-channel-link:hover {
    color: var(--accent-hover);
}

.video-channel-views {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 5px;
    color: var(--text-muted);
}

.tags-container {
    width: 100%;
    height: 26px;
    min-height: 26px;
    max-height: 26px;
    margin-top: 7px;
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: nowrap;
    overflow: hidden;
}

.tag {
    flex: 0 0 auto;
    max-width: 130px;
    padding: 2px 6px;
    overflow: hidden;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    font-size: 0.68rem;
    font-weight: 700;
    text-overflow: ellipsis;
    text-transform: lowercase;
    white-space: nowrap;
}

.tag:hover {
    color: #fff;
    background: var(--accent);
    border-color: var(--accent-dark);
}

.video-card-actions,
.card-actions,
.video-card-footer,
.moderation-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.card-actions,
.video-card-footer {
    margin-top: auto;
    padding-top: 9px;
}

.feed-card .btn,
.video-card-button,
.video-comment-btn,
.video-favorite-btn {
    min-height: 29px;
    padding: 4px 9px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 1px solid var(--border);
    box-shadow: none;
    font-size: 0.7rem;
    font-weight: 900;
    text-transform: uppercase;
}

.feed-card .btn:hover,
.video-card-button:hover,
.video-comment-btn:hover,
.video-favorite-btn:hover {
    color: #fff;
    background: #292d31;
    border-color: #111315;
    transform: none;
    box-shadow: none;
}

.video-favorite-btn.active,
.video-favorite-btn.is-favorite,
.favorite-active {
    color: #181a1b;
    background: var(--industrial-yellow);
    border-color: #a5790d;
}

.star-rating {
    display: flex;
    gap: 1px;
}

.star-rating i {
    color: #777d81;
    cursor: pointer;
    transition: color var(--transition);
}

.star-rating i.active,
.star-rating i:hover {
    color: var(--industrial-yellow);
    transform: none;
    text-shadow: none;
}

.rating-value {
    color: var(--text-muted);
    font-size: 0.78rem;
}

.video-card-pin {
    padding: 3px;
    color: var(--text-muted);
    background: none;
    border: 0;
    cursor: pointer;
}

.video-card-pin.is-pinned {
    color: var(--industrial-yellow);
}

.video-language-flag,
.video-country-flag {
    border: 1px solid #1a1b1d;
    box-shadow: 2px 2px 0 rgba(0, 0, 0, 0.34);
}

/* =========================================================
   PAGINATION / EMPTY / SKELETON
   ========================================================= */
.pagination {
    margin-top: 28px;
    display: flex;
    justify-content: center;
    gap: 3px;
    flex-wrap: wrap;
}

.page-btn {
    min-width: 36px;
    min-height: 34px;
    padding: 0 9px;
    color: var(--text-secondary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    font-weight: 900;
    cursor: pointer;
}

.page-btn:hover:not(.active) {
    color: #fff;
    background: #292d31;
    border-color: var(--accent);
}

.page-btn.active {
    color: #fff;
    background: var(--accent);
    border-color: var(--accent-dark);
    box-shadow: inset 0 -3px 0 var(--accent-dark);
}

.empty-state {
    padding: 70px 20px;
    color: var(--text-secondary);
    text-align: center;
}

.empty-icon {
    margin-bottom: 16px;
    font-size: 4rem;
}

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

.skeleton-preview {
    aspect-ratio: 16 / 9;
    background: #22262a;
}

.skeleton-content {
    padding: 14px;
}

.skeleton-line {
    height: 12px;
    margin-bottom: 11px;
    background: linear-gradient(90deg, #24282c, #383d42, #24282c);
    background-size: 300% 100%;
    animation: shimmer 1.2s infinite;
}

.skeleton-line-lg { height: 16px; }
.skeleton-line-sm { width: 60%; }

/* =========================================================
   MODALS / FORMS
   ========================================================= */
.modal {
    position: fixed;
    inset: 0;
    z-index: 5000;
    display: none;
    padding: 20px;
    background: rgba(0, 0, 0, 0.76);
    backdrop-filter: blur(3px);
}

.modal.active {
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-content {
    width: 100%;
    max-width: 700px;
    max-height: 90vh;
    padding: 22px;
    overflow: auto;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-top: 6px solid var(--industrial-steel);
    border-left: 6px solid var(--accent);
    box-shadow: var(--shadow-lg);
    animation: modalIn 0.18s ease;
}

.modal-content h1,
.modal-content h2,
.modal-content h3,
.modal-content h4 {
    margin: 0 0 14px;
    padding-bottom: 8px;
    color: var(--text-primary);
    border-bottom: 2px solid var(--border-soft);
    font-family: "Russo One", sans-serif;
    font-weight: 400;
    text-transform: uppercase;
}

.modal-content p,
.modal-content small {
    color: var(--text-secondary);
}

.modal-close-btn {
    width: 38px;
    height: 38px;
    padding: 0;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    cursor: pointer;
}

.modal-close-btn:hover {
    color: #fff;
    background: var(--accent);
    border-color: var(--accent);
}

.confirm-actions,
.profile-actions {
    margin-top: 18px;
    display: flex;
    justify-content: flex-end;
    gap: 9px;
}

.input-field,
textarea,
select,
input[type="text"],
input[type="url"],
input[type="number"],
input[type="password"] {
    width: 100%;
    margin-bottom: 12px;
    padding: 12px 13px;
    color: var(--text-primary);
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-left: 4px solid var(--border-strong);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.12);
}

.input-field:focus,
textarea:focus,
select:focus,
input[type="text"]:focus,
input[type="url"]:focus,
input[type="number"]:focus:focus,
input[type="password"]:focus {
    border-color: var(--accent);
    border-left-color: var(--accent);
    box-shadow: inset 4px 0 0 var(--accent);
}

input::placeholder,
textarea::placeholder {
    color: var(--text-muted);
}

#addVideoModal label,
.add-video-form label,
.modal-content label {
    color: var(--text-primary);
    font-weight: 800;
}

.video-preview-box,
#previewBlock,
.video-preview,
.video-info-preview,
.add-video-preview,
.video-preview-block {
    margin-bottom: 12px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    color: var(--text-primary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}

.video-preview-box img {
    width: 100%;
}

#previewTitle,
#videoPreviewTitle,
.video-preview-title,
.video-info-title,
.add-video-preview h3,
#previewBlock strong {
    color: var(--text-primary);
    font-weight: 900;
}

#previewDescription,
#videoPreviewDescription,
.video-preview-description,
.video-info-description,
.add-video-preview p {
    color: var(--text-secondary);
}

#previewChannel,
#previewViews,
#previewDuration,
.video-preview-meta {
    color: var(--text-muted);
}

.category-buttons {
    margin-bottom: 12px;
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
}

.profile-box {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.avatar-drop {
    padding: 22px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 13px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px dashed var(--border-strong);
    text-align: center;
    cursor: pointer;
}

.avatar-drop.dragover {
    border-color: var(--accent);
    box-shadow: inset 4px 0 0 var(--accent);
}

.empty-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.5rem;
}

/* =========================================================
   COMMENTS
   ========================================================= */
.comments-list {
    max-height: 380px;
    margin-bottom: 14px;
    display: flex;
    flex-direction: column;
    gap: 9px;
    overflow: auto;
}

.comment,
.comment-item {
    padding: 11px 12px;
    color: var(--text-primary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--border-strong);
}

.comment:hover,
.comment-item:hover {
    border-left-color: var(--accent);
}

.comment-head,
.comment-header {
    margin-bottom: 7px;
    display: flex;
    justify-content: space-between;
    gap: 10px;
    color: var(--text-secondary);
}

.comment-author,
.comment-username,
.comment-user-name,
.comment-name,
.comment-nick,
.comment-header strong,
.comment-item strong {
    color: var(--accent-hover);
    font-weight: 900;
    text-decoration: none;
}

.comment-nick.admin-nick {
    color: var(--danger);
    text-shadow: none;
}

.comment-text,
.comment-content,
.comment-message,
.comment p {
    color: var(--text-primary);
}

.comment-date,
.comment-time,
.comment-meta {
    color: var(--text-muted);
}

.comment-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 5px;
}

.comment-role {
    padding: 2px 6px;
    color: var(--danger);
    background: rgba(227, 72, 63, 0.14);
    border: 1px solid rgba(227, 72, 63, 0.35);
    font-size: 0.65rem;
    font-weight: 900;
}

.comment-delete,
.comment-delete-icon {
    padding: 3px;
    color: var(--danger);
    background: transparent;
    border: 0;
    cursor: pointer;
}

.mention-link {
    color: var(--accent-hover);
    font-weight: 900;
    text-decoration: none;
}

/* =========================================================
   NOTIFICATIONS
   ========================================================= */
.notification-filters {
    margin-bottom: 13px;
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
}

.notifications-list,
.notification-list {
    margin-bottom: 15px;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.notification-item {
    padding: 10px 11px;
    display: flex;
    gap: 11px;
    color: var(--text-primary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--border-strong);
}

.notification-item.unread {
    border-left-color: var(--accent);
}

.notification-item.clickable {
    cursor: pointer;
    transition: transform var(--transition), border-color var(--transition), background var(--transition);
}

.notification-item.clickable:hover {
    background: var(--bg-elevated);
    border-color: var(--border-strong);
    border-left-color: var(--accent);
    transform: translateY(-1px);
    box-shadow: none;
}

.notification-icon {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--accent);
    border: 1px solid var(--accent-dark);
}

.notification-content {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.notification-item p,
.notification-item span {
    color: var(--text-secondary);
}

/* =========================================================
   ADMIN
   ========================================================= */
#adminModal .modal-content {
    max-width: 980px;
    padding: 0;
    overflow: hidden;
}

.admin-panel,
.admin-panel-shell,
.admin-card,
.admin-section {
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 5px solid var(--industrial-steel);
    box-shadow: var(--shadow-sm);
}

.admin-panel-shell {
    display: flex;
    flex-direction: column;
    border-left: 0;
    box-shadow: none;
}

.admin-panel-header {
    padding: 21px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    border-bottom: 1px solid var(--border);
}

.admin-panel-header h2 {
    margin: 0;
    color: var(--text-primary);
}

.admin-panel-header p {
    margin-top: 5px;
    color: var(--text-muted);
}

.admin-tabs,
.admin-nav {
    padding: 6px;
    display: flex;
    gap: 2px;
    overflow-x: auto;
    background: #181b1e;
    border-bottom: 1px solid #3e4348;
}

.admin-tab,
.admin-nav-btn {
    min-height: 34px;
    padding: 7px 12px;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    flex: 0 0 auto;
    color: #b3b6b8;
    background: #22262a;
    border: 1px solid #3b4045;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
    white-space: nowrap;
    cursor: pointer;
}

.admin-tab:hover,
.admin-nav-btn:hover {
    color: #fff;
    background: #30353a;
    border-color: var(--accent);
}

.admin-tab.active,
.admin-nav-btn.active {
    color: #fff;
    background: var(--accent);
    border-color: #ef4d43;
}

.admin-tab-page {
    display: none;
    padding: 20px;
}

.admin-tab-page.active {
    display: block;
}

.admin-section {
    margin-bottom: 16px;
    padding: 16px;
}

.admin-section h3 {
    margin: 0 0 13px;
}

.admin-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 11px;
}

.admin-inline-form,
.admin-search-row {
    margin-top: 13px;
    display: flex;
    gap: 9px;
}

.admin-inline-form .input-field,
.admin-search-row .input-field {
    margin: 0;
}

.admin-actions-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
}

.admin-list {
    margin-bottom: 12px;
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
}

.admin-badge {
    padding: 5px 9px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.admin-badge small {
    padding: 2px 5px;
    color: var(--accent-hover);
    background: var(--accent-soft);
    border: 1px solid rgba(201, 42, 32, 0.3);
    font-size: 0.68rem;
}

.remove-admin {
    padding: 2px;
    color: var(--danger);
    background: transparent;
    border: 0;
    cursor: pointer;
}

.admin-table-wrap {
    margin: 13px 0;
    overflow: auto;
    border: 1px solid var(--border);
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
}

.admin-table th,
.admin-table td {
    padding: 11px;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border);
    text-align: left;
}

.admin-table th {
    color: var(--text-muted);
    font-size: 0.76rem;
    text-transform: uppercase;
}

.admin-link-btn {
    color: var(--accent-hover);
    font-weight: 900;
    text-decoration: none;
}

.admin-empty-cell {
    color: var(--text-muted) !important;
    text-align: center !important;
}

.maintenance-switch {
    margin-bottom: 13px;
    display: flex;
    align-items: center;
    gap: 11px;
    cursor: pointer;
}

.maintenance-switch input {
    display: none;
}

.maintenance-switch span {
    position: relative;
    width: 48px;
    height: 27px;
    background: var(--border);
    border: 1px solid var(--border-strong);
}

.maintenance-switch span::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 19px;
    height: 19px;
    background: #fff;
    transition: transform var(--transition);
}

.maintenance-switch input:checked + span {
    background: var(--danger);
}

.maintenance-switch input:checked + span::after {
    transform: translateX(21px);
}

.maintenance-toggle {
    margin: 11px 0;
    display: flex;
    align-items: center;
    gap: 9px;
    color: var(--text-secondary);
}

.activity-head {
    margin-bottom: 16px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 15px;
}

.activity-head p {
    margin-top: 4px;
    color: var(--text-muted);
}

.activity-chart-box {
    height: 360px;
    padding: 15px;
    background: rgba(0, 0, 0, 0.13);
    border: 1px solid var(--border);
}

.activity-legend {
    margin-top: 13px;
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
}

.activity-legend-item span {
    width: 9px;
    height: 9px;
}

.activity-legend-item.muted {
    opacity: 0.28;
}

.moderation-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.moderation-card {
    padding: 13px;
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 15px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.moderation-card img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border: 1px solid var(--border);
}

.moderation-info h4 {
    margin: 0 0 7px;
}

.moderation-info p {
    margin: 0 0 5px;
    color: var(--text-secondary);
}

/* =========================================================
   LISTS / MAINTENANCE / TOASTS
   ========================================================= */
.list-item {
    margin-bottom: 9px;
    padding: 11px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    color: var(--text-primary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--border-strong);
}

.list-item a {
    color: var(--text-primary);
    text-decoration: none;
}

.list-item a:hover {
    color: var(--accent-hover);
}

.maintenance-page {
    min-height: 100vh;
    padding: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-primary);
}

.maintenance-card {
    width: 100%;
    max-width: 520px;
    padding: 39px 26px;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-top: 5px solid var(--accent);
    box-shadow: var(--shadow-lg);
    text-align: center;
}

.maintenance-icon {
    margin-bottom: 16px;
    font-size: 3.6rem;
}

.maintenance-card h1 {
    margin: 0 0 11px;
    color: var(--accent-hover);
}

.maintenance-card p {
    color: var(--text-secondary);
}

.toast-container {
    position: fixed;
    top: 105px;
    right: 20px;
    z-index: 9000;
    display: flex;
    flex-direction: column;
    gap: 9px;
}

.toast {
    min-width: 280px;
    padding: 13px 15px;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-md);
    animation: toastIn 0.22s ease;
}

.toast.success { border-left: 4px solid var(--success); }
.toast.error { border-left: 4px solid var(--danger); }

/* =========================================================
   DONATE ALIASES (main structure remains in donates.css)
   ========================================================= */
.donate-card {
    color: var(--text-primary);
    background: var(--bg-card);
    border-color: var(--border);
    box-shadow: var(--shadow-md);
}

.donate-card:hover {
    border-top-color: var(--accent);
    box-shadow: var(--shadow-lg);
}

.donate-participate-btn {
    text-decoration: none;
}

/* =========================================================
   ANIMATIONS
   ========================================================= */
@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.08); }
}

@keyframes fadeUp {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes modalIn {
    from { opacity: 0; transform: translateY(14px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes toastIn {
    from { opacity: 0; transform: translateX(16px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes shimmer {
    from { background-position: 300% 0; }
    to { background-position: -300% 0; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1100px) {
    .header-inner {
        grid-template-columns: minmax(190px, 1fr) auto;
        grid-template-rows: 42px 38px 34px;
        min-height: 121px;
        padding: 10px 14px 8px;
    }

    .logo,
    .logo.industrial-logo {
        grid-column: 1;
        grid-row: 1;
    }

    .user-area,
    .header-user-panel {
        grid-column: 2;
        grid-row: 1;
    }

    .search-section {
        grid-column: 1 / -1;
        grid-row: 2;
        max-width: none;
    }

    .header-nav,
    .header-tabs,
    .main-tabs,
    .site-tabs {
        grid-column: 1 / -1;
        grid-row: 3;
    }

    .controls {
        align-items: flex-start;
    }

    .admin-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 800px) {
    .container {
        padding: 15px 12px 40px;
    }

    .stats-bar,
    .admin-metrics-grid,
    .admin-actions-grid {
        grid-template-columns: 1fr;
    }

    .controls {
        padding: 7px;
        flex-direction: column;
        align-items: stretch;
    }

    .filters {
        width: 100%;
        flex-wrap: nowrap;
        overflow-x: auto;
        padding-bottom: 4px;
    }

    .filter-btn {
        flex: 0 0 auto;
        white-space: nowrap;
    }

    .controls-row {
        align-items: stretch;
    }

    #sortSelect,
    .sort-select,
    .sort-pill,
    .my-videos-btn,
    .add-video-btn {
        width: 100%;
    }

    .video-grid {
        grid-template-columns: 1fr;
    }

    .admin-inline-form,
    .admin-search-row,
    .activity-head {
        flex-direction: column;
    }

    .activity-chart-box {
        height: 300px;
    }
}

@media (max-width: 700px) {
    .moderation-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 620px) {
    .header-inner {
        grid-template-columns: minmax(145px, 1fr) auto;
        padding-left: 10px;
        padding-right: 10px;
    }

    .industrial-logo-name,
    .industrial-logo-text,
    .logo-text,
    .logo > span {
        font-size: 0.88rem;
    }

    .industrial-logo-subtitle {
        display: none;
    }

    .logo,
    .logo.industrial-logo {
        max-width: 175px;
        top: 3px;
    }

    .header-profile-name {
        display: none;
    }

    .header-actions-group {
        padding: 0 5px;
    }

    .header-icon-btn,
    .header-theme-btn,
    .theme-btn,
    .icon-action-btn,
    .notification-btn {
        width: 34px;
        height: 34px;
        min-width: 34px;
    }

    .header-admin-btn {
        width: 36px;
        padding: 0;
        font-size: 0;
    }

    .header-admin-btn i {
        font-size: 0.9rem;
    }

    .nav-tab,
    .header-tab,
    .main-tab,
    .site-tab {
        min-width: 92px;
        padding: 6px 12px;
    }

    .modal {
        padding: 10px;
    }

    .modal-content {
        padding: 16px;
    }

    .toast-container {
        left: 10px;
        right: 10px;
    }

    .toast {
        min-width: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ---------- COMPATIBILITY ALIASES ---------- */
.comment-input {
    width: 100%;
    margin-bottom: 12px;
    padding: 12px 13px;
    color: var(--text-primary);
    background: var(--bg-input);
    border: 1px solid var(--border);
    border-left: 4px solid var(--border-strong);
}

.comment-input:focus {
    border-color: var(--accent);
    border-left-color: var(--accent);
    box-shadow: inset 4px 0 0 var(--accent);
}

.toggle-my-btn {
    min-height: 34px;
    padding: 7px 12px;
    color: #b2b5b7;
    background: #202428;
    border: 1px solid #3b4045;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    cursor: pointer;
}

.toggle-my-btn:hover,
.toggle-my-btn.active {
    color: #fff;
    background: var(--gradient-primary);
    border-color: #ef4d43;
}


/* =========================================================
   FINAL PATCH V2
   Search structure, donate heading and complete light theme
   ========================================================= */

/* ---------- SEARCH: ONE CONTAINER, NO INNER INPUT BOX ---------- */
.header-center {
    min-width: 0;
    background: transparent !important;
    border: 0 !important;
    outline: 0 !important;
    box-shadow: none !important;
}

.header-center .search-section,
.search-section {
    padding: 0 !important;
}

.header-center .search-section input,
.search-section input,
.search-section input[type="search"],
.search-section input[type="text"] {
    width: auto !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
    height: 38px !important;
    margin: 0 !important;
    padding: 8px 10px 8px 0 !important;
    color: #f3f1eb !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    outline: 0 !important;
    box-shadow: none !important;
    appearance: none;
    -webkit-appearance: none;
}

.search-section input:focus,
.search-section input:focus-visible {
    border: 0 !important;
    outline: 0 !important;
    box-shadow: none !important;
}

.search-section input::-webkit-search-decoration,
.search-section input::-webkit-search-cancel-button,
.search-section input::-webkit-search-results-button,
.search-section input::-webkit-search-results-decoration {
    -webkit-appearance: none;
}

/* ---------- DONATES PAGE HEADING ---------- */
#donatesPage .donates-header,
#donatesPage .donate-page-header,
#donatesPage .donates-page-header,
#donatesPage .donates-page-head,
#donatesPage .donates-hero,
#donatesPage .donates-head,
#donatesPage .page-header {
    color: var(--text-primary) !important;
    background: var(--bg-card) !important;
    border-color: var(--border) !important;
}

#donatesPage .donates-header h1,
#donatesPage .donates-header h2,
#donatesPage .donate-page-header h1,
#donatesPage .donate-page-header h2,
#donatesPage .donates-page-header h1,
#donatesPage .donates-page-header h2,
#donatesPage .donates-page-head h1,
#donatesPage .donates-page-head h2,
#donatesPage .donates-hero h1,
#donatesPage .donates-hero h2,
#donatesPage .donates-head h1,
#donatesPage .donates-head h2,
#donatesPage .page-header h1,
#donatesPage .page-header h2,
#donatesPage .donates-title,
#donatesPage .page-title {
    color: var(--text-primary) !important;
    -webkit-text-fill-color: var(--text-primary) !important;
    text-shadow: none !important;
}

#donatesPage .donates-header p,
#donatesPage .donate-page-header p,
#donatesPage .donates-page-header p,
#donatesPage .donates-page-head p,
#donatesPage .donates-hero p,
#donatesPage .donates-head p,
#donatesPage .page-header p,
#donatesPage .donates-subtitle,
#donatesPage .page-subtitle {
    color: var(--text-secondary) !important;
    -webkit-text-fill-color: var(--text-secondary) !important;
    text-shadow: none !important;
}

/* Fallback for the current render where the heading wrapper has no stable class. */
#donatesPage > div:first-child > div:first-child > h1,
#donatesPage > div:first-child > div:first-child > h2,
#donatesPage > section:first-child > div:first-child > h1,
#donatesPage > section:first-child > div:first-child > h2 {
    color: var(--text-primary) !important;
    -webkit-text-fill-color: var(--text-primary) !important;
}

#donatesPage > div:first-child > div:first-child > p,
#donatesPage > section:first-child > div:first-child > p {
    color: var(--text-secondary) !important;
    -webkit-text-fill-color: var(--text-secondary) !important;
}

/* ---------- COMPLETE LIGHT INDUSTRIAL THEME ---------- */
body.light .header {
    color: #191b1d;
    background: linear-gradient(180deg, #efede6 0%, #d6d3cb 100%);
    border-bottom-color: var(--accent);
    box-shadow: 0 5px 0 rgba(0, 0, 0, 0.12);
}

body.light .industrial-logo-name,
body.light .industrial-logo-text,
body.light .logo-text,
body.light .logo > span {
    color: #191b1d !important;
    -webkit-text-fill-color: #191b1d !important;
    text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.55) !important;
}

body.light .industrial-logo-subtitle {
    color: #666b6e !important;
    -webkit-text-fill-color: #666b6e !important;
}

body.light .search-section {
    color: var(--text-primary);
    background: var(--bg-input);
    border-color: var(--border);
    border-left-color: var(--border-strong);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.08);
}

body.light .search-section input,
body.light .search-section input[type="search"],
body.light .search-section input[type="text"] {
    color: var(--text-primary) !important;
    background: transparent !important;
}

body.light .search-section input::placeholder {
    color: var(--text-muted) !important;
}

body.light .search-icon,
body.light .clear-search-btn {
    color: var(--text-muted);
}

body.light .header-profile,
body.light .header-icon-btn,
body.light .header-theme-btn,
body.light .header-admin-btn {
    color: var(--text-primary);
    background: var(--bg-card);
    border-color: var(--border);
}

body.light .header-profile {
    border-left-color: var(--accent);
}

body.light .header-actions-group {
    border-color: var(--border);
}

body.light .header-icon-btn .fa-bell {
    color: #555b5f;
}

body.light .header-nav,
body.light .header-tabs,
body.light .main-tabs,
body.light .site-tabs {
    background: #d0cdc5;
    border-color: var(--border);
}

body.light .nav-tab,
body.light .header-tab,
body.light .main-tab,
body.light .site-tab {
    color: var(--text-secondary);
    background: var(--bg-card);
    border-color: var(--border) !important;
}

body.light .nav-tab:hover,
body.light .header-tab:hover,
body.light .main-tab:hover,
body.light .site-tab:hover {
    color: var(--text-primary);
    background: var(--bg-elevated);
}

body.light .nav-tab.active,
body.light .header-tab.active,
body.light .main-tab.active,
body.light .site-tab.active {
    color: #fff;
    background: var(--accent);
    border-color: var(--accent) !important;
}

body.light .controls {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
    border-left-color: var(--accent);
    box-shadow: var(--shadow-md);
}

body.light .controls::before,
body.light .controls::after {
    background: #8a8b86;
    border-color: #4d4f4c;
}

body.light .filter-btn,
body.light .cat-btn,
body.light .notif-filter,
body.light .activity-legend-item {
    color: var(--text-secondary);
    background: var(--bg-card);
    border-color: var(--border);
}

body.light .filter-btn:hover,
body.light .cat-btn:hover,
body.light .notif-filter:hover,
body.light .activity-legend-item:hover {
    color: var(--text-primary);
    background: var(--bg-elevated);
    border-color: var(--border-strong);
}

body.light .filter-btn .count {
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

body.light #sortSelect,
body.light .sort-select,
body.light .sort-pill,
body.light .controls select,
body.light .compact-input {
    color: var(--text-primary);
    background-color: var(--bg-input);
    border-color: var(--border);
}

body.light .feed-card,
body.light .donate-card,
body.light .comment,
body.light .comment-item,
body.light .notification-item,
body.light .list-item,
body.light .moderation-card,
body.light .admin-panel,
body.light .admin-panel-shell,
body.light .admin-card,
body.light .admin-section,
body.light .admin-metric-card,
body.light .modal-content,
body.light .maintenance-card,
body.light .toast {
    color: var(--text-primary) !important;
    background: var(--bg-card) !important;
    border-color: var(--border) !important;
}

body.light .feed-card-title,
body.light .feed-card-title a,
body.light .donate-card-title,
body.light .comment-nick,
body.light .modal-content h1,
body.light .modal-content h2,
body.light .modal-content h3,
body.light .modal-content h4,
body.light .admin-panel-header h2,
body.light .admin-section h3 {
    color: var(--text-primary) !important;
    -webkit-text-fill-color: var(--text-primary) !important;
}

body.light .video-card-meta,
body.light .video-channel-link,
body.light .video-channel-views,
body.light .donate-card-description,
body.light .donate-short-description,
body.light .donate-author,
body.light .donate-created-at,
body.light .comment-head,
body.light .comment-date,
body.light .comment-time,
body.light .comment-meta,
body.light .notification-content,
body.light .admin-panel-header p,
body.light .admin-metric-card span {
    color: var(--text-secondary) !important;
}

body.light .tags-container .tag,
body.light .tag,
body.light .admin-badge {
    color: var(--text-secondary) !important;
    background: var(--bg-secondary) !important;
    border-color: var(--border) !important;
}

body.light .input-field,
body.light textarea,
body.light select,
body.light input[type="text"],
body.light input[type="url"],
body.light input[type="number"],
body.light input[type="password"] {
    color: var(--text-primary);
    background: var(--bg-input);
    border-color: var(--border);
    border-left-color: var(--border-strong);
}

body.light .video-preview-box,
body.light #previewBlock,
body.light .video-preview,
body.light .video-info-preview,
body.light .add-video-preview,
body.light .video-preview-block {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
    border-left-color: var(--accent);
}

body.light .admin-tabs,
body.light .admin-nav {
    background: var(--bg-secondary);
    border-color: var(--border);
}

body.light .admin-tab,
body.light .admin-nav-btn {
    color: var(--text-secondary);
    background: var(--bg-card);
    border-color: var(--border);
}

body.light .admin-table-wrap,
body.light .admin-table th,
body.light .admin-table td {
    border-color: var(--border);
}

body.light .activity-chart-box {
    background: rgba(255, 255, 255, 0.35);
    border-color: var(--border);
}

body.light .donate-progress-bar {
    background: var(--bg-secondary) !important;
    border-color: var(--border) !important;
}

/* Keep intentionally dark media surfaces dark in both themes. */
body.light .feed-card-preview,
body.light .preview-iframe,
body.light .video-thumb-duration,
body.light .video-thumb-date {
    color: #fff;
}

/* Светлая тема: ник пользователя в шапке */
body.industrial-theme.light .header-profile,
body.industrial-theme.light .header-profile-name,
body.industrial-theme.light .header-profile span,
body.industrial-theme.light .user-pill,
body.industrial-theme.light .user-pill span {
    color: #181a1c !important;
    -webkit-text-fill-color: #181a1c !important;
    text-shadow: none !important;
}

/* =========================================================
   СТРАНИЦА ЛЕНТЫ
   ========================================================= */

.site-page {
    width: 100%;
}

#feedPage {
    min-height: 460px;
}

.feed-page-header {
    margin-bottom: 18px;
    padding: 14px 16px;

    color: var(--text-primary);
    background: var(--bg-card);

    border: 1px solid var(--border);
    border-left: 5px solid var(--accent);

    box-shadow: var(--shadow-sm);
}

.feed-page-heading {
    display: flex;
    align-items: center;
    gap: 13px;
}

.feed-page-marker {
    width: 8px;
    height: 40px;

    flex: 0 0 8px;

    background:
        repeating-linear-gradient(
            0deg,
            var(--accent) 0 8px,
            var(--accent-dark) 8px 13px
        );

    transform: skewX(-7deg);
}

.feed-page-header h1 {
    margin: 0;

    color: var(--text-primary);

    font-family: "Russo One", sans-serif;
    font-size: 1.2rem;
    font-weight: 400;
    text-transform: uppercase;
}

.feed-page-header p {
    margin: 4px 0 0;

    color: var(--text-secondary);
    font-size: 0.86rem;
}

.feed-stream {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.feed-empty-state {
    min-height: 290px;
    padding: 44px 20px;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    color: var(--text-secondary);
    background: var(--bg-card);

    border: 1px solid var(--border);
    border-top: 4px solid var(--industrial-steel);

    box-shadow: var(--shadow-md);

    text-align: center;
}

.feed-empty-icon {
    width: 58px;
    height: 58px;
    margin-bottom: 16px;

    display: flex;
    align-items: center;
    justify-content: center;

    color: #ffffff;
    background: var(--gradient-primary);

    border: 1px solid #ef4d43;
    border-left: 5px solid var(--accent-dark);

    font-size: 1.35rem;

    box-shadow: var(--shadow-sm);
}

.feed-empty-state h2 {
    margin: 0 0 8px;

    color: var(--text-primary);
    font-size: 1.05rem;
    text-transform: uppercase;
}

.feed-empty-state p {
    max-width: 520px;
    margin: 0;

    color: var(--text-muted);
    line-height: 1.55;
}

body.light .feed-page-header,
body.light .feed-empty-state {
    color: var(--text-primary);
    background: var(--bg-card);
    border-color: var(--border);
}

/* Поиск: компактнее и немного ниже */
body.industrial-theme .header-center {
    width: min(460px, 100%) !important;
    max-width: 460px !important;

    position: relative;
    top: 20px;
    left: 120px;
}

body.industrial-theme .header-center .search-section {
    width: 100% !important;
    max-width: 460px !important;
    min-height: 34px !important;

    margin: 0 auto !important;
}

body.industrial-theme .header-center .search-section input {
    min-height: 32px !important;
    padding-top: 6px !important;
    padding-bottom: 6px !important;
}

@media (max-width: 700px) {
    body.industrial-theme .header-center {
        width: 100% !important;
        max-width: 100% !important;
        top: 4px;
    }

    body.industrial-theme .header-center .search-section {
        max-width: 100% !important;
    }
}

/* Опускаем правую часть шапки на 10px */
.header .user-area,
.header .header-user-panel {
    transform: translateY(19px) !important;
}

/* =========================================================
   USER ROLES — STREAMER / MODERATOR / SUPERADMIN
   Additive patch: existing layout and functions are untouched.
   ========================================================= */

.user-role-badges {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
    vertical-align: middle;
}

.user-role-badge {
    min-height: 22px;
    padding: 3px 7px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    border: 1px solid currentColor;
    font-size: 0.66rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0.055em;
    text-transform: uppercase;
    white-space: nowrap;
}

.user-role-badges--compact {
    flex-wrap: nowrap;
}

.user-role-badges--compact .user-role-badge {
    width: 22px;
    height: 22px;
    min-height: 22px;
    padding: 0;
}

.user-role-badges--compact .user-role-badge-label {
    display: none;
}

.role-streamer {
    color: #ff6b5f;
    background: rgba(201, 42, 32, 0.17);
    border-color: rgba(255, 107, 95, 0.5);
}

.role-moderator {
    color: #c9ced2;
    background: rgba(109, 117, 124, 0.18);
    border-color: rgba(201, 206, 210, 0.42);
}

.role-superadmin {
    color: #e0aa18;
    background: rgba(224, 170, 24, 0.16);
    border-color: rgba(224, 170, 24, 0.5);
}

.header-profile-name.is-streamer,
.comment-nick.streamer-nick {
    color: #ff6b5f !important;
    -webkit-text-fill-color: #ff6b5f !important;
}

.header-profile .user-role-badges {
    margin-left: 1px;
}

.comment-user .user-role-badges {
    margin-left: 3px;
}

.profile-role-row {
    margin: 0 0 14px;
    padding: 10px 11px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    color: var(--text-primary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}

.profile-role-row strong {
    color: var(--text-primary);
    font-weight: 900;
}

body.light .role-streamer {
    color: #a71912;
    background: rgba(201, 42, 32, 0.1);
    border-color: rgba(167, 25, 18, 0.42);
}

body.light .role-moderator {
    color: #454b50;
    background: rgba(69, 75, 80, 0.09);
    border-color: rgba(69, 75, 80, 0.35);
}

body.light .role-superadmin {
    color: #805f00;
    background: rgba(224, 170, 24, 0.13);
    border-color: rgba(128, 95, 0, 0.4);
}

body.light .header-profile-name.is-streamer,
body.light .comment-nick.streamer-nick {
    color: #a71912 !important;
    -webkit-text-fill-color: #a71912 !important;
}

@media (max-width: 620px) {
    .header-profile .user-role-badges--compact {
        display: none;
    }

    .comment-user .user-role-badge {
        min-height: 20px;
        padding: 3px 5px;
        font-size: 0.6rem;
    }
}

/* =========================================================
   COMMUNITY FEATURES
   Репутація, публічні профілі, коментарі, журнал, масові дії
   ========================================================= */

.modal-content-wide {
    max-width: 920px !important;
}

.modal-content-extra-wide {
    max-width: 1180px !important;
}

.profile-loading {
    min-height: 160px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--text-secondary);
}

.profile-link,
.comment-nick.profile-link,
.mention-link.profile-link {
    padding: 0;
    color: var(--accent-hover);
    background: transparent;
    border: 0;
    font: inherit;
    font-weight: 900;
    text-decoration: none;
    cursor: pointer;
}

.profile-link:hover,
.comment-nick.profile-link:hover,
.mention-link.profile-link:hover {
    color: var(--text-primary);
    text-decoration: underline;
}

.public-profile-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.public-profile-head {
    display: flex;
    align-items: center;
    gap: 16px;
}

.public-profile-avatar {
    width: 96px;
    height: 96px;
    flex: 0 0 96px;
    object-fit: cover;
    border: 2px solid var(--border-strong);
    border-radius: 50%;
    box-shadow: var(--shadow-sm);
}

.public-profile-avatar--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--accent);
    font-size: 2rem;
    font-weight: 900;
}

.public-profile-identity {
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
}

.public-profile-identity h2 {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
}

.public-profile-identity a {
    color: var(--text-muted);
    text-decoration: none;
}

.public-profile-identity a:hover {
    color: var(--accent-hover);
}

.public-profile-bio {
    padding: 13px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
    white-space: pre-wrap;
}

.reputation-card {
    padding: 14px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.reputation-card-head {
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.reputation-card-head > div {
    display: flex;
    align-items: baseline;
    gap: 9px;
}

.reputation-label {
    color: var(--text-muted);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.reputation-card-head strong {
    color: var(--accent-hover);
    font-size: 1.65rem;
}

.reputation-level {
    padding: 4px 8px;
    border: 1px solid currentColor;
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.reputation-level-newcomer { color: var(--text-muted); }
.reputation-level-active { color: #4fb77b; }
.reputation-level-verified { color: #e0aa18; }
.reputation-level-veteran { color: #ff6b5f; }

.reputation-progress {
    height: 8px;
    margin-bottom: 8px;
    overflow: hidden;
    background: var(--bg-primary);
    border: 1px solid var(--border);
}

.reputation-progress span {
    display: block;
    height: 100%;
    background: var(--gradient-primary);
}

.reputation-card small {
    color: var(--text-muted);
}

.public-profile-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 9px;
}

.public-profile-stats > div {
    padding: 13px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    text-align: center;
}

.public-profile-stats strong {
    color: var(--accent-hover);
    font-size: 1.35rem;
}

.public-profile-stats span {
    color: var(--text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
}

.public-profile-actions,
.comments-modal-actions,
.comment-reply-actions,
.bulk-action-buttons {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.comments-modal-head,
.admin-dialog-head {
    margin-bottom: 14px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 15px;
}

.comments-modal-head h2,
.admin-dialog-head h2 {
    margin-bottom: 4px !important;
}

.comments-modal-head p,
.admin-dialog-head p {
    margin: 0;
}

.comment-thread {
    min-width: 0;
}

.comment-replies {
    margin: 8px 0 0 24px;
    padding-left: 11px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-left: 2px solid var(--border);
}

.comment-actions {
    margin-top: 8px;
    display: flex;
    align-items: center;
    gap: 7px;
}

.comment-action-btn {
    min-height: 28px;
    padding: 4px 8px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--text-muted);
    background: transparent;
    border: 1px solid var(--border);
    cursor: pointer;
}

.comment-action-btn:hover,
.comment-action-btn.active {
    color: #fff;
    background: var(--accent);
    border-color: var(--accent);
}

.comment-reply-composer {
    margin: 8px 0 10px 24px;
    padding: 11px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}

.comment-reply-label {
    margin-bottom: 7px;
    color: var(--text-secondary);
    font-size: 0.78rem;
}

.comment-reply-label strong {
    color: var(--accent-hover);
}

.comment-reply-input {
    min-height: 86px;
    margin-bottom: 8px !important;
}

.community-admin-tools {
    padding: 16px;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
}

.community-admin-tools-head {
    margin-bottom: 11px;
}

.community-admin-tools-head h3 {
    margin: 0 0 4px;
}

.community-admin-tools-head p {
    margin: 0;
    color: var(--text-muted);
}

.community-admin-tools-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 9px;
}

.admin-tool-button {
    min-height: 78px;
    padding: 12px;
    display: flex;
    align-items: center;
    gap: 11px;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 4px solid var(--industrial-steel);
    text-align: left;
    cursor: pointer;
}

.admin-tool-button:hover {
    border-left-color: var(--accent);
    background: var(--bg-elevated);
}

.admin-tool-button > i {
    width: 28px;
    color: var(--accent-hover);
    font-size: 1.25rem;
    text-align: center;
}

.admin-tool-button span {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.admin-tool-button strong {
    color: var(--text-primary);
}

.admin-tool-button small {
    color: var(--text-muted);
}

.streamer-role-list {
    max-height: 58vh;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow: auto;
}

.streamer-role-item {
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.streamer-role-user,
.streamer-role-state {
    display: flex;
    align-items: center;
    gap: 10px;
}

.streamer-role-user > div {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.streamer-role-user small {
    color: var(--text-muted);
}

.audit-log-list {
    max-height: 65vh;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow: auto;
}

.audit-log-item {
    padding: 11px;
    display: flex;
    gap: 11px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--border-strong);
}

.audit-log-icon {
    width: 34px;
    height: 34px;
    flex: 0 0 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--accent);
}

.audit-log-content {
    min-width: 0;
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 4px;
}

.audit-log-content p,
.audit-log-content small {
    margin: 0;
    color: var(--text-muted);
}

.audit-log-content p span {
    color: var(--accent-hover);
    font-weight: 900;
}

.audit-log-content details {
    margin-top: 4px;
}

.audit-log-content summary {
    color: var(--text-secondary);
    cursor: pointer;
}

.audit-log-content pre {
    max-width: 100%;
    padding: 8px;
    overflow: auto;
    color: var(--text-secondary);
    background: var(--bg-primary);
    border: 1px solid var(--border);
    white-space: pre-wrap;
}

.bulk-actions-toolbar {
    margin-bottom: 11px;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.bulk-select-all {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    cursor: pointer;
}

.bulk-selected-count {
    margin-left: auto;
    color: var(--text-muted);
    font-weight: 800;
}

.bulk-video-list {
    max-height: 54vh;
    margin-bottom: 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    overflow: auto;
}

.bulk-video-item {
    padding: 8px;
    display: grid;
    grid-template-columns: auto 96px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    cursor: pointer;
}

.bulk-video-item:hover {
    border-color: var(--border-strong);
}

.bulk-video-item img {
    width: 96px;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    background: var(--bg-primary);
}

.bulk-video-info {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.bulk-video-info strong {
    overflow: hidden;
    color: var(--text-primary);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.bulk-video-info small {
    color: var(--text-muted);
}

body.light .community-admin-tools,
body.light .public-profile-bio,
body.light .reputation-card,
body.light .public-profile-stats > div,
body.light .comment-reply-composer,
body.light .streamer-role-item,
body.light .audit-log-item,
body.light .bulk-video-item {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

@media (max-width: 800px) {
    .community-admin-tools-grid,
    .public-profile-stats {
        grid-template-columns: 1fr;
    }

    .streamer-role-item {
        align-items: stretch;
        flex-direction: column;
    }

    .streamer-role-state {
        justify-content: space-between;
    }

    .bulk-video-item {
        grid-template-columns: auto 72px minmax(0, 1fr);
    }

    .bulk-video-item img {
        width: 72px;
    }
}

@media (max-width: 620px) {
    .public-profile-head {
        align-items: flex-start;
    }

    .public-profile-avatar {
        width: 72px;
        height: 72px;
        flex-basis: 72px;
    }

    .comment-replies,
    .comment-reply-composer {
        margin-left: 10px;
    }

    .bulk-action-buttons .btn {
        width: 100%;
    }
}

/* =========================================================
   FINAL ADMIN TOOLS + WATCHED VIDEOS
   ========================================================= */

.header-admin-tools-btn {
    min-height: 38px;
    padding: 0 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    color: #f1efe8;
    background: #202428;
    border: 1px solid #4a5055;
    border-left: 3px solid var(--industrial-yellow);
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: 0.035em;
    text-transform: uppercase;
    cursor: pointer;
}

.header-admin-tools-btn:hover {
    color: #fff;
    background: #2b3035;
    border-color: var(--industrial-yellow);
}

body.light .header-admin-tools-btn {
    color: var(--text-primary);
    background: var(--bg-card);
    border-color: var(--border);
    border-left-color: #9d7308;
}

.community-tools-dashboard {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.community-tool-card {
    min-height: 104px;
    padding: 15px;
    display: flex;
    align-items: center;
    gap: 14px;
    color: var(--text-primary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 5px solid var(--industrial-steel);
    text-align: left;
    cursor: pointer;
}

.community-tool-card:hover {
    background: var(--bg-elevated);
    border-left-color: var(--accent);
}

.community-tool-card > i {
    width: 38px;
    color: var(--accent-hover);
    font-size: 1.55rem;
    text-align: center;
}

.community-tool-card > span {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.community-tool-card strong {
    color: var(--text-primary);
    font-size: 0.93rem;
    text-transform: uppercase;
}

.community-tool-card small {
    color: var(--text-muted);
    line-height: 1.35;
}

.community-tools-access-note {
    margin: 14px 0 0;
    padding: 10px 12px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--industrial-yellow);
}

.community-admin-tools-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

#videoGrid .feed-card.video-watched {
    opacity: 0.56;
    filter: grayscale(1) saturate(0.25);
    border-top-color: #5b6064;
    box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.18);
    transition:
        opacity var(--transition),
        filter var(--transition),
        transform var(--transition);
}

#videoGrid .feed-card.video-watched:hover {
    opacity: 0.78;
    filter: grayscale(0.82) saturate(0.45);
}

#videoGrid .feed-card.video-watched .video-thumb-image {
    filter: grayscale(1) contrast(0.88);
}

.video-watched-badge {
    position: absolute;
    top: 7px;
    right: 7px;
    z-index: 7;
    padding: 4px 7px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: #fff;
    background: rgba(44, 48, 52, 0.94);
    border: 1px solid #767b80;
    border-left: 4px solid #9ca1a5;
    font-size: 0.67rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    pointer-events: none;
}

.watched-clear-btn {
    min-height: 34px;
    padding: 7px 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    font-size: 0.74rem;
    font-weight: 900;
    text-transform: uppercase;
    cursor: pointer;
}

.watched-clear-btn:hover {
    color: #fff;
    background: #30353a;
    border-color: var(--accent);
}

body.light .community-tool-card,
body.light .community-tools-access-note,
body.light .watched-clear-btn {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

@media (max-width: 1050px) {
    .header-admin-tools-btn span {
        display: none;
    }

    .header-admin-tools-btn {
        width: 38px;
        min-width: 38px;
        padding: 0;
    }
}

@media (max-width: 700px) {
    .community-tools-dashboard {
        grid-template-columns: 1fr;
    }

    .community-tool-card {
        min-height: 86px;
    }

    .watched-clear-btn {
        width: 100%;
    }
}

/* =========================================================
   NEXT FIXES — MERGED TOOLS, PROFILE, NOTIFICATIONS, SCROLL
   ========================================================= */

/* Єдина кнопка адміністративних інструментів. */
.header-admin-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
}

/* Список відео на перевірці більше не обрізається після 3 карток. */
#adminModal .moderation-list,
#adminModal .moderation-grid,
#adminModal [data-moderation-list],
.bulk-video-list {
    max-height: min(62vh, 680px) !important;
    min-height: 180px;
    padding-right: 7px;
    overflow-y: auto !important;
    overflow-x: hidden;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
}

#adminModal .admin-tab-page {
    max-height: 72vh;
    overflow-y: auto;
    overscroll-behavior: contain;
}

/* Панель інструментів зручно розміщується разом зі старими функціями. */
#adminModal .community-admin-tools {
    position: sticky;
    top: 0;
    z-index: 4;
    box-shadow: 0 5px 0 rgba(0, 0, 0, 0.14);
}

#adminModal .community-admin-tools-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* Повний власний профіль. */
.own-profile {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.own-profile-bio-editor {
    padding: 13px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}

.own-profile-bio-editor label {
    display: block;
    margin-bottom: 7px;
    color: var(--text-primary);
    font-weight: 900;
}

.own-profile-bio-editor textarea {
    min-height: 110px;
    margin-bottom: 7px;
}

.own-profile-bio-editor small,
.profile-avatar-disabled-note {
    color: var(--text-muted);
}

.own-profile-actions {
    display: flex;
    justify-content: flex-end;
    gap: 9px;
    flex-wrap: wrap;
}

/* Система сповіщень. */
.notification-badge.hidden {
    display: none !important;
}

.notifications-center-list {
    max-height: 62vh;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.notifications-center-list .notification-content time {
    color: var(--text-muted);
    font-size: 0.72rem;
}

.notifications-center-list .notification-content strong {
    color: var(--text-primary);
}

.notifications-center-list .notification-content p {
    margin: 0;
}

/* Керування роллю стрімера для будь-якого Twitch-логіна. */
.streamer-role-manual-form,
.trusted-user-add-form {
    margin-bottom: 12px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 9px;
}

.streamer-role-manual-form .input-field,
.trusted-user-add-form .input-field {
    margin: 0;
}

/* Довірені користувачі завантажуються напряму з Supabase. */
.trusted-user-list {
    max-height: 58vh;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.trusted-user-item {
    padding: 10px 11px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.trusted-user-item > div {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.trusted-user-item small {
    color: var(--text-muted);
}

body.light .own-profile-bio-editor,
body.light .trusted-user-item {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

@media (max-width: 1120px) {
    #adminModal .community-admin-tools-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    #adminModal .community-admin-tools-grid {
        grid-template-columns: 1fr;
    }

    .streamer-role-manual-form,
    .trusted-user-add-form {
        grid-template-columns: 1fr;
    }

    .trusted-user-item {
        align-items: stretch;
        flex-direction: column;
    }

    .own-profile-actions .btn {
        width: 100%;
    }
}

/* =========================================================
   ADMIN DASHBOARD + FILTERS REORGANIZATION
   ========================================================= */

/* Усі головні розділи адмін-панелі — великі зрозумілі блоки. */
#adminModal .admin-tabs,
#adminModal .admin-nav {
    padding: 12px !important;
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
    gap: 10px !important;
    overflow: visible !important;
    background: var(--bg-secondary) !important;
    border-bottom: 1px solid var(--border) !important;
}

#adminModal .admin-tab,
#adminModal .admin-nav-btn,
#adminModal .admin-dashboard-card {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 86px !important;
    padding: 13px 15px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 11px !important;
    color: var(--text-primary) !important;
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    border-left: 5px solid var(--industrial-steel) !important;
    box-shadow: var(--shadow-sm) !important;
    text-align: left !important;
    white-space: normal !important;
}

#adminModal .admin-tab i,
#adminModal .admin-nav-btn i,
#adminModal .admin-dashboard-card i {
    width: 30px;
    flex: 0 0 30px;
    color: var(--accent-hover);
    font-size: 1.25rem;
    text-align: center;
}

#adminModal .admin-tab:hover,
#adminModal .admin-nav-btn:hover,
#adminModal .admin-dashboard-card:hover {
    color: var(--text-primary) !important;
    background: var(--bg-elevated) !important;
    border-left-color: var(--accent) !important;
}

#adminModal .admin-tab.active,
#adminModal .admin-nav-btn.active,
#adminModal .admin-dashboard-card.active {
    color: #fff !important;
    background: linear-gradient(180deg, #272b2f, #171a1d) !important;
    border-color: var(--accent) !important;
    border-left-color: var(--accent) !important;
    box-shadow:
        inset 0 -3px 0 var(--accent-dark),
        var(--shadow-sm) !important;
}

#adminModal .community-tab-hidden,
#adminModal .community-trusted-section-hidden {
    display: none !important;
}

#adminModal .admin-tab-page.admin-merged-visible {
    display: block !important;
}

#adminModal .admin-tab-page[data-community-secondary-merged] {
    border-top: 1px solid var(--border);
}

/* «Мої» залишається робочим фільтром, але його оригінал прихований. */
#controls .community-original-my-filter {
    display: none !important;
}

#controls .filter-my-relocated {
    margin-left: auto;
    min-height: 38px;
    padding: 8px 13px;
    flex: 0 0 auto;
}

#controls .filter-my-relocated + #openAddModal {
    margin-left: 0;
}

/* Після перенесення «Мої» кнопка додавання більше не відштовхується сама. */
#controls #openAddModal {
    margin-left: 0 !important;
}

/* Заборонені категорії додатково ховаються, якщо старий код перемалював форму. */
#addModalContent .community-category-hidden {
    display: none !important;
}

@media (max-width: 900px) {
    #adminModal .admin-tabs,
    #adminModal .admin-nav {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #controls .filter-my-relocated {
        margin-left: 0;
    }
}

@media (max-width: 600px) {
    #adminModal .admin-tabs,
    #adminModal .admin-nav {
        grid-template-columns: 1fr !important;
    }

    #adminModal .admin-tab,
    #adminModal .admin-nav-btn,
    #adminModal .admin-dashboard-card {
        min-height: 72px !important;
    }

    #controls .filter-my-relocated,
    #controls #openAddModal {
        width: 100%;
    }
}

/* =========================================================
   MODERATION / ACTIVITY / SMART SEARCH / LINK CHECKER
   ========================================================= */

/* «Мої» + «Додати відео» завжди стоять поруч без дублювання. */
#controls .filter-action-group {
    margin-left: auto;
    display: inline-flex;
    align-items: stretch;
    gap: 4px;
    flex: 0 0 auto;
}

#controls .filter-action-group .filter-my-relocated,
#controls .filter-action-group #openAddModal {
    margin: 0 !important;
}

/* Картки нових інструментів залишаються у спільній сітці. */
#adminModal .community-admin-tools-grid {
    grid-template-columns: repeat(auto-fit, minmax(205px, 1fr)) !important;
}

/* Огляд і графік. */
.advanced-metrics-grid {
    margin-bottom: 16px;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
}

.advanced-metric-card {
    min-height: 94px;
    padding: 14px;
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--industrial-steel);
}

.advanced-metric-card > i {
    width: 34px;
    color: var(--accent-hover);
    font-size: 1.35rem;
    text-align: center;
}

.advanced-metric-card > div {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.advanced-metric-card strong {
    color: var(--accent-hover);
    font-size: 1.55rem;
}

.advanced-metric-card span {
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 900;
    text-transform: uppercase;
}

.advanced-activity-section,
.advanced-recent-events,
.author-profile-section {
    margin-top: 15px;
    padding: 15px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

/* Відновлена модерація. */
.moderation-toolbar {
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 9px;
    flex-wrap: wrap;
}

.moderation-toolbar .input-field {
    min-width: 260px;
    flex: 1;
    margin: 0;
}

.advanced-moderation-list {
    max-height: min(64vh, 720px);
    padding-right: 7px;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
}

.advanced-moderation-card {
    grid-template-columns: auto 220px minmax(0, 1fr) !important;
    align-items: start;
}

.moderation-select {
    padding-top: 4px;
}

.moderation-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}

.moderation-title-row h4 {
    flex: 1;
}

.moderation-presets {
    margin-top: 10px;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.status-badge,
.link-status-badge {
    padding: 4px 7px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    border: 1px solid currentColor;
    font-size: 0.67rem;
    font-weight: 900;
    text-transform: uppercase;
    white-space: nowrap;
}

.status-pending {
    color: var(--warning);
    background: rgba(217, 164, 27, 0.11);
}

.link-status-badge.available {
    color: var(--success);
    background: rgba(58, 166, 107, 0.1);
}

.link-status-badge.unavailable {
    color: var(--danger);
    background: rgba(227, 72, 63, 0.1);
}

.link-status-badge.unknown {
    color: var(--text-muted);
    background: rgba(141, 146, 150, 0.08);
}

/* Повний профіль автора. */
.full-author-profile .public-profile-stats {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.author-profile-columns {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    gap: 12px;
}

.author-profile-section {
    min-width: 0;
    margin-top: 0;
}

.author-video-list,
.author-comment-list {
    max-height: 55vh;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.author-video-item {
    padding: 8px;
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr) auto;
    align-items: center;
    gap: 9px;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    text-decoration: none;
}

.author-video-item:hover {
    border-color: var(--accent);
}

.author-video-item img {
    width: 92px;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.author-video-item > span {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.author-video-item strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.author-video-item small {
    color: var(--text-muted);
}

.author-comment-item {
    padding: 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 4px solid var(--border-strong);
}

.author-comment-item p {
    margin: 0 0 6px;
    color: var(--text-secondary);
}

.author-comment-item small {
    color: var(--text-muted);
}

/* Розумний пошук. */
.smart-search-host {
    position: relative;
    overflow: visible !important;
}

.smart-search-results {
    position: absolute;
    top: calc(100% + 7px);
    left: -1px;
    right: -1px;
    z-index: 2200;
    max-height: 62vh;
    overflow-y: auto;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border-strong);
    border-top: 3px solid var(--accent);
    box-shadow: var(--shadow-lg);
}

.smart-search-result {
    padding: 9px;
    display: grid;
    grid-template-columns: 104px minmax(0, 1fr);
    gap: 10px;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border);
    text-decoration: none;
}

.smart-search-result:hover {
    background: var(--bg-elevated);
}

.smart-search-result img {
    width: 104px;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.smart-search-result-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.smart-search-result-main strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.smart-search-result-main small {
    color: var(--text-muted);
}

.smart-search-meta {
    display: flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
}

.smart-search-meta em {
    padding: 2px 5px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    font-size: 0.65rem;
    font-style: normal;
    text-transform: uppercase;
}

.smart-search-empty {
    padding: 16px;
    color: var(--text-muted);
    text-align: center;
}

/* Перевірка посилань. */
.link-checker-summary {
    margin-bottom: 12px;
    padding: 12px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}

.link-checker-actions {
    margin-bottom: 12px;
    display: flex;
    justify-content: flex-end;
}

.link-checker-results {
    max-height: 52vh;
    display: flex;
    flex-direction: column;
    gap: 7px;
    overflow-y: auto;
}

.link-check-result {
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.link-check-result.available {
    border-left: 4px solid var(--success);
}

.link-check-result.unavailable {
    border-left: 4px solid var(--danger);
}

.link-check-result.unknown {
    border-left: 4px solid var(--text-muted);
}

.video-link-status-badge {
    position: absolute;
    top: 7px;
    right: 7px;
    z-index: 8;
    padding: 4px 7px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: #fff;
    background: rgba(126, 17, 12, 0.94);
    border: 1px solid #ef6a62;
    border-left: 4px solid var(--danger);
    font-size: 0.65rem;
    font-weight: 900;
    text-transform: uppercase;
    pointer-events: none;
}

#videoGrid .feed-card.video-link-unavailable {
    border-top-color: var(--danger);
}

#videoGrid .feed-card.video-link-unavailable .video-thumb-image {
    filter: grayscale(0.9) contrast(0.8);
}

body.light .advanced-metric-card,
body.light .advanced-activity-section,
body.light .advanced-recent-events,
body.light .author-profile-section,
body.light .author-video-item,
body.light .author-comment-item,
body.light .smart-search-results,
body.light .link-checker-summary,
body.light .link-check-result {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

@media (max-width: 1100px) {
    .advanced-metrics-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .author-profile-columns {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    #controls .filter-action-group {
        width: 100%;
        margin-left: 0;
    }

    #controls .filter-action-group > * {
        flex: 1;
    }

    .advanced-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .advanced-moderation-card {
        grid-template-columns: auto minmax(0, 1fr) !important;
    }

    .advanced-moderation-card img {
        grid-column: 1 / -1;
    }

    .moderation-info {
        grid-column: 1 / -1;
    }

    .full-author-profile .public-profile-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .smart-search-results {
        position: fixed;
        top: 78px;
        left: 10px;
        right: 10px;
        max-height: 70vh;
    }
}

@media (max-width: 520px) {
    .advanced-metrics-grid {
        grid-template-columns: 1fr;
    }

    .author-video-item {
        grid-template-columns: 72px minmax(0, 1fr);
    }

    .author-video-item img {
        width: 72px;
    }

    .author-video-item .link-status-badge {
        grid-column: 1 / -1;
    }
}

/* =========================================================
   ADMIN DASHBOARD FIX / PROFILES / RATING STARS
   ========================================================= */

/* Прибираємо старі заголовки та підпис рівня доступу. */
#adminModal .admin-header-label-hidden {
    display: none !important;
}

/* Єдина структурована сітка блоків. */
#adminModal .admin-launcher-grid {
    padding: 14px !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 10px !important;
    overflow: visible !important;
    background: var(--bg-secondary) !important;
    border: 1px solid var(--border) !important;
}

#adminModal .admin-launcher-grid > .admin-dashboard-card,
#adminModal .admin-launcher-grid > .admin-tool-button,
#adminModal .admin-launcher-grid > .admin-tab,
#adminModal .admin-launcher-grid > .admin-nav-btn {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 94px !important;
    margin: 0 !important;
    padding: 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    color: var(--text-primary) !important;
    background: var(--bg-card) !important;
    border: 1px solid var(--border) !important;
    border-left: 5px solid var(--industrial-steel) !important;
    box-shadow: var(--shadow-sm) !important;
    text-align: left !important;
    white-space: normal !important;
}

#adminModal .admin-launcher-grid > .admin-dashboard-card:hover,
#adminModal .admin-launcher-grid > .admin-tool-button:hover,
#adminModal .admin-launcher-grid > .admin-tab:hover,
#adminModal .admin-launcher-grid > .admin-nav-btn:hover {
    color: var(--text-primary) !important;
    background: var(--bg-elevated) !important;
    border-left-color: var(--accent) !important;
    transform: translate(-1px, -1px);
}

#adminModal .admin-launcher-grid > * > i {
    width: 34px;
    flex: 0 0 34px;
    color: var(--accent-hover);
    font-size: 1.35rem;
    text-align: center;
}

#adminModal .admin-duplicate-tab-hidden,
#adminModal .admin-duplicate-page-hidden,
#adminModal .community-tab-hidden,
#adminModal .community-trusted-section-hidden {
    display: none !important;
}

/*
 * При відкритті панелі бачимо лише блоки.
 * Статистика та старі сторінки з'являються тільки після вибору розділу.
 */
#adminModalContent.admin-dashboard-landing .admin-tab-page {
    display: none !important;
}

#adminModalContent.admin-dashboard-landing .admin-dashboard-back {
    display: none !important;
}

#adminModal .admin-dashboard-back {
    margin: 12px 14px 0;
}

#adminModal .admin-tab-page.admin-merged-visible {
    display: block !important;
}

/* «Мої» акуратно притиснуто до кнопки додавання. */
#controls .filter-action-group {
    margin-left: auto;
    display: inline-flex;
    align-items: stretch;
    gap: 2px;
    flex: 0 0 auto;
}

#controls .filter-action-group .filter-my-relocated,
#controls .filter-action-group #openAddModal {
    margin: 0 !important;
}

#controls .filter-my-relocated {
    min-height: 38px !important;
    padding: 8px 12px !important;
    color: #b2b5b7 !important;
    background: #202428 !important;
    border: 1px solid #3b4045 !important;
    border-left: 3px solid var(--industrial-steel) !important;
    box-shadow: none !important;
    font-size: 0.78rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.035em;
    text-transform: uppercase;
}

#controls .filter-my-relocated::before {
    content: none !important;
    display: none !important;
}

#controls .filter-my-relocated:hover {
    color: #fff !important;
    background: #30353a !important;
    border-color: var(--accent) !important;
}

#controls .filter-my-relocated.active {
    color: #fff !important;
    background: var(--gradient-primary) !important;
    border-color: #ef4d43 !important;
    border-left-color: var(--accent-dark) !important;
}

/* Адмінські дії у чужому профілі. */
.public-profile-admin-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Власні додані відео. */
.own-profile-videos {
    padding: 13px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.own-profile-section-head {
    margin-bottom: 10px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.own-profile-section-head h3 {
    margin: 0 0 4px;
}

.own-profile-section-head p {
    margin: 0;
    color: var(--text-muted);
}

.own-profile-video-count {
    min-width: 30px;
    height: 30px;
    padding: 0 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--accent);
    font-weight: 900;
}

.own-profile-video-list {
    max-height: 340px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    overflow-y: auto;
    overscroll-behavior: contain;
}

.own-profile-video-item {
    padding: 8px;
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    align-items: center;
    gap: 9px;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    text-decoration: none;
}

.own-profile-video-item:hover {
    border-color: var(--accent);
}

.own-profile-video-item img {
    width: 92px;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.own-profile-video-item > span {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.own-profile-video-item strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.own-profile-video-item small {
    color: var(--text-muted);
}

.author-profile-columns--single {
    grid-template-columns: 1fr !important;
}

/* Оновлене оформлення рейтингу під відео. */
.star-rating {
    padding: 3px;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.star-rating i {
    width: 23px;
    height: 23px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #6f7478;
    background: #15181b;
    border: 1px solid #34393e;
    font-size: 0.72rem;
    cursor: pointer;
    transition:
        color var(--transition),
        background var(--transition),
        border-color var(--transition),
        transform var(--transition);
}

.star-rating i:hover {
    color: #201b0c;
    background: #efbe2b;
    border-color: #ffd65a;
    transform: translateY(-1px);
}

.star-rating i.active {
    color: #201b0c;
    background: var(--industrial-yellow);
    border-color: #f1c43c;
    box-shadow: inset 0 -2px 0 #8b6507;
}

.rating-value {
    min-height: 23px;
    padding: 3px 7px;
    display: inline-flex;
    align-items: center;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    font-size: 0.72rem;
    font-weight: 900;
}

body.light .own-profile-videos,
body.light .own-profile-video-item,
body.light .star-rating,
body.light .rating-value {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

body.light .star-rating i {
    color: #777;
    background: var(--bg-card);
    border-color: var(--border);
}

@media (max-width: 1100px) {
    #adminModal .admin-launcher-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 700px) {
    #adminModal .admin-launcher-grid {
        grid-template-columns: 1fr !important;
    }

    #controls .filter-action-group {
        width: 100%;
        margin-left: 0;
    }

    #controls .filter-action-group > * {
        flex: 1;
    }

    .public-profile-admin-actions {
        align-items: stretch;
        flex-direction: column-reverse;
    }

    .own-profile-video-item {
        grid-template-columns: 72px minmax(0, 1fr);
    }

    .own-profile-video-item img {
        width: 72px;
    }
}

/* =========================================================
   STABLE ADMIN HUB — єдина адмін-панель без DOM-інʼєкцій
   ========================================================= */

.stable-admin-hub {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.stable-admin-hub-close-row {
    display: flex;
    justify-content: flex-end;
}

.stable-admin-group {
    padding: 14px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 5px solid var(--industrial-steel);
}

.stable-admin-group-title {
    margin-bottom: 11px;
    display: flex;
    align-items: center;
    gap: 9px;
    color: var(--text-primary);
    font-size: 0.8rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.stable-admin-group-title i {
    width: 24px;
    color: var(--accent-hover);
    text-align: center;
}

.stable-admin-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.stable-admin-card {
    min-height: 104px;
    padding: 14px;
    display: flex;
    align-items: center;
    gap: 13px;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 5px solid var(--industrial-steel);
    box-shadow: var(--shadow-sm);
    text-align: left;
    cursor: pointer;
}

.stable-admin-card:hover {
    color: var(--text-primary);
    background: var(--bg-elevated);
    border-left-color: var(--accent);
    transform: translate(-1px, -1px);
}

.stable-admin-card > i {
    width: 38px;
    flex: 0 0 38px;
    color: var(--accent-hover);
    font-size: 1.45rem;
    text-align: center;
}

.stable-admin-card > span {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.stable-admin-card strong {
    color: var(--text-primary);
    font-size: 0.88rem;
    text-transform: uppercase;
}

.stable-admin-card small {
    color: var(--text-muted);
    line-height: 1.35;
}

/*
 * Важливо: стара адмін-панель більше не отримує
 * класи сітки та не змішується з новим hub.
 */
#adminModal .admin-launcher-grid,
#adminModal .admin-dashboard-card {
    all: revert;
}

body.light .stable-admin-group,
body.light .stable-admin-card {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

@media (max-width: 1000px) {
    .stable-admin-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 650px) {
    .stable-admin-grid {
        grid-template-columns: 1fr;
    }

    .stable-admin-card {
        min-height: 86px;
    }
}

/* =========================================================
   DIRECT ADMIN SECTIONS + MINIMAL DARK RATING
   ========================================================= */

.stable-admin-hub-header {
    padding: 2px 2px 10px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    border-bottom: 1px solid var(--border);
}

.stable-admin-hub-header h2 {
    margin: 0 0 4px !important;
    padding: 0 !important;
    border: 0 !important;
    color: var(--text-primary);
    font-size: 1.45rem;
    text-transform: uppercase;
}

.stable-admin-hub-header p {
    margin: 0;
    color: var(--text-muted);
}

.direct-admin-add-form,
.ban-create-form {
    margin-bottom: 12px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 8px;
}

.ban-create-form {
    grid-template-columns:
        minmax(150px, 0.75fr)
        minmax(220px, 1.4fr)
        110px
        auto;
}

.direct-admin-add-form .input-field,
.ban-create-form .input-field,
.direct-admin-add-form .compact-input,
.ban-create-form .compact-input {
    margin: 0;
}

.access-note,
.ban-form-help {
    margin: 0 0 12px;
    padding: 10px;
    color: var(--text-muted);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--industrial-steel);
}

.direct-admin-list,
.ban-list {
    max-height: 60vh;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
}

.direct-admin-item,
.ban-list-item {
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.direct-admin-user,
.direct-admin-actions {
    display: flex;
    align-items: center;
    gap: 9px;
}

.direct-admin-user > div,
.ban-list-item > div {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.direct-admin-user small,
.ban-list-item small,
.ban-list-item p {
    margin: 0;
    color: var(--text-muted);
}

.system-data-single-block {
    display: flex;
    flex-direction: column;
    gap: 0;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.system-data-section {
    padding: 15px;
}

.system-data-section + .system-data-section {
    border-top: 1px solid var(--border);
}

.system-data-section-head {
    margin-bottom: 11px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.system-data-section-head h3 {
    margin: 0 0 4px;
}

.system-data-section-head p {
    margin: 0;
    color: var(--text-muted);
}

.system-data-section textarea {
    min-height: 105px;
    margin-bottom: 10px;
}

.system-data-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

.backup-summary {
    margin-top: 11px;
    padding: 10px;
    color: var(--text-muted);
    background: var(--bg-primary);
    border: 1px solid var(--border);
}

.maintenance-switch {
    position: relative;
    width: 48px;
    height: 26px;
    flex: 0 0 48px;
}

.maintenance-switch input {
    position: absolute;
    opacity: 0;
}

.maintenance-switch span {
    position: absolute;
    inset: 0;
    background: #30353a;
    border: 1px solid #555b60;
    cursor: pointer;
}

.maintenance-switch span::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    background: #8d9296;
    transition: transform var(--transition);
}

.maintenance-switch input:checked + span {
    background: #5a1713;
    border-color: var(--accent);
}

.maintenance-switch input:checked + span::after {
    background: var(--accent-hover);
    transform: translateX(21px);
}

/* Мінімалістичний темно-сірий рейтинг. */
.star-rating {
    padding: 0 !important;
    gap: 4px !important;
    background: transparent !important;
    border: 0 !important;
}

.star-rating i {
    width: auto !important;
    height: auto !important;
    padding: 1px !important;
    color: #4f5458 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    font-size: 0.86rem !important;
    transform: none !important;
}

.star-rating i:hover {
    color: #70767b !important;
    background: transparent !important;
    border: 0 !important;
    transform: none !important;
}

.star-rating i.active {
    color: #62686d !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

.rating-value {
    min-height: 0 !important;
    padding: 0 0 0 5px !important;
    color: #777d82 !important;
    background: transparent !important;
    border: 0 !important;
    font-size: 0.7rem !important;
}

body.light .direct-admin-item,
body.light .ban-list-item,
body.light .system-data-single-block,
body.light .backup-summary {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

body.light .star-rating i {
    color: #8a8f93 !important;
}

body.light .star-rating i.active {
    color: #555b60 !important;
}

@media (max-width: 850px) {
    .direct-admin-add-form,
    .ban-create-form {
        grid-template-columns: 1fr;
    }

    .direct-admin-item,
    .ban-list-item {
        align-items: stretch;
        flex-direction: column;
    }

    .direct-admin-actions {
        flex-wrap: wrap;
    }
}

/* =========================================================
   COMMUNITY FEED POSTS
   ========================================================= */

.feed-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.feed-create-post-btn {
    flex: 0 0 auto;
    min-height: 40px;
}

.feed-create-post-btn--blocked {
    cursor: not-allowed;
    opacity: 0.5;
}

.feed-stream {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
    align-items: stretch;
    gap: 15px;
}

.feed-stream > .feed-empty-state {
    grid-column: 1 / -1;
}

.community-post-card {
    min-width: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-top: 4px solid var(--industrial-steel);
    box-shadow: var(--shadow-md);
    animation: fadeUp 0.25s ease;
    transition:
        transform var(--transition),
        border-color var(--transition),
        box-shadow var(--transition);
}

.community-post-card:hover {
    transform: translate(-2px, -2px);
    border-color: var(--border-strong);
    border-top-color: var(--accent);
    box-shadow: var(--shadow-lg);
}

.community-post-preview {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    padding: 0;
    overflow: hidden;
    background: #08090a;
    border: 0;
    border-bottom: 2px solid #23272a;
    cursor: pointer;
}

.community-post-preview::after {
    content: '';
    position: absolute;
    inset: auto 0 0;
    height: 54px;
    pointer-events: none;
    background: linear-gradient(
        transparent,
        rgba(0, 0, 0, 0.82)
    );
}

.community-post-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(0.88) contrast(1.04);
    transition:
        transform var(--transition),
        filter var(--transition);
}

.community-post-card:hover .community-post-preview img {
    transform: scale(1.025);
    filter: saturate(1) contrast(1.07);
}

.community-post-open-label {
    position: absolute;
    right: 8px;
    bottom: 8px;
    z-index: 2;
    padding: 4px 7px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: #fff;
    background: rgba(12, 14, 16, 0.88);
    border: 1px solid rgba(255, 255, 255, 0.18);
    font-size: 0.67rem;
    font-weight: 900;
    text-transform: uppercase;
}

.community-post-body {
    min-height: 0;
    padding: 11px 12px 13px;
    display: flex;
    flex: 1;
    flex-direction: column;
}

.community-post-author-row {
    margin-bottom: 9px;
    padding-bottom: 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    border-bottom: 1px solid var(--border-soft);
}

.community-post-author {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    text-align: left;
}

.community-post-author > span {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.community-post-author strong {
    max-width: 145px;
    overflow: hidden;
    color: var(--accent-hover);
    text-overflow: ellipsis;
    white-space: nowrap;
}

.community-post-author-row time {
    flex: 0 0 auto;
    color: var(--text-muted);
    font-size: 0.7rem;
}

.community-post-title {
    min-height: 2.55em;
    max-height: 2.55em;
    padding: 0;
    display: -webkit-box;
    overflow: hidden;
    color: var(--text-primary);
    background: transparent;
    border: 0;
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.27;
    text-align: left;
    cursor: pointer;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.community-post-title:hover {
    color: var(--accent-hover);
}

.community-post-description {
    min-height: 4.6em;
    max-height: 4.6em;
    margin: 8px 0 0;
    display: -webkit-box;
    overflow: hidden;
    color: var(--text-secondary);
    font-size: 0.82rem;
    line-height: 1.5;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.community-post-tags {
    min-height: 24px;
    margin-top: 9px;
    display: flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
}

.community-post-tags span {
    padding: 3px 6px;
    color: var(--text-muted);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    font-size: 0.68rem;
    font-weight: 800;
}

.community-post-footer {
    margin-top: auto;
    padding-top: 10px;
    display: flex;
    align-items: center;
    gap: 13px;
    color: var(--text-muted);
    font-size: 0.76rem;
}

.community-post-footer > span,
.community-post-stat-button {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.community-post-stat-button {
    padding: 0;
    color: var(--text-muted);
    background: transparent;
    border: 0;
    font: inherit;
    cursor: pointer;
}

.community-post-stat-button:hover,
.community-post-stat-button.active {
    color: var(--accent-hover);
}

/* Composer */

.feed-composer-form {
    display: flex;
    flex-direction: column;
    gap: 13px;
}

.feed-composer-form label {
    display: flex;
    flex-direction: column;
    gap: 6px;
    color: var(--text-primary);
    font-weight: 900;
}

.feed-composer-form label > small {
    color: var(--text-muted);
    font-weight: 400;
    line-height: 1.4;
}

.feed-composer-form textarea {
    min-height: 180px;
    resize: vertical;
}

.feed-image-source-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.feed-image-preview {
    min-height: 180px;
    max-height: 360px;
    padding: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #090b0c;
    border: 1px solid var(--border);
}

.feed-image-preview img {
    max-width: 100%;
    max-height: 340px;
    object-fit: contain;
}

.feed-composer-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

/* Post details */

.feed-post-detail {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.feed-post-detail-author {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 12px;
}

.feed-post-detail-author > .profile-link {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 9px;
    text-align: left;
}

.feed-post-detail-author > .profile-link > span {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 7px;
    flex-wrap: wrap;
}

.feed-post-detail-author time {
    color: var(--text-muted);
    font-size: 0.75rem;
}

.feed-post-detail-title {
    margin: 0 !important;
    padding: 0 !important;
    color: var(--text-primary);
    border: 0 !important;
    font-size: 1.45rem;
    line-height: 1.3;
}

.feed-post-detail-image {
    max-height: 62vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #070809;
    border: 1px solid var(--border);
}

.feed-post-detail-image img {
    max-width: 100%;
    max-height: 62vh;
    object-fit: contain;
}

.feed-post-detail-description {
    padding: 14px;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
    line-height: 1.7;
    white-space: normal;
}

.feed-post-detail-stats {
    display: flex;
    align-items: center;
    gap: 16px;
    color: var(--text-muted);
}

.feed-post-detail-stats > span,
.feed-post-detail-stats > button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* Integrated comments */

.feed-post-comments {
    padding-top: 14px;
    border-top: 1px solid var(--border);
}

.feed-post-comments-head {
    margin-bottom: 11px;
}

.feed-post-comments-head h3 {
    margin: 0 0 4px;
    color: var(--text-primary);
}

.feed-post-comments-head p {
    margin: 0;
    color: var(--text-muted);
}

.feed-main-comment-form {
    margin-bottom: 13px;
    padding: 11px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}

.feed-main-comment-form textarea {
    min-height: 100px;
    margin-bottom: 8px;
}

.feed-main-comment-form > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.feed-main-comment-form small {
    color: var(--text-muted);
}

.feed-comment-login-note {
    margin-bottom: 13px;
    padding: 11px;
    color: var(--text-muted);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.feed-post-comment-list {
    display: flex;
    flex-direction: column;
    gap: 9px;
}

.feed-comment-thread {
    min-width: 0;
}

.feed-comment-item {
    padding: 11px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--industrial-steel);
}

.feed-comment-head {
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 9px;
}

.feed-comment-author {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 7px;
}

.feed-comment-author > span {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.feed-comment-head time {
    color: var(--text-muted);
    font-size: 0.7rem;
}

.feed-comment-text {
    color: var(--text-secondary);
    line-height: 1.55;
}

.feed-comment-actions {
    margin-top: 9px;
    display: flex;
    align-items: center;
    gap: 7px;
    flex-wrap: wrap;
}

.feed-comment-like-static {
    color: var(--text-muted);
    font-size: 0.76rem;
}

.danger-action {
    color: var(--danger) !important;
}

.feed-comment-replies {
    margin: 8px 0 0 25px;
    padding-left: 11px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-left: 2px solid var(--border);
}

.feed-comment-reply-slot {
    margin-left: 25px;
}

.feed-inline-reply-form {
    margin-top: 8px;
    padding: 10px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
}

.feed-inline-reply-form > div:first-child {
    margin-bottom: 7px;
    color: var(--text-muted);
    font-size: 0.78rem;
}

.feed-inline-reply-form textarea {
    min-height: 82px;
    margin-bottom: 7px;
}

.feed-inline-reply-actions {
    display: flex;
    justify-content: flex-end;
    gap: 7px;
}

.feed-comments-empty {
    padding: 14px;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    text-align: center;
}

body.light .community-post-card,
body.light .community-post-tags span,
body.light .feed-post-detail-description,
body.light .feed-main-comment-form,
body.light .feed-comment-login-note,
body.light .feed-comment-item,
body.light .feed-inline-reply-form,
body.light .feed-comments-empty {
    color: var(--text-primary);
    background: var(--bg-secondary);
    border-color: var(--border);
}

@media (max-width: 760px) {
    .feed-page-header {
        align-items: stretch;
        flex-direction: column;
    }

    .feed-create-post-btn {
        width: 100%;
    }

    .feed-stream {
        grid-template-columns: 1fr;
    }

    .feed-image-source-grid {
        grid-template-columns: 1fr;
    }

    .feed-composer-actions {
        flex-direction: column-reverse;
    }

    .feed-composer-actions .btn {
        width: 100%;
    }

    .feed-post-detail-author {
        align-items: flex-start;
        flex-direction: column;
    }

    .feed-main-comment-form > div {
        align-items: stretch;
        flex-direction: column;
    }

    .feed-main-comment-form .btn {
        width: 100%;
    }

    .feed-comment-replies,
    .feed-comment-reply-slot {
        margin-left: 12px;
    }
}

/* =========================================================
   FEED SAFETY / EDIT / PIN / MENTIONS / EMOJIS
   ========================================================= */

.community-post-pinned-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 3;
    padding: 4px 7px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: #d8dbdd;
    background: rgba(29, 32, 35, 0.94);
    border: 1px solid #62686d;
    border-left: 4px solid var(--accent);
    font-size: 0.66rem;
    font-weight: 900;
    text-transform: uppercase;
}

.community-post-card--pinned {
    border-top-color: var(--accent);
}

.community-post-date-group {
    flex: 0 0 auto;
    display: flex;
    align-items: flex-end;
    flex-direction: column;
    gap: 2px;
}

.community-post-date-group small {
    color: #70767b;
    font-size: 0.62rem;
}

.feed-post-detail-admin-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}

.feed-post-detail-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.feed-post-pinned-label {
    flex: 0 0 auto;
    padding: 4px 7px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--accent-hover);
    background: var(--bg-secondary);
    border: 1px solid var(--accent-dark);
    font-size: 0.68rem;
    font-weight: 900;
    text-transform: uppercase;
}

.feed-post-edited-label {
    margin-top: -7px;
    color: var(--text-muted);
    font-size: 0.72rem;
}

/* Shared mentions */

.mention-input-host {
    position: relative;
    width: 100%;
}

.mention-input-host > textarea {
    width: 100%;
}

.mention-suggestions {
    position: absolute;
    left: 0;
    right: 0;
    bottom: calc(100% + 5px);
    z-index: 4000;
    max-height: 270px;
    overflow-y: auto;
    color: var(--text-primary);
    background: var(--bg-card);
    border: 1px solid var(--border-strong);
    border-top: 3px solid var(--accent);
    box-shadow: var(--shadow-lg);
}

.mention-suggestion {
    width: 100%;
    padding: 8px 10px;
    display: flex;
    align-items: center;
    gap: 9px;
    color: var(--text-primary);
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--border);
    text-align: left;
    cursor: pointer;
}

.mention-suggestion:hover,
.mention-suggestion.keyboard-active {
    background: var(--bg-elevated);
}

.mention-suggestion > span {
    min-width: 0;
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 2px;
}

.mention-suggestion strong,
.mention-suggestion small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mention-suggestion small {
    color: var(--text-muted);
}

.mention-suggestions-empty {
    padding: 12px;
    color: var(--text-muted);
    text-align: center;
}

.mention-link {
    color: var(--accent-hover);
    font-weight: 900;
}

/* Emoji picker */

.comment-composer-toolbar {
    position: relative;
    margin-top: 6px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.emoji-picker-button {
    padding: 4px 7px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--text-muted);
    background: var(--bg-card);
    border: 1px solid var(--border);
    font-size: 0.72rem;
    cursor: pointer;
}

.emoji-picker-button:hover {
    color: var(--text-primary);
    border-color: var(--border-strong);
}

.emoji-picker-panel {
    position: absolute;
    left: 0;
    bottom: calc(100% + 5px);
    z-index: 4100;
    width: min(310px, 90vw);
    padding: 8px;
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 5px;
    background: var(--bg-card);
    border: 1px solid var(--border-strong);
    border-top: 3px solid var(--accent);
    box-shadow: var(--shadow-lg);
}

.emoji-picker-item {
    aspect-ratio: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    font-size: 1.08rem;
    cursor: pointer;
}

.emoji-picker-item:hover {
    background: var(--bg-elevated);
    border-color: var(--accent);
}

.feed-main-comment-form .comment-composer-toolbar,
.feed-inline-reply-form .comment-composer-toolbar {
    margin-bottom: 7px;
}

body.light .mention-suggestions,
body.light .emoji-picker-panel,
body.light .emoji-picker-button,
body.light .emoji-picker-item {
    color: var(--text-primary);
    background: var(--bg-card);
    border-color: var(--border);
}

@media (max-width: 760px) {
    .feed-post-detail-admin-actions {
        width: 100%;
    }

    .feed-post-detail-admin-actions .btn {
        flex: 1;
    }

    .feed-post-detail-title-row {
        flex-direction: column;
    }

    .emoji-picker-panel {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }
}


/* Production pagination and compact controls */
.feed-load-more-row,
.donates-load-more {
    grid-column: 1 / -1;
    display: flex;
    justify-content: center;
    padding: 12px 0 4px;
}

.rating-star {
    width: auto;
    height: auto;
    padding: 1px;
    color: inherit;
    background: transparent;
    border: 0;
    box-shadow: none;
    cursor: pointer;
}

.rating-star i {
    pointer-events: none;
}

.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 18px 0;
}

.pagination > span {
    color: var(--text-muted);
    font-weight: 800;
}

.compact-video-list {
    max-height: 65vh;
    display: flex;
    flex-direction: column;
    gap: 8px;
    overflow-y: auto;
}

.compact-video-item {
    padding: 8px;
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    color: var(--text-primary);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    text-decoration: none;
}

.compact-video-item img {
    width: 120px;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.compact-video-item span {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.compact-video-item strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.compact-video-item small { color: var(--text-muted); }

/* =========================================================
   RESTORED VIDEO CARD LAYOUT
   ========================================================= */
.feed-card.is-video-pinned {
    border-top-color: var(--industrial-yellow);
}

.video-card-top .video-author {
    min-width: 0;
    flex: 1;
}

.video-card-top .video-card-pin {
    width: 30px;
    height: 30px;
    flex: 0 0 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    background: var(--bg-secondary);
    border: 1px solid var(--border);
}

.video-card-top .video-card-pin:hover {
    color: var(--text-primary);
    border-color: var(--border-strong);
}

.video-card-top .video-card-pin.is-pinned {
    color: #17191a;
    background: var(--industrial-yellow);
    border-color: #9e730a;
}

.video-pin-meta {
    margin: -1px 0 7px;
    padding: 4px 7px;
    display: flex;
    align-items: center;
    gap: 5px;
    overflow: hidden;
    color: var(--text-muted);
    background: var(--bg-secondary);
    border-left: 3px solid var(--industrial-yellow);
    font-size: 0.7rem;
    white-space: nowrap;
}

.video-pin-meta .profile-link {
    min-width: 0;
    overflow: hidden;
    color: var(--text-secondary);
    font-weight: 900;
    text-overflow: ellipsis;
}

.video-card-meta {
    justify-content: space-between;
}

.video-channel-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.video-channel-link .fa-youtube {
    color: var(--accent-hover);
}

.video-channel-views {
    white-space: nowrap;
}

.video-card-footer {
    min-height: 38px;
    justify-content: flex-end;
}

.video-card-footer .star-rating {
    margin-right: auto;
}

.video-card-footer .rating-star {
    padding: 0;
    color: #4f5458;
    background: transparent;
    border: 0;
}

.video-card-footer .rating-star.active,
.video-card-footer .rating-star:hover {
    color: #686e73;
}

.filter-btn .approved-filter-icon {
    margin-right: 5px;
    color: #5e6469;
}

.filter-btn.active .approved-filter-icon {
    color: currentColor;
}

@media (max-width: 520px) {
    .video-card-meta {
        align-items: flex-start;
        flex-direction: column;
        gap: 4px;
        max-height: none;
    }

    .video-channel-views {
        padding-left: 1px;
    }
}

/* =========================================================
   UI / LOGO HOTFIX
   ========================================================= */

.loader-logo {
    width: 76px;
    height: 76px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0;
}

.loader-logo img {
    width: 76px;
    height: 76px;
    display: block;
    object-fit: contain;
    border: 2px solid #70757a;
    border-radius: 18px;
    box-shadow:
        5px 5px 0 rgba(0, 0, 0, 0.32),
        0 0 28px rgba(201, 42, 32, 0.18);
}

.logo-avatar,
.logo > img {
    display: block;
    object-fit: contain;
    background: #111416;
}

.feed-page-header.feed-page-header-actions-only {
    min-height: 0;
    margin-bottom: 14px;
    padding: 0;
    justify-content: flex-end;
    color: inherit;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.feed-page-header-actions-only::before,
.feed-page-header-actions-only::after {
    content: none;
    display: none;
}

@media (max-width: 700px) {
    .feed-page-header.feed-page-header-actions-only {
        align-items: stretch;
    }

    .feed-page-header-actions-only .feed-create-post-btn {
        width: 100%;
    }
}


/* =========================================================
   UPLOADED SITE LOGO + NAVIGATION HOTFIX
   ========================================================= */

.logo-avatar,
.logo > img,
.loader-logo img {
    object-fit: cover;
    object-position: center;
    background: #d7d1c7;
}

.logo-avatar {
    border-radius: 50%;
}

.loader-logo img {
    border-radius: 50%;
}

.header-nav {
    scrollbar-width: thin;
}

@media (max-width: 1120px) {
    .header-nav {
        max-width: 100%;
        overflow-x: auto;
        overscroll-behavior-inline: contain;
    }

    .nav-tab {
        flex: 0 0 auto;
    }
}


/* =========================================================
   HEADER, GLOBAL SEARCH, LIVE LOGO AND PAGE TOOLBARS — FINAL FIX
   ========================================================= */

.header-inner {
    min-height: 94px !important;
    grid-template-columns: 235px minmax(320px, 680px) minmax(250px, auto) !important;
    grid-template-rows: 44px 34px !important;
    gap: 7px 20px !important;
}

.header-brand {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    display: flex;
    align-items: center;
}

.header-brand .logo {
    position: static !important;
    top: auto !important;
}

.header-inner > .header-nav {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    width: fit-content;
    max-width: 100%;
    justify-self: center !important;
    margin: 0 !important;
}

.header-center {
    grid-column: 2 !important;
    grid-row: 1 !important;
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: 100% !important;
    max-width: 680px !important;
    align-self: center;
    justify-self: center;
}

.header-center .search-section {
    width: 100% !important;
    max-width: none !important;
    min-height: 40px !important;
    margin: 0 !important;
}

.header-right {
    grid-column: 3;
    grid-row: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.header .user-area,
.header .header-user-panel {
    transform: none !important;
}

.logo-live-link {
    position: relative;
    flex: 0 0 36px;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    text-decoration: none;
}

.logo-live-link .logo-avatar {
    width: 36px;
    height: 36px;
    border: 2px solid #70757a !important;
    box-shadow:
        3px 3px 0 rgba(0, 0, 0, 0.45),
        0 0 0 rgba(201, 42, 32, 0) !important;
    transition:
        border-color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.25s ease;
}

.logo-live-dot {
    position: absolute;
    right: -2px;
    bottom: -1px;
    width: 9px;
    height: 9px;
    display: block;
    background: #6f7478;
    border: 2px solid #111315;
    border-radius: 50%;
    transition: background 0.25s ease, box-shadow 0.25s ease;
}

.logo-live-link.is-live .logo-avatar {
    border-color: #ef3f35 !important;
    box-shadow:
        3px 3px 0 rgba(0, 0, 0, 0.45),
        0 0 9px rgba(239, 63, 53, 0.62),
        0 0 18px rgba(201, 42, 32, 0.28) !important;
}

.logo-live-link.is-live .logo-live-dot {
    background: #ff3c32;
    box-shadow: 0 0 7px rgba(255, 60, 50, 0.9);
    animation: logoLivePulse 1.8s ease-in-out infinite;
}

.logo-live-link:hover .logo-avatar {
    transform: translateY(-1px);
}

@keyframes logoLivePulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.22); opacity: 0.78; }
}

.global-search-results {
    position: absolute;
    z-index: 1400;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    max-height: min(68vh, 560px);
    overflow-y: auto;
    color: var(--text-primary);
    background: #111416;
    border: 1px solid #4a5055;
    border-top: 3px solid var(--accent);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.52);
}

.global-search-result {
    width: 100%;
    min-height: 66px;
    padding: 9px 11px;
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr) auto;
    align-items: center;
    gap: 11px;
    color: var(--text-primary);
    background: transparent;
    border: 0;
    border-bottom: 1px solid #2f3438;
    cursor: pointer;
    text-align: left;
}

.global-search-result:last-child {
    border-bottom: 0;
}

.global-search-result:hover,
.global-search-result.keyboard-active {
    background: #252a2e;
    box-shadow: inset 4px 0 0 var(--accent);
}

.global-search-result > img {
    width: 46px;
    height: 46px;
    object-fit: cover;
    background: #d7d1c7;
    border: 1px solid #555b60;
    border-radius: 4px;
}

.global-search-result-copy {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.global-search-result-copy strong,
.global-search-result-copy small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.global-search-result-copy strong {
    color: var(--text-primary);
    font-size: 0.9rem;
}

.global-search-result-copy small {
    color: var(--text-muted);
    font-size: 0.75rem;
}

.global-search-result-type {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #b7bbbe;
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.global-search-loading,
.global-search-empty {
    min-height: 92px;
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    color: var(--text-muted);
    text-align: center;
}

.global-search-empty {
    flex-direction: column;
}

.global-search-empty i,
.global-search-loading i {
    color: var(--accent);
}

.global-search-empty.is-error {
    color: #ffcfcb;
}

.feed-page-header.feed-page-header-actions-only,
#donatesPage .donates-header.donates-header-actions-only {
    min-height: 58px !important;
    margin: 0 0 18px !important;
    padding: 8px 0 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    color: inherit !important;
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid var(--border-soft) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.search-result-highlight {
    animation: searchResultHighlight 1.15s ease-in-out 3;
}

@keyframes searchResultHighlight {
    0%, 100% { box-shadow: 5px 5px 0 rgba(0, 0, 0, 0.2); }
    50% {
        border-color: var(--accent);
        box-shadow:
            0 0 0 3px rgba(201, 42, 32, 0.22),
            0 0 20px rgba(201, 42, 32, 0.32);
    }
}

@media (max-width: 1220px) {
    .header-inner {
        min-height: 132px !important;
        grid-template-columns: minmax(220px, 1fr) auto !important;
        grid-template-rows: 42px 42px 34px !important;
    }

    .header-brand {
        grid-column: 1;
        grid-row: 1;
    }

    .header-right {
        grid-column: 2;
        grid-row: 1;
    }

    .header-center {
        grid-column: 1 / -1 !important;
        grid-row: 2 !important;
        max-width: 760px !important;
    }

    .header-inner > .header-nav {
        grid-column: 1 / -1 !important;
        grid-row: 3 !important;
    }
}

@media (max-width: 700px) {
    .header-inner {
        padding-inline: 10px !important;
    }

    .header-inner > .header-nav {
        width: 100%;
        overflow-x: auto;
        justify-content: flex-start;
    }

    .nav-tab {
        min-width: 104px;
        padding-inline: 13px;
    }

    .global-search-result {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .global-search-result > img {
        width: 42px;
        height: 42px;
    }

    .global-search-result-type {
        grid-column: 2;
        justify-self: start;
    }

    .feed-page-header.feed-page-header-actions-only,
    #donatesPage .donates-header.donates-header-actions-only {
        min-height: 54px !important;
        align-items: stretch !important;
    }
}
