/* ============================================================
   UNDERGROUNDTEKNO DOWNLOAD — Design System 2026
   Palette: #141414 | #e57e22 | #9a9a9a | #ffffff
   Style: Kinetic Brutalism + Dark OLED
   ============================================================ */

:root {
	--ugt-bg:        #141414;
	--ugt-bg-2:      #1a1a1a;
	--ugt-bg-3:      #222222;
	--ugt-bg-4:      #2c2c2c;
	--ugt-orange:    #e57e22;
	--ugt-orange-10: rgba(229,126,34,.10);
	--ugt-orange-20: rgba(229,126,34,.20);
	--ugt-orange-40: rgba(229,126,34,.40);
	--ugt-white:     #ffffff;
	--ugt-grey:      #9a9a9a;
	--ugt-grey-dim:  #555555;
	--ugt-border:    #2a2a2a;
	--ugt-border-2:  #383838;
	--transition:    180ms ease;

	/* ── Kill Bootstrap / MDB blue everywhere ─────────────── */
	--bs-primary:              #e57e22;
	--bs-primary-rgb:          229, 126, 34;
	--bs-link-color:           #ffffff;
	--bs-link-color-rgb:       255, 255, 255;
	--bs-link-hover-color:     #e57e22;
	--bs-link-hover-color-rgb: 229, 126, 34;
	--bs-link-decoration:      none;
	/* MDB primary override */
	--mdb-primary:             #e57e22;
	--mdb-primary-rgb:         229, 126, 34;
}

/* ── RESET & BASE ─────────────────────────────────────────── */

*,
*::before,
*::after {
	box-sizing: border-box;
}

body {
	color: #ffffff;
	font-family: "Roboto", sans-serif;
	background-color: var(--ugt-bg);
	font-size: 0.9375rem;
	line-height: 1.55;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
	font-family: "Oswald", sans-serif;
	letter-spacing: 0.02em;
}

a,
body a {
	color: inherit !important;
	text-decoration: none !important;
	transition: color var(--transition);
}

img {
	display: block;
	max-width: 100%;
}

/* ── TYPOGRAPHY UTILITIES ─────────────────────────────────── */

.text-grey      { color: var(--ugt-grey) !important; }
.text-orange    { color: var(--ugt-orange) !important; }
.text-underline { text-decoration: underline; }
.text-ellipsis  { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.text-h-ellipsis   { display:-webkit-box; -webkit-line-clamp:5; -webkit-box-orient:vertical; overflow:hidden; }
.text-h-ellipsis-1 { display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; }
.text-h-ellipsis-2 { display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

label {
	font-size: 0.8125rem;
	font-weight: 400;
	color: var(--ugt-grey);
}

/* ── BG OVERRIDES ─────────────────────────────────────────── */

.bg-tertiary {
	background-color: var(--ugt-bg-2) !important;
}

/* MDB hardcodes rgba(34,49,58) for .bg-dark — kill it */
.bg-dark {
	--mdb-dark-rgb: 34, 34, 34;
	background-color: var(--ugt-bg-3) !important;
	color: #fff !important;
}

.table {
  background: transparent !important
}

.checkout-select-paiement{background-color: #1a1a1a !important;}

/* ── NAVBAR ───────────────────────────────────────────────── */

.navbar {
	background-color: var(--ugt-bg-2) !important;
	border-bottom: 1px solid var(--ugt-border-2);
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
}

.logo-top {
	height: 31px;
}

.navbar-nav .nav-link {
	font-family: "Oswald", sans-serif;
	text-transform: uppercase;
	font-size: 1rem;
	color: #bbbbbb;
	font-weight: 400;
	letter-spacing: 0.05em;
	padding: 0.5rem 0.75rem;
	transition: color var(--transition);
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active {
	color: #ffffff;
}

/* ── NAVBAR ICONS ─────────────────────────────────────────── */

.toggle-search,
.toggle-cart,
.toggle-nav-burger,
.toggle-login,
.toggle-account {
	color: #999 !important;
	position: relative;
	transition: color var(--transition);
	cursor: pointer;
}

.toggle-search:hover,
.toggle-cart:hover,
.toggle-nav-burger:hover,
.toggle-login:hover,
.toggle-account:hover {
	color: var(--ugt-orange) !important;
}

.cart-total-items {
	width: 17px;
	height: 17px;
	line-height: 17px;
	border-radius: 0;
	display: inline-block;
	text-align: center;
	font-size: 0.5rem;
	font-weight: 900;
	position: absolute;
	top: 1px;
	right: -5px;
	padding: 0;
	background-color: var(--ugt-orange) !important;
	color: #fff !important;
}

.logged-in {
	position: absolute;
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: var(--ugt-orange);
	box-shadow: 0 0 6px var(--ugt-orange-40);
	bottom: 2px;
	right: -2px;
}

#add-cart-success {
	left: -160px;
}

/* ── NAVBAR DROPDOWN ──────────────────────────────────────── */

.dropdown-menu-navbar-top {
	background-color: var(--ugt-bg-2);
	border-radius: 0;
	border: 1px solid var(--ugt-border-2);
	border-top: 2px solid var(--ugt-orange);
	top: 24px !important;
	min-width: 200px;
}

.dropdown-menu-navbar-top .dropdown-item {
	padding: 0.75rem 1.25rem;
	font-family: "Oswald", sans-serif;
	text-transform: uppercase;
	font-size: 0.9rem;
	color: #bbbbbb;
	font-weight: 400;
	letter-spacing: 0.04em;
	border-radius: 0;
	transition: color var(--transition), background-color var(--transition);
}

.dropdown-menu-navbar-top .dropdown-item:hover {
	background-color: var(--ugt-orange-10);
	color: #fff;
}

.dropdown-menu.dropdown-menu-navbar-top > li:first-child .dropdown-item,
.dropdown-menu.dropdown-menu-navbar-top > li:last-child .dropdown-item {
	border-radius: 0;
}

/* ── SIDENAV ──────────────────────────────────────────────── */

#sidenav-top {
	background-color: var(--ugt-bg-2) !important;
	border-left: 1px solid var(--ugt-border-2) !important;
}

#sidenav-filters {
	width: 70% !important;
	max-width: 320px !important;
	background-color: var(--ugt-bg-2) !important;
	border-right: 2px solid var(--ugt-orange) !important;
}

.sidenav-white .sidenav-link,
.sidenav-white .sidenav-link i {
	color: #aaaaaa !important;
	transition: color var(--transition), background-color var(--transition);
}

.sidenav-white .sidenav-link:hover,
.sidenav-white .sidenav-link:hover i {
	color: #ffffff !important;
}

.sidenav-white .sidenav-link.active,
.sidenav-white .sidenav-link.active:hover {
	background-color: var(--ugt-orange-10);
	border-left: 3px solid var(--ugt-orange);
	color: #ffffff !important;
}

.sidenav-collapse .sidenav-link {
	padding-left: 1.5rem;
	font-weight: 300;
}

/* ── MODAL LOGIN LINKS ────────────────────────────────────── */

#modal-login .toggle-register,
#modal-login .toggle-password-forgotten,
#modal-login .toggle-login {
	color: var(--ugt-orange);
	cursor: pointer;
}

#modal-login .toggle-register:hover,
#modal-login .toggle-password-forgotten:hover,
#modal-login .toggle-login:hover {
	opacity: 0.75;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── HOME SECTIONS ────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.home-section {
	padding: 2.5rem 1rem;
	border-bottom: 1px solid var(--ugt-border);
}

.home-section--alt {
	background-color: var(--ugt-bg-2);
}

@media (min-width: 768px) {
	.home-section { padding: 3rem 1.5rem; }
}

.section-header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 1.5rem;
	border-left: 4px solid var(--ugt-orange);
	padding-left: 1rem;
}

.section-title {
	font-family: "Oswald", sans-serif;
	font-size: 1.4rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #ffffff;
	margin: 0;
	line-height: 1.2;
}

.section-title-accent {
	color: var(--ugt-orange);
}

.section-link {
	font-family: "Oswald", sans-serif;
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: var(--ugt-grey);
	white-space: nowrap;
	transition: color var(--transition);
}

.section-link:hover {
	color: var(--ugt-orange);
}

.section-badge {
	font-family: "Oswald", sans-serif;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--ugt-orange);
	border: 1px solid var(--ugt-orange);
	padding: 0.15rem 0.6rem;
}

/* Legacy title classes (category pages, etc.) */
.h1-title {
	color: #ffffff;
	font-weight: 700;
	text-transform: uppercase;
	padding: 1rem 0;
	margin: 0;
	letter-spacing: 0.05em;
	font-family: "Oswald", sans-serif;
	font-size: 1.5rem;
}

.h2-title {
	color: #ffffff;
	font-weight: 600;
	text-transform: uppercase;
	padding: 1rem 0;
	margin: 0;
	letter-spacing: 0.05em;
	font-family: "Oswald", sans-serif;
	font-size: 1.25rem;
}

