/**
 * TN: Lazy Loading Styles
 */

/* WebView fixes: отключаем font boosting и автозум */
html { 
  -webkit-text-size-adjust: 100%; 
  text-size-adjust: 100%; 
}

/* Aspect ratio containers */
.tn-ratio-16x9 {
    aspect-ratio: 16 / 9;
    position: relative;
    overflow: hidden;
}

.tn-ratio-4x3 {
    aspect-ratio: 4 / 3;
    position: relative;
    overflow: hidden;
}

.tn-ratio-1x1 {
    aspect-ratio: 1 / 1;
    position: relative;
    overflow: hidden;
}

/* Image wrappers */
.tn-img-wrapper {
    position: relative;
    overflow: hidden;
}

.tn-img-wrapper img {
    display: block;
    width: 100%;
    height: auto;
}

/* Card images */
.tn-card-img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* Placeholder blur effect */
.tn-img-ph {
    filter: blur(8px);
    transition: filter 0.25s ease-in-out;
}

.tn-img-ph.loaded {
    filter: none;
}

/* Lazy background images */
.tn-bg-lazy {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    min-height: 200px; /* Fallback for older browsers */
}

.tn-bg-loaded {
    /* Background image loaded - placeholder for future styles */
    opacity: 1;
}

/* Embed containers */
.tn-embed {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%; /* 16:9 aspect ratio fallback */
    overflow: hidden;
}

.tn-embed iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.tn-embed-placeholder {
    position: relative;
    background-color: #262b30;
}

.tn-embed-placeholder-img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: pointer;
    transition: opacity 0.3s ease;
}

.tn-embed-placeholder-img:hover {
    opacity: 0.9;
}

/* Similar streamers section */
.tn-similar-streamers {
    margin-top: 3rem;
    margin-bottom: 3rem;
}

.tn-similar-title {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
}

.tn-grid-similar {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
}

@media (max-width: 640px) {
    .tn-grid-similar {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 641px) and (max-width: 1024px) {
    .tn-grid-similar {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Streamer card */
.tn-card-streamer {
    background: rgba(38, 43, 48, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 0.5rem;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.tn-card-streamer:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.tn-card-streamer .tn-card-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.tn-card-streamer .tn-card__media {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}

.tn-card-streamer .tn-card__body {
    padding: 1rem;
}

.tn-card-streamer .tn-card-title {
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0 0 0.5rem 0;
    line-height: 1.4;
}

.tn-card-streamer .tn-card__meta {
    font-size: 0.875rem;
    color: rgba(229, 231, 235, 0.7);
    margin: 0;
}

/* Honeypot field (hidden) - accessibility-friendly */
.tn-hp,
input[name*="honeypot"],
input[type="text"][name*="human"],
input[type="text"][name*="bot"] {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    clip: rect(0, 0, 0, 0) !important;
}

/* Hide honeypot labels */
label[for*="honeypot"],
label[for*="human"],
label[for*="bot"] {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
}

/* Hide "Only fill in if you are not human" text */
.tn-hp-text,
*:contains("Only fill in if you are not human") {
    display: none !important;
    visibility: hidden !important;
}

/* Fallback for browsers without aspect-ratio support */
@supports not (aspect-ratio: 16 / 9) {
    .tn-ratio-16x9::before {
        content: '';
        display: block;
        padding-bottom: 56.25%; /* 16:9 */
    }
    
    .tn-ratio-4x3::before {
        content: '';
        display: block;
        padding-bottom: 75%; /* 4:3 */
    }
    
    .tn-ratio-1x1::before {
        content: '';
        display: block;
        padding-bottom: 100%; /* 1:1 */
    }
    
    .tn-ratio-16x9 > *,
    .tn-ratio-4x3 > *,
    .tn-ratio-1x1 > * {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }
}

/* ============================================
   Streamers DB Table Styles
   ============================================ */

/* Remove underline from tabs and table header links */
#tn-streamers-db .mb-3 a,
#tn-streamers-db thead a {
    text-decoration: none !important;
    border-bottom: 0 !important;
}

#tn-streamers-db .mb-3 a:hover,
#tn-streamers-db thead a:hover {
    text-decoration: none !important;
}

/* Tabs */
#tn-streamers-db .tn-tab {
    position: relative;
    color: var(--text);
}

#tn-streamers-db .tn-tab--active {
    color: var(--tn-accent);
    background: transparent;
    box-shadow: inset 0 0 0 1px var(--tn-accent);
    border-radius: 8px;
}

/* Prevent bottom clipping of active tab border/outline */
#tn-streamers-db > .overflow-x-auto {
    overflow-y: visible;
}

