/* App footer wrapper anchors the toast above the player.
   z-index keeps the player clickable above sidebar backdrops (z 197-212). */
.ks-app-footer {
    position: relative;
    flex-shrink: 0;
    width: 100%;
    z-index: 300;
}

/* Audio player */
[data-testid="audio-player"] {
    position: relative;
    height: var(--ks-player-height);
    background: linear-gradient(180deg, rgba(49, 38, 28, 0.96), rgba(33, 26, 18, 0.98));
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0 1.25rem calc(0.25rem + env(safe-area-inset-bottom, 0));
    display: flex;
    align-items: center;
    gap: 0.5rem;
    backdrop-filter: blur(16px);
    overflow: hidden;
    isolation: isolate;
}

[data-testid="audio-player"]::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(49, 38, 28, 0.7), rgba(33, 26, 18, 0.8)),
        url("https://external-content.duckduckgo.com/iu/?u=http%3A%2F%2Fsports.teilar.gr%2Fwp-content%2Fuploads%2F2014%2F10%2Fparadosiakoi.jpg&f=1&nofb=1&ipt=508bb9a6b369bd353554181e4ae265f58444acc2bad81adcea611b05d3d5e334");
    background-size: cover;
    background-position: center;
    opacity: 0.3;
    pointer-events: none;
    z-index: -1;
}

[data-testid="audio-player"] .ks-player-row-time,
[data-testid="audio-player"] .ks-player-row-info,
[data-testid="audio-player"] .ks-player-row-controls,
[data-testid="audio-player"] .ks-player-controls-left,
[data-testid="audio-player"] .ks-player-controls-center,
[data-testid="audio-player"] .ks-player-controls-right {
    display: contents;
}

[data-testid="audio-player"] [data-testid="player-prev"] { order: 1; }
[data-testid="audio-player"] [data-testid="player-play-pause"] { order: 2; }
[data-testid="audio-player"] [data-testid="player-next"] { order: 3; }
[data-testid="audio-player"] [data-testid="player-dance-info"] { order: 4; }
[data-testid="audio-player"] [data-testid="player-track-info"] { order: 5; }
[data-testid="audio-player"] [data-testid="switch-song-button"] { order: 5; }
[data-testid="audio-player"] [data-testid="player-time-elapsed"] { order: 6; }
[data-testid="audio-player"] [data-testid="player-progress"] { order: 7; }
[data-testid="audio-player"] [data-testid="player-time-total"] { order: 8; }
[data-testid="audio-player"] [data-testid="session-drawer-toggle"] { order: 0; }
[data-testid="audio-player"] [data-testid="shuffle-mode-button"] { order: 9; }
[data-testid="audio-player"] [data-testid="shuffle-config-button"] { order: 10; }
[data-testid="audio-player"] [data-testid="wake-lock-unavailable"] { order: 11; }

.ks-player-time {
    font-size: 0.75rem;
    color: var(--ks-text-secondary);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    flex-shrink: 0;
}

[data-testid="audio-player"] md-filled-tonal-icon-button,
[data-testid="audio-player"] md-filled-icon-button {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
}

/* Responsive transport control sizing (Issue #98).
   prev/next use md-filled-tonal-icon-button; play/pause uses .ks-material-icon-button. */
[data-testid="audio-player"] [data-testid="player-prev"],
[data-testid="audio-player"] [data-testid="player-next"] {
    width: 40px;
    height: 40px;
}

[data-testid="audio-player"] [data-testid="player-play-pause"].ks-material-icon-button {
    width: 48px;
    height: 48px;
}

[data-testid="audio-player"] [data-testid="player-play-pause"] .material-symbols-outlined {
    font-size: 28px;
}

@media (min-width: 360px) {
    [data-testid="audio-player"] [data-testid="player-prev"],
    [data-testid="audio-player"] [data-testid="player-next"] {
        width: 48px;
        height: 48px;
    }
    [data-testid="audio-player"] [data-testid="player-play-pause"].ks-material-icon-button {
        width: 56px;
        height: 56px;
    }
    [data-testid="audio-player"] [data-testid="player-play-pause"] .material-symbols-outlined {
        font-size: 32px;
    }
}

@media (min-width: 480px) {
    [data-testid="audio-player"] [data-testid="player-prev"],
    [data-testid="audio-player"] [data-testid="player-next"] {
        width: 56px;
        height: 56px;
    }
    [data-testid="audio-player"] [data-testid="player-play-pause"].ks-material-icon-button {
        width: 64px;
        height: 64px;
    }
    [data-testid="audio-player"] [data-testid="player-play-pause"] .material-symbols-outlined {
        font-size: 36px;
    }
}

[data-testid="player-progress"] {
    flex: 1;
    min-width: 60px;
    height: 4px;
    -webkit-appearance: none;
    appearance: none;
    background: var(--ks-border);
    border-radius: 2px;
    outline: none;
    cursor: pointer;
    margin: 0;
}

[data-testid="player-progress"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--ks-accent);
    cursor: pointer;
}

.ks-player-switch-song {
    flex-shrink: 0;
    --md-filled-tonal-icon-button-container-color: rgba(255, 255, 255, 0.06);
}

[data-testid="audio-player"] [data-testid="shuffle-mode-button"] {
    flex-shrink: 0;
}

.ks-player-control-button {
    --md-filled-tonal-icon-button-container-color: rgba(255, 255, 255, 0.06);
}

.ks-player-control-button--toggle.active {
    --md-filled-tonal-icon-button-container-color: var(--md-sys-color-primary);
    --md-filled-tonal-icon-button-icon-color: var(--md-sys-color-on-primary);
}

.ks-player-control-button.ks-material-icon-button {
    width: 32px;
    height: 32px;
    background: rgba(255, 255, 255, 0.06);
    color: var(--ks-text-primary);
    font-size: 0.9rem;
}

.ks-player-control-button--primary {
    --md-filled-icon-button-container-color: var(--md-sys-color-primary);
    --md-filled-icon-button-icon-color: var(--md-sys-color-on-primary);
}

.ks-player-control-button--primary.ks-material-icon-button {
    background: var(--md-sys-color-primary);
    color: var(--md-sys-color-on-primary);
}

[data-testid="player-dance-info"],
[data-testid="player-track-info"] {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
    flex: 0 1 auto;
    max-width: 220px;
    gap: 1px;
}

[data-testid="player-dance-info"] .ks-player-label {
    font-family: 'Literata', Georgia, serif;
    color: var(--ks-accent);
}

[data-testid="player-track-info"] {
    padding-left: 0.75rem;
    border-left: 1px solid var(--ks-border-subtle);
}

.ks-player-label {
    font-size: 0.88rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
}

.ks-player-sublabel {
    font-size: 0.6rem;
    color: var(--ks-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