.title-mulish {
	font-family: "Roboto", sans-serif;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── PRODUCT CARD (pcard) ─────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.pcard {
	display: flex;
	flex-direction: column;
	background-color: var(--ugt-bg-3);
	border: 1px solid var(--ugt-border);
	transition: border-color 200ms ease, box-shadow 200ms ease, transform 200ms ease;
	position: relative;
}

.pcard:hover {
	border-color: var(--ugt-orange);
	box-shadow: 0 4px 24px rgba(0,0,0,.6), 0 0 0 1px var(--ugt-orange-20);
	transform: translateY(-2px);
}

/* Cover */
.pcard-cover {
	overflow: hidden;
	aspect-ratio: 1 / 1;
	background-color: var(--ugt-bg-4);
}

.pcard-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 300ms ease;
}

.pcard:hover .pcard-img {
	transform: scale(1.04);
}

.pcard-cover-link {
	display: block;
	width: 100%;
	height: 100%;
}

/* Hover overlay with play button */
.pcard-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.55);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 200ms ease;
}

.pcard:hover .pcard-overlay {
	opacity: 1;
}

.pcard-play-btn {
	width: 52px;
	height: 52px;
	border-radius: 0;
	border: 2px solid #fff;
	background: rgba(0,0,0,.4);
	color: #fff;
	font-size: 1.1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease;
}

.pcard-play-btn:hover {
	background-color: var(--ugt-orange);
	border-color: var(--ugt-orange);
}

/* Type badge */
.pcard-type-badge {
	position: absolute;
	top: 0;
	left: 0;
	font-family: "Oswald", sans-serif;
	font-size: 0.6rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 0.2rem 0.55rem;
	color: #fff !important;
	z-index: 2;
}

/* History icon */
.pcard-history-icon {
	position: absolute;
	top: 6px;
	right: 6px;
	color: var(--ugt-orange) !important;
	z-index: 2;
	font-size: 0.9rem;
}

/* Body */
.pcard-body {
	flex: 1;
	padding: 0.75rem 0.875rem 0.5rem;
}

.pcard-title {
	font-family: "Oswald", sans-serif;
	font-size: 0.95rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.25;
	margin: 0 0 0.3rem;
	color: #fff;
}

.pcard-title a {
	color: #fff !important;
	display: block;
}

.pcard-title a:hover {
	color: var(--ugt-orange) !important;
}

.pcard-version {
	font-weight: 300;
	font-size: 0.8rem;
	text-transform: lowercase;
	color: var(--ugt-grey);
	display: block;
}

.pcard-label {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--ugt-orange);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 0.35rem;
}

.pcard-label a,
.nav-label {
	color: var(--ugt-orange) !important;
}

.pcard-meta {
	font-size: 0.72rem;
	color: var(--ugt-grey);
	margin-bottom: 0.3rem;
	line-height: 1.4;
}

.pcard-meta-item {
	color: var(--ugt-grey) !important;
	transition: color var(--transition);
}

.pcard-meta-item:hover {
	color: #ccc !important;
}

.pcard-meta-item + .pcard-meta-item::before {
	content: " · ";
}

.pcard-styles {
	display: inline;
}

.pcard-artists {
	font-size: 0.75rem;
	color: var(--ugt-grey);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Footer */
.pcard-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.6rem 0.875rem;
	border-top: 1px solid var(--ugt-border);
	background-color: rgba(0,0,0,.25);
	gap: 0.5rem;
}

.pcard-chips {
	display: flex;
	align-items: center;
	gap: 0.3rem;
	flex-wrap: nowrap;
	overflow: hidden;
}

.pcard-chip {
	font-family: "Oswald", sans-serif;
	font-size: 0.6rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0.15rem 0.45rem;
	border: 1px solid;
	white-space: nowrap;
}

.pcard-chip--bpm {
	color: var(--ugt-orange);
	border-color: var(--ugt-orange-40);
}

.pcard-chip--key {
	color: var(--ugt-grey);
	border-color: var(--ugt-border-2);
}

.pcard-actions {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	flex-shrink: 0;
}

.pcard-price {
	font-family: "Oswald", sans-serif;
	font-size: 0.95rem;
	font-weight: 600;
	color: #ffffff;
	letter-spacing: 0.02em;
	white-space: nowrap;
}

/* ── Shared button style for card + list actions ─────────── */

.pcard-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border: 1px solid var(--ugt-border-2);
	background-color: transparent;
	color: var(--ugt-grey);
	font-size: 0.8rem;
	cursor: pointer;
	transition: border-color var(--transition), color var(--transition), background-color var(--transition);
	font-family: "Oswald", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.pcard-btn:hover {
	border-color: var(--ugt-grey);
	color: #fff;
}

.pcard-btn--play {
	border-color: var(--ugt-orange);
	color: var(--ugt-orange);
}

.pcard-btn--play:hover {
	background-color: var(--ugt-orange);
	color: #fff;
	box-shadow: 0 0 10px var(--ugt-orange-20);
}

.pcard-btn--buy:hover {
	border-color: #fff;
	color: #fff;
}

.pcard-btn--pre {
	border-color: #cc3c3c;
	color: #cc3c3c;
	width: auto;
	padding: 0 0.5rem;
	font-size: 0.65rem;
}

.pcard-btn--pre:hover {
	background-color: #cc3c3c;
	color: #fff;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── PRODUCT LIST VIEW (plist) ────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.plist-row {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem 1rem;
	border-bottom: 1px solid var(--ugt-border);
	transition: background-color var(--transition);
}

.plist-row:hover {
	background-color: var(--ugt-bg-3);
}

.plist-row:nth-child(even) {
	background-color: rgba(0,0,0,.15);
}

.plist-row:nth-child(even):hover {
	background-color: var(--ugt-bg-3);
}

/* Cover */
.plist-cover {
	flex-shrink: 0;
	position: relative;
}

.plist-img {
	width: 56px;
	height: 56px;
	object-fit: cover;
	display: block;
}

.plist-type-badge {
	position: absolute;
	top: 0;
	left: 0;
	font-size: 0.5rem;
	font-family: "Oswald", sans-serif;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0.1rem 0.35rem;
	color: #fff !important;
	z-index: 1;
	line-height: 1.4;
}

/* Info */
.plist-info {
	flex: 1;
	min-width: 0;
}

.plist-title {
	font-family: "Oswald", sans-serif;
	font-size: 0.9rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	color: #ffffff;
	display: block;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin-bottom: 0.15rem;
}

.plist-title:hover {
	color: var(--ugt-orange);
}

.plist-version {
	font-weight: 300;
	font-size: 0.75rem;
	color: var(--ugt-grey);
	text-transform: lowercase;
}