#tn-streamers-db .mb-3 {
    padding-bottom: 6px;
    overflow: visible;
}

#tn-streamers-db .mb-3 a {
    display: inline-flex;
    align-items: center;
    line-height: 1.25;
}

/* Mobile-only helpers default hidden on desktop */
#tn-streamers-db .tn-card-toggle,
#tn-streamers-db .tn-card-extra,
#tn-streamers-db .tn-dot--mobile,
#tn-streamers-db .tn-mobile-extra {
    display: none;
}

/* Mobile responsive styles - Beautiful card layout on mobile */
@media (max-width: 768px) {
    /* Скрываем старую верхнюю панель вкладок на мобильных */
    #tn-streamers-db .mb-3.flex.flex-wrap.gap-2 {
        display: none !important;
    }

    /* Нижняя мобильная панель сортировки */
    #tn-streamers-db {
        padding-bottom: 70px;
    }

    #tn-streamers-db .tn-mobile-sort-bar {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 40;
        padding-top: 4px !important;
        padding-bottom: 4px !important;
        background: rgba(15,23,42,0.98);
        backdrop-filter: blur(14px);
        -webkit-backdrop-filter: blur(14px);
        border-top: 1px solid rgba(255,255,255,0.12);
        gap: 6px;
    }

    #tn-streamers-db .tn-mobile-sort-bar a.tn-tab {
        border-radius: 999px;
        padding: 4px 10px !important;
        margin-right: 6px !important;
        background: rgba(31,41,55,0.96);
        color: rgba(249,250,251,0.9);
        border: 1px solid rgba(148,163,184,0.45);
        box-shadow: 0 4px 10px rgba(0,0,0,0.45);
    }

    #tn-streamers-db .tn-mobile-sort-bar a.tn-tab:last-child {
        margin-right: 0 !important;
    }

    #tn-streamers-db .tn-mobile-sort-bar a.tn-tab--active {
        background: var(--tn-accent);
        border-color: var(--tn-accent);
        color: #ffffff;
        box-shadow: 0 4px 14px rgba(0,0,0,0.7);
    }
    
    /* Show game filters on mobile when games tab is active */
    #tn-streamers-db .mb-3.flex.flex-wrap.items-center.gap-2 {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 6px !important;
        margin-bottom: 12px !important;
    }
    
    #tn-streamers-db .mb-3.flex.flex-wrap.items-center.gap-2 a {
        font-size: 12px !important;
        padding: 6px 10px !important;
    }
    
    /* Override any table display styles */
    #tn-streamers-db .overflow-x-auto,
    #tn-streamers-db .overflow-x-auto .tn-table,
    #tn-streamers-db .tn-table {
        display: block !important;
        min-width: 0 !important;
        width: 100% !important;
        overflow: visible !important;
    }

    #tn-streamers-db .tn-table thead {
        display: none !important;
    }

    #tn-streamers-db .tn-table tbody {
        display: block !important;
        padding: 0 !important;
    }

    /* Mobile card styling - Строка таблицы должна оставаться табличной */
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card {
        display: table-row !important;
        padding: 0 !important;
        gap: 0 !important;
    }
    
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card > td {
        display: table-cell !important;
        padding: 0 !important;
        border: 0 !important;
    }
    
    /* Любые stacked-псевдолейблы отключаем для карточек */
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card > td::before {
        content: none !important;
    }
    
    /* Внутренняя раскладка — внутри .tn-card, не на <tr> */
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-card {
        display: flex;
        flex-direction: column;
        gap: 8px;
        padding: 18px;
    }
    
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-card-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
        margin-bottom: 12px !important;
    }

    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-card-left {
        display: flex;
        align-items: center;
        gap: 10px;
    }
    
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-card-avatar {
        width: 40px; height: 40px; border-radius: 50%; object-fit: cover;
    }
    
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-online-badge {
        display: inline-flex; align-items: center; gap: 6px;
    }
    
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-dot {
        width: 8px; height: 8px; border-radius: 50%; display: inline-block; background: #9CA3AF;
    }
    
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-dot--on { background: #22c55e; }
    
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-live-badge {
        font-size: 12px; font-weight: 700; text-transform: uppercase;
    }
    
    #tn-streamers-db .tn-table tbody tr.tn-mobile-card .tn-card-metric {
        white-space: nowrap; text-align: right;
    }

    #tn-streamers-db .tn-metric-label {
        font-size: 12px !important;
        color: rgba(255, 255, 255, 0.6) !important;
        display: block !important;
        margin-bottom: 2px !important;
    }

    #tn-streamers-db .tn-metric-value {
        font-size: 20px !important;
        font-weight: 800 !important;
        color: var(--text, #e5e7eb) !important;
        display: block !important;
        text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3) !important;
        letter-spacing: -0.3px !important;
    }

    /* Details section */
    #tn-streamers-db .tn-card-details {
        margin-top: 16px !important;
        padding-top: 16px !important;
        border-top: 1px solid rgba(255, 255, 255, 0.12) !important;
        animation: slideDown 0.3s ease-out !important;
    }
    
    @keyframes slideDown {
        from {
            opacity: 0;
            transform: translateY(-10px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    #tn-streamers-db .tn-details-list {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
    }

    #tn-streamers-db .tn-detail-row {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        font-size: 14px !important;
        padding: 10px 12px !important;
        margin: 4px 0 !important;
        border-radius: 8px !important;
        background: rgba(255, 255, 255, 0.02) !important;
        border: 1px solid rgba(255, 255, 255, 0.05) !important;
        transition: all 0.2s ease !important;
    }
    
    #tn-streamers-db .tn-detail-row:hover {
        background: rgba(255, 255, 255, 0.05) !important;
        border-color: rgba(145, 70, 255, 0.2) !important;
        transform: translateX(4px) !important;
    }

    #tn-streamers-db .tn-detail-row:last-child {
        margin-bottom: 0 !important;
    }

    #tn-streamers-db .tn-detail-label {
        color: rgba(255, 255, 255, 0.7) !important;
        font-weight: 500 !important;
    }

    #tn-streamers-db .tn-detail-value {
        color: var(--text, #e5e7eb) !important;
        font-weight: 600 !important;
        text-align: right !important;
    }

    /* Toggle button */
    #tn-streamers-db .tn-card-toggle {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        margin-top: 16px !important;
        padding: 12px 20px !important;
        font-size: 15px !important;
        font-weight: 700 !important;
        color: #fff !important;
        background: linear-gradient(135deg, rgba(145, 70, 255, 0.9) 0%, rgba(145, 70, 255, 0.7) 100%) !important;
        border: 1px solid rgba(145, 70, 255, 0.5) !important;
        border-radius: 12px !important;
        cursor: pointer !important;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
        box-shadow: 0 4px 12px rgba(145, 70, 255, 0.3), 0 2px 4px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
        position: relative !important;
        overflow: hidden !important;
    }
    
    #tn-streamers-db .tn-card-toggle::before {
        content: '' !important;
        position: absolute !important;
        top: 0 !important;
        left: -100% !important;
        width: 100% !important;
        height: 100% !important;
        background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent) !important;
        transition: left 0.5s ease !important;
    }
    
    #tn-streamers-db .tn-card-toggle:hover::before {
        left: 100% !important;
    }

    #tn-streamers-db .tn-card-toggle:hover {
        background: linear-gradient(135deg, rgba(145, 70, 255, 1) 0%, rgba(145, 70, 255, 0.85) 100%) !important;
        border-color: rgba(145, 70, 255, 0.7) !important;
        transform: translateY(-2px) scale(1.02) !important;
        box-shadow: 0 6px 16px rgba(145, 70, 255, 0.4), 0 3px 6px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.25) !important;
    }
    
    #tn-streamers-db .tn-card-toggle:active {
        transform: translateY(0) scale(0.98) !important;
        box-shadow: 0 2px 6px rgba(145, 70, 255, 0.3), inset 0 2px 4px rgba(0, 0, 0, 0.2) !important;
    }

    #tn-streamers-db .tn-card-toggle.tn-toggle-active {
        background: linear-gradient(135deg, rgba(145, 70, 255, 0.7) 0%, rgba(145, 70, 255, 0.5) 100%) !important;
        border-color: rgba(145, 70, 255, 0.6) !important;
    }

}

