*,
:after,
:before {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgba(59, 130, 246, .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}

::backdrop {
    --tw-border-spacing-x: 0;
    --tw-border-spacing-y: 0;
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
    --tw-pan-x: ;
    --tw-pan-y: ;
    --tw-pinch-zoom: ;
    --tw-scroll-snap-strictness: proximity;
    --tw-gradient-from-position: ;
    --tw-gradient-via-position: ;
    --tw-gradient-to-position: ;
    --tw-ordinal: ;
    --tw-slashed-zero: ;
    --tw-numeric-figure: ;
    --tw-numeric-spacing: ;
    --tw-numeric-fraction: ;
    --tw-ring-inset: ;
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: rgba(59, 130, 246, .5);
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
    --tw-blur: ;
    --tw-brightness: ;
    --tw-contrast: ;
    --tw-grayscale: ;
    --tw-hue-rotate: ;
    --tw-invert: ;
    --tw-saturate: ;
    --tw-sepia: ;
    --tw-drop-shadow: ;
    --tw-backdrop-blur: ;
    --tw-backdrop-brightness: ;
    --tw-backdrop-contrast: ;
    --tw-backdrop-grayscale: ;
    --tw-backdrop-hue-rotate: ;
    --tw-backdrop-invert: ;
    --tw-backdrop-opacity: ;
    --tw-backdrop-saturate: ;
    --tw-backdrop-sepia: ;
    --tw-contain-size: ;
    --tw-contain-layout: ;
    --tw-contain-paint: ;
    --tw-contain-style:
}

*,
:after,
:before {
    border: 0 solid #e5e7eb;
    box-sizing: border-box
}

:after,
:before {
    --tw-content: ""
}

:host,
html {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    font-family: ui-sans-serif, system-ui, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
    font-feature-settings: normal;
    font-variation-settings: normal;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    -webkit-tap-highlight-color: transparent
}

body {
    line-height: inherit;
    margin: 0
}

hr {
    border-top-width: 1px;
    color: inherit;
    height: 0
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: inherit;
    font-weight: inherit
}

a {
    color: inherit;
    text-decoration: inherit
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
pre,
samp {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
    font-feature-settings: normal;
    font-size: 1em;
    font-variation-settings: normal
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    border-collapse: collapse;
    border-color: inherit;
    text-indent: 0
}

button,
input,
optgroup,
select,
textarea {
    color: inherit;
    font-family: inherit;
    font-feature-settings: inherit;
    font-size: 100%;
    font-variation-settings: inherit;
    font-weight: inherit;
    letter-spacing: inherit;
    line-height: inherit;
    margin: 0;
    padding: 0
}

/* Mostrar por defecto el logo oscuro */
.logo-light {
    display: none;
}
.logo-dark {
    display: block;
}

/* Cuando el tema claro esté activo, se muestra el logo claro */
.light-theme .logo-light {
    display: block;
}
.light-theme .logo-dark {
    display: none;
}



button,
select {
    text-transform: none
}

button,
input:where([type=button]),
input:where([type=reset]),
input:where([type=submit]) {
    -webkit-appearance: button;
    background-color: transparent;
    background-image: none
}

:-moz-focusring {
    outline: auto
}

:-moz-ui-invalid {
    box-shadow: none
}

progress {
    vertical-align: baseline
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

summary {
    display: list-item
}

blockquote,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
p,
pre {
    margin: 0
}

fieldset {
    margin: 0
}

fieldset,
legend {
    padding: 0
}

menu,
ol,
ul {
    list-style: none;
    margin: 0;
    padding: 0
}

dialog {
    padding: 0
}

textarea {
    resize: vertical
}

input::-moz-placeholder,
textarea::-moz-placeholder {
    color: #9ca3af;
    opacity: 1
}

input::placeholder,
textarea::placeholder {
    color: #9ca3af;
    opacity: 1
}

[role=button],
button {
    cursor: pointer
}

:disabled {
    cursor: default
}

audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
    display: block;
    vertical-align: middle
}

img,
video {
    height: auto;
    max-width: 100%
}

[hidden]:where(:not([hidden=until-found])) {
    display: none
}

:root {
    --rst-body-color: 4, 4, 4;
    --rst-primary-color: 220, 38, 38;
    --rst-secondary-color: 249, 115, 22;
    --rst-text-color: 23, 23, 23;
    --rst-light-color: 36, 36, 36;
    --rst-light-color-hover: 51, 51, 51;
    --rst-light-color-hover-2: 72, 72, 72;
    --rst-container-color: 18, 18, 18;
    --rst-wrapper-color: 24, 24, 24;
    --rst-player-width: 370px;
    --rst-player-height-mobile: 72px
}

.container {
    width: 100%
}

@media (min-width:640px) {
    .container {
        max-width: 640px
    }
}

@media (min-width:768px) {
    .container {
        max-width: 768px
    }
}

@media (min-width:1024px) {
    .container {
        max-width: 1024px
    }
}

@media (min-width:1280px) {
    .container {
        max-width: 1280px
    }
}

@media (min-width:1536px) {
    .container {
        max-width: 1536px
    }
}

.pointer-events-none {
    pointer-events: none
}

.visible {
    visibility: visible
}

.absolute {
    position: absolute
}

.relative {
    position: relative
}

.left-0 {
    left: 0
}

.right-\[1\.25rem\] {
    right: 1.25rem
}

.top-0 {
    top: 0
}

.top-6 {
    top: 1.5rem
}

.z-50 {
    z-index: 50
}

.z-\[1\] {
    z-index: 1
}

.col-span-full {
    grid-column: 1/-1
}

.clear-both {
    clear: both
}

.mx-auto {
    margin-left: auto;
    margin-right: auto
}

.-mb-2 {
    margin-bottom: -.5rem
}

.-ml-1 {
    margin-left: -.25rem
}

.-mr-2\.5 {
    margin-right: -.625rem
}

.mb-12 {
    margin-bottom: 3rem
}

.mb-3 {
    margin-bottom: .75rem
}

.mb-4 {
    margin-bottom: 1rem
}

.mb-6 {
    margin-bottom: 1.5rem
}

.mb-8 {
    margin-bottom: 2rem
}

.mr-2 {
    margin-right: .5rem
}

.mt-10 {
    margin-top: 2.5rem
}

.mt-12 {
    margin-top: 3rem
}

.line-clamp-1 {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1
}

.block {
    display: block
}

.inline {
    display: inline
}

.flex {
    display: flex
}

.grid {
    display: grid
}

.\!hidden {
    display: none !important
}

.hidden {
    display: none
}

.aspect-square {
    aspect-ratio: 1/1
}

.\!h-4 {
    height: 1rem !important
}

.\!h-\[20px\] {
    height: 20px !important
}

.\!h-\[24px\] {
    height: 24px !important
}

.h-10 {
    height: 2.5rem
}

.h-4 {
    height: 1rem
}

.h-5 {
    height: 1.25rem
}

.h-6 {
    height: 1.5rem
}

.h-\[24px\] {
    height: 24px
}

.h-auto {
    height: auto
}

.h-full {
    height: 100%
}

.\!w-4 {
    width: 1rem !important
}

.w-4 {
    width: 1rem
}

.w-5 {
    width: 1.25rem
}

.w-6 {
    width: 1.5rem
}

.w-\[60\%\] {
    width: 60%
}

.w-\[85\%\] {
    width: 85%
}

.w-\[90px\] {
    width: 90px
}

.w-\[calc\(100\%_-_90px\)\] {
    width: calc(100% - 90px)
}

.w-full {
    width: 100%
}

.animate-pulse {
    animation: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite
}

.grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr))
}