.plist-sub {
	font-size: 0.72rem;
	color: var(--ugt-grey);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.plist-label {
	color: var(--ugt-orange);
	font-weight: 500;
	margin-right: 0.5rem;
}

.plist-cat {
	color: var(--ugt-grey);
	margin-right: 0.4rem;
}

.plist-cat:hover { color: #ccc; }

.plist-styles {
	color: var(--ugt-grey-dim);
}

.plist-artists {
	font-size: 0.7rem;
	color: var(--ugt-grey-dim);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin-top: 0.1rem;
}

/* Chips */
.plist-chips {
	flex-shrink: 0;
	align-items: center;
	gap: 0.3rem;
}

/* Actions */
.plist-actions {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.plist-price {
	font-family: "Oswald", sans-serif;
	font-size: 0.9rem;
	font-weight: 600;
	color: #ffffff;
	white-space: nowrap;
	min-width: 48px;
	text-align: right;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── BEST SALES ───────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.home-topsales {
	background-color: var(--ugt-bg);
}

.topsales-slide {
	padding: 0 0.5rem;
}

.topsales-genre {
	font-family: "Oswald", sans-serif;
	font-size: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--ugt-orange);
	margin-bottom: 1rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--ugt-border-2);
}

.topsales-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.topsales-item {
	position: relative;
}

.topsales-rank {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 3;
	font-family: "Oswald", sans-serif;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	background-color: var(--ugt-orange);
	color: #fff;
	width: 24px;
	height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.owl-theme .owl-dots .owl-dot.active span,
.owl-theme .owl-dots .owl-dot:hover span {
	background: var(--ugt-orange);
}

/* ═══════════════════════════════════════════════════════════ */
/* ── DEMO BANNER ──────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.demo-banner {
	background-color: var(--ugt-bg-2);
	border-top: 2px solid var(--ugt-orange);
	border-bottom: 1px solid var(--ugt-border);
	padding: 2.5rem 1rem;
}

.demo-banner-inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.demo-banner-inner {
		flex-direction: row;
		justify-content: space-between;
		text-align: left;
	}
}

.demo-banner-title {
	font-family: "Oswald", sans-serif;
	font-size: 1.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #fff;
	margin: 0 0 0.4rem;
}

.demo-banner-sub {
	color: var(--ugt-grey);
	font-size: 0.9rem;
	margin: 0;
}

.demo-banner-cta {
	display: inline-flex;
	align-items: center;
	white-space: nowrap;
	font-family: "Oswald", sans-serif;
	font-size: 1rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 0.875rem 2rem;
	background-color: var(--ugt-orange);
	color: #fff !important;
	border: 2px solid var(--ugt-orange);
	transition: background-color var(--transition), color var(--transition), box-shadow var(--transition);
}

.demo-banner-cta:hover {
	background-color: transparent;
	color: var(--ugt-orange) !important;
	box-shadow: 0 0 20px var(--ugt-orange-20);
}

/* ═══════════════════════════════════════════════════════════ */
/* ── CATALOG PAGE ─────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.catalog-type {
	border-bottom: 3px solid var(--ugt-border-2);
	color: var(--ugt-grey) !important;
	cursor: pointer;
	font-family: "Oswald", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-size: 0.875rem;
	transition: color var(--transition), border-color var(--transition);
}

.catalog-type:hover {
	color: #fff !important;
	border-bottom-color: #555;
}

.active-catalog-type {
	border-bottom: 3px solid var(--ugt-orange);
	color: #ffffff !important;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── BOTTOM PLAYER ────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

#player-show-bar {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: var(--ugt-bg-4);
	border-top: 1px solid var(--ugt-border-2);
	color: var(--ugt-grey);
	font-family: "Oswald", sans-serif;
	font-size: 0.8rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 0.5rem 1rem;
	z-index: 1040;
	cursor: pointer;
}

#player-show-bar:hover {
	color: #fff;
}

#player {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: var(--ugt-bg-2);
	border-top: 2px solid var(--ugt-orange);
	z-index: 1040;
	padding: 0;
}

.player-inner {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 0.6rem 1rem;
	max-width: 100%;
}

/* Track info */
.player-track-info {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	min-width: 0;
	width: 220px;
}

.player-track-cover {
	width: 48px;
	height: 48px;
	object-fit: cover;
	flex-shrink: 0;
}

.player-track-text {
	min-width: 0;
	overflow: hidden;
}

.player-track-title {
	font-family: "Oswald", sans-serif;
	font-size: 0.9rem;
	font-weight: 500;
	color: #fff;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.player-track-artists {
	font-size: 0.72rem;
	color: var(--ugt-grey);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Waveform area */
#player-track-wavform-outer {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	min-width: 0;
}

#player-track-wavform {
	flex: 1;
	height: 40px;
	background-size: 100% 100%;
	background-repeat: no-repeat;
	cursor: pointer;
}

.progress-offset {
	height: 40px;
	background-color: var(--ugt-orange-10);
	cursor: pointer;
	position: relative;
	overflow: hidden;
}

.progress-bar-prepend {
	background-color: transparent !important;
	box-shadow: none !important;
}

.progress-bar.bg-primary {
	background-color: var(--ugt-orange) !important;
}

.player-playhead {
	width: 2px;
	background-color: var(--ugt-orange);
}

#player-track-progress-bar {
	background-color: var(--ugt-orange-20) !important;
	transition: none;
}

/* Player controls */
.player-controls {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-shrink: 0;
}

.player-duration {
	font-family: "Oswald", sans-serif;
	font-size: 0.75rem;
	color: var(--ugt-grey);
	letter-spacing: 0.04em;
	white-space: nowrap;
}

.player-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid var(--ugt-border-2);
	background-color: transparent;
	color: var(--ugt-grey);
	font-size: 0.9rem;
	cursor: pointer;
	transition: border-color var(--transition), color var(--transition), background-color var(--transition);
}

.player-btn:hover {
	border-color: var(--ugt-orange);
	color: var(--ugt-orange);
}

.player-play-sound.player-btn {
	border-color: var(--ugt-orange);
	color: var(--ugt-orange);
}

.player-play-sound.player-btn:hover {
	background-color: var(--ugt-orange);
	color: #fff;
}

/* Side actions */
.player-side-actions {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	gap: 0.5rem;
}

/* Album tracks popover */
#popover-player-list-album-tracks {
	position: fixed;
	bottom: 72px;
	left: 0;
	right: 0;
	z-index: 2000;
	max-height: 50vh;
	overflow-y: auto;
	background-color: var(--ugt-bg-4);
	border-bottom: 2px solid var(--ugt-orange);
	border-top: 1px solid var(--ugt-border-2);
}

/* ═══════════════════════════════════════════════════════════ */
/* ── BUTTONS ──────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.btn {
	text-transform: uppercase !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	font-family: "Oswald", sans-serif !important;
	letter-spacing: 0.07em;
	font-weight: 500;
}

.btn-primary {
	/* override every Bootstrap btn-primary internal variable */
	--bs-btn-color:            #fff;
	--bs-btn-bg:               #e57e22;
	--bs-btn-border-color:     #e57e22;
	--bs-btn-hover-color:      #fff;
	--bs-btn-hover-bg:         #c96a1a;
	--bs-btn-hover-border-color: #c96a1a;
	--bs-btn-active-color:     #fff;
	--bs-btn-active-bg:        #c96a1a;
	--bs-btn-active-border-color: #c96a1a;
	--bs-btn-focus-shadow-rgb: 229, 126, 34;
	background-color: var(--ugt-orange) !important;
	border-color:     var(--ugt-orange) !important;
	color: #fff !important;
}

.btn-primary:hover {
	box-shadow: 0 0 14px var(--ugt-orange-40) !important;
}

/* Bootstrap focus ring — replace blue with orange */
:focus-visible,
.btn:focus-visible {
	outline-color: var(--ugt-orange) !important;
	box-shadow: 0 0 0 0.2rem rgba(229,126,34,0.4) !important;
}

.btn-warning,
.btn-warning:hover,
.btn-warning:focus {
	background-color: var(--ugt-orange) !important;
	border-color: var(--ugt-orange) !important;
	color: #fff !important;
}

.btn-outline-primary {
	color: #aaa !important;
	border-color: var(--ugt-border-2) !important;
	background-color: transparent !important;
}

.btn-outline-primary:hover {
	border-color: #fff !important;
	color: #fff !important;
}

.btn-outline-warning {
	color: var(--ugt-orange) !important;
	border-color: var(--ugt-orange) !important;
	background-color: transparent !important;
}

.btn-outline-warning:hover {
	background-color: var(--ugt-orange) !important;
	color: #fff !important;
}

.btn-outline-danger {
	background-color: transparent !important;
}

.btn-dark {
	background-color: var(--ugt-bg-4) !important;
	border-color: var(--ugt-border-2) !important;
	color: #bbb !important;
}

.btn-dark:hover {
	color: #fff !important;
	border-color: #555 !important;
}

.btn-light {
	color: #1a1a1a !important;
}