/* TN-PATCH START: Streamer cards responsive */
.tn-streamer-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}

.tn-streamer-card {
  grid-column: span 4;
  background:#111;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:16px;
  color:#fff;
  box-shadow: 0 4px 18px rgba(0,0,0,.2);
}

.tn-streamer-card .tn-card-header {
  display:flex; align-items:center; gap:12px;
}

.tn-streamer-card .tn-avatar {
  width:64px; height:64px; border-radius:12px; object-fit:cover; flex:0 0 64px;
  background:#222;
}

.tn-streamer-card .tn-title {
  font-size: clamp(16px, 2.5vw, 20px);
  line-height: 1.25;
  margin:0;
}

.tn-live-badge {
  display:inline-block;
  font-size:12px;
  font-weight:700;
  padding:2px 8px;
  border-radius:999px;
  background:#ff2d2d;
  color:#fff;
  margin-left:8px;
  vertical-align: middle;
}

.tn-offline { opacity:.7; }

.tn-streamer-card .tn-meta {
  margin-top:8px; display:flex; flex-wrap:wrap; gap:10px;
  font-size: 13px; opacity:.9;
}

.tn-streamer-card .tn-stat {
  background: rgba(255,255,255,.06);
  border-radius: 10px;
  padding:6px 10px;
}

