/* =============================================================
   Audio Player Block — assets/css/blocks/audio-player.css
   Plyr-based player styled to brand spec:
     • Background: #A11FFF
     • Text: white
     • No rounded corners
   ============================================================= */

/* ----------------------------------------------------------
   Plyr CSS custom properties (scoped to this block)
   ---------------------------------------------------------- */
.block-audio-player .plyr {
    --plyr-color-main:                          #A11FFF;
    --plyr-audio-controls-background:           #A11FFF;
    --plyr-audio-control-color:                 #ffffff;
    --plyr-audio-control-color-hover:           rgba(255, 255, 255, 0.75);
    --plyr-audio-control-background-hover:      rgba(255, 255, 255, 0.12);
    --plyr-audio-progress-buffered-background:  rgba(255, 255, 255, 0.25);
    --plyr-range-fill-background:               #ffffff;
    --plyr-range-thumb-background:              #ffffff;
    --plyr-range-track-height:                  3px;
    --plyr-control-radius:                      0;
    --plyr-menu-radius:                         0;
    --plyr-badge-border-radius:                 0;
    --plyr-tooltip-radius:                      0;
    --plyr-menu-background:                     #1a0033;
    --plyr-menu-color:                          #ffffff;
    --plyr-menu-shadow:                         0 4px 16px rgba(0, 0, 0, 0.5);
    border-radius: 0 !important;
}

/* ----------------------------------------------------------
   Outer wrapper — shared background for both states
   ---------------------------------------------------------- */
.block-audio-player .audio-player-wrapper {
    background-color: #A11FFF;
    color: #ffffff;
    padding: 0.8rem 1rem;
    border-radius: 0;
    width: 375px;
    box-sizing: border-box;
    transition: width 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}

.block-audio-player.is-playing .audio-player-wrapper {
    width: 100%;
    padding: 0.63rem 1rem;
}

/* ----------------------------------------------------------
   IDLE STATE (before first play)
   ---------------------------------------------------------- */
.block-audio-player .audio-player-idle {
    display: flex;
    align-items: center;
    gap: 1rem;
    width: 100%;
    justify-content: center;
}

/* Play button */
.block-audio-player .audio-play-btn {
    background: none;
    border: none;
    color: #ffffff;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    flex-shrink: 0;
    transition: opacity 0.15s ease;
    border-radius: 0;
}

.block-audio-player .audio-play-btn:hover {
    opacity: 0.8;
}

.block-audio-player .audio-play-btn svg {
    width: 2.75rem;
    height: 2.75rem;
    fill: #ffffff;
    display: block;
}

/* Title beside the play button */
.block-audio-player .audio-player-title {
    font-size: 1.3rem;
    font-weight: 400;
    color: #ffffff;
    line-height: 1.4;
}

/* ----------------------------------------------------------
   ACTIVE STATE (hidden until is-playing is set by JS)
   ---------------------------------------------------------- */
.block-audio-player .audio-player-active {
    display: none;
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
}

/* Slide idle content out when transitioning begins */
.block-audio-player.is-transitioning .audio-player-idle {
    animation: audioIdleSlideOut 0.25s ease forwards;
}

@keyframes audioIdleSlideOut {
    from { opacity: 1; transform: translateX(0); }
    to   { opacity: 0; transform: translateX(-40px); }
}

/* Flip states on play */
.block-audio-player.is-playing .audio-player-idle {
    display: none;
}

.block-audio-player.is-playing .audio-player-active {
    display: block;
    animation: audioActiveSlideIn 0.35s ease 0.2s both;
}

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

/* ----------------------------------------------------------
   Plyr control strip overrides
   ---------------------------------------------------------- */
.block-audio-player .plyr--audio .plyr__controls {
    background: #A11FFF;
    border-radius: 0;
    padding: 0.42rem 0;
}

.block-audio-player .plyr--audio .plyr__control {
    color: #ffffff;
    border-radius: 0;
}

.block-audio-player .plyr--audio .plyr__control:hover,
.block-audio-player .plyr--audio .plyr__control:focus {
    color: #ffffff;
}

.block-audio-player .plyr--audio .plyr__control svg {
    fill: #ffffff;
    transform: scaleY(0.8) scaleX(0.6);
}

/* Time display */
.block-audio-player .plyr__time {
    color: #ffffff;
    font-size: 0.8125rem;
}

/* Reorder controls: play → time → progress → mute → volume → settings */
.block-audio-player .plyr__control[data-plyr="play"] { 
    order: 1; 
    border-radius: 50%;
    border: solid 1.5px;
    padding: 0.5rem;
    margin-right: 2rem;
    scale: 1.2;
}
.block-audio-player .plyr__time                      { 
    order: 2; 
    font-size: 1rem;
}
.block-audio-player .plyr__progress                  { order: 3; }
.block-audio-player .plyr__progress__container { 
    order: 3;
    margin-right: 2rem;
 }
 @media (min-width: 1200px) {
     .block-audio-player .plyr__progress__container { 
            margin-left: 2rem;
            margin-right: 4rem;
    }
    .block-audio-player .audio-player-active {
        padding-left: 2.8rem;
    }
 }
