/* ===================================================================
 * IMBYTE Esports — CS2 accent layer поверх qladder-theme.css.
 *
 * Файл аддитивный: только новые классы и переменные. Не переопределяет
 * существующие .ql-* стили — чтобы не ломать ранее сделанные экраны.
 * Подключается в base.twig сразу после qladder-theme.css.
 * ================================================================== */

/* ────────────────────────── ДОП. ТОКЕНЫ ─────────────────────────── */

:root {
    /* IMBYTE accents — синхронизированы с глобальной palette (--ql-*). */
    --imb-accent:        var(--ql-accent);       /* #00FFB2 neon teal */
    --imb-accent-2:      var(--ql-cyan);         /* #00D1FF */
    --imb-accent-gold:   var(--ql-gold);         /* #F59E0B */
    --imb-accent-pink:   var(--ql-violet);       /* #8B5CF6 — premium tier */

    /* Cinematic gradients для hero/cards. */
    --imb-grad-hero:    radial-gradient(80% 100% at 0% 0%, rgba(0,255,178,0.08) 0%, transparent 55%),
                        radial-gradient(80% 100% at 100% 100%, rgba(0,209,255,0.06) 0%, transparent 55%),
                        linear-gradient(180deg, #0A0F1F 0%, #060816 100%);
    --imb-grad-card:    linear-gradient(180deg, rgba(17,24,39,0.95) 0%, rgba(10,15,31,0.95) 100%);
    --imb-grad-accent:  var(--ql-grad-accent);
    --imb-grad-gold:    linear-gradient(135deg, #F59E0B, #D97706);

    /* Статусы матчей/турниров. */
    --imb-status-live:    var(--ql-danger);      /* #EF4444 */
    --imb-status-upcoming:var(--ql-cyan);        /* #00D1FF */
    --imb-status-final:   var(--ql-fg-3);
    --imb-status-vetoing: var(--ql-gold);
}

/* ────────────────────────── IMBYTE HERO ─────────────────────────── */

.imb-hero {
    position: relative;
    overflow: hidden;
    border-radius: var(--ql-r-xl);
    background: var(--imb-grad-hero);
    border: 1px solid var(--ql-border);
    padding: var(--ql-sp-8) var(--ql-sp-7);
    margin-bottom: var(--ql-sp-6);
}
.imb-hero::before {
    content: '';
    position: absolute; inset: 0;
    background:
        radial-gradient(900px 400px at 85% -10%, rgba(0,255,178,0.18), transparent 60%),
        radial-gradient(700px 400px at 0% 100%, rgba(25,212,255,0.12), transparent 60%);
    pointer-events: none;
}
.imb-hero::after {
    content: '';
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
    background-size: 32px 32px;
    pointer-events: none;
    mask-image: linear-gradient(180deg, rgba(0,0,0,0.7), transparent 70%);
}
.imb-hero__inner { position: relative; z-index: 1; }
.imb-hero__eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 6px 14px; margin-bottom: var(--ql-sp-3);
    background: rgba(0,255,178,0.10);
    border: 1px solid rgba(0,255,178,0.35);
    border-radius: var(--ql-r-pill);
    color: var(--imb-accent);
    font-family: var(--ql-font-display);
    text-transform: uppercase; letter-spacing: 2px;
    font-size: 11px; font-weight: 700;
}
.imb-hero__eyebrow i { font-size: 9px; animation: ql-pulse 1.8s infinite; }
.imb-hero__title {
    font-family: var(--ql-font-display);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-size: 48px;
    line-height: 1.05;
    color: var(--ql-fg);
    margin: 0 0 var(--ql-sp-3);
}
.imb-hero__title-accent {
    background: var(--imb-grad-accent);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.imb-hero__subtitle {
    color: var(--ql-fg-2);
    font-size: 16px;
    max-width: 560px;
    margin: 0 0 var(--ql-sp-5);
    line-height: 1.55;
}
.imb-hero__stats {
    display: flex; gap: var(--ql-sp-6);
    margin-top: var(--ql-sp-5);
    flex-wrap: wrap;
}
.imb-hero__stat-label {
    font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px;
    color: var(--ql-fg-3); font-weight: 700;
}
.imb-hero__stat-value {
    font-family: var(--ql-font-display);
    font-size: 26px; color: var(--ql-fg); font-weight: 700;
    margin-top: 4px;
}
.imb-hero__actions { display: flex; gap: var(--ql-sp-3); flex-wrap: wrap; }

@media (max-width: 900px) {
    .imb-hero { padding: var(--ql-sp-6); }
    .imb-hero__title { font-size: 32px; letter-spacing: 1.5px; }
}

/* ─────────────────────── СТАТУС-ПИЛЛЫ ─────────────────────────── */

.imb-status-pill {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 11px; border-radius: var(--ql-r-pill);
    font-family: var(--ql-font-display);
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1.5px;
    background: var(--ql-bg-3); color: var(--ql-fg-2);
    border: 1px solid var(--ql-border);
}
.imb-status-pill::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: currentColor;
}
.imb-status-pill--live    { color: var(--imb-status-live);    background: rgba(255,61,80,0.10); border-color: rgba(255,61,80,0.35); }
.imb-status-pill--live::before { animation: ql-pulse-glow 1.5s infinite; box-shadow: 0 0 0 2px rgba(255,61,80,0.4); }
.imb-status-pill--upcoming{ color: var(--imb-status-upcoming);background: rgba(25,212,255,0.10); border-color: rgba(25,212,255,0.35); }
.imb-status-pill--final   { color: var(--imb-status-final);   background: rgba(107,115,136,0.15); }
.imb-status-pill--vetoing { color: var(--imb-status-vetoing); background: rgba(255,180,0,0.10);  border-color: rgba(255,180,0,0.35); }
.imb-status-pill--draft   { color: var(--ql-fg-3); }
.imb-status-pill--signup  { color: var(--imb-accent); background: var(--ql-accent-soft); border-color: rgba(0,255,178,0.3); }

/* ──────────────────────── ФИЛЬТРЫ ──────────────────────────────── */

.imb-filters {
    display: flex; gap: var(--ql-sp-3); flex-wrap: wrap;
    align-items: center;
    padding: var(--ql-sp-3) var(--ql-sp-4);
    background: var(--ql-bg-2); border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-lg);
    margin-bottom: var(--ql-sp-5);
}
.imb-filters__group {
    display: inline-flex; gap: 2px;
    background: var(--ql-bg-0);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-md);
    padding: 3px;
}
.imb-filters__btn {
    padding: 6px 14px;
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1px;
    color: var(--ql-fg-2);
    background: transparent;
    border: 0;
    border-radius: var(--ql-r-sm);
    cursor: pointer; text-decoration: none;
    transition: all .12s var(--ql-ease);
}
.imb-filters__btn:hover { color: var(--ql-fg); }
.imb-filters__btn.is-active {
    background: var(--imb-grad-accent);
    color: var(--ql-bg-0);
    box-shadow: 0 2px 8px rgba(0,255,178,0.25);
}
.imb-filters__search {
    flex: 1; min-width: 200px;
    position: relative;
}
.imb-filters__search input {
    width: 100%; padding: 8px 14px 8px 36px;
    background: var(--ql-bg-0);
    border: 1px solid var(--ql-border);
    color: var(--ql-fg);
    border-radius: var(--ql-r-md);
    font-size: 13px;
}
.imb-filters__search input:focus { outline: 0; border-color: var(--imb-accent); }
.imb-filters__search i {
    position: absolute; left: 13px; top: 50%; transform: translateY(-50%);
    color: var(--ql-fg-3);
}