@media (max-width: 1024px) {
  .tn-streamer-card { grid-column: span 6; }
}
@media (max-width: 640px) {
  .tn-streamer-grid { gap:12px; }
  .tn-streamer-card { grid-column: 1 / -1; padding:14px; border-radius:14px; }
  .tn-streamer-card .tn-avatar { width:56px; height:56px; border-radius:10px; }
  .tn-streamer-card .tn-title { font-size: clamp(16px, 4.5vw, 18px); }
  .tn-streamer-card .tn-meta { font-size: 12px; gap:8px; }
}
/* TN-PATCH END: Streamer cards responsive */

/* ===== TN Streamers DB: mobile/table fixes ===== */
.tn-streamers-db * { box-sizing: border-box; }

/* Скрываем элемент "Twitch news" ТОЛЬКО внутри контейнера топ стримеров */
.tn-streamers-db li a[href="https://twitch-news.ru/"],
.tn-streamers-db li a[href*="twitch-news.ru"][href*="Twitch news"],
#tn-streamers-db li a[href="https://twitch-news.ru/"],
#tn-streamers-db li a[href*="twitch-news.ru"][href*="Twitch news"] {
  display: none !important;
}
.tn-streamers-db li:has(a[href="https://twitch-news.ru/"]),
#tn-streamers-db li:has(a[href="https://twitch-news.ru/"]) {
  display: none !important;
}