.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr))
}

.flex-col {
    flex-direction: column
}

.flex-wrap {
    flex-wrap: wrap
}

.place-content-center {
    place-content: center
}

.items-center {
    align-items: center
}

.\!justify-center {
    justify-content: center !important
}

.justify-between {
    justify-content: space-between
}

.gap-2 {
    gap: .5rem
}

.gap-3 {
    gap: .75rem
}

.gap-4 {
    gap: 1rem
}

.gap-5 {
    gap: 1.25rem
}

.self-stretch {
    align-self: stretch
}

.overflow-hidden {
    overflow: hidden
}

.rounded-full {
    border-radius: 9999px
}

.rounded-lg {
    border-radius: .5rem
}

.rounded-xl {
    border-radius: .75rem
}

.border-b {
    border-bottom-width: 1px
}

.border-l-2 {
    border-left-width: 2px
}

.border-light {
    --tw-border-opacity: 1;
    border-color: rgba(var(--rst-light-color), var(--tw-border-opacity, 1))
}

.border-white\/10 {
    border-color: hsla(0, 0%, 100%, .1)
}

.bg-light {
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-light-color), var(--tw-bg-opacity, 1))
}

.bg-wrapper {
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-wrapper-color), var(--tw-bg-opacity, 1))
}

.bg-gradient-to-l {
    background-image: linear-gradient(to left, var(--tw-gradient-stops))
}