.block-audio-player .plyr__control[data-plyr="mute"] { 
    order: 4; 
    width: 2rem;
    padding-right: 0;
    justify-content: center;
    scale: 1.5;
    padding-left: 0;
}
.block-audio-player .plyr__menu                      { order: 5; }

/* Volume is moved into the settings popup by JS — hide from control bar */
.block-audio-player .plyr__controls .plyr__volume    { display: none; }

/* Progress / seek bar */
.block-audio-player .plyr__progress input[type=range] {
    color: #ffffff;
}

.block-audio-player .plyr--full-ui input[type=range] {
    color: #220F38;
}

.block-audio-player .plyr__progress__buffer {
    color: rgba(255, 255, 255, 0.25);
}

/* Volume slider — lives inside the settings popup */
.block-audio-player .plyr__menu__container .plyr__volume {
    display: flex;
    align-items: center;
    padding: 0.5rem 1rem;
    gap: 0;
    width: 100%;
    box-sizing: border-box;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.block-audio-player .plyr__menu__container .plyr__volume label {
    font-size: 0.8125rem;
    color: #ffffff;
    white-space: nowrap;
    flex-shrink: 0;
}

.block-audio-player .plyr__menu__container .plyr__volume input[type=range] {
    flex: 1;
    height:2px;
    color: #ffffff;
    background: linear-gradient(to right, #ffffff var(--value, 100%), #000000 var(--value, 100%)) !important;
}

.block-audio-player .plyr__menu__container .plyr__volume input[type=range]::-webkit-slider-runnable-track {
    background: linear-gradient(to right, #ffffff var(--value, 100%), #000000 var(--value, 100%));
}

.block-audio-player .plyr__menu__container .plyr__volume input[type=range]::-moz-range-track {
    background: #000000;
}

.block-audio-player .plyr__menu__container .plyr__volume input[type=range]::-moz-range-progress {
    background: #ffffff;
}

/* ----------------------------------------------------------
   Settings button — replace gear icon with vertical three dots
   ---------------------------------------------------------- */
.block-audio-player [data-plyr="settings"] svg {
    display: none !important;
}

.block-audio-player [data-plyr="settings"] {
    position: relative;
    font-size: 0;        /* hide any text fallback */
}

.block-audio-player [data-plyr="settings"]::after {
    content: '\22EE';   /* ⋮ VERTICAL ELLIPSIS */
    font-size: 1rem;
    font-weight: 700;
    color: #ffffff;
    line-height: 1;
    display: block;
    letter-spacing: 0;
}

/* ----------------------------------------------------------
   Settings / speed menu popup
   ---------------------------------------------------------- */
.block-audio-player .plyr__menu__container {
    background: #A11FFF;
    border-radius: 0;
    color: #ffffff;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.5);
}

.block-audio-player .plyr__menu__container .plyr__control {
    color: #ffffff;
    border-radius: 0;
}

.block-audio-player .plyr__menu__container .plyr__control:hover {
    background: rgba(161, 31, 255, 0.4);
    border-radius: 0;
}

.block-audio-player .plyr__menu__container .plyr__menu__value,
.block-audio-player .plyr__menu__container label {
    color: #ffffff;
}

.block-audio-player .plyr__menu__container [role="menuitemradio"]::before {
    border-color: #ffffff;
}

.block-audio-player .plyr__menu__container [role="menuitemradio"][aria-checked="true"]::after {
    background: #A11FFF;
}

/* ----------------------------------------------------------
   Tooltip
   ---------------------------------------------------------- */
.block-audio-player .plyr__tooltip {
    background: #1a0033;
    color: #ffffff;
    border-radius: 0;
}

.block-audio-player .plyr__tooltip::before {
    border-top-color: #1a0033;
}

/* ----------------------------------------------------------
   Editor preview placeholder — no pointer events on disabled btn
   ---------------------------------------------------------- */
.block-audio-player .audio-play-btn[disabled] {
    opacity: 0.6;
    cursor: default;
    pointer-events: none;
}
.block-audio-player .plyr {
    --plyr-audio-progress-buffered-background: rgb(255 255 255);
}
.block-audio-player [data-plyr="settings"]::after {
    transform: scale(2.2)!important;
}
.plyr__menu__container .plyr__control--forward {
    display: none;
}
.block-audio-player .plyr__menu__container .plyr__volume {
    border-bottom: none;
}
.plyr__controls .plyr__controls__item:first-child {
    flex-direction: row-reverse;
}