/* Скрываем разделитель "›" ТОЛЬКО внутри контейнера топ стримеров, если следующий или предыдущий элемент скрыт */
.tn-streamers-db li[aria-hidden="true"]:has(+ li:has(a[href="https://twitch-news.ru/"])),
.tn-streamers-db li[aria-hidden="true"]:has(+ li a[href="https://twitch-news.ru/"]),
.tn-streamers-db li:has(a[href="https://twitch-news.ru/"]) + li[aria-hidden="true"],
.tn-streamers-db li:has(a[href="https://twitch-news.ru/"]) ~ li[aria-hidden="true"]:first-of-type,
#tn-streamers-db li[aria-hidden="true"]:has(+ li:has(a[href="https://twitch-news.ru/"])),
#tn-streamers-db li[aria-hidden="true"]:has(+ li a[href="https://twitch-news.ru/"]),
#tn-streamers-db li:has(a[href="https://twitch-news.ru/"]) + li[aria-hidden="true"],
#tn-streamers-db li:has(a[href="https://twitch-news.ru/"]) ~ li[aria-hidden="true"]:first-of-type {
  display: none !important;
}
/* Скрываем разделители, которые остались без соседей ТОЛЬКО внутри контейнера топ стримеров */
.tn-streamers-db nav ol li[aria-hidden="true"].mx-1:only-child,
.tn-streamers-db nav ol li[aria-hidden="true"].mx-1:last-child:not(:first-child),
#tn-streamers-db nav ol li[aria-hidden="true"].mx-1:only-child,
#tn-streamers-db nav ol li[aria-hidden="true"].mx-1:last-child:not(:first-child) {
  display: none !important;
}

/* ===== Классы для управления хлебными крошками ===== */
/* Доступные классы:
   - .post-kroshki - хлебные крошки на страницах постов
   - .category-kroshki - хлебные крошки на страницах категорий
   - .tag-kroshki - хлебные крошки на страницах тегов
   - .search-kroshki - хлебные крошки на странице поиска
   - .author-kroshki - хлебные крошки на страницах авторов
   - .archive-kroshki - хлебные крошки на архивных страницах
   - .page-kroshki - хлебные крошки на обычных страницах
   - .top-streamers-kroshki - хлебные крошки на странице топа стримеров
   - .streamer-kroshki - хлебные крошки на странице профиля стримера
*/

/* Скрываем хлебные крошки на странице топа стримеров */
.top-streamers-kroshki {
  display: none !important;
}

/* Бейдж LIVE — компактный */
.tn-streamers-db .tn-live-badge {
  display: inline-block;
  padding: 2px 6px;
  font-size: 12px;
  line-height: 1;
  border-radius: 6px;
  background: rgba(255,0,0,.15);
  text-transform: uppercase;
  letter-spacing: .5px;
  font-weight: 700;
}

/* Таблица: безопасные переносы и прокрутка по X на очень узких экранах */
.tn-streamers-db .tn-table-wrap { width: 100%; overflow-x: visible; }
@media (max-width: 768px) {
  .tn-streamers-db .tn-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}