.from-primary {
    --tw-gradient-from: rgba(var(--rst-primary-color), 1) var(--tw-gradient-from-position);
    --tw-gradient-to: rgba(var(--rst-primary-color), 0) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
}

.to-secondary {
    --tw-gradient-to: rgba(var(--rst-secondary-color), 1) var(--tw-gradient-to-position)
}

.object-cover {
    -o-object-fit: cover;
    object-fit: cover
}

.p-3 {
    padding: .75rem
}

.p-4 {
    padding: 1rem
}

.p-6 {
    padding: 1.5rem
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem
}

.px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem
}

.py-4 {
    padding-bottom: 1rem;
    padding-top: 1rem
}

.\!pr-0 {
    padding-right: 0 !important
}

.pb-12 {
    padding-bottom: 3rem
}

.pb-6 {
    padding-bottom: 1.5rem
}

.text-base {
    font-size: 1rem;
    line-height: 1.5rem
}

.text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem
}

.text-sm {
    font-size: .875rem;
    line-height: 1.25rem
}

.font-semibold {
    font-weight: 600
}

.leading-10 {
    line-height: 2.5rem
}

.leading-none {
    line-height: 1
}

.text-primary {
    --tw-text-opacity: 1;
    color: rgba(var(--rst-primary-color), var(--tw-text-opacity, 1))
}

.text-sky-500 {
    --tw-text-opacity: 1;
    color: rgb(14 165 233/var(--tw-text-opacity, 1))
}

.text-white {
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity, 1))
}

.text-white\/75 {
    color: hsla(0, 0%, 100%, .75)
}

.opacity-50 {
    opacity: .5
}

.opacity-75 {
    opacity: .75
}

.duration-300 {
    transition-duration: .3s
}

.animate-duration-300 {
    animation-duration: .3s
}

html {
    min-height: calc(100% + env(safe-area-inset-top));
    padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)
}

body {
    margin: 0;
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-body-color), var(--tw-bg-opacity, 1));
    font-family: Montserrat;
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity, 1))
}

body.is-overlay {
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}

body.is-overlay .plyer {
    pointer-events: none
}

body:before {
    background-color: rgba(var(--rst-body-color), .8);
    height: 100%;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    z-index: 99;
    --tw-backdrop-blur: blur(4px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    transition-duration: .5s
}

body:after,
body:before {
    content: "";
    left: 0;
    top: 0;
    width: 100%
}

body:after {
    background-image: linear-gradient(to top, var(--tw-gradient-stops));
    height: 50%;
    position: absolute;
    z-index: 100;
    --tw-gradient-from: transparent var(--tw-gradient-from-position);
    --tw-gradient-to: transparent var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
    --tw-gradient-to: var(--bg-cover-color, transparent) var(--tw-gradient-to-position);
    opacity: .15;
    transition-duration: .3s;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1)
}