.btn-group,
.btn-group:hover,
.btn-group:focus {
	box-shadow: none;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── BADGES ───────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.badge-album,
.badge-single,
.badge-track,
.badge-production {
	color: #fff !important;
	text-align: center;
	padding: 0.18rem 0.55rem;
	font-size: 0.58rem;
	font-family: "Oswald", sans-serif;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: 0;
}

.badge-album      { background-color: var(--ugt-orange); }
.badge-single     { background-color: #4a4a4a; }
.badge-track      { background-color: #353535; }
.badge-production { background-color: #aa3030; }

.badge-success { background-color: #1d7a45; border-radius:0; color:#fff; }
.badge-warning { background-color: var(--ugt-orange); border-radius:0; color:#fff; }
.badge-info    { background-color: #3a3a3a; border-radius:0; color:#fff; }
.badge-danger  { background-color: #aa3333; border-radius:0; color:#fff; }

.badge-position-absolute {
	position: absolute;
	top: 0;
	right: 0;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── BREADCRUMB ───────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.breadcrumb,
.breadcrumb a,
.breadcrumb-item+.breadcrumb-item:before {
	color: var(--ugt-grey-dim) !important;
	font-weight: 400;
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.breadcrumb-item.active {
	color: #cccccc !important;
	font-weight: 300;
}

.breadcrumb a:hover { color: var(--ugt-orange) !important; }

a.nav-artist, .nav-artist { color: var(--ugt-grey) !important; }
a.nav-artist:hover, .nav-artist:hover { color: var(--ugt-orange) !important; }
a.nav-label, .nav-label { color: var(--ugt-orange) !important; }
a.nav-label:hover, .nav-label:hover { color: var(--ugt-orange) !important; opacity: 0.8; }

/* ═══════════════════════════════════════════════════════════ */
/* ── MODALS ───────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.modal-content {
	background-color: var(--ugt-bg-3);
	border: 1px solid var(--ugt-border-2);
	border-radius: 0 !important;
}

.modal-header,
.modal-footer {
	background-color: var(--ugt-bg-4);
	border: none;
	border-radius: 0 !important;
}

.modal-footer {
	border-top: 1px solid var(--ugt-border) !important;
}

.modal-header .btn-close {
	background: none;
	font-family: "Font Awesome 6 Pro";
	color: #fff;
	font-size: 1.75rem;
	width: auto;
	margin: -5px 0 0 auto;
}

.modal-header .btn-close:before { content: "\f00d"; }

.modal-header .modal-title {
	font-family: "Oswald", sans-serif;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: #fff;
}

.modal-body { color: #fff; }

/* ── LOGIN / REGISTER MODAL ───────────────────────────────── */

/* Force MDB dark — --mdb-body-bg drives notch/input backgrounds */
#modal-login {
	--mdb-body-bg: var(--ugt-bg-4);
	--mdb-body-color: #ffffff;
	--mdb-body-color-rgb: 255, 255, 255;
	--mdb-surface-color: #ffffff;
	--mdb-surface-color-rgb: 255, 255, 255;
	--mdb-border-color: #383838;
}

#box-login,
#box-register,
#box-password-forgotten {
	padding: 1.5rem 0;
}

/* Dark inputs */
#modal-login .form-control,
#modal-login .form-control.form-control-lg,
#modal-login .form-outline .form-control {
	background-color: var(--ugt-bg-4) !important;
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	border: 1px solid var(--ugt-border-2) !important;
	border-radius: 0 !important;
	box-shadow: none; /* pas !important — laisse le fix autofill gagner */
	caret-color: #ffffff;
}

#modal-login .form-control:focus {
	border-color: var(--ugt-orange) !important;
	outline: none !important;
	box-shadow: none;
	-webkit-text-fill-color: #ffffff !important;
}

/* Tuer le form-notch MDB — div absolue qui recouvre le texte */
#modal-login .form-notch {
	display: none !important;
}

/* Border directement sur l'input puisque le notch est supprimé */
#modal-login .form-outline .form-control,
#modal-login .form-outline .form-control.form-control-lg {
	border: 1px solid var(--ugt-border-2) !important;
	border-radius: 0 !important;
	padding: 0.75rem 1rem !important;
}

#modal-login .form-outline:focus-within .form-control {
	border-color: var(--ugt-orange) !important;
}

/* Autofill inside the login modal — dark bg */
#modal-login input:-webkit-autofill,
#modal-login input:-webkit-autofill:hover,
#modal-login input:-webkit-autofill:focus,
#modal-login input:-webkit-autofill:active {
	-webkit-text-fill-color: #ffffff !important;
	-webkit-box-shadow: 0 0 0 1000px var(--ugt-bg-4) inset !important;
	box-shadow: 0 0 0 1000px var(--ugt-bg-4) inset !important;
	caret-color: #ffffff;
}

/* Google button — dark variant */
#modal-login .btn-light {
	background-color: var(--ugt-bg-4) !important;
	border: 1px solid var(--ugt-border-2) !important;
	color: #ffffff !important;
	border-radius: 0 !important;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	font-family: "Oswald", sans-serif;
	font-size: 0.9rem;
	letter-spacing: 0.08em;
	transition: border-color var(--transition), background-color var(--transition);
}

#modal-login .btn-light:hover {
	background-color: var(--ugt-bg-3) !important;
	border-color: var(--ugt-orange) !important;
}

/* Login CTA button */
#modal-login .btn-primary {
	background-color: var(--ugt-orange) !important;
	border-color: var(--ugt-orange) !important;
	color: #fff !important;
	border-radius: 0 !important;
	font-family: "Oswald", sans-serif;
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	transition: background-color var(--transition), color var(--transition);
}

#modal-login .btn-primary:hover {
	background-color: transparent !important;
	color: var(--ugt-orange) !important;
}

/* "Créer un compte" / "Mot de passe oublié" toggles */
.toggle-register,
.toggle-password-forgotten,
.toggle-login {
	color: var(--ugt-grey) !important;
	cursor: pointer;
	font-size: 0.85rem;
	transition: color var(--transition);
}

.toggle-register:hover,
.toggle-password-forgotten:hover,
.toggle-login:hover {
	color: var(--ugt-orange) !important;
}

/* Divider "Ou" */
#modal-login .text-center.fw-300 {
	color: var(--ugt-grey-dim);
	font-size: 0.8rem;
	letter-spacing: 0.05em;
}

/* Form check labels */
#modal-login .form-check-label,
#modal-login .form-label {
	color: var(--ugt-grey) !important;
	font-size: 0.82rem;
}

#modal-login .form-check-input {
	background-color: var(--ugt-bg-4) !important;
	border-color: var(--ugt-border-2) !important;
}

#modal-login .form-check-input:checked {
	background-color: var(--ugt-orange) !important;
	border-color: var(--ugt-orange) !important;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── CARDS (Bootstrap) ────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.card {
	background-color: var(--ugt-bg-3);
	border: 1px solid var(--ugt-border);
	border-radius: 0 !important;
}

.card-footer,
.card-header {
	background-color: var(--ugt-bg-4) !important;
	border: none !important;
	border-top: 1px solid var(--ugt-border) !important;
	color: #bbb !important;
	font-weight: 500;
	border-radius: 0 !important;
}