/* ──────────────────── КАРТОЧКА ЛИГИ / ТУРНИРА ───────────────────── */

.imb-league-card {
    position: relative; overflow: hidden;
    border-radius: var(--ql-r-lg);
    background: var(--imb-grad-card);
    border: 1px solid var(--ql-border);
    transition: transform .18s var(--ql-ease), border-color .18s var(--ql-ease);
    text-decoration: none;
    color: inherit;
    display: flex; flex-direction: column;
}
.imb-league-card:hover {
    border-color: rgba(0,255,178,0.4);
    transform: translateY(-2px);
    color: inherit;
}
.imb-league-card__cover {
    height: 140px;
    background: var(--ql-bg-3) center/cover no-repeat;
    position: relative;
}
.imb-league-card__cover::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(13,16,24,0.85));
}
.imb-league-card__cover-pills {
    position: absolute; top: 12px; left: 12px; right: 12px;
    display: flex; gap: 6px; flex-wrap: wrap;
    z-index: 1;
}
.imb-league-card__game {
    position: absolute; bottom: 10px; left: 14px;
    z-index: 1;
    font-family: var(--ql-font-display);
    text-transform: uppercase; letter-spacing: 1.5px;
    font-size: 11px; color: var(--ql-fg-1);
}
.imb-league-card__body {
    padding: var(--ql-sp-4);
    flex: 1; display: flex; flex-direction: column; gap: var(--ql-sp-2);
}
.imb-league-card__title {
    font-family: var(--ql-font-display);
    font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px;
    font-size: 16px; color: var(--ql-fg);
    margin: 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.imb-league-card__meta {
    display: flex; gap: var(--ql-sp-3); flex-wrap: wrap;
    font-size: 12px; color: var(--ql-fg-2);
}
.imb-league-card__meta-item { display: inline-flex; align-items: center; gap: 5px; }
.imb-league-card__meta-item i { color: var(--ql-fg-3); width: 12px; text-align: center; }
.imb-league-card__footer {
    padding: var(--ql-sp-3) var(--ql-sp-4);
    border-top: 1px solid var(--ql-border);
    display: flex; justify-content: space-between; align-items: center;
    font-size: 12px; color: var(--ql-fg-2);
}
.imb-league-card__prize {
    font-family: var(--ql-font-display);
    color: var(--imb-accent-gold);
    font-weight: 700;
    display: inline-flex; align-items: center; gap: 6px;
}

/* ──────────────────────── HALL OF FAME ─────────────────────────── */

.imb-hof-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--ql-sp-4);
}
.imb-hof-card {
    position: relative;
    background: var(--imb-grad-card);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-lg);
    padding: var(--ql-sp-5);
    text-align: center;
    overflow: hidden;
    transition: transform .18s var(--ql-ease), border-color .18s var(--ql-ease);
}
.imb-hof-card:hover { transform: translateY(-3px); border-color: rgba(255,180,0,0.5); }
.imb-hof-card__rank {
    position: absolute; top: 10px; left: 12px;
    font-family: var(--ql-font-display);
    font-size: 22px; font-weight: 700;
    color: var(--ql-fg-3);
    line-height: 1;
}
.imb-hof-card--gold   { border-color: rgba(255,180,0,0.4); }
.imb-hof-card--gold .imb-hof-card__rank   { color: var(--imb-accent-gold); }
.imb-hof-card--silver { border-color: rgba(192,192,192,0.3); }
.imb-hof-card--silver .imb-hof-card__rank { color: #c0c0c0; }
.imb-hof-card--bronze { border-color: rgba(205,127,50,0.35); }
.imb-hof-card--bronze .imb-hof-card__rank { color: #cd7f32; }
.imb-hof-card__crest {
    width: 64px; height: 64px; border-radius: 50%;
    background: var(--ql-bg-3) center/cover no-repeat;
    margin: 0 auto var(--ql-sp-3);
    border: 2px solid var(--ql-border);
}
.imb-hof-card--gold   .imb-hof-card__crest { border-color: var(--imb-accent-gold); box-shadow: 0 0 18px rgba(255,180,0,0.35); }
.imb-hof-card--silver .imb-hof-card__crest { border-color: #c0c0c0; }
.imb-hof-card--bronze .imb-hof-card__crest { border-color: #cd7f32; }
.imb-hof-card__name {
    font-family: var(--ql-font-display);
    font-weight: 700; text-transform: uppercase; letter-spacing: 1.2px;
    font-size: 14px; color: var(--ql-fg);
    margin: 0 0 var(--ql-sp-1);
}
.imb-hof-card__sub {
    font-size: 11px; color: var(--ql-fg-3);
    text-transform: uppercase; letter-spacing: 1px;
}

/* ──────────────────── ПРОФИЛЬ ИГРОКА HERO ──────────────────────── */

.imb-profile-hero {
    position: relative;
    border-radius: var(--ql-r-xl);
    overflow: hidden;
    margin-bottom: var(--ql-sp-5);
    background: var(--ql-bg-2);
    border: 1px solid var(--ql-border);
}
.imb-profile-hero__cover {
    height: 220px;
    background:
        radial-gradient(80% 100% at 20% 0%, rgba(0,255,178,0.10) 0%, transparent 55%),
        radial-gradient(80% 100% at 80% 100%, rgba(139,92,246,0.08) 0%, transparent 55%),
        linear-gradient(135deg, #0A0F1F 0%, #060816 100%);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
}
.imb-profile-hero__cover::before {
    /* Едва видимая grid pattern. */
    content: '';
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.015) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px);
    background-size: 32px 32px;
    mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.7), transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse at center, rgba(0,0,0,0.7), transparent 80%);
}
.imb-profile-hero__cover::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(6,8,22,0.0) 0%, rgba(6,8,22,0.90) 100%);
}
.imb-profile-hero__body {
    position: relative;
    padding: 0 var(--ql-sp-6) var(--ql-sp-5);
    display: flex; gap: var(--ql-sp-5); align-items: flex-end;
    margin-top: -64px;
}
.imb-profile-hero__avatar {
    width: 128px; height: 128px;
    border-radius: 50%;
    border: 4px solid var(--ql-bg-1);
    background: var(--ql-bg-0) center/cover no-repeat;
    flex-shrink: 0;
    box-shadow: var(--ql-shadow-2);
    position: relative;
}
.imb-profile-hero__avatar--premium { border-color: var(--imb-accent-gold); }
.imb-profile-hero__status {
    position: absolute; bottom: 6px; right: 6px;
    width: 22px; height: 22px; border-radius: 50%;
    background: var(--ql-fg-3);
    border: 3px solid var(--ql-bg-1);
}
.imb-profile-hero__status--online  { background: var(--imb-accent); }
.imb-profile-hero__status--in-game { background: var(--imb-status-live); animation: ql-pulse 1.6s infinite; }
.imb-profile-hero__info { flex: 1; padding-bottom: 8px; }
.imb-profile-hero__name {
    font-family: var(--ql-font-display);
    font-weight: 700; text-transform: uppercase; letter-spacing: 2px;
    font-size: 32px; color: var(--ql-fg);
    margin: 0;
    display: flex; align-items: center; gap: var(--ql-sp-3); flex-wrap: wrap;
}
.imb-profile-hero__handle {
    font-size: 13px; color: var(--ql-fg-3);
    margin-top: 4px;
    display: flex; align-items: center; gap: var(--ql-sp-2); flex-wrap: wrap;
}
.imb-profile-hero__quick {
    display: flex; gap: var(--ql-sp-5); align-items: center;
    padding-bottom: 12px;
}
.imb-profile-hero__quick-label { font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--ql-fg-3); font-weight: 700; }
.imb-profile-hero__quick-value { font-family: var(--ql-font-display); font-size: 22px; color: var(--ql-fg); font-weight: 700; margin-top: 2px; }
.imb-profile-hero__quick-value--accent { color: var(--imb-accent); }