body.is-overlay:before {
    opacity: 1
}

::-webkit-scrollbar {
    height: 8px;
    width: 8px
}

::-webkit-scrollbar-track {
    background: rgba(var(--rst-body-color), 1)
}

::-webkit-scrollbar-thumb {
    background: rgba(var(--rst-light-color-hover), 1);
    border-radius: 10px
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(var(--rst-light-color-hover-2), 1)
}

.hder {
    height: 5rem;
    z-index: 110;
    --tw-gradient-from: transparent var(--tw-gradient-from-position);
    --tw-gradient-to: transparent var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
    --tw-gradient-to: rgba(var(--rst-wrapper-color), 1) var(--tw-gradient-to-position);
    padding-bottom: 1.5rem;
    padding-top: calc(32px + env(safe-area-inset-top))
}

@media not all and (min-width:1024px) {
    .hder {
        background-image: linear-gradient(to top, var(--tw-gradient-stops))
    }
}

body.is-overlay .hder {
    z-index: 40
}

.logo img {
    height: 38px
}

.logo a {
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -.05em;
    line-height: 1.75rem;
    text-transform: uppercase
}

@media (min-width:1024px) {
    .logo a {
        font-size: 1.875rem;
        line-height: 2.25rem
    }
}

.btn {
    align-items: center;
    background-color: hsla(0, 0%, 100%, .05);
    border-radius: 9999px;
    display: flex;
    font-size: .875rem;
    font-weight: 700;
    gap: 1rem;
    height: 2.5rem;
    line-height: 1.25rem;
    padding-left: .75rem;
    padding-right: .75rem;
    text-transform: uppercase;
    transition-duration: .3s
}

.btn:hover {
    background-color: hsla(0, 0%, 100%, .2)
}

@media (min-width:1024px) {
    .btn {
        font-size: 1.125rem;
        height: 3rem;
        line-height: 1.75rem;
        padding-left: 1rem;
        padding-right: 1rem
    }
}

.btn#theme-toggle {
    display: grid;
    height: 2.5rem;
    padding-left: 0;
    padding-right: 0;
    place-content: center;
    width: 2.5rem
}

@media (min-width:1024px) {
    .btn#theme-toggle {
        height: 3rem;
        width: 3rem
    }
}

.btn#theme-toggle .light {
    display: block
}

.btn#theme-toggle .dark,
.light-theme .btn#theme-toggle .light {
    display: none
}

.light-theme .btn#theme-toggle .dark {
    display: block
}

.animate-spin {
    animation: spin 7s linear infinite;
    transform-origin: center
}

@keyframes spin {
    0% {
        transform: rotate(0deg)
    }

    to {
        transform: rotate(-1turn)
    }
}

.animate-pulse {
    animation: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite
}

@keyframes pulse {

    0%,
    to {
        opacity: 1
    }

    50% {
        opacity: .5
    }
}

.plyer {
    align-content: center;
    background-color: rgba(var(--rst-body-color), .8);
    height: 100vh;
    left: 0;
    overflow: auto;
    padding: 5rem 1rem;
    position: fixed;
    top: 0;
    width: 100vw;
    z-index: 30;
    --tw-backdrop-blur: blur(40px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)
}

.plyer-wrapper {
    bottom: 0;
    left: 0;
    margin-left: auto;
    margin-right: auto;
    max-width: 320px;
    position: relative;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 120
}

.plyer-cover {
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-wrapper-color), var(--tw-bg-opacity, 1));
    --tw-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
    --tw-shadow-color: rgba(0, 0, 0, .1);
    --tw-shadow: var(--tw-shadow-colored)
}

.plyer-cover,
.plyer-cover img {
    aspect-ratio: 1/1;
    border-radius: .75rem;
    display: block
}