.card-title,
.card-title a { color: #ffffff !important; }
.card-title a:hover { color: var(--ugt-orange) !important; }
.card-body { overflow: hidden; }

/* ═══════════════════════════════════════════════════════════ */
/* ── PAGINATION ───────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.page-link {
	border: 1px solid var(--ugt-border-2) !important;
	background-color: var(--ugt-bg-3) !important;
	color: var(--ugt-grey) !important;
	margin-right: 0.25rem;
	padding: 0.5rem 0.85rem;
	border-radius: 0 !important;
	font-family: "Oswald", sans-serif;
	transition: all var(--transition);
}

.page-link.active,
.active>.page-link {
	border-color: var(--ugt-orange) !important;
	background-color: var(--ugt-orange) !important;
	color: #fff !important;
}

.page-link:hover {
	background-color: var(--ugt-orange-10) !important;
	border-color: var(--ugt-orange) !important;
	color: #fff !important;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── MDB SELECT — dark theme overrides ───────────────────── */
/* Override CSS custom properties directly — kills the #27a4fb */
/* ═══════════════════════════════════════════════════════════ */

/* Outer wrapper: focused notch border + label */
.select-wrapper {
	--mdb-form-outline-select-notch-border-color: var(--ugt-orange);
	--mdb-form-outline-select-label-color: var(--ugt-orange);
	--mdb-form-outline-select-input-focused-arrow-color: var(--ugt-orange);
	--mdb-form-outline-select-white-focus-arrow-color: var(--ugt-orange);
	--mdb-form-outline-select-clear-btn-focus-color: var(--ugt-orange);
}

/* Dropdown panel: bg + option highlight colors */
.select-dropdown-container {
	--mdb-form-outline-select-dropdown-bg: var(--ugt-bg-3);
	--mdb-form-outline-select-option-color: rgba(255,255,255,0.85);
	--mdb-form-outline-select-option-selected-bg: rgba(229,126,34,0.15);
	--mdb-form-outline-select-option-selected-active-bg: rgba(229,126,34,0.3);
	--mdb-form-outline-select-option-selected-hover-bg: rgba(229,126,34,0.3);
	--mdb-form-outline-select-option-hover-not-disabled-bg: var(--ugt-bg-4);
	--mdb-form-outline-select-option-active-bg: var(--ugt-bg-4);
	box-shadow: 0 8px 32px rgba(0,0,0,0.5) !important;
	border-radius: 8px !important;
	overflow: hidden;
}

/* Search input inside dropdown — Bootstrap focus override */
.select-dropdown-container input,
.select-dropdown-container input:focus,
.select-dropdown-container .select-filter-input,
.select-dropdown-container .select-filter-input:focus {
	background-color: var(--ugt-bg-4) !important;
	color: #fff !important;
	border-color: var(--ugt-border-2) !important;
	box-shadow: none !important;
	outline: none !important;
}

.select-dropdown-container input:focus,
.select-dropdown-container .select-filter-input:focus {
	border-color: var(--ugt-orange) !important;
}

.select-dropdown-container input::placeholder,
.select-dropdown-container .select-filter-input::placeholder {
	color: rgba(255,255,255,0.4) !important;
}

/* Select-all separator */
.select-all-option {
	border-bottom: 1px solid var(--ugt-border-2) !important;
}

/* Checkboxes — Bootstrap override */
.select-dropdown-container .form-check-input {
	border-color: rgba(255,255,255,0.3) !important;
	background-color: transparent !important;
}

.select-dropdown-container .form-check-input:checked {
	background-color: var(--ugt-orange) !important;
	border-color: var(--ugt-orange) !important;
}

.select-dropdown-container .form-check-input:focus {
	border-color: var(--ugt-orange) !important;
	box-shadow: 0 0 0 0.2rem rgba(229,126,34,0.25) !important;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── FORMS ────────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

span.required { color: #e05252; }

.form-outline .form-control~.form-notch div {
	border-color: var(--ugt-grey);
}

.form-outline .form-control:focus~.form-notch .form-notch-trailing,
.form-outline .form-control:focus~.form-notch .form-notch-leading,
.form-outline .form-control:focus~.form-notch .form-notch-middle,
.select-input.focused~.form-notch .form-notch-trailing,
.select-input.focused~.form-notch .form-notch-leading,
.select-input.focused~.form-notch .form-notch-middle {
	box-shadow: none;
	border-color: var(--ugt-orange) !important;
}

.form-control::-moz-placeholder { color:rgba(255,255,255,.5)!important; font-weight:300!important; font-size:.9rem!important; opacity:1!important; }
.form-control::placeholder       { color:rgba(255,255,255,.5)!important; font-weight:300!important; font-size:.9rem!important; opacity:1!important; }

/* Autofill — inset box-shadow to kill browser yellow */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
	-webkit-text-fill-color: #ffffff !important;
	caret-color: #ffffff;
	-webkit-box-shadow: 0 0 0 1000px var(--ugt-bg-4) inset !important;
	box-shadow: 0 0 0 1000px var(--ugt-bg-4) inset !important;
	transition: background-color 9999s ease-in-out 0s;
}

.alert-info {
	background-color: var(--ugt-bg-3);
	color: var(--ugt-grey);
	border: 1px solid var(--ugt-border-2);
	border-radius: 0;
}

.input-group-xl .form-control-lg { height: 56px; }

.form-control.form-control-lg,
.form-outline .form-control.form-control-lg { font-weight: 600; }

.toggle-password-outer { position: relative; }
.toggle-password-outer .toggle-password {
	position: absolute;
	top: 10px;
	right: 15px;
	color: var(--ugt-grey);
	font-size: 17px;
	cursor: pointer;
}

.iti { width: 100%; }

.iti__search-input {
	background-color: var(--ugt-bg-4);
	color: #fff;
	border: 1px solid var(--ugt-border-2);
}

.iti__search-input:focus,
.iti__search-input:focus-visible {
	box-shadow: none;
	border: 1px solid var(--ugt-orange);
}

.iti--inline-dropdown .iti__dropdown-content { bottom: 47px; }

/* ═══════════════════════════════════════════════════════════ */
/* ── TABLES ───────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

table td { font-weight: 300; vertical-align: middle; }

.table th {
	font-weight: 600 !important;
	font-family: "Oswald", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #ffffff !important;
}

.datatable table th,
.datatable table td { vertical-align: middle; }

/* ═══════════════════════════════════════════════════════════ */
/* ── POPOVER ──────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.popover {
	border: 1px solid var(--ugt-border-2);
	border-radius: 0;
	background-color: var(--ugt-bg-3);
}

.popover-header {
	color: #fff !important;
	font-weight: 500;
	font-family: "Oswald", sans-serif;
	text-transform: uppercase;
	font-size: 0.9rem;
	padding: 0.875rem 1rem;
	background-color: var(--ugt-bg-4);
	border-bottom: 1px solid var(--ugt-border-2);
	border-radius: 0;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── CHECKOUT ─────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.checkout-select-paiement {
	border: 1px solid transparent;
	transition: border-color var(--transition);
}

.checkout-select-paiement.active {
	border: 1px solid var(--ugt-orange);
	box-shadow: 0 0 10px var(--ugt-orange-10);
}

.checkout-select-paiement.active .paiement-title { color: #fff !important; }

#row-cart-total {
	position: fixed;
	right: 0;
	left: 0;
	bottom: 0;
	background-color: var(--ugt-bg-2);
	border-top: 2px solid var(--ugt-orange);
}

/* ═══════════════════════════════════════════════════════════ */
/* ── MISC / UTILITIES ─────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.border-none { border: none !important; }

#main.close { transform: translateY(-100%); display: none; }
body.modal-open #main { position: inherit; }

.price {
	font-family: "Oswald", sans-serif;
	color: #ffffff;
	font-weight: 600;
	font-size: 0.95rem;
}

.fixed-height-chart { height: 300px; }

#install-prompt {
	right: 0;
	top: 0;
	left: auto;
	width: 280px;
	border-radius: 0;
	border: 2px solid var(--ugt-orange);
	background-color: var(--ugt-bg-3);
}

/* ── SELECT DROPDOWNS ─────────────────────────────────────── */

#select-dropdown-container-payer-languages-id .select-option-icon.rounded-circle { border-radius:11%!important; }
#select-dropdown-container-payer-languages-id .select-option-icon { width:40px; height:20px; }
#select-dropdown-container-add-track-artists-id .select-option-icon { width:24px; height:24px; }
#select-dropdown-container-add-track-artists-id .select-option-icon.rounded-circle { border-radius:50%!important; }

/* ── ICON REPLAY ──────────────────────────────────────────── */

.fal.icon-replay:before {
	content: "\61";
	line-height: initial;
	font-size: 16px;
	vertical-align: -2px;
}

.icon-replay.player-sound-history { color: var(--ugt-orange) !important; }
.pcard-history-icon { color: var(--ugt-orange) !important; }

/* ── SEARCH INPUT ─────────────────────────────────────────── */

input[type="search"]::-webkit-search-cancel-button {
	-webkit-appearance: none;
	display: block;
	height: 1em;
	width: 1em;
	background: url(https://pro.fontawesome.com/releases/v5.10.0/svgs/solid/times-circle.svg) no-repeat 50% 50%;
	background-size: contain;
	opacity: 0;
	pointer-events: none;
	filter: invert(1);
}

input[type="search"]:focus::-webkit-search-cancel-button {
	opacity: .3;
	pointer-events: all;
}

/* ── WAVEFORM SEEK ────────────────────────────────────────── */

div#timeline1 {
	width: 100%;
	display: block;
	cursor: pointer;
	background-size: 100% 100%;
	background-repeat: no-repeat;
}

div#seekObj1 {
	width: 0px;
	height: 40px;
	background: var(--ugt-orange);
	cursor: pointer;
	opacity: 0.55;
}

div#seekObjContainer { width: 90%; }

/* ── LOADING ──────────────────────────────────────────────── */

div.blockOverlay { background-color: var(--ugt-bg) !important; opacity: .9 !important; }

#overlay-loading .blockMsg,
div.blockMsg {
	width: 40px;
	height: 40px;
	top:0; bottom:0; left:0; right:0;
	margin: auto;
	text-align: center;
	display: inline-block;
	background-color: transparent;
	border: none;
	box-shadow: none;
}

#overlay-loading .blockMsg { position: absolute; }

#img-loading,
div.blockMsg img {
	animation: spin 2s linear infinite;
}

#overlay-loading {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	background-color: var(--ugt-bg);
	text-align: center;
}

@keyframes spin {
	100% { transform: rotate(360deg); }
}

/* ── TOASTS ───────────────────────────────────────────────── */

.toast-close-button {
	position: absolute;
	right: 0.75rem;
	top: 0;
	font-size: 28px;
	font-weight: 300;
	color: #fff;
	opacity: 1;
}

.toast-close-button:hover { opacity: .7; }

#toast-container > div {
	position: relative;
	margin: 0 0 20px;
	padding: 1.25rem 1.75rem;
	opacity: 1;
	border-radius: 0 !important;
	border-left: 4px solid var(--ugt-orange);
}

#toast-container > .toast-success,
#toast-container > .toast-error,
#toast-container > .toast-warning,
#toast-container > .toast-info {
	background-image: none !important;
}

.toast-top-right {
	animation: toast_slidein .25s ease;
}

@keyframes toast_slidein {
	from { right: -355px; }
	to   { right: 12px; }
}

/* ═══════════════════════════════════════════════════════════ */
/* ── PRODUCT PAGE ─────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

/* Breadcrumb bar */
.product-breadcrumb-bar {
	background-color: var(--ugt-bg-2);
	border-bottom: 1px solid var(--ugt-border);
	padding: 0.6rem 1rem;
}

/* Hero layout */
.product-hero {
	padding: 2rem 1rem 0;
}

.product-hero-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}

@media (min-width: 768px) {
	.product-hero-grid {
		grid-template-columns: 280px 1fr;
		gap: 2.5rem;
		align-items: start;
	}
}

@media (min-width: 1200px) {
	.product-hero-grid {
		grid-template-columns: 340px 1fr;
		gap: 3rem;
	}
}

/* Cover */
.product-cover-col {
	position: relative;
}

.product-cover-wrap {
	position: relative;
	overflow: hidden;
	aspect-ratio: 1 / 1;
	background-color: var(--ugt-bg-4);
}

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

.product-cover-gift {
	aspect-ratio: 1 / 1;
	background-color: var(--ugt-bg-4);
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--ugt-border-2);
}

.product-cover-gift i {
	font-size: 6rem;
	color: var(--ugt-orange);
}

.product-cover-play {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,.45);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 200ms ease;
	color: #fff;
	font-size: 2rem;
}

.product-cover-wrap:hover .product-cover-play {
	opacity: 1;
}

/* Info column */
.product-info-col {
	padding-bottom: 2rem;
}

/* Title */
.product-title-row {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	flex-wrap: wrap;
	margin-bottom: 0.5rem;
}

.product-title {
	font-family: "Oswald", sans-serif;
	font-size: 2rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: #ffffff;
	margin: 0;
	line-height: 1.1;
	flex: 1;
	min-width: 0;
}