@media (max-width: 800px) {
    .imb-profile-hero__body { flex-direction: column; align-items: flex-start; gap: var(--ql-sp-3); }
    .imb-profile-hero__quick { padding-bottom: 0; flex-wrap: wrap; }
    .imb-profile-hero__name { font-size: 24px; }
}

/* ──────────────────────── ПРОФИЛЬ ВКЛАДКИ ───────────────────────── */

.imb-tabs {
    display: flex; gap: 0;
    border-bottom: 1px solid var(--ql-border);
    margin-bottom: var(--ql-sp-5);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.imb-tabs__item {
    padding: var(--ql-sp-3) var(--ql-sp-4);
    color: var(--ql-fg-2);
    text-decoration: none;
    font-family: var(--ql-font-display);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    font-size: 12px;
    border-bottom: 2px solid transparent;
    transition: all .15s var(--ql-ease);
    white-space: nowrap;
    background: transparent;
    border-top: 0; border-left: 0; border-right: 0;
    cursor: pointer;
    position: relative;
}
.imb-tabs__item:hover { color: var(--ql-fg); }
.imb-tabs__item.is-active { color: var(--imb-accent); border-bottom-color: var(--imb-accent); }
.imb-tabs__item i { margin-right: 6px; opacity: 0.7; }

/* ──────────────────────── КАРТОЧКА КОМАНДЫ ──────────────────────── */

.imb-team-hero {
    position: relative;
    border-radius: var(--ql-r-xl);
    overflow: hidden;
    margin-bottom: var(--ql-sp-5);
    background: var(--imb-grad-hero);
    border: 1px solid var(--ql-border);
    padding: var(--ql-sp-6);
}
.imb-team-hero::before {
    content: ''; position: absolute; inset: 0;
    background:
        radial-gradient(600px circle at 80% 30%, rgba(0,255,178,0.12), transparent 60%),
        radial-gradient(500px circle at 10% 90%, rgba(0,209,255,0.08), transparent 60%);
    pointer-events: none;
}
.imb-team-hero__inner {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--ql-sp-5);
    align-items: center;
}
.imb-team-hero__crest {
    width: 110px; height: 110px;
    border-radius: var(--ql-r-lg);
    background: var(--ql-bg-3) center/cover no-repeat;
    border: 2px solid var(--ql-border);
    box-shadow: var(--ql-shadow-2);
}
.imb-team-hero__info { min-width: 0; }
.imb-team-hero__tag {
    font-family: var(--ql-font-display);
    color: var(--imb-accent);
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 4px;
    font-weight: 700;
}
.imb-team-hero__name {
    font-family: var(--ql-font-display);
    font-weight: 700; text-transform: uppercase; letter-spacing: 2px;
    font-size: 32px; color: var(--ql-fg);
    margin: 0 0 var(--ql-sp-3);
}
.imb-team-hero__meta {
    display: flex; gap: var(--ql-sp-4); flex-wrap: wrap;
    color: var(--ql-fg-2); font-size: 13px;
}
.imb-team-hero__meta-item i { color: var(--ql-fg-3); margin-right: 4px; }
.imb-team-hero__quick {
    display: grid;
    grid-template-columns: repeat(3, auto);
    gap: var(--ql-sp-4);
    text-align: right;
}
.imb-team-hero__quick-label { font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--ql-fg-3); font-weight: 700; }
.imb-team-hero__quick-value { font-family: var(--ql-font-display); font-size: 22px; color: var(--ql-fg); font-weight: 700; margin-top: 2px; }