.plyer-cover img {
    width: 100%
}

.plyer-header,
.plyer-song {
    display: flex;
    flex-direction: column;
    gap: .375rem;
    margin-top: 1rem;
    text-align: left
}

.plyer-header {
    gap: 0;
    line-height: 1;
    margin-bottom: 1rem;
    text-align: center
}

.plyer-header__title {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.5rem;
    line-height: 1
}

@media (min-width:1024px) {
    .plyer-header__title {
        font-size: 1.125rem;
        line-height: 1.75rem
    }
}

.plyer-header__desc {
    font-size: .875rem;
    font-weight: 300;
    line-height: 1.25rem;
    opacity: .75
}

@media (min-width:1024px) {
    .plyer-header__desc {
        font-size: 1rem;
        line-height: 1.5rem
    }
}

.plyer-song__name {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.5rem
}

@media (min-width:1024px) {
    .plyer-song__name {
        font-size: 1.125rem;
        line-height: 1.75rem
    }
}

.plyer-song__desc {
    font-size: .875rem;
    line-height: 1.25rem
}

@media (min-width:1024px) {
    .plyer-song__desc {
        font-size: 1rem;
        line-height: 1.5rem
    }
}

.plyer-skel {
    border-radius: 9999px;
    display: block;
    height: 1rem;
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-light-color), var(--tw-bg-opacity, 1))
}

.plyer-progress {
    background-color: hsla(0, 0%, 100%, .25);
    border-radius: 9999px;
    height: .25rem;
    margin-top: 1rem;
    overflow: hidden;
    position: relative;
    width: 100%
}

@media not all and (min-width:1024px) {
    .plyer-progress {
        display: none
    }
}

.plyer-progress span {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: var(--w-progress);
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255/var(--tw-bg-opacity, 1));
    transition-duration: .3s
}

.plyer-duration {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-top: .5rem
}

@media not all and (min-width:1024px) {
    .plyer-duration {
        display: none
    }
}

.plyer-duration span {
    font-size: .875rem;
    line-height: 1.25rem
}

.plyer-action {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    justify-content: center;
    margin-top: 2rem;
    width: 100%
}

.plyer-action svg {
    height: 1.5rem;
    width: 1.5rem;
    fill: currentColor
}

.plyer-action div[data-nxt-action=volume] {
    display: flex;
    position: relative
}

.plyer-action div[data-nxt-action=volume] .vol {
    bottom: 100%;
    display: flex;
    height: 32px;
    left: 50%;
    margin-bottom: 5rem;
    pointer-events: none;
    position: absolute;
    width: auto;
    --tw-translate-x: -50%;
    --tw-translate-y: 1rem;
    --tw-rotate: -90deg;
    align-items: center;
    border-radius: 9999px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255/var(--tw-bg-opacity, 1));
    padding-left: 8px;
    padding-right: 8px;
    --tw-text-opacity: 1;
    color: rgba(var(--rst-text-color), var(--tw-text-opacity, 1));
    opacity: 0;
    transition-duration: .5s
}

.plyer-action div[data-nxt-action=volume] .vol input {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 9999px;
    height: 6px;
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-light-color-hover), var(--tw-bg-opacity, 1))
}

.plyer-action div[data-nxt-action=volume] .vol input::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    border: none;
    border-radius: 50%;
    height: 16px;
    -webkit-transition: .2s ease-in-out;
    transition: .2s ease-in-out;
    width: 16px;
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-light-color-hover), var(--tw-bg-opacity, 1))
}

.plyer-action div[data-nxt-action=volume] button {
    position: relative;
    z-index: 10
}