.tn-streamers-db table { width: 100%; border-collapse: collapse; table-layout: auto; min-width: auto; }
.tn-streamers-db table th,
.tn-streamers-db table td { 
  padding: 10px 12px; 
  vertical-align: middle; 
  border-bottom: 1px solid rgba(255,255,255,.06);
  white-space: nowrap;
}
.tn-streamers-db .tn-name,
.tn-streamers-db .tn-game,
.tn-streamers-db .tn-meta { 
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Псевдо-заголовки ячеек (content: attr(data-label)) на мобилках */
@media (max-width: 768px) {
  /* КРИТИЧНО: Скрываем заголовок таблицы на мобильных */
  .tn-streamers-db table thead,
  .tn-streamers-db .tn-table thead,
  .tn-streamers-db thead,
  .tn-streamers-db table thead tr,
  .tn-streamers-db .tn-table thead tr { display: none !important; }
  
  /* Спрячем колонку # (ранг), чтобы не ломала строку */
  .tn-streamers-db .col-rank,
  .tn-streamers-db th.col-rank,
  .tn-streamers-db td[data-label="#"] { display: none !important; }
  
  /* Уменьшим отступы и разрешим переносы */
  .tn-streamers-db table th,
  .tn-streamers-db table td { padding: 8px 10px; }
  
  /* Если используется карточная разметка (div-строки), зададим компактный грид */
  .tn-streamers-db .tn-row,
  .tn-streamers-db .tn-card {
    display: grid;
    grid-template-columns: 40px 1fr auto;
    gap: 8px 10px;
    align-items: center;
    padding: 10px 12px;
  }
  
  .tn-streamers-db .tn-avatar { 
    width: 40px; height: 40px; border-radius: 50%; object-fit: cover; 
  }
  
  .tn-streamers-db .tn-name { 
    font-weight: 700; 
    font-size: clamp(14px, 4vw, 16px);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  
  .tn-streamers-db .tn-game,
  .tn-streamers-db .tn-meta {
    font-size: 12px; opacity: .85;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  
  .tn-streamers-db .tn-viewers { 
    text-align: right; 
    font-variant-numeric: tabular-nums; 
    white-space: nowrap;
  }
  
  /* ВАЖНО: чтобы кириллица из attr(data-label) корректно рисовалась, 
     устраняем влияние наследованных стилей и разрешаем нормальный bidi */
  .tn-streamers-db td::before {
    unicode-bidi: plaintext;
  }
}

/* ===== tn_streamers_db: mobile card fixes ===== */
/* ФИНАЛЬНАЯ СТРАХОВКА: перебить любые оставшиеся !important */
@media (max-width: 768px) {
  table .tn-mobile-card { display: table-row !important; }
  table .tn-mobile-card > td { display: table-cell !important; }
}
/* Вся flex/grid-раскладка только внутри карточки */
.tn-card { 
  display: block !important; 
  padding: 10px 12px; 
  visibility: visible !important;
  opacity: 1 !important;
  min-height: auto !important;
  color: inherit;
}
.tn-card, .tn-card * { 
  color: inherit; 
}
.tn-card-header { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; }
.tn-card-left { display: grid; grid-template-columns: 40px 1fr; gap: 10px; align-items: center; }
.tn-card-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; }
.tn-online-badge { display: inline-flex; align-items: center; gap: 6px; }
.tn-dot { width: 8px; height: 8px; border-radius: 50%; background: #9CA3AF; display: inline-block; }
.tn-dot--on { background: #22c55e; }
.tn-live-badge { font-size: 12px; font-weight: 700; text-transform: uppercase; }
.tn-card-metric { text-align: right; white-space: nowrap; }
.tn-metric-label { opacity: .85; margin-right: 6px; }
.tn-metric-value { font-variant-numeric: tabular-nums; }
.tn-card-details { margin-top: 8px; }
.tn-details-list { display: grid; gap: 6px; }
.tn-detail-row { display: grid; grid-template-columns: 1fr auto; gap: 12px; }
.tn-detail-label { opacity: .85; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tn-detail-value { font-weight: 600; }
.tn-card-toggle { width: 100%; margin-top: 8px; font-size: 14px; padding: 10px 12px; background: transparent; border: 1px solid rgba(255,255,255,.12); border-radius: 10px; cursor: pointer; color: inherit; }
/* если где-то остался таблицезависимый "stacked table" с td::before — вырубить для мобильной карточки */
.tn-mobile-card td::before { content: none !important; }
@media (min-width: 769px) {
  /* На десктопе эти обёртки не должны влиять */
  .tn-mobile-card { display: table-row; }
}

/* ===== Переключение режимов таблица/карточки ===== */
/* Переключение режимов по медиазапросу */
@media (min-width: 850px) {
  .tn-streamers-cards { display: none !important; }
  .tn-table { display: table !important; }
}

@media (max-width: 849px) {
  /* Уменьшаем отступы контейнера на мобильных */
  .container {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-right: 5px;
    padding-left: 5px;
  }
  
  .tn-streamers-cards { 
    display: grid !important; 
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .tn-table { display: none !important; }
  /* Перебиваем любые внешние стили для карточек */
  #tn-streamers-db .tn-streamers-cards,
  .tn-streamers-db .tn-streamers-cards {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  #tn-streamers-db .tn-streamer-card,
  .tn-streamers-db .tn-streamer-card {
    display: block !important;
    border-radius: 14px !important;
    padding: 12px !important;
    background: rgba(255,255,255,.03) !important;
    box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset !important;
  }
  
  /* Ранг над аватаркой на мобильных */
  .tn-card-left {
    grid-template-columns: 40px 1fr !important;
    gap: 8px !important;
    position: relative !important;
  }
  .tn-card-rank {
    position: absolute !important;
    top: -8px !important;
    left: 0 !important;
    font-size: 12px !important;
    background: rgba(0,0,0,0.6) !important;
    padding: 2px 4px !important;
    border-radius: 4px !important;
    z-index: 1 !important;
    line-height: 1.2 !important;
  }
  
  /* Уменьшение шрифта для длинных никнеймов (только если больше 14 символов) */
  .tn-card-name {
    font-size: 16px !important;
  }
  .tn-card-name a {
    display: block !important;
  }
  .tn-card-name.long-name {
    font-size: 13px !important;
  }
  
  /* Жёсткий запрет ломать табличную модель, если где-то остался старый css */
  table .tn-mobile-card { display: table-row !important; }
  table .tn-mobile-card > td { display: table-cell !important; }
  table .tn-mobile-card > td::before { content: none !important; }
}

/* Лёгкие, быстрые карточки */
.tn-streamers-cards { 
  display: grid !important; 
  gap: 14px; 
  grid-template-columns: 1fr;
}
.tn-streamer-card { 
  border-radius: 14px; 
  padding: 12px; 
  background: rgba(255,255,255,.03) !important; 
  box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset !important; 
  display: block !important;
}
.tn-card-header { 
  display: grid !important; 
  grid-template-columns: 1fr auto !important; 
  gap: 10px; 
  align-items: center; 
}
.tn-card-left { 
  display: grid !important; 
  grid-template-columns: 40px 1fr !important; 
  gap: 10px; 
  align-items: center; 
}
.tn-card-rank {
  font-weight: 700;
  font-size: 16px;
  white-space: nowrap;
  min-width: 32px;
  text-align: center;
}
.tn-card-avatar { 
  width: 40px !important; 
  height: 40px !important; 
  border-radius: 50% !important; 
  object-fit: cover !important; 
  display: block !important;
}
.tn-online-badge { 
  display: inline-flex !important; 
  align-items: center; 
  gap: 6px; 
}
.tn-dot { 
  width: 8px; 
  height: 8px; 
  border-radius: 50%; 
  background: #9CA3AF; 
  display: inline-block; 
}
.tn-dot--on { background: #22c55e; }
.tn-live-badge { 
  font-size: 12px; 
  font-weight: 700; 
  text-transform: uppercase; 
}
.tn-card-right {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 6px;
  justify-content: flex-start;
}
.tn-card-metric { 
  text-align: right !important; 
  white-space: nowrap; 
}
.tn-metric-label { 
  opacity: .85; 
  margin-right: 6px; 
}
.tn-metric-value { 
  font-variant-numeric: tabular-nums; 
}
.tn-card-details { 
  margin-top: 8px; 
  display: none; 
}
.tn-details-list { 
  display: grid; 
  gap: 6px; 
}
.tn-detail-row { 
  display: grid; 
  grid-template-columns: 1fr auto; 
  gap: 12px; 
}
.tn-detail-label { 
  opacity: .85; 
  min-width: 0; 
  overflow: hidden; 
  text-overflow: ellipsis; 
  white-space: nowrap; 
}
.tn-detail-value { 
  font-weight: 600; 
}
.tn-card-toggle {
  width: 100%;
  margin-top: 12px;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  font-weight: 700;
  font-size: 15px;
  line-height: 1.2;
  background: linear-gradient(180deg, rgba(149, 88, 255, .95), rgba(118, 56, 226, .95));
  color: #fff;
  transition: transform .12s ease, box-shadow .12s ease, background .2s ease;
  cursor: pointer;
  text-align: center;
}
.tn-card-toggle:active { 
  transform: translateY(1px); 
}
.tn-card-toggle:focus-visible { 
  outline: 2px solid rgba(149,88,255,.9); 
  outline-offset: 2px; 
}
/* Цвет дельты */
.tn-pos { color: #22c55e; }
.tn-neg { color: #ef4444; }