@media (max-width: 800px) {
    .imb-team-hero__inner { grid-template-columns: 1fr; text-align: left; }
    .imb-team-hero__quick { grid-template-columns: repeat(3, 1fr); text-align: left; }
    .imb-team-hero__name { font-size: 26px; }
}

/* ──────────────────────── РОСТЕР ────────────────────────────────── */

.imb-roster {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--ql-sp-3);
}
.imb-roster__row {
    display: grid;
    grid-template-columns: 56px 1fr auto;
    gap: var(--ql-sp-3);
    align-items: center;
    padding: var(--ql-sp-3);
    background: var(--ql-bg-2);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-md);
    transition: border-color .15s var(--ql-ease);
    text-decoration: none;
    color: inherit;
}
.imb-roster__row:hover { border-color: rgba(0,255,178,0.4); color: inherit; }
.imb-roster__avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--ql-bg-3) center/cover no-repeat; }
.imb-roster__name { color: var(--ql-fg); font-weight: 700; font-size: 14px; }
.imb-roster__role {
    font-size: 11px; color: var(--ql-fg-3);
    text-transform: uppercase; letter-spacing: 1px;
    margin-top: 2px;
}
.imb-roster__role i { color: var(--imb-accent); margin-right: 4px; }
.imb-roster__elo { font-family: var(--ql-font-display); color: var(--ql-fg); font-weight: 700; font-size: 16px; }

/* ──────────────── РОЛИ ИГРОКОВ (badge-цвета) ────────────────────── */