.plyer-action div[data-nxt-action=volume]:hover .vol {
    margin-bottom: 3.5rem;
    pointer-events: auto;
    --tw-translate-y: 0px;
    opacity: 1;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.plyer-action button[data-nxt-action=play] svg {
    height: 3rem;
    width: 3rem
}

.plyer-backdrop {
    background-position: 50%;
    background-size: cover;
    z-index: 10
}

.plyer-backdrop,
.plyer-backdrop:before {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.plyer-backdrop:before {
    background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
    content: "";
    z-index: 20;
    --tw-gradient-from: transparent var(--tw-gradient-from-position);
    --tw-gradient-to: transparent var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
    --tw-gradient-to: var(--bg-cover-color, transparent) var(--tw-gradient-to-position)
}

.loader {
    display: flex;
    height: var(--icon-size, 32px);
    position: relative;
    width: var(--icon-size, 32px)
}

.loader:before {
    animation: spin .7s linear infinite;
    border-color: currentColor transparent transparent;
    border-radius: 9999px;
    border-width: 3px;
    content: "";
    height: 75%;
    left: 15%;
    position: absolute;
    top: 15%;
    width: 75%
}

.history-item {
    align-items: center;
    border-radius: .5rem;
    display: flex;
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-light-color), var(--tw-bg-opacity, 1));
    padding: 1rem
}

.history-item:not(:last-child) {
    margin-bottom: .5rem
}

.history-item img {
    border-radius: .5rem;
    height: 3.5rem;
    width: 3.5rem
}

.history-item__body {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    padding-left: 1rem;
    padding-right: 1rem;
    width: calc(100% - 56px)
}

.history-item__body .artist,
.history-item__body .title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.5rem;
    line-height: 1
}

.history-item__body .artist {
    font-size: .875rem;
    font-weight: 300;
    line-height: 1.25rem
}

.offcanvas {
    height: 100%;
    max-width: 360px;
    padding-top: env(safe-area-inset-top);
    pointer-events: auto;
    position: fixed;
    right: 0;
    top: 0;
    width: 90%;
    z-index: 9999;
    --tw-translate-x: 100%;
    overflow-y: auto;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-wrapper-color), var(--tw-bg-opacity, 1));
    padding-left: 1rem;
    padding-right: 1rem;
    transition-duration: .5s
}

.offcanvas__wrapper {
    padding: 1.5rem
}

.offcanvas__top {
    align-items: center;
    display: flex;
    font-weight: 700;
    justify-content: space-between;
    padding-bottom: 1rem;
    padding-top: 1rem
}

.offcanvas .close-offcanvas {
    display: grid;
    height: 1.75rem;
    place-content: center;
    width: 1.75rem
}

.offcanvas .close-offcanvas svg {
    pointer-events: none
}