@media (min-width: 992px) {
	.product-title { font-size: 2.4rem; }
}

.product-version {
	display: block;
	font-weight: 300;
	font-size: 0.85rem;
	text-transform: capitalize;
	letter-spacing: 0.01em;
	color: var(--ugt-grey);
	margin-top: 0.15rem;
}

/* Type badges */
.product-type-badges {
	display: flex;
	align-items: center;
	gap: 0.3rem;
	padding-top: 0.25rem;
	flex-shrink: 0;
}

.prod-badge {
	font-family: "Oswald", sans-serif;
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.25rem 0.65rem;
	color: #fff;
}

.prod-badge--single     { background-color: #4a4a4a; }
.prod-badge--track      { background-color: #353535; }
.prod-badge--album      { background-color: var(--ugt-orange); }
.prod-badge--prod       { background-color: #aa3030; }

/* Album link */
.product-album-link {
	display: inline-flex;
	align-items: center;
	font-size: 0.8rem;
	font-family: "Oswald", sans-serif;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--ugt-grey);
	border: 1px solid var(--ugt-border-2);
	padding: 0.3rem 0.75rem;
	margin-bottom: 0.875rem;
	transition: border-color var(--transition), color var(--transition);
}

.product-album-link:hover {
	border-color: var(--ugt-orange);
	color: var(--ugt-orange);
}

/* Category + styles */
.product-category {
	display: flex;
	align-items: baseline;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-bottom: 0.25rem;
}

.product-category-link {
	font-family: "Oswald", sans-serif;
	font-size: 1.2rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: #ffffff !important;
	transition: color var(--transition);
}

.product-category-link:hover { color: var(--ugt-orange) !important; }

.product-styles {
	font-size: 0.8rem;
	color: var(--ugt-grey);
}

/* Label */
.product-label-row {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	margin-bottom: 0.4rem;
	font-size: 0.85rem;
}

.product-label-prefix {
	font-family: "Oswald", sans-serif;
	text-transform: uppercase;
	font-size: 0.7rem;
	letter-spacing: 0.07em;
	color: var(--ugt-grey);
	font-weight: 500;
}

.product-label-name {
	font-family: "Oswald", sans-serif;
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--ugt-orange) !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	transition: opacity var(--transition);
}

.product-label-name:hover { opacity: 0.8 !important; }

/* Artists */
.product-artists {
	font-size: 0.9rem;
	color: #cccccc;
	margin-bottom: 0.3rem;
}

/* Date */
.product-date {
	font-size: 0.78rem;
	color: var(--ugt-grey);
	margin-bottom: 1.25rem;
}

/* ── Pricing ──────────────────────────────────────────────── */

.product-pricing {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	margin-bottom: 1.5rem;
	padding: 1.25rem;
	background-color: var(--ugt-bg-3);
	border: 1px solid var(--ugt-border-2);
	border-left: 3px solid var(--ugt-orange);
}

.pricing-row {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.pricing-price {
	font-family: "Oswald", sans-serif;
	font-size: 1.25rem;
	font-weight: 600;
	color: #ffffff;
	letter-spacing: 0.03em;
}

/* Format badges (MP3/WAV) */
.format-badge {
	font-family: "Oswald", sans-serif;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.2rem 0.6rem;
	min-width: 44px;
	text-align: center;
	color: #fff;
}

.format-badge--mp3 {
	background-color: #2a5c3c;
	border: 1px solid #3a7c52;
}

.format-badge--wav {
	background-color: #1e3d5c;
	border: 1px solid #2a5c8c;
}

.format-badge--sm {
	font-size: 0.55rem;
	padding: 0.15rem 0.4rem;
}

/* ── CTA buttons ──────────────────────────────────────────── */

.product-cta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.product-btn {
	display: inline-flex;
	align-items: center;
	font-family: "Oswald", sans-serif;
	font-size: 0.9rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 0.75rem 1.5rem;
	border: 2px solid;
	cursor: pointer;
	transition: background-color var(--transition), color var(--transition), box-shadow var(--transition);
}

.product-btn--buy {
	background-color: var(--ugt-orange);
	border-color: var(--ugt-orange);
	color: #ffffff;
}

.product-btn--buy:hover {
	background-color: transparent;
	color: var(--ugt-orange);
	box-shadow: 0 0 20px var(--ugt-orange-20);
}

.product-btn--pre {
	background-color: transparent;
	border-color: #cc3c3c;
	color: #cc3c3c;
}

.product-btn--pre:hover {
	background-color: #cc3c3c;
	color: #fff;
}

.product-btn--play {
	background-color: transparent;
	border-color: var(--ugt-border-2);
	color: var(--ugt-grey);
}

.product-btn--play:hover {
	border-color: var(--ugt-orange);
	color: var(--ugt-orange);
}

/* ── Description ──────────────────────────────────────────── */

.product-description {
	padding: 2rem 1rem;
	border-top: 1px solid var(--ugt-border);
	color: var(--ugt-grey);
	font-size: 0.9rem;
	line-height: 1.7;
}

/* ── Section title (within product page) ─────────────────── */

.product-section-title {
	font-family: "Oswald", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--ugt-grey);
	margin-bottom: 0.875rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--ugt-border);
}

/* ── Tracklist table ──────────────────────────────────────── */

.product-tracklist {
	padding: 2rem 1rem;
	border-top: 1px solid var(--ugt-border);
}

.product-table {
	width: 100%;
	border-collapse: collapse;
	color: #cccccc;
	font-size: 0.875rem;
	/* Kill MDB/Bootstrap blue table variables */
	--bs-table-bg:           transparent;
	--bs-table-color:        #cccccc;
	--bs-table-border-color: var(--ugt-border);
	--bs-table-hover-bg:     rgba(229,126,34,.05);
	--bs-table-striped-bg:   transparent;
	--mdb-table-bg:          transparent;
	--mdb-table-accent-bg:   transparent;
	--mdb-table-color:       #cccccc;
	background-color: var(--ugt-bg-3) !important;
}

/* MDB uses box-shadow: inset 0 0 0 9999px to color cells — kill on all tables */
table > :not(caption) > * > *,
td, th {
	background-color: transparent !important;
	box-shadow: none !important;
}

.product-table thead tr {
	background-color: var(--ugt-bg-3) !important;
}

.product-table thead tr {
	border-bottom: 2px solid var(--ugt-orange);
}

.product-table th {
	font-family: "Oswald", sans-serif;
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--ugt-grey) !important;
	padding: 0.75rem 0.75rem;
	background-color: var(--ugt-bg-3);
	border: none !important;
}

.product-table td {
	padding: 0.75rem 0.75rem;
	border-bottom: 1px solid var(--ugt-border);
	vertical-align: middle;
}

.product-table tbody tr:hover td {
	background-color: rgba(229,126,34,.04);
}

.product-table td a {
	color: #fff;
	transition: color var(--transition);
}

.product-table td a:hover { color: var(--ugt-orange); }

.track-title   { font-weight: 500; color: #fff; }
.track-duration,
.track-bpm,
.track-key     { color: var(--ugt-grey); font-family: "Oswald", sans-serif; font-size: 0.85rem; }
.track-actions { white-space: nowrap; }
.track-price   {
	font-family: "Oswald", sans-serif;
	font-size: 0.85rem;
	font-weight: 600;
	color: #ffffff;
	white-space: nowrap;
}

/* ── Platform links ───────────────────────────────────────── */

.product-platforms {
	padding: 2rem 1rem;
	border-top: 1px solid var(--ugt-border);
}

.platforms-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 0.75rem;
}

.platform-card {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 0.875rem 1.25rem;
	background-color: var(--ugt-bg-3);
	border: 1px solid var(--ugt-border);
	transition: border-color var(--transition), background-color var(--transition);
	cursor: pointer;
}

.platform-card:hover {
	border-color: var(--ugt-orange);
	background-color: var(--ugt-orange-10);
}

.platform-card img {
	max-height: 28px;
	width: auto;
	object-fit: contain;
}

/* ── Related sections ─────────────────────────────────────── */

.related-section {
	padding: 2.5rem 1rem;
	border-top: 1px solid var(--ugt-border);
}

.related-section--alt {
	background-color: var(--ugt-bg-2);
}

/* ═══════════════════════════════════════════════════════════ */
/* ── BOOTSTRAP COLOR OVERRIDES (écraser les bleus/verts) ─── */
/* ═══════════════════════════════════════════════════════════ */

/* bg-info → utilisé pour les badges MP3/WAV dans l'ancien code */
.badge.bg-info,
span.badge.bg-info {
	background-color: #2a2a2a !important;
	color: #cccccc !important;
}