.imb-role-badge {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 2px 8px;
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1px;
    border-radius: var(--ql-r-pill);
    border: 1px solid currentColor;
    background: rgba(0,0,0,0.2);
}
.imb-role-badge--awp     { color: #00FFB2; }
.imb-role-badge--igl     { color: #ffb400; }
.imb-role-badge--entry   { color: #ff3d8a; }
.imb-role-badge--support { color: #19d4ff; }
.imb-role-badge--lurk    { color: #b48cff; }
.imb-role-badge--rifler  { color: #d8d1e0; }

/* ──────────────────── /TRAINING HUB СЕТКА ───────────────────────── */

.imb-training-hub {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--ql-sp-4);
}
.imb-training-tile {
    position: relative;
    overflow: hidden;
    border-radius: var(--ql-r-lg);
    background: var(--imb-grad-card);
    border: 1px solid var(--ql-border);
    padding: var(--ql-sp-5);
    text-decoration: none;
    color: inherit;
    transition: transform .18s var(--ql-ease), border-color .18s var(--ql-ease);
    min-height: 180px;
    display: flex; flex-direction: column; justify-content: space-between;
}
.imb-training-tile::before {
    content: ''; position: absolute;
    width: 200px; height: 200px;
    right: -60px; top: -60px;
    border-radius: 50%;
    background: var(--ql-accent-soft);
    transition: transform .25s var(--ql-ease);
}
.imb-training-tile:hover { color: inherit; transform: translateY(-2px); border-color: rgba(0,255,178,0.4); }
.imb-training-tile:hover::before { transform: scale(1.15); }
.imb-training-tile__icon {
    position: relative; z-index: 1;
    width: 52px; height: 52px;
    border-radius: var(--ql-r-md);
    background: var(--imb-grad-accent);
    color: var(--ql-bg-0);
    display: grid; place-items: center;
    font-size: 22px;
    margin-bottom: var(--ql-sp-3);
}
.imb-training-tile__title {
    position: relative; z-index: 1;
    font-family: var(--ql-font-display);
    font-size: 17px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1.5px;
    color: var(--ql-fg); margin: 0 0 var(--ql-sp-1);
}
.imb-training-tile__desc {
    position: relative; z-index: 1;
    color: var(--ql-fg-2); font-size: 13px; line-height: 1.5;
    margin-bottom: var(--ql-sp-3);
}
.imb-training-tile__cta {
    position: relative; z-index: 1;
    font-family: var(--ql-font-display);
    color: var(--imb-accent);
    text-transform: uppercase; letter-spacing: 1.5px;
    font-size: 11px; font-weight: 700;
}

/* ──────────────────── SUBSCRIPTION LANDING ──────────────────────── */

.imb-sub-tiers {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--ql-sp-5);
    margin: var(--ql-sp-6) 0;
}
.imb-sub-tier {
    position: relative;
    background: var(--imb-grad-card);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-xl);
    padding: var(--ql-sp-6);
    overflow: hidden;
}
.imb-sub-tier--featured {
    border-color: rgba(0,255,178,0.5);
    transform: scale(1.03);
    box-shadow: 0 12px 40px rgba(0,255,178,0.12);
}
.imb-sub-tier--featured::before {
    content: 'РЕКОМЕНДУЕМ';
    position: absolute; top: 12px; right: -28px;
    transform: rotate(45deg);
    background: var(--imb-grad-accent);
    color: var(--ql-bg-0);
    padding: 4px 36px;
    font-family: var(--ql-font-display);
    font-size: 10px; font-weight: 800;
    letter-spacing: 1.5px;
}
.imb-sub-tier__name {
    font-family: var(--ql-font-display);
    font-size: 18px; text-transform: uppercase; letter-spacing: 2px;
    color: var(--ql-fg); font-weight: 700;
    margin: 0 0 var(--ql-sp-2);
}
.imb-sub-tier__price {
    font-family: var(--ql-font-display);
    font-size: 42px; font-weight: 700;
    color: var(--ql-fg);
    line-height: 1;
    margin: var(--ql-sp-3) 0;
}
.imb-sub-tier__price-period {
    font-size: 14px; color: var(--ql-fg-3); font-weight: 400;
    margin-left: 4px;
}
.imb-sub-tier__features {
    list-style: none; padding: 0;
    margin: var(--ql-sp-5) 0;
    display: flex; flex-direction: column; gap: var(--ql-sp-2);
}
.imb-sub-tier__features li {
    display: flex; align-items: center; gap: 10px;
    color: var(--ql-fg-1); font-size: 13px;
}
.imb-sub-tier__features li::before {
    content: '\f00c';
    font-family: 'Font Awesome 5 Free'; font-weight: 900;
    color: var(--imb-accent);
}
.imb-sub-tier__features li.is-disabled { color: var(--ql-fg-3); }
.imb-sub-tier__features li.is-disabled::before {
    content: '\f00d';
    color: var(--ql-fg-3);
}
.imb-sub-tier__cta {
    display: block; width: 100%; text-align: center;
    padding: 12px;
    background: var(--ql-bg-3);
    color: var(--ql-fg);
    border-radius: var(--ql-r-md);
    text-decoration: none;
    font-family: var(--ql-font-display);
    text-transform: uppercase; letter-spacing: 1.5px;
    font-size: 12px; font-weight: 700;
    border: 1px solid var(--ql-border);
    transition: all .15s var(--ql-ease);
}
.imb-sub-tier__cta:hover { border-color: var(--imb-accent); color: var(--ql-fg); }
.imb-sub-tier--featured .imb-sub-tier__cta {
    background: var(--imb-grad-accent);
    color: var(--ql-bg-0);
    border-color: var(--imb-accent);
}
.imb-sub-tier--featured .imb-sub-tier__cta:hover {
    box-shadow: 0 6px 24px rgba(0,255,178,0.35);
    color: var(--ql-bg-0);
}

/* Сравнение тарифов */
.imb-sub-compare {
    width: 100%; border-collapse: collapse;
    background: var(--ql-bg-2);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-lg);
    overflow: hidden;
    margin: var(--ql-sp-6) 0;
}
.imb-sub-compare th, .imb-sub-compare td {
    padding: 12px 16px; text-align: left;
    border-bottom: 1px solid var(--ql-border);
}
.imb-sub-compare th {
    background: var(--ql-bg-3);
    font-family: var(--ql-font-display);
    text-transform: uppercase; letter-spacing: 1px;
    font-size: 12px; color: var(--ql-fg);
}
.imb-sub-compare td.imb-sub-yes { color: var(--imb-accent); }
.imb-sub-compare td.imb-sub-no  { color: var(--ql-fg-3); }
.imb-sub-compare tbody tr:last-child td { border-bottom: 0; }

/* FAQ */
.imb-faq-item {
    background: var(--ql-bg-2);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-md);
    margin-bottom: var(--ql-sp-2);
    overflow: hidden;
}
.imb-faq-item__q {
    padding: var(--ql-sp-4);
    cursor: pointer;
    font-family: var(--ql-font-display);
    text-transform: uppercase; letter-spacing: 1px;
    font-size: 13px; color: var(--ql-fg);
    font-weight: 700;
    display: flex; align-items: center; justify-content: space-between;
    list-style: none;
}
.imb-faq-item__q::-webkit-details-marker { display: none; }
.imb-faq-item__q::after {
    content: '\f078';
    font-family: 'Font Awesome 5 Free'; font-weight: 900;
    color: var(--ql-fg-3);
    transition: transform .2s var(--ql-ease);
    font-size: 11px;
}
.imb-faq-item[open] .imb-faq-item__q::after { transform: rotate(180deg); color: var(--imb-accent); }
.imb-faq-item__a {
    padding: 0 var(--ql-sp-4) var(--ql-sp-4);
    color: var(--ql-fg-1); line-height: 1.6; font-size: 13px;
}

/* ──────────────────── MATCHMAKING SIDEBAR ───────────────────────── */

.imb-mm-toggle {
    position: fixed; right: 18px; bottom: 18px;
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--imb-grad-accent);
    color: var(--ql-bg-0);
    border: 0; cursor: pointer;
    display: grid; place-items: center;
    font-size: 22px;
    box-shadow: 0 10px 32px rgba(0,255,178,0.45);
    z-index: 40;
    transition: transform .15s var(--ql-ease);
}
.imb-mm-toggle:hover { transform: scale(1.08); }
.imb-mm-toggle__badge {
    position: absolute; top: -4px; right: -4px;
    min-width: 22px; height: 22px;
    background: var(--imb-status-live);
    color: #fff; font-size: 11px; font-weight: 700;
    border-radius: var(--ql-r-pill);
    border: 2px solid var(--ql-bg-0);
    display: grid; place-items: center;
    padding: 0 6px;
}