.offcanvas.is-active {
    --tw-translate-x: 0px;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

@media screen and (max-width:1023px) {
    .menu {
        bottom: 0;
        left: 0;
        max-width: 360px;
        pointer-events: auto;
        position: fixed;
        top: 0;
        width: 90%;
        z-index: 9999;
        --tw-translate-x: -100%;
        overflow-y: auto;
        --tw-bg-opacity: 1;
        background-color: rgba(var(--rst-wrapper-color), var(--tw-bg-opacity, 1));
        padding: calc(env(safe-area-inset-top) + 16px) 1.5rem 1.5rem;
        transition-duration: .5s
    }

    .menu,
    .menu.is-active {
        transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
    }

    .menu.is-active {
        --tw-translate-x: 0px
    }
}

@media (min-width:1024px) {
    .menu__wrapper {
        bottom: 0;
        left: 0;
        padding-bottom: 1.5rem;
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        position: fixed;
        width: 100%;
        z-index: 90
    }
}

.footer {
    pointer-events: none
}

.footer__copy {
    font-weight: 700;
}

.footer__copy span {
    font-weight: 300;
    opacity: 0.5;
}

.socials {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem
}

@media not all and (min-width:1024px) {
    .socials {
        flex-direction: column;
        justify-content: center;
        width: 100%
    }
}

@media (min-width:1024px) {
    .socials {
        gap: 1rem
    }
}

.socials a {
    align-items: center;
    background-color: hsla(0, 0%, 100%, .05);
    border-radius: 9999px;
    display: flex;
    font-size: 1.125rem;
    height: 3rem;
    line-height: 1.75rem;
    width: 100%;
    --tw-text-opacity: 1;
    color: rgb(255 255 255/var(--tw-text-opacity, 1));
    --tw-backdrop-blur: blur(4px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    transition-duration: .3s
}

.socials a:hover {
    --tw-scale-x: 1.1;
    --tw-scale-y: 1.1;
    background-color: hsla(0, 0%, 100%, .2);
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

@media (min-width:1024px) {
    .socials a {
        display: grid;
        place-content: center;
        width: 3rem
    }
}

.socials a {
    font-weight: 600;
    pointer-events: auto
}

@media not all and (min-width:1024px) {
    .socials a {
        --tw-scale-x: 1 !important;
        --tw-scale-y: 1 !important;
        gap: 1.5rem;
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y)) !important
    }
}

@media not all and (min-width:640px) {
    .socials a {
        font-size: 1rem;
        line-height: 1.5rem
    }
}

@media not all and (min-width:1024px) {

    .socials a i,
    .socials a svg {
        opacity: .5
    }
}

.socials a.facebook-f:hover,
.socials a.facebook:hover {
    background-color: #3b5998
}

.socials a.x-twitter:hover,
.socials a.x:hover {
    background-color: #14171a
}

.socials a.twitter:hover {
    background-color: #1da1f2
}

.socials a.youtube:hover {
    background-color: red
}

.socials a.instagram:hover {
    background-color: #c32aa3
}

.socials a.tiktok:hover {
    background-color: #010101
}

.socials a.whatsapp:hover {
    background-color: #25d366
}

.socials a.tumblr:hover {
    background-color: #35465d
}

.light-theme {
    --rst-body-color: 248, 250, 252;
    --rst-primary-color: 124, 58, 237;
    --rst-secondary-color: 236, 72, 153;
    --rst-text-color: 51, 65, 85;
    --rst-light-color: 226, 232, 240;
    --rst-light-color-hover: 226, 232, 240;
    --rst-light-color-hover-2: 209, 213, 219;
    --rst-container-color: 241, 245, 249;
    --rst-wrapper-color: 255, 255, 255
}

.light-theme body {
    --rst-body-color: 255, 255, 255
}

.light-theme .logo,
.light-theme .offcanvas__top,
.light-theme .plyer-action button,
.light-theme .plyer-header,
.light-theme .plyer-song {
    --tw-text-opacity: 1;
    color: rgba(var(--rst-text-color), var(--tw-text-opacity, 1))
}

.light-theme .footer__copy {
    color: #333;
}

.light-theme .footer__copy span {
    --tw-text-opacity: 1;
    color: rgba(var(--rst-text-color), var(--tw-text-opacity, 1))
}

.light-theme .socials a:first-child,
.light-theme .socials a:not(:hover) {
    background-color: rgba(0, 0, 0, .1)
}

.light-theme .socials a:first-child:hover {
    background-color: rgba(0, 0, 0, .3)
}

.light-theme .plyer-skel {
    background-color: rgba(0, 0, 0, .25)
}

.light-theme .btn {
    background-color: rgba(0, 0, 0, .1)
}

.light-theme .btn:hover {
    background-color: rgba(0, 0, 0, .2)
}

.light-theme .vol {
    --tw-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);
    --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
    --tw-shadow-color: rgba(0, 0, 0, .05);
    --tw-shadow: var(--tw-shadow-colored)
}

.light-theme .vol input {
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-light-color), var(--tw-bg-opacity, 1))
}

.light-theme .history-item {
    background-color: rgba(var(--rst-light-color), .5);
    --tw-text-opacity: 1;
    color: rgba(var(--rst-text-color), var(--tw-text-opacity, 1))
}