/* bg-primary Bootstrap → orange */
.bg-primary { background-color: var(--ugt-orange) !important; }
a.bg-primary:hover { background-color: #c96a1a !important; }

/* btn-primary → orange (doublon de sécurité) */
.btn.btn-primary,
.btn.btn-primary:hover,
.btn.btn-primary:focus {
	background-color: var(--ugt-orange) !important;
	border-color: var(--ugt-orange) !important;
	color: #fff !important;
}

/* btn-secondary → dark neutre */
.btn.btn-secondary,
.btn.btn-secondary:hover,
.btn.btn-secondary:focus {
	background-color: var(--ugt-bg-4) !important;
	border-color: var(--ugt-border-2) !important;
	color: #cccccc !important;
}

.btn.btn-secondary:hover {
	border-color: var(--ugt-orange) !important;
	color: #fff !important;
}

/* table-dark header Bootstrap */
.table-dark,
.table-dark thead,
.table-dark th,
.table-dark td {
	background-color: var(--ugt-bg-3) !important;
	color: #cccccc !important;
	border-color: var(--ugt-border) !important;
}

/* Links dans le contexte produit */
.product-info-col a:not(.product-btn):not(.product-label-name):not(.product-category-link):not(.product-album-link):not(.ajaxify) {
	color: var(--ugt-orange);
}

/* h2/h4 category links dans ancien code (sécurité) */
.col-md-9 h2 a,
.col-md-9 h4 a,
.col-md-9 h3 a {
	color: #ffffff;
	transition: color var(--transition);
}

.col-md-9 h2 a:hover,
.col-md-9 h4 a:hover,
.col-md-9 h3 a:hover {
	color: var(--ugt-orange);
}

/* ═══════════════════════════════════════════════════════════ */
/* ── POPOVER ALBUM TRACKS HEADER ─────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.popover-album-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1rem 1.25rem;
	border-bottom: 1px solid var(--ugt-border-2);
	background-color: var(--ugt-bg-4);
}

.popover-album-title {
	font-family: "Oswald", sans-serif;
	font-size: 0.95rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #fff;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── FORCE REMOVE ALL BOOTSTRAP BLUES from bg-info ───────── */
/* ═══════════════════════════════════════════════════════════ */

/* MDB / Bootstrap blue overrides — exhaustive */
.bg-info   { background-color: #2e2e2e !important; color: #ccc !important; }
.bg-primary { background-color: var(--ugt-orange) !important; }
.text-info  { color: var(--ugt-grey) !important; }

.badge.bg-info,
.badge.bg-primary,
.badge.bg-secondary {
	background-color: #2e2e2e !important;
	color: #cccccc !important;
}

/* bg-tertiary used as badge background (price in tracklist) */
.badge.bg-tertiary {
	background-color: transparent !important;
	color: #ffffff !important;
	font-family: "Oswald", sans-serif;
	font-weight: 600;
	font-size: 0.85rem;
	padding: 0;
	border: none;
}

/* table-dark from Bootstrap — full override */
.table-dark {
	background-color: transparent !important;
	--bs-table-bg: var(--ugt-bg-3) !important;
	--bs-table-striped-bg: var(--ugt-bg-4) !important;
	--bs-table-hover-bg: rgba(229,126,34,.05) !important;
	--bs-table-border-color: var(--ugt-border) !important;
	--bs-table-color: #cccccc !important;
	color: #cccccc !important;
}

.table-dark thead,
.table-dark thead th {
	background-color: var(--ugt-bg-3) !important;
	border-bottom: 2px solid var(--ugt-orange) !important;
	color: var(--ugt-grey) !important;
}

.table-dark td,
.table-dark th {
	border-color: var(--ugt-border) !important;
}

/* ═══════════════════════════════════════════════════════════ */
/* ── HERO SLIDER ──────────────────────────────────────────── */
/* ═══════════════════════════════════════════════════════════ */

.hero-slider {
	position: relative;
	overflow: hidden;
	height: min(55vh, 520px);
	min-height: 360px;
	background-color: #000;
}

/* Blurred background + Ken Burns */
.hero-bg {
	position: absolute;
	inset: -60px;
	background-size: cover;
	background-position: center;
	filter: blur(30px) brightness(0.28) saturate(0.5);
	animation: heroBgZoom 10s ease-out forwards;
	will-change: transform;
}

@keyframes heroBgZoom {
	from { transform: scale(1.22); }
	to   { transform: scale(1.08); }
}

/* Dark gradient overlay */
.hero-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(
		90deg,
		rgba(0,0,0,0.92) 0%,
		rgba(0,0,0,0.60) 52%,
		rgba(0,0,0,0.18) 100%
	);
}

/* Slide */
.hero-slide {
	position: absolute;
	inset: 0;
	z-index: 1;
	opacity: 0;
	pointer-events: none;
	transition: opacity 650ms ease;
}

.hero-slide--active {
	opacity: 1;
	z-index: 3;
	pointer-events: auto;
}

/* Content area */
.hero-inner {
	position: relative;
	z-index: 2;
	height: 100%;
}

.hero-grid {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	height: 100%;
	gap: 2.5rem;
	padding: 2.5rem 0 4rem;
}

/* Cover art */
.hero-cover-wrap {
	position: relative;
	width: clamp(200px, 28vw, 340px);
	aspect-ratio: 1 / 1;
	flex-shrink: 0;
	box-shadow: 0 12px 60px rgba(0,0,0,0.8), 0 0 0 1px var(--ugt-border);
	overflow: hidden;
}

.hero-cover-link {
	display: block;
	width: 100%;
	height: 100%;
	overflow: hidden;
}

.hero-cover-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 500ms ease;
}

.hero-cover-wrap:hover .hero-cover-img {
	transform: scale(1.05);
}

.hero-cover-play {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 2;
	width: 52px;
	height: 52px;
	background-color: var(--ugt-orange);
	color: #fff;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
	cursor: pointer;
	transition: background-color var(--transition), transform var(--transition);
}

.hero-cover-play:hover {
	background-color: #c96b15;
	transform: scale(1.08);
}

/* Info block */
.hero-info {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	min-width: 0;
}

.hero-slide--active .hero-info {
	animation: heroInfoIn 550ms ease forwards;
}

@keyframes heroInfoIn {
	from { opacity: 0; transform: translateY(22px); }
	to   { opacity: 1; transform: translateY(0); }
}

.hero-eyebrow {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.hero-new-badge {
	font-family: "Oswald", sans-serif;
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	background-color: var(--ugt-orange);
	color: #fff;
	padding: 0.22rem 0.65rem;
}

.hero-label-name {
	font-family: "Oswald", sans-serif;
	font-size: 0.75rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--ugt-orange);
	opacity: 0.85;
}