.imb-mm-panel {
    position: fixed; right: 0; top: 0;
    width: 360px; height: 100vh;
    background: var(--ql-bg-1);
    border-left: 1px solid var(--ql-border);
    box-shadow: -8px 0 32px rgba(0,0,0,0.4);
    transform: translateX(100%);
    transition: transform .25s var(--ql-ease);
    z-index: 70;
    display: flex; flex-direction: column;
}
.imb-mm-panel.is-open { transform: none; }
.imb-mm-panel__header {
    padding: var(--ql-sp-4) var(--ql-sp-5);
    border-bottom: 1px solid var(--ql-border);
    display: flex; justify-content: space-between; align-items: center;
}
.imb-mm-panel__title {
    font-family: var(--ql-font-display);
    text-transform: uppercase; letter-spacing: 2px;
    font-size: 13px; color: var(--ql-fg); font-weight: 700;
    margin: 0;
}
.imb-mm-panel__close {
    width: 32px; height: 32px;
    background: transparent;
    border: 0; color: var(--ql-fg-2); cursor: pointer;
    border-radius: var(--ql-r-md);
    display: grid; place-items: center;
}
.imb-mm-panel__close:hover { color: var(--ql-fg); background: var(--ql-bg-2); }
.imb-mm-panel__body { flex: 1; overflow-y: auto; padding: var(--ql-sp-5); }
.imb-mm-mode {
    padding: var(--ql-sp-4);
    background: var(--ql-bg-2);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-md);
    margin-bottom: var(--ql-sp-3);
    cursor: pointer;
    transition: all .15s var(--ql-ease);
}
.imb-mm-mode:hover { border-color: rgba(0,255,178,0.4); }
.imb-mm-mode.is-selected {
    border-color: var(--imb-accent);
    background: linear-gradient(180deg, var(--ql-accent-soft) 0%, var(--ql-bg-2) 100%);
}
.imb-mm-mode__title { font-family: var(--ql-font-display); text-transform: uppercase; letter-spacing: 1px; color: var(--ql-fg); font-size: 13px; font-weight: 700; }
.imb-mm-mode__desc  { color: var(--ql-fg-2); font-size: 12px; margin-top: 4px; }
.imb-mm-mode__meta  { color: var(--ql-fg-3); font-size: 11px; margin-top: 6px; display: flex; gap: var(--ql-sp-3); }
.imb-mm-panel__footer {
    padding: var(--ql-sp-4) var(--ql-sp-5);
    border-top: 1px solid var(--ql-border);
}

/* Backdrop при открытой panel. */
.imb-mm-backdrop {
    position: fixed; inset: 0;
    background: rgba(0,0,0,0.5);
    opacity: 0; visibility: hidden;
    transition: opacity .2s var(--ql-ease);
    z-index: 65;
}
.imb-mm-backdrop.is-open { opacity: 1; visibility: visible; }

@media (max-width: 480px) {
    .imb-mm-panel { width: 100vw; border-left: 0; }
}

/* ──────────────────── НОВОСТИ (карточки) ────────────────────────── */

.imb-news-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--ql-sp-4);
}
.imb-news-card {
    background: var(--imb-grad-card);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-lg);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform .18s var(--ql-ease), border-color .18s var(--ql-ease);
    display: flex; flex-direction: column;
}
.imb-news-card:hover { transform: translateY(-2px); border-color: rgba(0,255,178,0.4); color: inherit; }
.imb-news-card__cover {
    height: 160px;
    background: var(--ql-bg-3) center/cover no-repeat;
    position: relative;
}
.imb-news-card__cover::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(13,16,24,0.7));
}
.imb-news-card__cat {
    position: absolute; top: 10px; left: 12px;
    z-index: 1;
    padding: 3px 10px;
    background: var(--imb-grad-accent);
    color: var(--ql-bg-0);
    font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 1px;
    border-radius: var(--ql-r-pill);
}
.imb-news-card__body { padding: var(--ql-sp-4); flex: 1; display: flex; flex-direction: column; gap: var(--ql-sp-2); }
.imb-news-card__title {
    font-family: var(--ql-font-display);
    font-size: 15px; line-height: 1.3;
    color: var(--ql-fg);
    margin: 0;
    text-transform: uppercase; letter-spacing: 0.5px;
    font-weight: 700;
}
.imb-news-card__excerpt { color: var(--ql-fg-2); font-size: 13px; line-height: 1.5; flex: 1; }
.imb-news-card__meta {
    display: flex; justify-content: space-between;
    color: var(--ql-fg-3); font-size: 11px;
    text-transform: uppercase; letter-spacing: 1px;
    border-top: 1px solid var(--ql-border);
    padding-top: var(--ql-sp-3);
}

/* ──────────────────── СТАТУС BADGES для матчей ──────────────────── */

.imb-match-row {
    display: grid;
    grid-template-columns: 100px 1fr auto 1fr 100px;
    align-items: center;
    gap: var(--ql-sp-3);
    padding: var(--ql-sp-3) var(--ql-sp-4);
    background: var(--ql-bg-2);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-md);
    text-decoration: none;
    color: inherit;
    transition: border-color .15s var(--ql-ease);
}
.imb-match-row:hover { border-color: rgba(0,255,178,0.4); color: inherit; }
.imb-match-row__time { font-family: var(--ql-font-display); color: var(--ql-fg-2); font-size: 13px; font-weight: 700; }
.imb-match-row__team { display: flex; align-items: center; gap: 10px; min-width: 0; }
.imb-match-row__team--right { flex-direction: row-reverse; text-align: right; }
.imb-match-row__team-logo { width: 32px; height: 32px; border-radius: var(--ql-r-sm); background: var(--ql-bg-3) center/cover no-repeat; flex-shrink: 0; }
.imb-match-row__team-name { font-weight: 700; color: var(--ql-fg); font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.imb-match-row__score {
    font-family: var(--ql-font-display);
    font-size: 18px; color: var(--ql-fg); font-weight: 700;
    padding: 6px 14px; background: var(--ql-bg-3);
    border-radius: var(--ql-r-md);
    min-width: 60px; text-align: center;
}
.imb-match-row__status { text-align: right; }

@media (max-width: 700px) {
    .imb-match-row { grid-template-columns: 1fr; gap: 6px; }
    .imb-match-row__team--right { flex-direction: row; text-align: left; }
    .imb-match-row__status { text-align: left; }
}

/* ──────────────────── ВЫДЕЛЕННЫЙ CTA-БАННЕР ─────────────────────── */

.imb-banner-cta {
    position: relative; overflow: hidden;
    border-radius: var(--ql-r-xl);
    padding: var(--ql-sp-7);
    background: var(--imb-grad-hero);
    border: 1px solid var(--ql-border);
    margin: var(--ql-sp-5) 0;
}
.imb-banner-cta::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(600px circle at 0% 100%, rgba(0,255,178,0.15), transparent 60%);
}
.imb-banner-cta__inner { position: relative; display: grid; grid-template-columns: 1fr auto; gap: var(--ql-sp-4); align-items: center; }
.imb-banner-cta__title { font-family: var(--ql-font-display); font-size: 24px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--ql-fg); margin: 0 0 var(--ql-sp-1); font-weight: 700; }
.imb-banner-cta__subtitle { color: var(--ql-fg-2); font-size: 14px; }