.light-theme body.is-overlay:before {
    background-color: rgba(0, 0, 0, .5)
}

.light-theme body:after {
    opacity: .05
}

@media screen and (max-height:648px) {
    .menu {
        pointer-events: none
    }

    .plyer-cover {
        margin-left: auto;
        margin-right: auto;
        max-width: 240px;
        width: 100%
    }

    .plyer-song {
        margin-top: .75rem
    }

    .plyer-action svg {
        height: 1rem;
        width: 1rem
    }

    .plyer-action button[data-nxt-action=play] svg {
        height: 2rem;
        width: 2rem
    }

    .plyer-song__desc,
    .plyer-song__name {
        font-size: .875rem;
        line-height: 1.25rem;
        text-align: center
    }
}

.hover\:bg-light:hover {
    --tw-bg-opacity: 1;
    background-color: rgba(var(--rst-light-color), var(--tw-bg-opacity, 1))
}

@media not all and (min-width:1024px) {
    .max-lg\:mt-6 {
        margin-top: 1.5rem
    }

    .max-lg\:\!hidden {
        display: none !important
    }

    .max-lg\:hidden {
        display: none
    }

    .max-lg\:w-full {
        width: 100%
    }

    .max-lg\:grow {
        flex-grow: 1
    }

    .max-lg\:flex-col {
        flex-direction: column
    }

    .max-lg\:flex-col-reverse {
        flex-direction: column-reverse
    }

    .max-lg\:justify-center {
        justify-content: center
    }

    .max-lg\:gap-3 {
        gap: .75rem
    }

    .max-lg\:gap-6 {
        gap: 1.5rem
    }
}

@media not all and (min-width:768px) {
    .max-md\:\!hidden {
        display: none !important
    }
}

@media not all and (min-width:640px) {
    .max-sm\:hidden {
        display: none
    }
}

@media (max-width:480px) {
    .max-\[480px\]\:hidden {
        display: none
    }
}

@media (min-width:640px) {
    .sm\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }
}

@media (min-width:768px) {
    .md\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .md\:grid-cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr))
    }
}

@media (min-width:1024px) {
    .lg\:hidden {
        display: none
    }

    .lg\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }

    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }

    .lg\:gap-4 {
        gap: 1rem
    }
}

@media (min-width:1536px) {
    .\32xl\:grid-cols-6 {
        grid-template-columns: repeat(6, minmax(0, 1fr))
    }
}
/* ✅ IFRAME tools: buscador + compartir */
.nxt-if-tools{display:flex;align-items:center;gap:10px;min-width:0}
.nxt-if-search{position:relative;min-width:190px;max-width:360px;width:min(44vw,360px)}
.nxt-if-search input{
  width:100%; padding:10px 12px 10px 38px;
  border-radius:14px; border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08); color:#fff; outline:none;
}
.nxt-if-search input::placeholder{color:rgba(255,255,255,.7)}
.nxt-if-search-ico{
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  opacity:.85; color:#fff;
}

.nxt-if-results{
  position:absolute; left:0; right:0; top:44px;
  background:#0b1220; border:1px solid rgba(255,255,255,.12);
  border-radius:14px; overflow:hidden; display:none;
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  z-index:999999;
}
.nxt-if-item{padding:10px 12px; cursor:pointer; display:flex; justify-content:space-between; gap:10px}
.nxt-if-item:hover{background:rgba(255,255,255,.08)}
.nxt-if-name{font-weight:800;color:#fff}
.nxt-if-meta{opacity:.75;font-size:12px;color:#fff;white-space:nowrap}

.nxt-if-toast{
  position:fixed; left:50%; bottom:16px; transform:translateX(-50%);
  background:#111827; color:#fff; padding:10px 12px; border-radius:999px;
  box-shadow:0 12px 30px rgba(0,0,0,.35);
  display:none; z-index:9999999;
}

@media (max-width:520px){
  .nxt-if-search{min-width:140px;width:42vw}
}