.hero-title {
	font-family: "Oswald", sans-serif;
	font-size: clamp(1.9rem, 4vw, 3.6rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.01em;
	line-height: 1.04;
	color: #fff;
	margin: 0;
}

.hero-title a { color: #ffffff !important; }
.hero-title a:hover { color: var(--ugt-orange) !important; }

.hero-version {
	font-size: 0.82rem;
	color: var(--ugt-grey);
	font-weight: 300;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	margin: -0.5rem 0 0;
}

.hero-artists {
	font-size: 0.88rem;
	color: #c0c0c0;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.2rem;
}

.hero-artists a { color: #c0c0c0; }
.hero-artists a:hover { color: var(--ugt-orange); }

.hero-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.hero-chip {
	font-family: "Oswald", sans-serif;
	font-size: 0.66rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background-color: rgba(255,255,255,0.06);
	border: 1px solid var(--ugt-border-2);
	color: var(--ugt-grey);
	padding: 0.2rem 0.6rem;
}

.hero-chip--cat {
	border-color: var(--ugt-orange-40);
	color: var(--ugt-orange);
	background-color: var(--ugt-orange-10);
}

.hero-actions {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 0.4rem;
}

.hero-price {
	font-family: "Oswald", sans-serif;
	font-size: 1.6rem;
	font-weight: 700;
	color: #fff;
	min-width: 56px;
}

.hero-btn-buy {
	display: inline-flex;
	align-items: center;
	font-family: "Oswald", sans-serif;
	font-size: 0.88rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.09em;
	padding: 0.7rem 1.5rem;
	background-color: var(--ugt-orange);
	color: #fff;
	border: 2px solid var(--ugt-orange);
	cursor: pointer;
	transition: background-color var(--transition), color var(--transition);
}

.hero-btn-buy:hover {
	background-color: transparent;
	color: var(--ugt-orange);
}

.hero-btn-play {
	display: inline-flex;
	align-items: center;
	font-family: "Oswald", sans-serif;
	font-size: 0.88rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.09em;
	padding: 0.7rem 1.5rem;
	background-color: transparent;
	color: #fff;
	border: 2px solid rgba(255,255,255,0.25);
	cursor: pointer;
	transition: border-color var(--transition), background-color var(--transition);
}

.hero-btn-play:hover {
	border-color: rgba(255,255,255,0.7);
	background-color: rgba(255,255,255,0.06);
}

.hero-btn-pre {
	display: inline-flex;
	align-items: center;
	font-family: "Oswald", sans-serif;
	font-size: 0.88rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.09em;
	padding: 0.7rem 1.5rem;
	background-color: transparent;
	color: var(--ugt-orange);
	border: 2px solid var(--ugt-orange-40);
	cursor: pointer;
	transition: border-color var(--transition), background-color var(--transition);
}

.hero-btn-pre:hover {
	border-color: var(--ugt-orange);
	background-color: var(--ugt-orange-10);
}

.hero-btn-detail {
	font-family: "Oswald", sans-serif;
	font-size: 0.78rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: var(--ugt-grey) !important;
	border-bottom: 1px solid transparent;
	padding-bottom: 1px;
	transition: color var(--transition), border-color var(--transition);
}

.hero-btn-detail:hover {
	color: #fff !important;
	border-bottom-color: rgba(255,255,255,0.5);
}

/* Progress bar */
.hero-progress {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2px;
	background-color: rgba(255,255,255,0.08);
	z-index: 10;
}

.hero-progress-bar {
	height: 100%;
	width: 0%;
	background: linear-gradient(90deg, var(--ugt-orange-40), var(--ugt-orange));
}

/* Navigation bar */
.hero-nav-wrap {
	position: absolute;
	bottom: 12px;
	left: 0;
	right: 0;
	z-index: 10;
}

.hero-nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.hero-indicators {
	display: flex;
	gap: 0.45rem;
}

.hero-dot {
	width: 32px;
	height: 3px;
	background-color: rgba(255,255,255,0.18);
	border: none;
	cursor: pointer;
	padding: 0;
	transition: background-color 250ms ease, width 250ms ease;
}

.hero-dot--active {
	background-color: var(--ugt-orange);
	width: 48px;
}

.hero-dot:hover:not(.hero-dot--active) {
	background-color: rgba(255,255,255,0.45);
}

.hero-arrows {
	display: flex;
	gap: 0.4rem;
}

.hero-arrow {
	width: 38px;
	height: 38px;
	border: 1px solid rgba(255,255,255,0.15);
	background-color: rgba(0,0,0,0.35);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-size: 0.82rem;
	transition: background-color var(--transition), border-color var(--transition);
}

.hero-arrow:hover {
	background-color: var(--ugt-orange);
	border-color: var(--ugt-orange);
}

/* ── HERO RESPONSIVE ─────────────────────────────────────── */

@media (max-width: 991px) {
	/* On mobile: slides are absolutely positioned → parent collapses to 0.
	   Switch to display:none/block + position:relative so content drives height. */
	.hero-slider {
		height: auto;
		min-height: 0;
	}

	.hero-slide {
		position: relative;
		inset: auto;
		opacity: 1;
		display: none;
		transition: none;
		pointer-events: none;
	}

	.hero-slide--active {
		display: block;
		pointer-events: auto;
	}

	/* hero-bg stays absolute inside the now-relative slide;
	   overflow:hidden on .hero-slider clips the -40px bleed */
	.hero-bg {
		inset: -40px;
	}

	.hero-inner {
		height: auto;
	}

	.hero-grid {
		grid-template-columns: 1fr;
		padding: 2rem 1rem 4.5rem;
		gap: 1.25rem;
	}

	.hero-cover-wrap {
		width: clamp(130px, 40vw, 220px);
		margin: 0 auto;
	}

	.hero-info {
		gap: 0.6rem;
	}

	.hero-title {
		font-size: clamp(1.5rem, 7vw, 2.2rem);
	}

	.hero-overlay {
		background: linear-gradient(
			180deg,
			rgba(0,0,0,0.3) 0%,
			rgba(0,0,0,0.75) 50%,
			rgba(0,0,0,0.95) 100%
		);
	}

	.hero-actions {
		flex-wrap: wrap;
		gap: 0.5rem;
	}

	/* Nav stays at the bottom of the auto-height slider */
	.hero-nav-wrap {
		position: relative;
		bottom: auto;
		padding: 0.75rem 0;
		background: linear-gradient(transparent, rgba(0,0,0,0.6));
	}
}

@media (max-width: 575px) {
	.hero-title { font-size: clamp(1.3rem, 6.5vw, 1.8rem); }

	.hero-btn-buy,
	.hero-btn-play,
	.hero-btn-pre {
		font-size: 0.78rem;
		padding: 0.5rem 1rem;
	}

	.hero-price { font-size: 1.15rem; }

	.hero-cover-wrap { width: 44vw; }

	.hero-chips { gap: 0.3rem; }
}

/* ═══════════════════════════════════════════════════════════
   FILTERS — key grid + BPM range slider
═══════════════════════════════════════════════════════════ */

.filter-label {
	font-family: 'Oswald', sans-serif;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--ugt-orange);
	margin-bottom: 10px;
}

.filter-hidden-select {
	display: none !important;
}

/* ── Chip grids ─────────────────────────────────────────── */
.key-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 5px;
}

.filter-chip-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
}

.filter-chip-grid .key-btn {
	flex: 0 0 auto;
	padding: 6px 10px;
	font-size: 12px;
}

/* Scrollable wrapper for long style lists */
.filter-chip-scroll {
	max-height: 190px;
	overflow-y: auto;
	padding-right: 4px;
	scrollbar-width: thin;
	scrollbar-color: var(--ugt-orange) var(--ugt-bg-4);
}
.filter-chip-scroll::-webkit-scrollbar      { width: 4px; }
.filter-chip-scroll::-webkit-scrollbar-track { background: var(--ugt-bg-4); border-radius: 2px; }
.filter-chip-scroll::-webkit-scrollbar-thumb { background: var(--ugt-orange); border-radius: 2px; }

/* Popularity tiers */
.key-btn--xl {
	font-size: 14px !important;
	font-weight: 700;
	padding: 8px 13px !important;
	border: 2px solid var(--ugt-orange) !important;
	background: rgba(229,126,34,0.08);
	color: #fff;
	box-shadow: 0 0 8px rgba(229,126,34,0.15);
}
.key-btn--xl:hover {
	background: rgba(229,126,34,0.18) !important;
	box-shadow: 0 0 12px rgba(229,126,34,0.3);
}

.key-btn--lg {
	font-size: 13px !important;
	font-weight: 500;
	border: 1.5px solid rgba(229,126,34,0.4) !important;
}

/* Active state wins over all tiers */
.key-btn--xl.key-btn--active,
.key-btn--lg.key-btn--active {
	background: var(--ugt-orange) !important;
	border-color: var(--ugt-orange) !important;
}

.key-btn {
	background: var(--ugt-bg-3);
	border: 1px solid rgba(255,255,255,0.1);
	color: rgba(255,255,255,0.75);
	border-radius: 6px;
	padding: 7px 4px;
	font-family: 'Oswald', sans-serif;
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 0.5px;
	cursor: pointer;
	transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.1s;
	text-align: center;
	line-height: 1;
}

.key-btn:hover {
	background: var(--ugt-bg-4);
	border-color: var(--ugt-orange);
	color: #fff;
}

.key-btn--active {
	background: var(--ugt-orange);
	border-color: var(--ugt-orange);
	color: #fff;
	font-weight: 600;
	transform: scale(1.04);
}

/* ── BPM dual-range slider ──────────────────────────────── */
.bpm-range-wrap {
	padding: 4px 0 8px;
}

.bpm-range-labels {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 14px;
}

.bpm-range-badge {
	background: var(--ugt-bg-3);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 6px;
	padding: 4px 10px;
	font-family: 'Oswald', sans-serif;
	font-size: 15px;
	color: #fff;
	font-weight: 500;
	min-width: 52px;
	text-align: center;
}

.bpm-range-sep {
	color: rgba(255,255,255,0.35);
	font-size: 12px;
}

.bpm-range-track {
	position: relative;
	height: 4px;
	background: rgba(255,255,255,0.12);
	border-radius: 2px;
	margin: 10px 0 18px;
}

.bpm-range-fill {
	position: absolute;
	top: 0;
	height: 100%;
	background: var(--ugt-orange);
	border-radius: 2px;
	pointer-events: none;
}

.bpm-range-input {
	position: absolute;
	width: 100%;
	top: 50%;
	transform: translateY(-50%);
	height: 4px;
	background: transparent;
	-webkit-appearance: none;
	appearance: none;
	outline: none;
	pointer-events: none;
	margin: 0;
	padding: 0;
}

.bpm-range-input::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--ugt-orange);
	border: 2px solid #fff;
	cursor: pointer;
	pointer-events: auto;
	box-shadow: 0 2px 6px rgba(0,0,0,0.5);
	transition: transform 0.1s;
}

.bpm-range-input::-webkit-slider-thumb:hover,
.bpm-range-input:active::-webkit-slider-thumb {
	transform: scale(1.2);
}

.bpm-range-input::-moz-range-thumb {
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--ugt-orange);
	border: 2px solid #fff;
	cursor: pointer;
	pointer-events: auto;
	box-shadow: 0 2px 6px rgba(0,0,0,0.5);
}

.bpm-range-input::-moz-range-track {
	background: transparent;
}

.bpm-range-input:first-of-type  { z-index: 3; }
.bpm-range-input:last-of-type   { z-index: 4; }