@media (max-width: 700px) {
    .imb-banner-cta__inner { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────────────────────
 * ИМБАЙТ: Steam CS2 Inventory (profile + dedicated page)
 * Подсветка редкости — на основании steam_rarity (нормализованного в slug
 * через .lower().replace(' ', '-')). Локализация русская + английская.
 * ──────────────────────────────────────────────────────────── */

.imb-inv,
.imb-inv-page {
    display: block;
    margin-bottom: var(--ql-sp-5);
}

.imb-inv__head,
.imb-inv-page__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--ql-sp-3);
    margin-bottom: var(--ql-sp-4);
    flex-wrap: wrap;
}

.imb-inv__title,
.imb-inv-page__title {
    margin: 0;
    font-family: var(--ql-font-display);
    font-size: 22px;
    color: var(--ql-fg);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.imb-inv__sub,
.imb-inv-page__sub {
    margin: 4px 0 0;
    color: var(--ql-fg-3);
    font-size: 13px;
}

.imb-inv__head-actions,
.imb-inv-page__actions {
    display: flex;
    gap: var(--ql-sp-2);
    align-items: center;
    flex-wrap: wrap;
}

.imb-inv-page__banner {
    border-radius: var(--ql-r-md);
    padding: var(--ql-sp-3) var(--ql-sp-4);
    margin-bottom: var(--ql-sp-4);
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.imb-inv-page__banner--warn {
    background: rgba(255, 196, 0, 0.10);
    border: 1px solid rgba(255, 196, 0, 0.35);
    color: #ffd967;
}
.imb-inv-page__banner--err {
    background: rgba(255, 80, 80, 0.10);
    border: 1px solid rgba(255, 80, 80, 0.35);
    color: #ff8d8d;
}

.imb-inv-page__filters {
    display: grid;
    grid-template-columns: 2fr repeat(5, 1fr) auto auto;
    gap: var(--ql-sp-2);
    margin-bottom: var(--ql-sp-4);
}
@media (max-width: 900px) {
    .imb-inv-page__filters { grid-template-columns: 1fr 1fr; }
}

.imb-inv__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: var(--ql-sp-3);
}

.imb-inv__card {
    position: relative;
    background: var(--ql-bg-2);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-md);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 120ms ease, border-color 120ms ease, box-shadow 120ms ease;
}
.imb-inv__card:hover {
    transform: translateY(-2px);
    border-color: var(--imb-accent);
    box-shadow: 0 6px 20px rgba(0,0,0,0.35);
}

