/* online-red.pro — сквозной футер-плеер и кнопки запуска станций */

:root {
    --orp-red: #e8202a;
    --orp-red-dark: #c5161f;
    --orp-bar-h: 72px;
}

/* ---------- Кнопка play на карточке (кружок в углу обложки) ---------- */
/* Все «кружковые» стили — только для карточной кнопки, НЕ для большой (.orp-play--lg). */
.content-body_item-img {
    position: relative;
}

.orp-play:not(.orp-play--lg) {
    position: absolute;
    right: 6px;
    bottom: 6px;
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 50%;
    background: var(--orp-red);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    opacity: 0;
    /* только scale (без translate) — позиция кнопки при клике не смещается */
    transform: scale(0.85);
    transition: opacity .15s ease, transform .15s ease, background .15s ease;
    box-shadow: 0 3px 10px rgba(0, 0, 0, .35);
    z-index: 2;
}

.orp-play:not(.orp-play--lg) svg {
    fill: #fff;
    pointer-events: none;
}

.orp-play__ic-pause {
    display: none;
}

.content-body_item:hover .orp-play:not(.orp-play--lg),
.orp-play:not(.orp-play--lg):focus-visible,
.orp-play:not(.orp-play--lg).orp-playing {
    opacity: 1;
    transform: scale(1);
}

.orp-play:not(.orp-play--lg):hover {
    background: var(--orp-red-dark);
}

.orp-play.orp-playing .orp-play__ic-play {
    display: none;
}

.orp-play.orp-playing .orp-play__ic-pause {
    display: flex;
}

/* На тач-устройствах кнопка всегда видна */
@media (hover: none) {
    .orp-play:not(.orp-play--lg) {
        opacity: 1;
        transform: scale(1);
    }
}

/* ---------- Большая кнопка на странице станции ---------- */
/* Наследует вид от .btn-more сайта; здесь — только переключение play/pause-подписи. */
.orp-play--lg .orp-play__lg-play,
.orp-play--lg .orp-play__lg-pause {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
}

.orp-play--lg .orp-play__lg-pause {
    display: none;
}

.orp-play--lg.orp-playing .orp-play__lg-play {
    display: none;
}

.orp-play--lg.orp-playing .orp-play__lg-pause {
    display: inline-flex;
}

/* ---------- Футер-плеер ---------- */
body.orp-has-player {
    padding-bottom: var(--orp-bar-h);
}

.orp-player {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1000;
    background: #fff;
    border-top: 1px solid #ececec;
    box-shadow: 0 -6px 24px rgba(0, 0, 0, .12);
    transform: translateY(110%);
    transition: transform .25s ease;
    will-change: transform;
}

.orp-player.is-active {
    transform: translateY(0);
}

.orp-player__inner {
    max-width: 1180px;
    margin: 0 auto;
    height: var(--orp-bar-h);
    padding: 0 16px;
    display: flex;
    align-items: center;
    gap: 14px;
}

.orp-player__cover {
    flex: 0 0 auto;
    width: 52px;
    height: 52px;
    border-radius: 8px;
    overflow: hidden;
    display: block;
    background: #f2f2f2;
}

.orp-player__cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.orp-player__toggle {
    flex: 0 0 auto;
    width: 46px;
    height: 46px;
    border: 0;
    border-radius: 50%;
    background: var(--orp-red);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    transition: background .15s ease;
}

.orp-player__toggle:hover {
    background: var(--orp-red-dark);
}

.orp-player__toggle svg {
    fill: #fff;
}

.orp-player__ic {
    display: none;
    align-items: center;
    justify-content: center;
}

.orp-player .orp-player__ic--play {
    display: flex;
}

.orp-player.is-playing .orp-player__ic--play {
    display: none;
}

.orp-player.is-playing .orp-player__ic--pause {
    display: flex;
}

/* Спиннер загрузки */
.orp-player.is-loading .orp-player__ic--play,
.orp-player.is-loading .orp-player__ic--pause {
    display: none;
}

.orp-player.is-loading .orp-player__ic--loading {
    display: block;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, .4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: orp-spin .7s linear infinite;
}

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

.orp-player__meta {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    line-height: 1.3;
}

.orp-player__station {
    font-weight: 700;
    font-size: 15px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.orp-player__station a {
    color: #1a1a1a;
    text-decoration: none;
}

.orp-player__station a:hover {
    color: var(--orp-red);
}

.orp-player__track {
    font-size: 13px;
    color: #777;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.orp-player__track:empty::before {
    content: "В эфире";
    color: #bbb;
}

.orp-player__volume {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 6px;
}

.orp-player__mute {
    border: 0;
    background: transparent;
    color: #555;
    cursor: pointer;
    padding: 4px;
    display: flex;
}

.orp-player__mute svg {
    fill: #555;
}

.orp-player.is-muted .orp-player__mute svg {
    fill: #ccc;
}

.orp-player__range {
    width: 90px;
    accent-color: var(--orp-red);
    cursor: pointer;
}

.orp-player__close {
    flex: 0 0 auto;
    border: 0;
    background: transparent;
    color: #999;
    cursor: pointer;
    padding: 6px;
    display: flex;
    border-radius: 50%;
}

.orp-player__close:hover {
    color: var(--orp-red);
    background: #f5f5f5;
}

/* Тонкая полоса прогресса навигации (pjax) */
body.orp-navigating::after {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    width: 100%;
    background: linear-gradient(90deg, var(--orp-red), #ff8a00);
    z-index: 2000;
    animation: orp-nav .8s ease-in-out infinite;
    transform-origin: left;
}

@keyframes orp-nav {
    0% { transform: scaleX(0); }
    50% { transform: scaleX(.7); }
    100% { transform: scaleX(1); }
}

/* ---------- Мобайл ---------- */
@media (max-width: 640px) {
    :root {
        --orp-bar-h: 64px;
    }

    .orp-player__inner {
        gap: 10px;
        padding: 0 10px;
    }

    .orp-player__cover {
        width: 44px;
        height: 44px;
    }

    .orp-player__toggle {
        width: 42px;
        height: 42px;
    }

    /* Громкость прячем — на телефоне регулируется системно */
    .orp-player__volume {
        display: none;
    }

    .orp-player__station {
        font-size: 14px;
    }

    .orp-player__track {
        font-size: 12px;
    }

    /* Кнопка на карточке компактнее, плотнее в угол — меньше перекрывает лого */
    .orp-play:not(.orp-play--lg) {
        width: 34px;
        height: 34px;
        right: 4px;
        bottom: 4px;
    }

    .orp-play:not(.orp-play--lg) svg {
        width: 16px;
        height: 16px;
    }
}