/* Цвета редкости — Steam categories (RU и EN). Slugify: lower-case, '-' вместо пробелов. */
.imb-inv__card[data-rarity*="базового"]      { border-top: 3px solid #b0c3d9; }
.imb-inv__card[data-rarity*="base-grade"]    { border-top: 3px solid #b0c3d9; }
.imb-inv__card[data-rarity*="consumer"]      { border-top: 3px solid #b0c3d9; }
.imb-inv__card[data-rarity*="ширпотреб"]     { border-top: 3px solid #b0c3d9; }
.imb-inv__card[data-rarity*="industrial"]    { border-top: 3px solid #5e98d9; }
.imb-inv__card[data-rarity*="промышленное"]  { border-top: 3px solid #5e98d9; }
.imb-inv__card[data-rarity*="mil-spec"]      { border-top: 3px solid #4b69ff; }
.imb-inv__card[data-rarity*="армейское"]     { border-top: 3px solid #4b69ff; }
.imb-inv__card[data-rarity*="restricted"]    { border-top: 3px solid #8847ff; }
.imb-inv__card[data-rarity*="запрещ"]        { border-top: 3px solid #8847ff; }
.imb-inv__card[data-rarity*="classified"]    { border-top: 3px solid #d32ce6; }
.imb-inv__card[data-rarity*="засекреченное"] { border-top: 3px solid #d32ce6; }
.imb-inv__card[data-rarity*="covert"]        { border-top: 3px solid #eb4b4b; }
.imb-inv__card[data-rarity*="тайное"]        { border-top: 3px solid #eb4b4b; }
.imb-inv__card[data-rarity*="contraband"]    { border-top: 3px solid #e4ae39; }
.imb-inv__card[data-rarity*="контрабанд"]    { border-top: 3px solid #e4ae39; }

.imb-inv__card-img {
    height: 130px;
    background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0) 100%), var(--ql-bg-1);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.imb-inv__card-img img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.imb-inv__card-img--placeholder {
    color: var(--ql-fg-3);
    font-size: 30px;
}

.imb-inv__card-body {
    padding: 10px 12px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.imb-inv__card-name {
    font-size: 13px;
    font-weight: 700;
    color: var(--ql-fg);
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.imb-inv__card-type {
    font-size: 11px;
    color: var(--ql-fg-3);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.imb-inv__card-meta {
    margin-top: auto;
    padding-top: 6px;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.imb-inv__pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 6px;
    border-radius: 6px;
    font-size: 10px;
    background: var(--ql-bg-1);
    color: var(--ql-fg-3);
    border: 1px solid var(--ql-border);
}
.imb-inv__pill--on  { color: var(--imb-accent); border-color: rgba(0,255,178,0.35); }
.imb-inv__pill--off { color: var(--ql-fg-3); opacity: 0.55; }

/* Empty / error placeholder. */
.imb-inv__empty {
    grid-column: 1 / -1;
    padding: var(--ql-sp-6);
    background: var(--ql-bg-2);
    border: 1px dashed var(--ql-border);
    border-radius: var(--ql-r-md);
    text-align: center;
    color: var(--ql-fg-3);
}
.imb-inv__empty i {
    font-size: 32px;
    margin-bottom: var(--ql-sp-2);
    color: var(--ql-fg-3);
    display: block;
}
.imb-inv__empty p { margin: 0; font-size: 14px; }

/* Skeleton loader. */
.imb-inv__card--skeleton .imb-inv__card-img { background: var(--ql-bg-1); }
.imb-inv__skeleton {
    background: linear-gradient(90deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.08) 50%, rgba(255,255,255,0.04) 100%);
    background-size: 200% 100%;
    animation: imb-shimmer 1.4s linear infinite;
    border-radius: 4px;
}
.imb-inv__skeleton--line { height: 10px; margin: 6px 0; width: 100%; }
.imb-inv__skeleton--short { width: 50%; }
@keyframes imb-shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

@media (max-width: 600px) {
    .imb-inv__grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
    .imb-inv__card-img { height: 100px; }
}

/* ─────────────────────────────────────────────────────────────
 * ИМБАЙТ: CS2 Inventory — цена на карточке + модалка детали
 * ──────────────────────────────────────────────────────────── */

.imb-inv__card { cursor: pointer; }
.imb-inv__card:focus-visible { outline: 2px solid var(--imb-accent); outline-offset: 2px; }

.imb-inv__card-price {
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px solid var(--ql-border);
    font-family: var(--ql-font-display), 'JetBrains Mono', monospace;
    font-size: 13px;
    font-weight: 700;
    color: var(--imb-accent);
    display: flex;
    align-items: center;
    gap: 5px;
}
.imb-inv__card-price i { font-size: 10px; opacity: 0.7; }

/* Модалка. */
.imb-inv-modal {
    position: fixed;
    inset: 0;
    z-index: 9000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.imb-inv-modal[hidden] { display: none; }

.imb-inv-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(6, 8, 22, 0.78);
    backdrop-filter: blur(4px);
    animation: imb-fade-in 0.15s ease;
}
@keyframes imb-fade-in { from { opacity: 0; } to { opacity: 1; } }

.imb-inv-modal__panel {
    position: relative;
    max-width: 720px;
    width: 100%;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    background: var(--ql-bg-2);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-md);
    box-shadow: 0 30px 80px rgba(0,0,0,0.6);
    animation: imb-pop-in 0.18s ease;
}
@keyframes imb-pop-in {
    from { opacity: 0; transform: translateY(6px) scale(0.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.imb-inv-modal__close {
    position: absolute;
    top: 12px; right: 12px;
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1px solid var(--ql-border);
    background: var(--ql-bg-1);
    color: var(--ql-fg-3);
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    z-index: 2;
}
.imb-inv-modal__close:hover { color: var(--ql-fg); border-color: var(--imb-accent); }

.imb-inv-modal__loading,
.imb-inv-modal__error {
    padding: 60px var(--ql-sp-5);
    text-align: center;
    color: var(--ql-fg-3);
}
.imb-inv-modal__loading i,
.imb-inv-modal__error i {
    font-size: 28px;
    display: block;
    margin-bottom: var(--ql-sp-2);
}
.imb-inv-modal__error i { color: var(--ql-danger); }

.imb-inv-modal__head {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: var(--ql-sp-4);
    padding: var(--ql-sp-5);
    border-bottom: 1px solid var(--ql-border);
}
@media (max-width: 600px) {
    .imb-inv-modal__head { grid-template-columns: 1fr; }
}
.imb-inv-modal__img-wrap {
    background: linear-gradient(180deg, rgba(255,255,255,0.03) 0%, rgba(255,255,255,0) 100%), var(--ql-bg-1);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-sm);
    aspect-ratio: 1.4;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.imb-inv-modal__img-wrap img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}
.imb-inv-modal__title {
    margin: 0;
    font-family: var(--ql-font-display);
    font-size: 22px;
    color: var(--ql-fg);
    line-height: 1.2;
}
.imb-inv-modal__sub {
    margin-top: 4px;
    color: var(--ql-fg-3);
    font-size: 13px;
}
.imb-inv-modal__pills {
    margin-top: var(--ql-sp-3);
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.imb-inv-modal__prices {
    padding: var(--ql-sp-5);
    border-bottom: 1px solid var(--ql-border);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--ql-sp-4);
}
@media (max-width: 600px) {
    .imb-inv-modal__prices { grid-template-columns: 1fr; }
}
.imb-inv-modal__price-label {
    color: var(--ql-fg-3);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.imb-inv-modal__price-val {
    font-family: var(--ql-font-display), 'JetBrains Mono', monospace;
    font-size: 36px;
    color: var(--imb-accent);
    font-weight: 800;
    line-height: 1.1;
    margin-top: 4px;
}
.imb-inv-modal__price-sub {
    color: var(--ql-fg-3);
    font-size: 12px;
    margin-top: 4px;
}
.imb-inv-modal__price-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    align-content: center;
}
.imb-inv-modal__price-grid > div {
    background: var(--ql-bg-1);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-sm);
    padding: 8px 10px;
    text-align: center;
}
.imb-inv-modal__price-grid span {
    display: block;
    color: var(--ql-fg-3);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.imb-inv-modal__price-grid b {
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
    color: var(--ql-fg);
}

.imb-trend--up   { color: #00ff9c; font-weight: 700; }
.imb-trend--down { color: #ff6b6b; font-weight: 700; }
.imb-trend--flat { color: var(--ql-fg-3); }

.imb-inv-modal__chart-wrap {
    padding: var(--ql-sp-5);
    border-bottom: 1px solid var(--ql-border);
}
.imb-inv-modal__chart-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: var(--ql-sp-3);
}
.imb-inv-modal__chart-head h3 {
    margin: 0;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--ql-fg);
}
.imb-inv-modal__chart {
    width: 100%;
    height: 180px;
    display: block;
    background: var(--ql-bg-1);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-sm);
}
.imb-inv-modal__sales-meta {
    margin-top: var(--ql-sp-3);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}
.imb-inv-modal__sales-meta > div {
    background: var(--ql-bg-1);
    border: 1px solid var(--ql-border);
    border-radius: var(--ql-r-sm);
    padding: 8px 10px;
    text-align: center;
}
.imb-inv-modal__sales-meta span {
    display: block;
    color: var(--ql-fg-3);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.imb-inv-modal__sales-meta b {
    font-family: 'JetBrains Mono', monospace;
    font-size: 14px;
    color: var(--ql-fg);
}

.imb-inv-modal__foot {
    padding: var(--ql-sp-4) var(--ql-sp-5);
    display: flex;
    gap: var(--ql-sp-2);
    flex-wrap: wrap;
}
