:root {
  --black: #050505;
  --blue: #5c7ce6;
  --white: #ffffff;
  --text: #161616;
  --muted: #6f6f6f;
  --line: #e6e6e6;
  --soft: #f6f6f6;
  --primary-rgb: 92, 124, 230;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Albert Sans', sans-serif;
  color: var(--text);
  background: var(--white);
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

.container {
  width: min(1360px, calc(100% - 48px));
  margin: 0 auto;
}

.site-header {
  background: rgba(5,5,5,.92);
  color: var(--white);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.header-inner {
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.logo-placeholder {
  width: 110px;
  height: 46px;
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.logo-placeholder.has-logo img {
  max-height: 46px;
  width: auto;
}

.main-nav {
  display: flex;
  align-items: center;
  gap: 20px;
  font-weight: 700;
  flex-wrap: wrap;
  justify-content: center;
}
.main-nav a {
  white-space: normal;
  padding: 10px 14px;
  border-radius: 999px;
  transition: background .22s ease, color .22s ease, transform .22s ease;
}
.main-nav a:hover {
  background: rgba(255,255,255,.1);
  transform: translateY(-1px);
}
.main-nav i { font-size: 12px; margin-left: 6px; }

.header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.header-actions .social-btn {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  transition: transform .22s ease, background .22s ease, border-color .22s ease;
}
.header-actions .social-btn:hover {
  transform: translateY(-1px);
  background: rgba(var(--primary-rgb), .95);
  border-color: rgba(var(--primary-rgb), 1);
}


.dedication-bar {
  position: relative;
  z-index: 20;
  background: var(--blue);
  color: rgba(255,255,255,.96);
  border-top: 1px solid rgba(255,255,255,.10);
  border-bottom: 1px solid rgba(255,255,255,.10);
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), inset 0 -1px 0 rgba(255,255,255,.08);
}

.dedication-inner {
  position: relative;
  min-height: 42px;
  display: flex;
  align-items: center;
  gap: 12px;
  overflow: hidden;
  padding-right: 48px;
}

.dedication-title {
  flex: 0 0 auto;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.82);
}

.dedication-feed {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  white-space: normal;
  position: relative;
  display: flex;
  align-items: center;
}

.dedication-track {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding-right: 28px;
  min-width: max-content;
  flex: 0 0 auto;
  animation: dedicationScroll 28s linear infinite;
}

.dedication-feed:hover .dedication-track,
.dedication-feed.is-paused .dedication-track,
.dedication-feed:focus-within .dedication-track {
  animation-play-state: paused;
}

.dedication-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(255,255,255,.95);
}

.dedication-item strong {
  color: var(--white);
}

.dedication-feed .sep {
  color: rgba(255,255,255,.58);
}

@keyframes dedicationScroll {
  from { transform: translateX(0); }
  to { transform: translateX(-100%); }
}

.hero {
  position: relative;
  min-height: 540px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  overflow: hidden;
}
.hero-bg-blur {
  position: absolute;
  inset: -24px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  transform: scale(1.12);
  filter: blur(28px);
  opacity: .9;
  transition: background-image .45s ease, opacity .25s ease, transform .45s ease;
}
.hero-bg-blur.is-updating {
  opacity: .72;
  transform: scale(1.16);
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.62) 100%);
}

.hero-content {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  min-height: 540px;
  padding: 56px 0 155px;
}

.hero-main {
  display: flex;
  align-items: center;
  gap: 28px;
  color: var(--white);
}

.cover-wrap {
  width: 182px;
  height: 182px;
  border: 0;
  overflow: hidden;
  border-radius: 16px;
  flex: 0 0 auto;
  background: #ddd;
  box-shadow: 0 18px 40px rgba(0,0,0,.22);
}
.cover-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity .24s ease, transform .32s ease;
}
.cover-wrap img.is-updating {
  opacity: .6;
  transform: scale(1.04);
}

.live-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 14px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
}

.hero-text h1,
.hero-text h2 {
  margin: 0;
  line-height: .95;
  transition: opacity .24s ease, transform .24s ease;
}
.hero-text h1.is-updating,
.hero-text h2.is-updating {
  opacity: .58;
  transform: translateY(4px);
}

.hero-text {
  min-width: 0;
  max-width: min(980px, 72vw);
}

.hero-text h1 {
  font-size: clamp(38px, 5vw, 64px);
  font-weight: 300;
  text-transform: uppercase;
  white-space: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.hero-text h2 {
  font-size: clamp(42px, 5.5vw, 68px);
  font-weight: 800;
  text-transform: uppercase;
  white-space: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.hero-meta {
  margin-top: 22px;
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  font-weight: 600;
  color: rgba(255,255,255,.88);
}
.hero-meta i { margin-right: 8px; }

.now-playing-band {
  position: relative;
  margin-top: 0;
  padding: 34px 0 6px;
  z-index: 3;
}

.now-playing-band .container {
  background: var(--white);
  border: 0px;
  padding: 0px;
  border-radius: 0px;
  overflow: hidden;
}

.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 22px;
}

.section-head h3 {
  margin: 0;
  font-size: 28px;
  font-weight: 800;
  color: var(--blue);
}

.section-head a {
  color: var(--blue);
  font-weight: 700;
}

.tracks-slider {
  --tracks-arrow-space: 56px;
  position: relative;
  display: block;
  padding-left: var(--tracks-arrow-space);
  padding-right: var(--tracks-arrow-space);
}

.tracks-slider.is-at-start {
  padding-left: 0;
}

.tracks-slider.is-at-end {
  padding-right: 0;
}

.tracks-slider-viewport {
  min-width: 0;
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  overflow-y: clip;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.tracks-slider-viewport::-webkit-scrollbar {
  display: none;
}

.tracks-slider-arrow {
  position: absolute;
  top: 96px;
  transform: translateY(-50%);
  z-index: 5;
  width: 46px;
  height: 46px;
  border: 1px solid #d9dce6;
  border-radius: 999px;
  background: #fff;
  color: var(--blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease, border-color .18s ease;
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}

.tracks-slider-arrow-prev {
  left: 0;
}

.tracks-slider-arrow-next {
  right: 0;
}

.tracks-slider-arrow[hidden] {
  display: none !important;
}

.tracks-slider-arrow:hover:not(:disabled) {
  transform: translateY(-50%) scale(1.03);
  box-shadow: 0 12px 28px rgba(0,0,0,.10);
  border-color: #cfd5e3;
}

.tracks-slider-arrow:disabled {
  opacity: .45;
  cursor: default;
  box-shadow: none;
}

.tracks-row {
  display: flex;
  gap: 18px;
  width: max-content;
  min-width: 100%;
}

.track-card {
  flex: 0 0 228px;
  width: 228px;
  max-width: 228px;
  border: 1px solid #dcdcdc;
  background: var(--white);
  padding: 12px;
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.track-card:hover {
  transform: translateY(-3px);
  border-color: #d8d8d8;
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

.track-cover {
  position: relative;
  overflow: hidden;
  background: #efefef;
  margin-bottom: 14px;
  border: 1px solid #e3e3e3;
  border-radius: 22px;
}

.track-cover::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(var(--primary-rgb), 0.08);
  opacity: 0;
  transition: opacity .35s ease;
  pointer-events: none;
}

.track-cover img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  transition: transform .35s ease;
}

.track-card:hover .track-cover img {
  transform: scale(1.06);
}

.track-card:hover .track-cover::after,
.track-cover:hover::after,
.track-cover:focus-within::after {
  opacity: 1;
}

.track-platforms {
  position: absolute;
  left: 50%;
  right: auto;
  bottom: 14px;
  width: calc(100% - 24px);
  transform: translate(-50%, 10px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s ease, transform .22s ease;
  z-index: 3;
  max-width: calc(100% - 24px);
}

.track-platforms a {
  width: 24px;
  height: 24px;
  color: rgba(255, 255, 255, 0.84);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: .92;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.35));
  transition: transform .18s ease, opacity .18s ease, color .18s ease;
}

.track-platforms a:hover {
  transform: translateY(-1px);
  opacity: 1;
  color: rgba(255, 255, 255, 0.98);
}

.track-platforms svg {
  width: 20px;
  height: 20px;
  display: block;
  fill: currentColor;
  stroke: currentColor;
  flex: 0 0 auto;
}

.track-cover:hover .track-platforms a,
.track-cover:focus-within .track-platforms a,
.track-card:hover .track-platforms a,
.track-card:focus-within .track-platforms a {
  pointer-events: auto;
}

.track-card:hover .track-platforms,
.track-card:focus-within .track-platforms,
.track-cover:hover .track-platforms,
.track-cover:focus-within .track-platforms {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}

.track-card:hover .track-time,
.track-card:focus-within .track-time,
.track-cover:hover .track-time,
.track-cover:focus-within .track-time {
  opacity: 0;
  transform: translateY(-4px);
}

.track-time {
  transition: opacity .2s ease, transform .2s ease;
}

@media (hover: none) {
  .track-platforms {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, 0);
    bottom: 14px;
  }

  .track-time {
    display: none;
  }
}

.track-time {
  position: absolute;
  top: 10px;
  right: 10px;
  background: var(--blue);
  color: var(--white);
  font-size: 12px;
  font-weight: 700;
  padding: 6px 10px;
  border-radius: 999px;
  line-height: 1;
  box-shadow: 0 8px 16px rgba(0,0,0,.14);
}


.track-text strong,
.track-text span {
  display: block;
  margin-top: 2px;
  font-size: 14px;
  line-height: 1.2;
  color: #6b7280;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.track-text strong {
  display: block;
  font-size: 15px;
  line-height: 1.15;
  font-weight: 800;
  color: #1d2433;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.track-text span {
  color: var(--muted);
  font-size: 14px;
  max-width: 100%;
}

.site-main {
  background: var(--white);
  padding: 48px 0 0;
}

.content-section {
  padding: 0 0 72px;
}

.section-head-dark h3 { color: var(--blue); }

.news-layout {
  display: grid;
  grid-template-columns: 1.5fr .95fr;
  gap: 24px;
}

.news-featured,
.news-card {
  background: var(--white);
  border: 0px;
}

.news-media,
.news-card-media {
  overflow: hidden;
  position: relative;
}

.news-media img,
.news-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}

.news-featured:hover .news-media img,
.news-card:hover .news-card-media img {
  transform: scale(1.06);
}

.news-media {
  min-height: 345px;
}

.news-tags {
  position: absolute;
  top: 18px;
  left: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.news-tag,
.article-cat {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  background: var(--blue);
  color: var(--white);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
}

.news-content,
.news-card-content {
  padding: 22px;
}

.news-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}

.news-meta {
  color: var(--muted);
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 12px;
}

.news-meta i { margin-right: 8px; }

.news-content h3,
.news-card-content h4 {
  margin: 0;
  line-height: 1.2;
}

.news-content h3 {
  font-size: 34px;
  margin-bottom: 14px;
}

.news-content p {
  margin: 0 0 18px;
  color: #4f4f4f;
  line-height: 1.65;
}

.news-link {
  color: var(--blue);
  font-weight: 800;
}

.news-list {
  display: grid;
  gap: 18px;
}

.news-card {
  display: grid;
  grid-template-columns: 170px 1fr;
}

.news-card-media { min-height: 100%; }
.news-card-content h4 { font-size: 21px; }

.site-footer {
  background: var(--black);
  color: var(--white);
  padding: 30px 0;
}

.footer-inner-centered {
  text-align: center;
}

.footer-inner p {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
}

@media (max-width: 1150px) {
  .main-nav { gap: 20px; font-size: 14px; }
  .track-card { flex: 0 0 220px; width: 220px; max-width: 220px; }
  .news-layout { grid-template-columns: 1fr; }
}

@media (max-width: 860px) {
  .header-inner {
    flex-wrap: wrap;
    justify-content: center;
    padding: 16px 0;
  }

  .main-nav {
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
  }

  .hero-content {
    padding: 44px 0 155px;
  }

  .hero-main {
    flex-direction: column;
    align-items: flex-start;
  }

  .cover-wrap {
    width: 156px;
    height: 156px;
  }

  .news-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .container {
    width: min(100% - 28px, 1280px);
  }

  .dedication-inner {
    gap: 16px;
  }

  .dedication-title {
    font-size: 14px;
  }

  .section-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .tracks-slider {
    padding: 0;
  }

  .tracks-slider-arrow {
    display: none;
  }

  .track-card {
    flex: 0 0 84%;
    width: 84%;
    max-width: 84%;
  }

  .hero-text h1 { font-size: 32px; }
  .hero-text h2 { font-size: 36px; }
  .news-content h3 { font-size: 28px; }
}


/* Admin */
.admin-body,
.admin-auth-body {
  background: #f3f5fb;
}

.admin-shell {
  min-height: 100vh;
}

.admin-sidebar {
  background: #0d1322;
  color: #fff;
  padding: 28px 20px;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 280px;
  overflow: hidden;
}

.admin-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 34px;
}

.admin-brand-logo {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: var(--blue);
  color: #fff;
  font-size: 18px;
}

.admin-brand strong { display: block; font-size: 18px; }
.admin-brand small { color: rgba(255,255,255,.65); }

.admin-nav { display: flex; flex-direction: column; gap: 8px; flex: 1; min-height: 0; }
.admin-nav-main { display: flex; flex-direction: column; gap: 8px; flex: 1; min-height: 0; }
.admin-nav-group-bottom { margin-top: auto; display: flex; flex-direction: column-reverse; gap: 8px; }
.admin-nav-group-bottom .admin-nav-submenu { padding-left: 12px; padding-bottom: 12px; }
.admin-nav-group-bottom.is-open .admin-nav-group-trigger > i { transform: rotate(0deg); }
.admin-nav a,
.admin-nav-group-trigger {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 16px;
  color: rgba(255,255,255,.88);
  font-weight: 600;
}
.admin-nav a:hover,
.admin-nav a.is-active,
.admin-nav-group-trigger:hover,
.admin-nav-group.is-open > .admin-nav-group-trigger { background: rgba(255,255,255,.08); color: #fff; }
.admin-nav-group { display: grid; gap: 8px; }
.admin-nav-group-trigger { width: 100%; background: transparent; border: 0; text-align: left; }
.admin-nav-group-trigger span { display: inline-flex; align-items: center; gap: 12px; }
.admin-nav-group-trigger .fa-chevron-down { margin-left: auto; font-size: 12px; transition: transform .2s ease; }
.admin-nav-group.is-open > .admin-nav-group-trigger .fa-chevron-down { transform: rotate(180deg); }
.admin-nav-submenu { display: none; padding-left: 14px; }
.admin-nav-group.is-open .admin-nav-submenu { display: grid; gap: 8px; }
.admin-nav-submenu a { border-left: 1px solid rgba(255,255,255,.16); padding-left: 16px; border-radius: 0 16px 16px 0; }

.admin-main {
  min-width: 0;
  margin-left: 280px;
}

.admin-topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid #e8ebf3;
  padding: 20px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.admin-topbar-role {
  border: 1px solid rgba(var(--primary-rgb), .18);
  color: var(--blue);
  background: rgba(var(--primary-rgb), .08);
  padding: 10px 14px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 13px;
}

.admin-content { padding: 28px; }
.admin-page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
}
.admin-page-head h1 { margin: 6px 0 8px; font-size: 34px; }
.admin-page-head p { margin: 0; color: #6d7587; }
.eyebrow { color: var(--blue); font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }

.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 22px;
}
.stat-card, .panel-card {
  background: #fff;
  border: 1px solid #e7eaf2;
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, .05);
}
.stat-card span { display: block; color: #7a8396; font-weight: 600; margin-bottom: 12px; }
.stat-card strong { display: block; font-size: 40px; line-height: 1; margin-bottom: 8px; }
.stat-card small { color: #8c95a5; font-weight: 600; }
.panel-card-accent { background: linear-gradient(180deg, rgba(var(--primary-rgb), .08), #fff); }
.panel-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 18px; }
.panel-card h2 { margin: 0; font-size: 24px; }
.mini-note { color: #8c95a5; font-size: 13px; font-weight: 700; }

.admin-grid-2 { display: grid; grid-template-columns: 1.3fr 1fr; gap: 18px; }
.admin-grid-top { margin-bottom: 18px; }
.feature-list { display: grid; gap: 14px; color: #334155; font-weight: 600; }
.feature-list div { display: flex; align-items: center; gap: 12px; }
.feature-list i { color: var(--blue); }
.quick-actions { display: grid; gap: 12px; }
.quick-action { display: flex; align-items: center; gap: 12px; border: 1px solid #e6eaf2; border-radius: 18px; padding: 16px 18px; font-weight: 700; }
.quick-action i { color: var(--blue); }
.steps-list { display: grid; gap: 12px; color: #334155; font-weight: 600; }
.steps-list div { display: flex; align-items: center; gap: 12px; }
.steps-list span { width: 28px; height: 28px; border-radius: 50%; background: var(--blue); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; }

.admin-form, .admin-form-stack { display: grid; gap: 14px; }
.admin-form label, .admin-form-stack label { font-size: 14px; font-weight: 700; color: #23304a; display: block; margin-bottom: 8px; }
.admin-form input, .admin-form textarea, .admin-form select, .admin-form-stack input, .admin-form-stack textarea, .admin-form-stack select {
  width: 100%;
  border: 1px solid #dfe5f0;
  border-radius: 16px;
  background: #fff;
  padding: 14px 16px;
  font: inherit;
  color: #111827;
}
.admin-form textarea, .admin-form-stack textarea { resize: vertical; min-height: 120px; }
.admin-form input:focus, .admin-form textarea:focus, .admin-form select:focus, .admin-form-stack input:focus, .admin-form-stack textarea:focus, .admin-form-stack select:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 4px rgba(var(--primary-rgb), .12); }
.form-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.form-grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; align-items: end; }
.checkbox-wrap, .checkbox-wrap-top { display: flex; align-items: center; }
.checkbox-line { display: inline-flex !important; align-items: center; gap: 10px; margin: 0; }
.checkbox-line input { width: 18px; height: 18px; }

.btn-primary, .btn-secondary, .btn-small {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 16px;
  padding: 13px 18px;
  font-weight: 800;
  border: 0;
  cursor: pointer;
  font-family: inherit;
}
.btn-primary { background: var(--blue); color: #fff; }
.btn-secondary { background: #fff; color: #111827; border: 1px solid #dce3ef; }
.btn-full { width: 100%; }
.btn-large { padding-inline: 28px; }
.btn-small { padding: 10px 14px; border-radius: 12px; background: #eef3ff; color: var(--blue); }
.btn-small-danger { background: #fff1f2; color: #e11d48; }

.alert-success, .alert-error { border-radius: 18px; padding: 15px 18px; margin-bottom: 16px; font-weight: 700; }
.alert-success { background: #edfdf3; color: #166534; border: 1px solid #bbf7d0; }
.alert-error { background: #fff1f2; color: #be123c; border: 1px solid #fecdd3; }

.table-wrap { overflow: auto; }
.admin-table, .table-wrap table { width: 100%; border-collapse: collapse; }
.admin-table th, .admin-table td, .table-wrap th, .table-wrap td { text-align: left; padding: 16px 12px; border-bottom: 1px solid #edf1f7; vertical-align: middle; }
.admin-table th, .table-wrap th { color: #617089; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; }
.table-sub { color: #8b96aa; font-size: 13px; margin-top: 4px; }
.table-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.table-actions form { margin: 0; }
.color-dot { width: 14px; height: 14px; border-radius: 50%; display: inline-block; vertical-align: middle; margin-right: 8px; border: 1px solid rgba(0,0,0,.08); }
.status-pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 8px 12px; font-size: 12px; font-weight: 800; }
.status-pill.is-on { background: #ecfdf5; color: #15803d; }
.status-pill.is-off { background: #fff7ed; color: #c2410c; }
.form-actions-sticky { position: sticky; bottom: 20px; display: flex; justify-content: flex-end; }

.admin-auth-page { min-height: 100vh; display: grid; place-items: center; padding: 24px; background: radial-gradient(circle at top, rgba(var(--primary-rgb), .18), transparent 35%), #f3f5fb; }
.admin-auth-card { width: min(460px, 100%); background: #fff; border: 1px solid #e6eaf2; border-radius: 28px; padding: 28px; box-shadow: 0 22px 55px rgba(15, 23, 42, .08); }
.admin-auth-card h1 { margin: 0 0 10px; font-size: 30px; }
.admin-auth-card p { margin: 0 0 20px; color: #6d7587; }
.admin-help { margin-top: 14px; color: #7b8497; font-size: 13px; }

@media (max-width: 1080px) {
  .admin-shell { display: block; }
  .admin-sidebar { position: static; width: auto; min-height: auto; overflow: visible; }
  .admin-main { margin-left: 0; }
  .stats-grid, .admin-grid-2, .form-grid-2, .form-grid-3 { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .admin-content, .admin-topbar { padding: 18px; }
  .admin-page-head { flex-direction: column; }
}


.logo-placeholder.has-logo{border:0;background:transparent}
.logo-placeholder.has-logo img{display:block;max-width:100%;max-height:100%;object-fit:contain}


.logo-placeholder.has-logo img { max-height: 64px; width: auto; }
.main-nav a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 18px;
  border-radius: 999px;
  transition: background-color .22s ease, color .22s ease, transform .22s ease;
}
.main-nav a:hover {
  background: rgba(255,255,255,.10);
  transform: translateY(-1px);
}
.header-actions { gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
.header-actions a {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  background: rgba(var(--primary-rgb), .22);
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .22s ease, background-color .22s ease, border-color .22s ease;
}
.header-actions a:hover {
  transform: translateY(-2px);
  background: rgba(var(--primary-rgb), .45);
  border-color: rgba(255,255,255,.25);
}
.hero { overflow: hidden; isolation: isolate; }
.hero-bg-blur {
  position: absolute;
  inset: -34px;
  background-position: center;
  background-size: cover;
  filter: blur(24px) saturate(1.05);
  transform: scale(1.10);
  opacity: .9;
  transition: background-image .55s ease, opacity .55s ease, transform .55s ease;
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(3, 7, 18, .50), rgba(3, 7, 18, .68));
  backdrop-filter: saturate(110%);
}
.cover-wrap {
  border: 0;
  border-radius: 24px;
  box-shadow: 0 24px 60px rgba(0,0,0,.34);
  transition: transform .45s ease, opacity .45s ease, filter .45s ease;
}
#heroCover.is-updating,
.hero-text h1.is-updating,
.hero-text h2.is-updating,
#heroBgBlur.is-updating {
  opacity: .55;
  transform: translateY(6px) scale(.985);
  filter: blur(2px);
}
.live-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(8px);
}
.hero-meta { margin-top: 18px; }
.hero-meta span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.12);
}
.section-head a,
.news-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  border-radius: 999px;
  background: rgba(var(--primary-rgb), .10);
  transition: transform .22s ease, background-color .22s ease;
}
.section-head a:hover,
.news-link:hover {
  transform: translateY(-2px);
  background: rgba(var(--primary-rgb), .16);
}
@media (max-width: 980px) {
  .header-inner { flex-wrap: wrap; padding: 12px 0; }
  .main-nav { order: 3; width: 100%; gap: 12px; overflow-x: auto; padding-bottom: 2px; }
  .main-nav a { padding: 10px 14px; }
}


.cover-wrap {
  position: relative;
}
.cover-play-toggle {
  position: absolute;
  right: 14px;
  bottom: 14px;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(5,5,5,.46);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  cursor: pointer;
  box-shadow: 0 18px 35px rgba(5,5,5,.22);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform .22s ease, background .22s ease, border-color .22s ease;
}
.cover-play-toggle:hover {
  transform: translateY(-1px) scale(1.02);
  background: rgba(var(--primary-rgb), .94);
  border-color: rgba(255,255,255,.3);
}
.cover-play-toggle.is-playing {
  background: rgba(var(--primary-rgb), .96);
}

.site-player-bar {
  position: fixed;
  left: 50%;
  bottom: 16px;
  width: min(1360px, calc(100% - 48px));
  z-index: 90;
  opacity: 0;
  transform: translateX(-50%) translateY(18px);
  pointer-events: none;
  transition: opacity .28s ease, transform .28s ease;
}
.site-player-bar.is-active {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.player-bar-inner {
  min-height: 86px;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(var(--primary-rgb), .96), rgba(var(--primary-rgb), .82));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  padding: 14px 20px;
  box-shadow: 0 22px 50px rgba(15, 23, 42, .28);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.player-track-info {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}
.player-cover {
  width: 58px;
  height: 58px;
  border-radius: 16px;
  overflow: hidden;
  flex: 0 0 auto;
  background: rgba(255,255,255,.16);
}
.player-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.player-text {
  min-width: 0;
  display: grid;
  gap: 5px;
}
.player-text strong,
.player-text span {
  display: block;
  max-width: min(44vw, 520px);
  white-space: normal;
  overflow: hidden;
  text-overflow: ellipsis;
}
.player-text strong {
  font-size: 18px;
  line-height: 1.1;
}
.player-text span {
  color: rgba(255,255,255,.82);
  font-weight: 600;
}
.player-controls {
  display: flex;
  align-items: center;
  gap: 18px;
  flex: 0 0 auto;
}
.player-control-btn {
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,.18);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 18px;
  transition: transform .2s ease, background .2s ease;
}
.player-control-btn:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,.26);
}
.player-volume-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 4px;
}
.player-volume-wrap input[type="range"] {
  width: 160px;
  accent-color: #fff;
}

@media (max-width: 900px) {
  .site-player-bar {
    bottom: 10px;
  }
  .player-bar-inner {
    min-height: auto;
    flex-wrap: wrap;
    justify-content: center;
    padding: 14px 16px;
  }
  .player-track-info,
  .player-controls {
    width: 100%;
    justify-content: center;
  }
  .player-text {
    text-align: center;
  }
  .player-text strong,
  .player-text span {
    max-width: 76vw;
  }
}

body.has-player-bar {
  padding-bottom: 116px;
}


.cover-wrap { position: relative; }
.cover-play-toggle {
  position: absolute; inset: 50% auto auto 50%; transform: translate(-50%, -50%);
  width: 68px; height: 68px; border-radius: 999px; border: 0;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.46); color: #fff; z-index: 4; cursor: pointer;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 12px 28px rgba(0,0,0,.25); transition: transform .2s ease, background .2s ease, opacity .2s ease;
}
.cover-play-toggle:hover { transform: translate(-50%, -50%) scale(1.05); background: rgba(var(--primary-rgb), .92); }
.cover-play-toggle i { font-size: 24px; margin-left: 3px; }
.cover-play-toggle.is-playing i { margin-left: 0; }

.site-player-bar {
  position: fixed;
  left: 50%;
  bottom: 16px;
  width: min(1360px, calc(100% - 48px));
  z-index: 90;
  opacity: 0;
  transform: translateX(-50%) translateY(18px);
  pointer-events: none;
  transition: opacity .28s ease, transform .28s ease;
}
.site-player-bar.is-active { transform: translateY(0); opacity: 1; pointer-events: auto; }
.site-player-inner {
  width: 100%;
  margin: 0;
  min-height: 76px;
  border-radius: 20px;
  background: rgb(var(--primary-rgb));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 14px 18px;
  box-shadow: 0 18px 50px rgba(0,0,0,.24);
}
.site-player-track { display:flex; align-items:center; gap:14px; min-width:0; flex:1 1 auto; }
.site-player-cover-wrap { width:48px; height:48px; border-radius:12px; overflow:hidden; background:rgba(255,255,255,.18); flex:0 0 auto; }
.site-player-cover-wrap img { width:100%; height:100%; object-fit:cover; }
.site-player-meta { min-width:0; display:grid; gap:3px; }
.site-player-meta strong, .site-player-meta span { white-space: normal; overflow:hidden; text-overflow:ellipsis; }
.site-player-meta strong { font-size:16px; }
.site-player-meta span { color:rgba(255,255,255,.86); font-size:14px; }
.site-player-controls { display:flex; align-items:center; gap:18px; flex:0 0 auto; }
.site-player-toggle { width:48px; height:48px; border-radius:999px; border:0; background:#fff; color:rgb(var(--primary-rgb)); cursor:pointer; display:inline-flex; align-items:center; justify-content:center; font-size:18px; box-shadow:0 6px 16px rgba(0,0,0,.14); }
.site-player-volume { display:flex; align-items:center; gap:10px; }
.site-player-volume input[type=range] { width:150px; accent-color:#fff; cursor:pointer; }
body.has-player-bar { padding-bottom: 108px; }
@media (max-width: 860px) {
  .site-player-bar { width: calc(100% - 20px); bottom: 10px; }
  .site-player-inner { width: 100%; margin-bottom: 0; border-radius: 16px; padding: 12px 14px; gap: 14px; }
  .site-player-volume input[type=range] { width: 96px; }
  .cover-play-toggle { width: 58px; height: 58px; }
}


.cover-play-toggle {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: 72px;
  height: 72px;
  border: 0;
  border-radius: 999px;
  background: rgba(var(--primary-rgb), .96);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  cursor: pointer;
  box-shadow: 0 14px 28px rgba(0,0,0,.28);
  transition: transform .22s ease, background .22s ease, box-shadow .22s ease;
  z-index: 3;
}
.cover-play-toggle:hover {
  transform: translate(-50%, -50%) scale(1.05);
  box-shadow: 0 18px 34px rgba(0,0,0,.32);
}
.cover-play-toggle i { margin-left: 4px; }
.cover-play-toggle.is-playing i { margin-left: 0; }

.site-player-bar {
  position: fixed;
  left: 50%;
  bottom: 16px;
  width: min(1360px, calc(100% - 48px));
  z-index: 90;
  opacity: 0;
  transform: translateX(-50%) translateY(18px);
  pointer-events: none;
  transition: opacity .28s ease, transform .28s ease;
}
.site-player-bar.is-active {
  transform: translate(-50%, 0);
  opacity: 1;
  pointer-events: auto;
}
.site-player-inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: 88px;
  padding: 14px 18px;
  border-radius: 0px;
  overflow: hidden;
  border: 2px solid rgba(var(--primary-rgb), .92);
  background: rgba(10, 12, 18, .72);
  box-shadow: 0 18px 40px rgba(0,0,0,.24);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.site-player-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  
  background-size: cover;
  background-position: center;
  transform: scale(1.12);
  filter: blur(24px);
  opacity: .52;
}
.site-player-inner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(7,8,12,.74) 0%, rgba(7,8,12,.55) 45%, rgba(7,8,12,.7) 100%);
}
.site-player-track,
.site-player-controls {
  position: relative;
  z-index: 1;
}
.site-player-track {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
  flex: 1 1 auto;
}
.site-player-cover-wrap {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  overflow: hidden;
  background: rgba(255,255,255,.14);
  box-shadow: 0 10px 20px rgba(0,0,0,.2);
  flex: 0 0 auto;
}
.site-player-cover-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.site-player-meta {
  min-width: 0;
  display: grid;
  gap: 1px;
}
.site-player-meta strong,
.site-player-meta span {
  display: block;
  white-space: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: min(56vw, 580px);
}
.site-player-meta strong {
  color: #fff;
  font-size: 18px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .02em;
  line-height: 1.05;
}
.site-player-meta span {
  color: rgba(255,255,255,.88);
  font-size: 14px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1.05;
}
.site-player-controls {
  display: flex;
  align-items: center;
  gap: 18px;
  flex: 0 0 auto;
}
.site-player-toggle {
  width: 52px;
  height: 52px;
  border-radius: 999px;
  border: 0;
  background: #fff;
  color: rgb(var(--primary-rgb));
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  box-shadow: 0 8px 20px rgba(0,0,0,.2);
}
.site-player-volume {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #fff;
}
.site-player-volume input[type=range] {
  width: 148px;
  accent-color: #fff;
  cursor: pointer;
}
body.has-player-bar {
  padding-bottom: 118px;
}

@media (max-width: 768px) {
  body.has-player-bar {
    padding-bottom: 104px;
  }
  .site-player-bar {
    width: calc(100% - 16px);
    bottom: 8px;
  }
  .site-player-inner {
    min-height: 78px;
    padding: 12px 14px;
    border-radius: 20px;
    gap: 14px;
  }
  .site-player-cover-wrap {
    width: 46px;
    height: 46px;
    border-radius: 12px;
  }
  .site-player-meta strong,
  .site-player-meta span {
    max-width: 42vw;
  }
  .site-player-meta strong {
    font-size: 15px;
  }
  .site-player-meta span {
    font-size: 12px;
  }
  .site-player-volume input[type=range] {
    width: 86px;
  }
  .cover-play-toggle {
    width: 58px;
    height: 58px;
  }
}

/* FIX PLAYBAR */
.player-bar {
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
    border-radius: 16px;
}

/* FINAL PLAYER FIX */
.player-bar{
    width:100%;
    max-width:1200px;
    margin:20px auto;
    background:var(--primary);
    border-radius:14px;
}

/* HERO COVER FIX */
.hero-cover img{
    border-radius:20px;
    box-shadow:0 10px 30px rgba(0,0,0,0.4);
    border:3px solid rgba(255,255,255,0.15);
}


/* PLAYBAR solid dominant color fix */
.site-player-bar {
  left: 50% !important;
  right: auto !important;
  width: min(1360px, calc(100% - 48px)) !important;
  max-width: none !important;
  bottom: 18px !important;
  transform: translate(-50%, 120%) !important;
}
.site-player-bar.is-active {
  transform: translate(-50%, 0) !important;
}
.site-player-inner {
  width: 100% !important;
  margin: 0 !important;
  background: rgb(var(--primary-rgb)) !important;
  background-image: none !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.site-player-inner::before,
.site-player-inner::after {
  display: none !important;
  content: none !important;
  background: none !important;
  background-image: none !important;
}
@media (max-width: 860px) {
  .site-player-bar {
    width: calc(100% - 20px) !important;
    bottom: 10px !important;
  }
}



/* Live badge + programme live refinements */
.hero-pill,
.hero-badge-live,
.badge-live {
  padding: 8px 14px !important;
  gap: 8px !important;
  font-size: 13px !important;
  line-height: 1 !important;
}
.hero-pill i,
.hero-badge-live i,
.badge-live i {
  font-size: 11px !important;
}

.hero-live-text {
  display: inline-flex;
  align-items: center;
  margin-top: 14px;
  font-size: 15px;
  font-weight: 700;
  color: rgba(255,255,255,.9);
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
}

.hero-meta .hero-live-text,
.hero-content .hero-live-text,
.hero__content .hero-live-text {
  display: inline-flex;
}

.hero-live-text::before {
  content: "\f130";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 13px;
  margin-right: 9px;
  opacity: .95;
}



/* Hero live badge smaller + Programme live not in badge */
.live-badge{
  gap: 6px !important;
  font-size: 11px !important;
  padding: 7px 12px !important;
  margin-bottom: 12px !important;
  border-radius: 999px !important;
}
.live-badge i{
  font-size: 10px !important;
}

.hero-meta{
  margin-top: 18px !important;
  gap: 0 !important;
}

.hero-meta span{
  display: inline !important;
  align-items: initial !important;
  gap: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
}

.hero-program-live{
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: rgba(255,255,255,.92) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,.24) !important;
}

.hero-program-live i{
  font-size: 13px !important;
  opacity: .92 !important;
}


/* REMOVE COVER BORDER */
.card img,
.track-card img,
.last-tracks img,
.cover img,
.track img {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}



/* REMOVE CARD BORDER AROUND COVER */
.track-card,
.last-tracks .item,
.card {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

.track-card .content,
.last-tracks .content {
    padding-top: 10px;
}



/* LAST TRACKS BLOCK ROUNDED */
.last-tracks,
.last-tracks-container,
.section-last-tracks {
    border-radius: 20px !important;
    overflow: hidden !important;
}

/* OPTIONAL nicer container look */
.last-tracks {
    padding: 20px !important;
}



.dedication-add-btn {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.12);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
  z-index: 3;
}
.dedication-add-btn:hover { transform: translateY(calc(-50% - 1px)); background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.3); }
.dedication-track.no-scroll { animation: none; }

.dedication-modal {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: none;
}
.dedication-modal.is-visible { display: block; }
.dedication-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5,7,12,.62);
  backdrop-filter: blur(8px);
}
.dedication-modal-dialog {
  position: relative;
  width: min(560px, calc(100% - 24px));
  margin: 8vh auto 0;
  background: #0f1320;
  color: #fff;
  border-radius: 24px;
  padding: 28px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 24px 80px rgba(0,0,0,.35);
}
.dedication-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: #fff;
  cursor: pointer;
}
.dedication-modal h3 { margin: 0 0 8px; font-size: 26px; }
.dedication-modal-intro { margin: 0 0 18px; color: rgba(255,255,255,.72); }
.dedication-form-group { display: grid; gap: 8px; margin-bottom: 14px; }
.dedication-form-group input,
.dedication-form-group textarea {
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: #fff;
  padding: 14px 16px;
  outline: none;
}
body.has-modal { overflow: hidden; }


.dedication-submit-wrap {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}

.dedication-submit-btn {
  min-width: 250px;
  padding: 16px 30px;
  border-radius: 999px;
  font-size: 18px;
  font-weight: 700;
  text-align: center;
}

.dedication-toast-success[hidden] {
  display: none !important;
}

.track-card-live .track-time-live {
  background: #ef4444;
  min-width: 42px;
  width: 42px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.tracks-row.is-sliding .track-card {
  opacity: .35;
  transform: translateX(-28px);
  transition: transform .22s ease, opacity .22s ease;
}


.track-live-wave {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  height: 12px;
  width: 100%;
}

.track-live-wave span {
  width: 3px;
  background: #fff;
  border-radius: 999px;
  display: block;
  animation: trackWave 1s ease-in-out infinite;
}

.track-live-wave span:nth-child(1) { height: 7px; animation-delay: 0s; }
.track-live-wave span:nth-child(2) { height: 12px; animation-delay: .15s; }
.track-live-wave span:nth-child(3) { height: 8px; animation-delay: .3s; }

@keyframes trackWave {
  0%, 100% { transform: scaleY(.55); opacity: .75; }
  50% { transform: scaleY(1); opacity: 1; }
}


.track-text {
  min-width: 0;
}


/* Force flat latest-tracks block */
.latest-tracks-section,
.latest-tracks-wrap,
.latest-tracks-shell,
.latest-tracks-card,
.latest-tracks-box,
.section-latest-tracks,
#latestTracksSection,
#latestTracks,
#lastTracks {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

.latest-tracks-section,
.latest-tracks-wrap,
.latest-tracks-shell,
.section-latest-tracks,
#latestTracksSection,
#latestTracks,
#lastTracks {
  padding: 0 !important;
  margin-top: -28px !important;
}

.latest-tracks-card,
.latest-tracks-box {
  padding: 0 !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

.latest-tracks-head,
.latest-tracks-header {
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-bottom: 18px !important;
}

.latest-tracks-row,
#latestTracksRow {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Remove any generic panel styling only when wrapping latest tracks */
.latest-tracks-section.panel-card,
.latest-tracks-card.panel-card,
.section-latest-tracks.panel-card {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}


/* Derniers titres: remove any visible container chrome */
.latest-tracks-section,
.latest-tracks-wrapper,
.latest-tracks-wrap,
.latest-tracks-shell,
.latest-tracks-card,
.latest-tracks-box,
.section-latest-tracks,
#latestTracksSection,
#latestTracks,
#lastTracks {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
}

.latest-tracks-section,
.latest-tracks-wrapper,
.latest-tracks-wrap,
.latest-tracks-shell,
.section-latest-tracks,
#latestTracksSection,
#latestTracks,
#lastTracks {
  padding: 0 !important;
}

.latest-tracks-card,
.latest-tracks-box {
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.latest-tracks-section .section-head,
.latest-tracks-section .latest-tracks-head,
.latest-tracks-section .latest-tracks-header,
.latest-tracks-card .section-head,
.latest-tracks-card .latest-tracks-head,
.latest-tracks-card .latest-tracks-header {
  padding: 0 !important;
  margin-bottom: 18px !important;
}

.latest-tracks-section .track-card,
.latest-tracks-card .track-card {
  margin-top: 0 !important;
}

.latest-tracks-section .container,
.latest-tracks-card .container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.latest-tracks-section .panel-card,
.latest-tracks-card .panel-card,
.section-latest-tracks .panel-card {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}


/* REMOVE CARD STYLE FROM LAST TITLES LIKE NEWS BLOCK */
.latest-tracks-section,
.latest-tracks-card,
.latest-tracks-box,
.section-latest-tracks {
  background: transparent !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.latest-tracks-section .container,
.latest-tracks-card .container {
  padding: 0 !important;
}

.latest-tracks-header,
.latest-tracks-head {
  padding: 0 !important;
  margin-bottom: 16px !important;
}


/* Reduce hero height */
.hero,
.hero-section,
.hero-banner,
.now-playing-band {
  min-height: 420px !important;
  height: auto !important;
  padding-top: 60px !important;
  padding-bottom: 60px !important;
}


/* spacing between latest tracks and news */
.latest-tracks-section {
  margin-bottom: 40px !important;
}

.news-section,
.actualites-section {
  margin-top: 40px !important;
}


/* MORE compact hero */
.hero,
.hero-section,
.hero-banner,
.now-playing-band {
  min-height: 320px !important;
  padding-top: 40px !important;
  padding-bottom: 40px !important;
}

/* FINAL HERO TUNING */
.hero,
.hero-section,
.hero-banner {
  min-height: 260px !important;
  height: auto !important;
}

.hero-content {
  min-height: 260px !important;
  padding: 30px 0 96px !important;
  align-items: center !important;
}

.hero-main {
  gap: 22px !important;
}

.cover-wrap {
  width: 154px !important;
  height: 154px !important;
  border-radius: 18px !important;
}

.hero-text h1 {
  font-size: clamp(30px, 4vw, 52px) !important;
}

.hero-text h2 {
  font-size: clamp(34px, 4.5vw, 56px) !important;
}

.hero-meta {
  margin-top: 14px !important;
}

.live-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 6px 12px !important;
  margin-bottom: 10px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.16) !important;
  border: 1px solid rgba(255,255,255,.24) !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .14em !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.16) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

.live-badge i {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  font-size: 8px !important;
  margin: 0 !important;
  border-radius: 50% !important;
  background: #ff4d4f !important;
  color: #fff !important;
  box-shadow: 0 0 0 4px rgba(255,77,79,.14) !important;
}

@media (max-width: 900px) {
  .hero,
  .hero-section,
  .hero-banner {
    min-height: 220px !important;
  }

  .hero-content {
    min-height: 220px !important;
    padding: 24px 0 88px !important;
  }

  .cover-wrap {
    width: 126px !important;
    height: 126px !important;
  }
}

@media (max-width: 640px) {
  .hero-content {
    padding: 22px 0 82px !important;
  }

  .hero-main {
    gap: 16px !important;
  }

  .cover-wrap {
    width: 108px !important;
    height: 108px !important;
  }

  .live-badge {
    padding: 5px 10px !important;
    font-size: 9px !important;
    letter-spacing: .12em !important;
  }

  .live-badge i {
    width: 16px !important;
    height: 16px !important;
    font-size: 7px !important;
  }
}


/* Hero vertical centering + live badge redesign */
.hero,
.hero-section,
.hero-banner {
  min-height: 300px !important;
  display: flex !important;
  align-items: stretch !important;
}

.hero-content {
  width: 100%;
  min-height: 300px !important;
  padding: 18px 0 !important;
  display: flex !important;
  align-items: center !important;
}

.hero-main {
  width: 100%;
  min-height: 0 !important;
  align-items: center !important;
}

.hero-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.live-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: fit-content !important;
  padding: 0 0 0 6px !important;
  min-height: 34px !important;
  margin: 0 0 14px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.14) !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 8px 22px rgba(0,0,0,.14) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  overflow: hidden !important;
}

.live-badge i {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 22px !important;
  height: 22px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  background: rgba(255,77,79,.16) !important;
  color: #ff5a5f !important;
  box-shadow: inset 0 0 0 1px rgba(255,90,95,.26) !important;
  font-size: 0 !important;
}

.live-badge i::before {
  content: '';
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ff4d4f;
  box-shadow: 0 0 0 6px rgba(255,77,79,.14);
}

.live-badge::after {
  content: '';
  width: 1px;
  align-self: stretch;
  background: rgba(255,255,255,.12);
}

.live-badge {
  padding-right: 14px !important;
}

@media (max-width: 900px) {
  .hero,
  .hero-section,
  .hero-banner {
    min-height: 250px !important;
  }

  .hero-content {
    min-height: 250px !important;
    padding: 16px 0 !important;
  }
}

@media (max-width: 640px) {
  .hero,
  .hero-section,
  .hero-banner {
    min-height: 220px !important;
  }

  .hero-content {
    min-height: 220px !important;
    padding: 14px 0 !important;
  }

  .live-badge {
    min-height: 30px !important;
    gap: 8px !important;
    font-size: 10px !important;
    letter-spacing: .14em !important;
    padding-left: 5px !important;
    padding-right: 12px !important;
    margin-bottom: 12px !important;
  }

  .live-badge i {
    width: 20px !important;
    height: 20px !important;
  }

  .live-badge i::before {
    width: 7px;
    height: 7px;
  }
}


/* FINAL FIXES: hero container + live badge + dedication fill */
.hero,
.hero-section,
.hero-banner {
  min-height: 340px !important;
}

.hero-content.container {
  width: min(1360px, calc(100% - 48px)) !important;
  max-width: none !important;
  margin: 0 auto !important;
  min-height: 340px !important;
  padding: 18px 0 !important;
  display: flex !important;
  align-items: center !important;
}

.hero-main {
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
}

.hero-text {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.live-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  width: fit-content !important;
  min-height: 38px !important;
  margin: 0 0 16px !important;
  padding: 0 16px 0 10px !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,.10) 100%) !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  box-shadow: 0 10px 30px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.10) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

.live-badge i,
.live-badge::after {
  display: none !important;
}

.live-badge-dot {
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  background: #ff4d4f !important;
  box-shadow: 0 0 0 5px rgba(255,77,79,.14) !important;
  flex: 0 0 auto !important;
}

.dedication-inner {
  gap: 16px !important;
}

.dedication-feed {
  display: flex !important;
  align-items: center !important;
  overflow: hidden !important;
}

.dedication-track {
  animation-duration: 40s !important;
}

@media (max-width: 900px) {
  .hero,
  .hero-section,
  .hero-banner {
    min-height: 280px !important;
  }

  .hero-content.container {
    min-height: 280px !important;
  }
}

@media (max-width: 640px) {
  .hero,
  .hero-section,
  .hero-banner {
    min-height: 240px !important;
  }

  .hero-content.container {
    width: min(1360px, calc(100% - 32px)) !important;
    min-height: 240px !important;
  }

  .live-badge {
    min-height: 34px !important;
    padding: 0 14px 0 9px !important;
    font-size: 10px !important;
    letter-spacing: .14em !important;
  }

  .live-badge-dot {
    width: 9px !important;
    height: 9px !important;
  }
}


/* FINAL FIXES V2: smaller live badge + faster dedications */
.live-badge {
  gap: 8px !important;
  min-height: 32px !important;
  margin: 0 0 14px !important;
  padding: 0 12px 0 9px !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  background: rgba(19, 24, 34, .28) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .14em !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.14), inset 0 1px 0 rgba(255,255,255,.08) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
}

.live-badge-dot {
  width: 8px !important;
  height: 8px !important;
  background: #ff4d4f !important;
  box-shadow: 0 0 0 4px rgba(255,77,79,.12) !important;
}

.dedication-track {
  animation-duration: 24s !important;
}

@media (max-width: 640px) {
  .live-badge {
    min-height: 30px !important;
    padding: 0 11px 0 8px !important;
    font-size: 10px !important;
    letter-spacing: .12em !important;
  }

  .live-badge-dot {
    width: 7px !important;
    height: 7px !important;
  }

  .dedication-track {
    animation-duration: 16s !important;
  }
}


/* FINAL FIXES V3: cleaner live badge + faster dedications + larger hero cover */
.live-badge {
  gap: 0 !important;
  min-height: 28px !important;
  padding: 0 11px !important;
  margin-bottom: 10px !important;
  background: rgba(20, 24, 31, .22) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.12), inset 0 1px 0 rgba(255,255,255,.06) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .16em !important;
}
.live-badge-dot { display: none !important; }

.cover-wrap {
  width: 174px !important;
  height: 174px !important;
  border-radius: 20px !important;
}

.dedication-track {
  animation-duration: 16s !important;
}

@media (max-width: 900px) {
  .cover-wrap {
    width: 138px !important;
    height: 138px !important;
  }
}

@media (max-width: 640px) {
  .live-badge {
    min-height: 26px !important;
    padding: 0 10px !important;
    font-size: 9px !important;
    letter-spacing: .14em !important;
  }

  .cover-wrap {
    width: 116px !important;
    height: 116px !important;
  }

  .dedication-track {
    animation-duration: 14s !important;
  }
}

.now-playing-title{white-space:normal;word-break:break-word;}


/* MOBILE HEADER + HERO + DEDICATIONS FINAL */
.mobile-menu-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: var(--white);
  align-items: center;
  justify-content: center;
  padding: 0;
  cursor: pointer;
}
.mobile-menu-toggle i { font-size: 18px; }
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: none;
}
.mobile-menu.is-visible { display: block; }
.mobile-menu-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.mobile-menu-panel {
  position: absolute;
  inset: 0;
  background: #090b10;
  color: var(--white);
  padding: 92px 24px 28px;
  display: flex;
  flex-direction: column;
}
.mobile-menu-close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: var(--white);
}
.mobile-menu-nav {
  display: grid;
  gap: 10px;
}
.mobile-menu-nav a {
  min-height: 54px;
  padding: 0 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 17px;
  font-weight: 800;
}
.mobile-menu-socials {
  margin-top: auto;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding-top: 24px;
}
.mobile-menu-socials .social-btn {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
}
body.has-mobile-menu { overflow: hidden; }

.dedication-title-icon { display: none; }

@media (max-width: 860px) {
  .site-header .container.header-inner {
    min-height: 72px !important;
    display: grid !important;
    grid-template-columns: 42px 1fr 42px !important;
    align-items: center !important;
    gap: 12px !important;
    position: relative;
  }

  .mobile-menu-toggle { display: inline-flex; }

  .main-nav,
  .header-actions { display: none !important; }

  .logo-placeholder {
    grid-column: 2;
    justify-self: center;
    width: auto;
    max-width: min(180px, 52vw);
    height: 44px;
  }

  .logo-placeholder.has-logo img {
    max-height: 44px;
    margin: 0 auto;
  }

  .dedication-inner {
    min-height: 44px;
    gap: 10px;
  }

  .dedication-title {
    width: 26px;
    min-width: 26px;
    justify-content: center;
    display: inline-flex;
    align-items: center;
  }

  .dedication-title-text { display: none; }
  .dedication-title-icon { display: inline-flex; font-size: 15px; }

  .hero-content {
    min-height: 420px !important;
    padding: 28px 0 84px !important;
  }

  .hero-main {
    width: 100%;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 18px !important;
  }

  .cover-wrap {
    width: 150px !important;
    height: 150px !important;
    border-radius: 22px !important;
  }

  .hero-text {
    max-width: min(100%, 560px) !important;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .live-badge {
    align-self: center;
    margin: 0 auto 12px !important;
    font-size: 9px !important;
    min-height: 24px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
  }

  .hero-text h1,
  .hero-text h2 {
    text-align: center;
    max-width: 100%;
  }

  .hero-text h1 { font-size: clamp(24px, 7.2vw, 38px) !important; }
  .hero-text h2 { font-size: clamp(28px, 8.2vw, 42px) !important; }

  .hero-meta {
    width: 100%;
    margin-top: 14px !important;
    justify-content: center !important;
  }

  .hero-program-live { justify-content: center; }
}

@media (max-width: 640px) {
  .dedication-track { animation-duration: 10s !important; }
  .cover-wrap { width: 162px !important; height: 162px !important; }
  .hero-content { min-height: 400px !important; padding: 24px 0 72px !important; }
}


/* PATCH 2026-03-23: mobile logo + socials centering + faster dedications */
.logo-placeholder {
  line-height: 0;
}

.logo-placeholder-fallback {
  display: none;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .08em;
  color: var(--white);
  line-height: 1;
}

.logo-placeholder.has-fallback .logo-placeholder-fallback,
.logo-placeholder:not(.has-logo) .logo-placeholder-fallback {
  display: inline-block;
}

.logo-placeholder.has-logo .logo-placeholder-fallback {
  display: none;
}

.mobile-menu-socials {
  justify-content: center !important;
  align-items: center !important;
  width: 100%;
}

.mobile-menu-socials .social-btn {
  flex: 0 0 auto;
}

.dedication-track {
  animation-duration: 12s !important;
}

@media (max-width: 860px) {
  .logo-placeholder {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0;
    overflow: hidden;
    line-height: 0;
  }

  .logo-placeholder.has-logo img {
    display: block !important;
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 44px !important;
    object-fit: contain !important;
    margin: 0 auto !important;
  }

  .logo-placeholder-fallback {
    display: inline-block;
    width: 100%;
    text-align: center;
    line-height: 1;
    font-size: 13px;
  }

  .logo-placeholder.has-logo .logo-placeholder-fallback {
    display: none;
  }

  .mobile-menu-socials {
    justify-content: center !important;
  }

  .dedication-track {
    animation-duration: 9s !important;
  }
}

@media (max-width: 640px) {
  .dedication-track {
    animation-duration: 7s !important;
  }
}


/* PATCH 2026-03-23 B: stronger mobile logo visibility + menu tabs closer to desktop */
@media (max-width: 860px) {
  .site-header .container.header-inner {
    grid-template-columns: 42px minmax(0,1fr) 42px !important;
  }

  .logo-placeholder,
  .logo-placeholder.has-logo {
    width: min(210px, 60vw) !important;
    height: 48px !important;
    max-width: min(210px, 60vw) !important;
    overflow: visible !important;
  }

  .logo-placeholder.has-logo img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin: 0 auto !important;
  }

  .mobile-menu-panel {
    padding: 88px 22px 28px;
  }

  .mobile-menu-nav {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .mobile-menu-nav a {
    min-height: 48px;
    padding: 0 18px;
    border-radius: 999px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
    font-size: 15px;
    letter-spacing: .01em;
    transition: background .2s ease, border-color .2s ease, transform .2s ease;
  }

  .mobile-menu-nav a:hover,
  .mobile-menu-nav a:focus-visible {
    background: rgba(255,255,255,.10);
    border-color: rgba(255,255,255,.18);
    transform: translateY(-1px);
  }
}

@media (max-width: 640px) {
  .logo-placeholder,
  .logo-placeholder.has-logo {
    width: min(200px, 62vw) !important;
    height: 46px !important;
    max-width: min(200px, 62vw) !important;
  }

  .mobile-menu-nav a {
    min-height: 46px;
    font-size: 14px;
  }
}


/* PATCH 2026-03-23 C: centered logo inside mobile menu + desktop-like mobile tabs */
.mobile-menu-brand {
  display: none;
}

@media (max-width: 860px) {
  .mobile-menu-panel {
    padding: 84px 24px 30px !important;
    align-items: stretch;
  }

  .mobile-menu-brand {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    align-self: center;
    width: min(240px, 72vw) !important;
    max-width: min(240px, 72vw) !important;
    height: 58px !important;
    margin: 0 auto 26px !important;
    overflow: visible !important;
    line-height: 0;
  }

  .mobile-menu-brand.has-logo img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin: 0 auto !important;
  }

  .mobile-menu-brand .logo-placeholder-fallback {
    display: inline-block;
    width: 100%;
    text-align: center;
    font-size: 14px;
    line-height: 1.1;
  }

  .mobile-menu-brand.has-logo .logo-placeholder-fallback {
    display: none;
  }

  .mobile-menu-nav {
    display: flex !important;
    flex-direction: column;
    gap: 4px !important;
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
  }

  .mobile-menu-nav a {
    min-height: 0 !important;
    padding: 12px 6px !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
    box-shadow: none !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    transition: color .2s ease, transform .2s ease, border-color .2s ease !important;
  }

  .mobile-menu-nav a:hover,
  .mobile-menu-nav a:focus-visible {
    background: transparent !important;
    border-color: rgba(255,255,255,.22) !important;
    color: rgba(255,255,255,.82) !important;
    transform: none !important;
  }

  .mobile-menu-nav a span {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
  }

  .mobile-menu-socials {
    margin-top: 28px !important;
    justify-content: center !important;
    gap: 14px !important;
  }
}

@media (max-width: 640px) {
  .mobile-menu-brand {
    width: min(220px, 74vw) !important;
    max-width: min(220px, 74vw) !important;
    height: 54px !important;
    margin-bottom: 22px !important;
  }

  .mobile-menu-nav {
    gap: 2px !important;
  }

  .mobile-menu-nav a {
    padding: 11px 4px !important;
    font-size: 15px !important;
  }
}

/* PATCH 2026-03-23 D: sharper cover edges + mobile menu tabs closer to desktop */
.cover-wrap,
.hero-cover,
#heroCover,
.cover-wrap img {
  outline: none !important;
}

.cover-wrap {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  overflow: hidden !important;
  isolation: isolate;
}

.cover-wrap img,
#heroCover {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  border-radius: inherit !important;
  background: transparent !important;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

@media (max-width: 860px) {
  .mobile-menu-panel {
    padding: 84px 20px 30px !important;
  }

  .mobile-menu-brand {
    display: inline-flex !important;
    align-self: center !important;
    justify-content: center !important;
    align-items: center !important;
    width: min(240px, 74vw) !important;
    max-width: min(240px, 74vw) !important;
    height: 58px !important;
    margin: 0 auto 24px !important;
  }

  .mobile-menu-brand.has-logo img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  .mobile-menu-nav {
    gap: 10px !important;
    max-width: 460px !important;
  }

  .mobile-menu-nav a {
    min-height: 46px !important;
    padding: 0 16px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.06) !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    letter-spacing: .01em !important;
    transition: background .2s ease, border-color .2s ease, transform .2s ease !important;
  }

  .mobile-menu-nav a:hover,
  .mobile-menu-nav a:focus-visible {
    background: rgba(255,255,255,.10) !important;
    border-color: rgba(255,255,255,.20) !important;
    color: var(--white) !important;
    transform: translateY(-1px) !important;
  }

  .mobile-menu-nav a span {
    display: inline-flex !important;
    align-items: center !important;
  }
}

@media (max-width: 640px) {
  .mobile-menu-brand {
    width: min(220px, 76vw) !important;
    max-width: min(220px, 76vw) !important;
    height: 54px !important;
  }

  .mobile-menu-nav {
    gap: 8px !important;
  }

  .mobile-menu-nav a {
    min-height: 44px !important;
    font-size: 14px !important;
  }
}


/* 2026-03-23 player bar refinement */
.site-player-inner {
  border-radius: 24px !important;
  overflow: hidden !important;
}
.site-player-bar {
  border-radius: 24px !important;
}
.site-player-meta {
  gap: 4px !important;
}
.site-player-meta strong,
.site-player-meta span {
  font-size: 14px !important;
  line-height: 1.15 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}
.site-player-meta strong {
  font-weight: 800 !important;
}
.site-player-meta span {
  font-weight: 600 !important;
  color: rgba(255,255,255,.96) !important;
}
.site-player-volume {
  gap: 12px !important;
}
.site-player-mute {
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: none;
  transform: none;
  transition: background .18s ease, opacity .18s ease;
}
.site-player-mute:hover,
.site-player-mute:focus-visible,
.site-player-toggle:hover,
.site-player-toggle:focus-visible {
  transform: none !important;
}
.site-player-mute:hover,
.site-player-mute:focus-visible {
  background: rgba(255,255,255,.22);
}
.site-player-volume input[type=range] {
  -webkit-appearance: none;
  appearance: none;
  width: 150px;
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.3);
  outline: none;
  cursor: pointer;
}
.site-player-volume input[type=range]::-webkit-slider-runnable-track {
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.32);
}
.site-player-volume input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  margin-top: -5px;
  border-radius: 50%;
  border: 0;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.18);
}
.site-player-volume input[type=range]::-moz-range-track {
  height: 6px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.32);
}
.site-player-volume input[type=range]::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border: 0;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.18);
}
.site-player-volume input[type=range]:hover,
.site-player-volume input[type=range]:focus,
.site-player-volume input[type=range]:active {
  opacity: 1;
  filter: none;
}
@media (max-width: 860px) {
  .site-player-volume input[type=range] {
    width: 92px;
  }
}


/* 2026-03-23 title/artist order + larger player text */
.track-text {
  display: grid !important;
  gap: 4px !important;
}
.track-text strong,
.track-text span {
  margin-top: 0 !important;
  text-transform: uppercase !important;
}
.track-text strong {
  font-size: 16px !important;
  font-weight: 800 !important;
  color: #1d2433 !important;
}
.track-text span {
  font-size: 14px !important;
  font-weight: 500 !important;
  color: var(--muted) !important;
}
.site-player-meta {
  gap: 5px !important;
}
.site-player-meta strong,
.site-player-meta span {
  display: block !important;
  line-height: 1.12 !important;
  text-transform: uppercase !important;
}
.site-player-meta strong {
  font-size: 16px !important;
  font-weight: 800 !important;
  color: #fff !important;
}
.site-player-meta span {
  font-size: 16px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,.92) !important;
}
@media (max-width: 860px) {
  .site-player-meta strong,
  .site-player-meta span {
    font-size: 15px !important;
  }
}
@media (max-width: 640px) {
  .track-text strong {
    font-size: 15px !important;
  }
  .track-text span,
  .site-player-meta strong,
  .site-player-meta span {
    font-size: 14px !important;
  }
}

/* 2026-03-23 v13: bottom gradient on latest covers + single-line hero title/artist */
.track-cover::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 34%;
  background: linear-gradient(180deg, rgba(var(--primary-rgb), 0) 0%, rgba(var(--primary-rgb), .18) 38%, rgba(var(--primary-rgb), .55) 100%);
  opacity: 0;
  transition: opacity .24s ease;
  pointer-events: none;
  z-index: 1;
}

.track-card:hover .track-cover::before,
.track-card:focus-within .track-cover::before,
.track-cover:hover::before,
.track-cover:focus-within::before {
  opacity: 1;
}

.track-platforms {
  z-index: 4;
  bottom: 12px;
}

.track-platforms a {
  color: rgba(255,255,255,.74);
  opacity: 1;
  filter: drop-shadow(0 3px 10px rgba(0,0,0,.34));
}

.track-platforms a:hover {
  color: rgba(255,255,255,.98);
}

.hero-text {
  max-width: min(1100px, 78vw) !important;
}

.hero-text h1,
.hero-text h2 {
  display: block !important;
  max-width: 100% !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  line-height: 1.08 !important;
  padding-bottom: .08em !important;
}

.hero-text h1 {
  font-weight: 800 !important;
}

.hero-text h2 {
  font-weight: 400 !important;
}

@media (max-width: 860px) {
  .hero-text {
    max-width: min(96vw, 720px) !important;
  }

  .hero-text h1,
  .hero-text h2 {
    width: 100% !important;
  }
}


/* v14 latest titles + hero spacing */
.hero-text h1,
.hero-text h2 {
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  line-height: 0.92 !important;
  margin: 0 !important;
}
.hero-text h1 { margin-bottom: 2px !important; }
.hero-text h2 { margin-top: 0 !important; }
.hero-text { gap: 10px !important; }

.latest-titles-page { padding: 32px 0 140px; }
.latest-titles-hero { min-height: 360px; }
.latest-tracks-list-section .container { display:block; }
.latest-tracks-list {
  display: grid;
  gap: 14px;
}
.latest-track-line {
  display: grid;
  grid-template-columns: 74px minmax(0,1fr) auto auto;
  align-items: center;
  gap: 16px;
  padding: 12px 14px;
  border-radius: 24px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 48px rgba(13,19,34,.08);
}
.latest-track-line-cover { width: 74px; height: 74px; border-radius: 18px; overflow: hidden; }
.latest-track-line-cover img { width:100%; height:100%; object-fit:cover; display:block; }
.latest-track-line-meta { min-width:0; display:grid; gap:3px; }
.latest-track-line-meta strong,
.latest-track-line-meta span { display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; text-transform:uppercase; }
.latest-track-line-meta strong { font-size: 16px; font-weight: 800; color: var(--blue); }
.latest-track-line-meta span { font-size: 14px; font-weight: 500; color: rgba(13,19,34,.72); }
.latest-track-line-status {
  min-width: 54px;
  justify-self: center;
  font-size: 13px;
  font-weight: 800;
  color: rgba(13,19,34,.55);
  text-transform: uppercase;
}
.latest-track-line-platforms .track-platforms {
  position: static;
  transform: none;
  opacity: 1;
  pointer-events: auto;
  gap: 10px;
  padding: 0;
  background: transparent;
}
.latest-track-line-platforms .track-platforms a {
  width: 20px;
  height: 20px;
  color: rgba(13,19,34,.55);
}
.latest-track-line-platforms .track-platforms a:hover { color: rgb(var(--primary-rgb)); transform: translateY(-1px) scale(1.06); }
.latest-track-line.is-live { border: 1px solid rgba(var(--primary-rgb), .18); }
.latest-track-line.is-live .latest-track-line-status { color: var(--primary); }

@media (max-width: 780px) {
  .latest-track-line {
    grid-template-columns: 64px minmax(0,1fr);
    grid-template-areas: 'cover meta' 'cover status' 'cover platforms';
    align-items: start;
  }
  .latest-track-line-cover { grid-area: cover; width:64px; height:64px; }
  .latest-track-line-meta { grid-area: meta; }
  .latest-track-line-status { grid-area: status; justify-self:start; }
  .latest-track-line-platforms { grid-area: platforms; }
}


/* v15 fixes: stable Voir tout button, tighter hero spacing, latest titles page robustness */
.section-head a,
.news-link {
  white-space: nowrap !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.section-head a i,
.news-link i {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  transition: transform .22s ease !important;
}

.section-head a:hover,
.news-link:hover {
  transform: none !important;
}

.section-head a:hover i,
.news-link:hover i {
  transform: translateX(2px) !important;
}

.hero-text {
  gap: 4px !important;
}

.hero-text h1,
.hero-text h2 {
  line-height: 0.86 !important;
  padding-bottom: .1em !important;
}

.hero-text h1 {
  margin-bottom: -2px !important;
}

.hero-text h2 {
  margin-top: -2px !important;
}

.latest-tracks-card {
  display: block !important;
}

.latest-track-line {
  min-width: 0;
}

.latest-track-line-platforms {
  min-width: 0;
}

@media (max-width: 860px) {
  .latest-track-line {
    grid-template-columns: 64px minmax(0,1fr) auto;
    gap: 12px;
  }

  .latest-track-line-platforms {
    grid-column: 2 / span 2;
    justify-self: start;
    margin-top: -2px;
  }
}


/* v17 latest titles page */
.page-title-band {
  width: 100%;
  background: var(--black);
  padding: 40px 0;
  margin: 0;
}
.page-title-band .container {
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-title-band h1 {
  margin: 0;
  color: #fff;
  text-align: center;
  font-size: clamp(30px, 4.6vw, 46px);
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.latest-titles-page--list-only {
  padding: 34px 0 140px;
}
.latest-tracks-page-shell {
  background: rgba(255,255,255,.96);
  border-radius: 28px;
  padding: 24px;
  box-shadow: 0 20px 56px rgba(13,19,34,.08);
}
.latest-page-head {
  margin-bottom: 16px;
}
.latest-page-head h2 {
  margin: 0;
}
.latest-track-badge {
  min-width: 56px;
  height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgb(var(--primary-rgb));
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.latest-track-badge-live {
  background: rgb(var(--primary-rgb));
}
.latest-track-line-status {
  min-width: 72px;
}
.latest-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}
.latest-pagination-pages {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.latest-pagination-btn,
.latest-pagination-page {
  height: 40px;
  min-width: 40px;
  padding: 0 14px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 700;
  color: var(--blue);
  background: rgba(13,19,34,.05);
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.latest-pagination-page.is-active,
.latest-pagination-btn:hover,
.latest-pagination-page:hover {
  background: rgb(var(--primary-rgb));
  color: #fff;
}
@media (max-width: 780px) {
  .page-title-band {
    padding: 22px 0;
  }
  .latest-tracks-page-shell {
    padding: 16px;
    border-radius: 22px;
  }
  .latest-track-line-status {
    min-width: 0;
  }
}


/* v20 derniers titres page refresh + pagination */
.page-title-band.latest-page-band {
  padding: 56px 0;
}
.page-title-band.latest-page-band h1 {
  font-size: clamp(32px, 5vw, 52px);
}
.latest-titles-page--list-only {
  padding-top: 10px;
}
.latest-tracks-list-section {
  margin-top: -6px;
}
.latest-page-head {
  display: none !important;
}
.latest-tracks-list {
  gap: 12px;
}
.latest-track-line {
  overflow: hidden;
}
.latest-track-line.is-incoming {
  animation: latestTitleFadeDown .5s ease both;
}
.latest-track-line.is-refreshing {
  animation: latestLivePulse .38s ease;
}
@keyframes latestTitleFadeDown {
  from { opacity: 0; transform: translateY(-18px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes latestLivePulse {
  0% { opacity: .6; transform: translateY(-8px); }
  100% { opacity: 1; transform: translateY(0); }
}
@media (max-width: 780px) {
  .page-title-band.latest-page-band {
    padding: 30px 0;
  }
}


/* v21 derniers titres: hover icones, refresh on track change only, simple pagination */
.latest-track-line-platforms .track-platforms a {
  transition: color .2s ease, transform .2s ease, opacity .2s ease;
}
.latest-track-line-platforms .track-platforms a:hover,
.latest-track-line-platforms .track-platforms a:focus-visible {
  color: rgb(var(--primary-rgb)) !important;
}
.latest-pagination {
  justify-content: center;
  gap: 14px;
}
.latest-pagination-pages {
  display: none !important;
}
.latest-pagination-btn {
  width: 46px;
  min-width: 46px;
  padding: 0;
  font-size: 15px;
}
.latest-pagination-btn i {
  line-height: 1;
}

/* v25 tighten gap between home hero and latest titles */
.now-playing-band {
  min-height: auto !important;
  height: auto !important;
  margin-top: 0 !important;
  padding-top: 12px !important;
  padding-bottom: 6px !important;
}

.site-main > .now-playing-band:first-child {
  margin-top: 0 !important;
}

@media (max-width: 780px) {
  .now-playing-band {
    padding-top: 8px !important;
    padding-bottom: 4px !important;
  }
}


/* v29 hero/player/news refinements */
.cover-play-toggle.is-playing {
  background: transparent !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  box-shadow: none !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.cover-play-toggle.is-playing:hover {
  background: rgba(255,255,255,.10) !important;
}

.site-player-bar {
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  transform: translateY(100%) !important;
  background: rgba(8, 10, 18, .88);
  border-top: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.site-player-bar.is-active {
  transform: translateY(0) !important;
}
.site-player-inner.container {
  width: min(1360px, calc(100% - 48px)) !important;
  min-height: 92px !important;
  padding: 14px 0 !important;
  margin: 0 auto !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  gap: 28px !important;
}
.site-player-track {
  gap: 16px !important;
}
.site-player-cover-wrap {
  width: 64px !important;
  height: 64px !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.12) !important;
}
.site-player-meta {
  gap: 4px !important;
}
.site-player-meta strong,
.site-player-meta span {
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.site-player-meta strong {
  font-size: 20px !important;
  line-height: 1.12 !important;
  letter-spacing: -.02em;
  font-weight: 800 !important;
  text-transform: none !important;
}
.site-player-meta span {
  font-size: 14px !important;
  color: rgba(255,255,255,.72) !important;
  font-weight: 700 !important;
  text-transform: none !important;
}
.site-player-toggle,
.site-player-mute {
  border: 1px solid rgba(255,255,255,.14) !important;
  background: rgba(255,255,255,.12) !important;
  color: #fff !important;
  box-shadow: none !important;
}
.site-player-toggle.is-playing {
  background: rgba(255,255,255,.18) !important;
}
.site-player-volume {
  gap: 12px !important;
}
.site-player-volume input[type=range] {
  width: 180px !important;
}

.news-media,
.news-card-media {
  border-radius: 28px;
  overflow: hidden;
}
.news-featured,
.news-card {
  border-radius: 28px;
}
.news-tag,
.article-cat {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
}
.news-card-top {
  display: flex;
  align-items: center;
  gap: 10px 12px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.news-card-top .news-card-tags,
.news-card-top .news-meta {
  margin: 0;
}
.news-card-top .news-meta {
  display: inline-flex;
  align-items: center;
}
.news-card-tags {
  gap: 10px;
}
.news-content {
  padding-top: 18px;
}
.news-card-content {
  padding: 12px 0 12px 20px;
}
.news-card {
  align-items: center;
}
.news-card .news-meta,
.news-content .news-meta {
  font-weight: 700;
}
.news-content .news-meta {
  margin-bottom: 14px;
}
.news-featured .news-tag {
  background: rgba(var(--primary-rgb), .96);
}
@media (max-width: 980px) {
  .site-player-inner.container {
    width: calc(100% - 24px) !important;
    min-height: auto !important;
    padding: 12px 0 !important;
    gap: 16px !important;
  }
  .site-player-bar {
    padding-bottom: env(safe-area-inset-bottom, 0);
  }
  .site-player-cover-wrap {
    width: 54px !important;
    height: 54px !important;
    border-radius: 16px !important;
  }
  .site-player-meta strong {
    font-size: 16px !important;
  }
  .site-player-meta span {
    font-size: 13px !important;
  }
  .site-player-volume input[type=range] {
    width: 110px !important;
  }
}
@media (max-width: 760px) {
  .news-card {
    grid-template-columns: 1fr;
  }
  .news-card-content {
    padding: 16px 0 0;
  }
}

/* v31 site news/article/player refinements */
.news-media-link,
.news-card-media-link {
  display: block;
  width: 100%;
  height: 100%;
}
.news-card-media {
  min-height: 126px;
  background: #f4f6fb;
  display: flex;
  align-items: center;
  justify-content: center;
}
.news-card-media img {
  width: 100%;
  height: 100%;
  object-fit: contain !important;
  background: #f4f6fb;
}
.news-content h3 a,
.news-card-content h4 a {
  transition: color .18s ease;
}
.news-content h3 a:hover,
.news-card-content h4 a:hover,
.news-link:hover {
  color: var(--blue);
}

.site-player-bar,
.site-player-inner,
.site-player-inner.container {
  border-radius: 0 !important;
}
.site-player-inner.container {
  border: 0 !important;
}
.site-player-cover-wrap {
  border-radius: 14px !important;
}
.site-player-meta strong,
.site-player-meta span {
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
}
.site-player-meta strong {
  font-size: 18px !important;
  line-height: 1.08 !important;
}
.site-player-meta span {
  font-size: 13px !important;
}

.article-page {
  padding: 34px 0 84px;
}
.article-shell {
  max-width: 980px;
  margin: 0 auto;
}
.article-back-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--blue);
  font-weight: 800;
  margin-bottom: 20px;
}
.article-card {
  background: #fff;
}
.article-cover {
  border-radius: 30px;
  overflow: hidden;
  background: #f4f6fb;
  margin-bottom: 24px;
}
.article-cover img {
  width: 100%;
  max-height: 560px;
  object-fit: cover;
}
.article-meta-row {
  display: flex;
  align-items: center;
  gap: 10px 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.article-page .news-tag,
.actualites-page .news-tag,
.actualites-page .article-cat {
  border-radius: 999px;
}
.article-title {
  margin: 0 0 16px;
  font-size: clamp(34px, 5vw, 54px);
  line-height: 1.02;
}
.article-excerpt {
  margin: 0 0 20px;
  color: #4d5768;
  font-size: 18px;
  line-height: 1.7;
}
.article-body {
  color: #1f2937;
  font-size: 18px;
  line-height: 1.85;
}
.article-body p {
  margin: 0 0 18px;
}
.actualites-page .news-list-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}
.actualites-page .news-card {
  grid-template-columns: 220px 1fr;
}

.table-actions--articles,
.table-actions--articles form {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}
.table-actions--articles {
  flex-wrap: nowrap !important;
}
.table-actions--articles .btn-small,
.table-actions--articles .btn-small-danger {
  font-size: 14px !important;
  line-height: 1 !important;
}

@media (max-width: 980px) {
  .actualites-page .news-list-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 760px) {
  .article-page {
    padding: 24px 0 68px;
  }
  .article-cover {
    border-radius: 22px;
  }
  .article-title {
    font-size: 30px;
  }
  .article-body,
  .article-excerpt {
    font-size: 16px;
  }
  .actualites-page .news-card {
    grid-template-columns: 1fr;
  }
}


/* v32 derniers titres pagination + bandeau */
.page-title-band.latest-page-band {
  padding: 68px 0 !important;
}
.page-title-band.latest-page-band h1 {
  letter-spacing: 0 !important;
}
.latest-pagination {
  justify-content: center;
  gap: 12px;
  margin-top: 22px;
}
.latest-pagination-pages {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}
.latest-pagination-btn,
.latest-pagination-page {
  min-width: 44px;
  height: 44px;
  padding: 0 14px;
}
.latest-pagination-btn.is-disabled {
  opacity: .38;
  pointer-events: none;
}
.latest-pagination-ellipsis {
  min-width: 28px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  font-weight: 800;
}
@media (max-width: 780px) {
  .page-title-band.latest-page-band {
    padding: 38px 0 !important;
  }
  .latest-pagination {
    gap: 8px;
  }
  .latest-pagination-btn,
  .latest-pagination-page {
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
  }
}


/* v33 actualites page + right news images */
.news-card-media {
  height: 126px;
  aspect-ratio: 16 / 10;
}
.news-card-media img {
  width: 100%;
  height: 100%;
  object-fit: contain !important;
  object-position: center center;
  display: block;
}
.actualites-page .actualites-hero-layout {
  margin-bottom: 30px;
}
.actualites-page .news-featured {
  display: block;
}
.actualites-page .news-featured .news-media {
  min-height: 420px;
}
.actualites-page .news-featured .news-content {
  padding: 18px 0 0;
}
.actualites-page .actualites-list-grid {
  margin-top: 8px;
}
.actualites-page .news-card-content p {
  margin: 10px 0 0;
  color: #4f4f4f;
  line-height: 1.6;
}
.actualites-page .actualites-pagination {
  margin-top: 30px;
}
@media (max-width: 980px) {
  .actualites-page .news-featured .news-media {
    min-height: 300px;
  }
}
@media (max-width: 760px) {
  .news-card-media {
    width: 100%;
    height: 180px;
  }
  .actualites-page .news-featured .news-media {
    min-height: 220px;
  }
}


/* v34 homepage + actualites layout fixes */
.news-list {
  gap: 24px;
}
.news-list .news-card {
  grid-template-columns: 170px minmax(0, 1fr);
  gap: 20px;
  align-items: center;
}
.news-list .news-card-media {
  width: 100%;
  max-width: 100%;
  height: 126px;
  aspect-ratio: auto !important;
  min-height: 126px;
}
.news-list .news-card-media img {
  width: 100%;
  height: 100%;
  object-fit: contain !important;
  object-position: center center;
}
.news-list .news-card-content {
  min-width: 0;
  padding: 0;
}
.news-list .news-card-content h4,
.actualites-page .news-card-content h4 {
  overflow-wrap: anywhere;
}
.actualites-page-band {
  padding: 72px 0 !important;
}
.actualites-page-band h1 {
  letter-spacing: 0 !important;
}
.actualites-page {
  padding-top: 30px;
}
.actualites-back-link {
  justify-content: flex-end;
  margin-bottom: 26px;
}
.actualites-page .actualites-hero-layout {
  margin-bottom: 36px;
}
.actualites-page .news-featured {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: 30px;
  align-items: center;
}
.actualites-page .news-featured .news-media {
  min-height: 420px;
  height: 100%;
}
.actualites-page .news-featured .news-content {
  padding: 0;
}
.actualites-page .news-featured .news-content h3 {
  margin-bottom: 18px;
}
.actualites-page .news-featured .news-content .news-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.actualites-page .actualites-list-grid {
  margin-top: 8px;
}
.actualites-page .news-card {
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}
.actualites-page .news-card-media {
  width: 100%;
  max-width: 100%;
  height: 138px;
  aspect-ratio: auto !important;
}
.actualites-page .news-card-media img {
  width: 100%;
  height: 100%;
  object-fit: contain !important;
  object-position: center center;
}
.actualites-page .news-card-content {
  min-width: 0;
  padding: 0;
}
@media (max-width: 980px) {
  .actualites-page .news-featured {
    grid-template-columns: 1fr;
  }
  .actualites-page .news-featured .news-media {
    min-height: 300px;
  }
}
@media (max-width: 760px) {
  .news-list .news-card,
  .actualites-page .news-card {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .news-list .news-card-media,
  .actualites-page .news-card-media {
    height: 180px;
  }
  .actualites-page {
    padding-top: 22px;
  }
  .actualites-back-link {
    justify-content: flex-start;
    margin-bottom: 20px;
  }
}

/* v35 actualites title + featured 50/50 + improved list news thumbnails */
.actualites-page-band h1 {
  letter-spacing: 0 !important;
}
.actualites-page {
  padding-top: 34px;
}
.actualites-page .news-featured {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 38px !important;
  align-items: center !important;
}
.actualites-page .news-featured .news-media {
  min-height: 420px !important;
  height: 420px !important;
}
.actualites-page .news-featured .news-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}
.news-list .news-card,
.actualites-page .news-card {
  align-items: center !important;
}
.news-list .news-card-media,
.actualites-page .news-card-media {
  width: 100%;
  max-width: 100%;
  height: 150px !important;
  min-height: 150px !important;
  aspect-ratio: auto !important;
  background: #f4f6fb;
}
.news-list .news-card-media-link,
.actualites-page .news-card-media-link {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: #f4f6fb;
}
.news-list .news-card-media img,
.actualites-page .news-card-media img {
  width: auto !important;
  max-width: 100% !important;
  height: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  display: block;
}
@media (max-width: 980px) {
  .actualites-page .news-featured {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .actualites-page .news-featured .news-media {
    height: 320px !important;
    min-height: 320px !important;
  }
}
@media (max-width: 760px) {
  .news-list .news-card-media,
  .actualites-page .news-card-media {
    height: 180px !important;
    min-height: 180px !important;
  }
  .actualites-page .news-featured .news-media {
    height: 240px !important;
    min-height: 240px !important;
  }
}


/* v36 actualites featured layout + full-height thumbnails */
.actualites-page .actualites-hero-layout {
  display: block !important;
}
.actualites-page .news-featured {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 36px !important;
  align-items: stretch !important;
}
.actualites-page .news-featured .news-media,
.actualites-page .news-featured .news-content {
  width: 100% !important;
  min-width: 0 !important;
}
.actualites-page .news-featured .news-media {
  min-height: 500px !important;
  height: 500px !important;
  border-radius: 30px !important;
}
.actualites-page .news-featured .news-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}
.actualites-page .news-featured .news-content {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  padding: 0 !important;
}
.actualites-page .news-featured .news-content h3 {
  font-size: clamp(34px, 3.2vw, 58px) !important;
  line-height: 1.12 !important;
  margin-bottom: 18px !important;
}
.actualites-page .news-featured .news-content p {
  margin-bottom: 0 !important;
}
.news-list .news-card,
.actualites-page .news-card {
  display: grid !important;
  grid-template-columns: 190px minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: center !important;
}
.news-list .news-card-media,
.actualites-page .news-card-media {
  width: 190px !important;
  min-width: 190px !important;
  max-width: 190px !important;
  height: 126px !important;
  min-height: 126px !important;
  border-radius: 26px !important;
  overflow: hidden !important;
  background: #f4f6fb !important;
}
.news-list .news-card-media-link,
.actualites-page .news-card-media-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}
.news-list .news-card-media img,
.actualites-page .news-card-media img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  background: transparent !important;
}
.news-list .news-card-content,
.actualites-page .news-card-content {
  min-width: 0 !important;
}
@media (max-width: 980px) {
  .actualites-page .news-featured {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .actualites-page .news-featured .news-media {
    min-height: 360px !important;
    height: 360px !important;
  }
}
@media (max-width: 760px) {
  .news-list .news-card,
  .actualites-page .news-card {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .news-list .news-card-media,
  .actualites-page .news-card-media {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 180px !important;
    min-height: 180px !important;
  }
  .actualites-page .news-featured .news-media {
    min-height: 260px !important;
    height: 260px !important;
  }
}


/* v37 article share + actualites featured/list fixes */
.article-share {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
  padding: 18px 0 6px;
  margin-bottom: 6px;
  border-top: 1px solid rgba(13,19,34,.08);
}
.article-share-label {
  font-size: 14px;
  font-weight: 800;
  color: #1d2433;
  text-transform: uppercase;
}
.article-share-buttons {
  display: flex;
  align-items: center;
  gap: 10px;
}
.article-share-btn {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  background: rgba(var(--primary-rgb), .10);
  color: var(--blue);
  transition: transform .2s ease, background .2s ease, color .2s ease;
}
.article-share-btn:hover {
  background: var(--blue);
  color: #fff;
  transform: translateY(-2px);
}
.actualites-page-band h1 {
  letter-spacing: 0 !important;
  line-height: 1.1 !important;
}
.actualites-page .news-featured {
  width: 100% !important;
  max-width: 100% !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 28px !important;
}
.actualites-page .news-featured .news-media {
  min-height: 0 !important;
  height: auto !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 32px !important;
}
.actualites-page .news-featured .news-content {
  min-height: 0 !important;
  height: auto !important;
  align-self: stretch !important;
}
.actualites-page .news-featured .news-content .news-meta {
  margin-bottom: 14px !important;
}
.actualites-page .news-featured .news-content h3 {
  font-size: clamp(32px, 3vw, 52px) !important;
  margin-bottom: 14px !important;
}
.actualites-page .news-featured .news-content p {
  font-size: 18px !important;
  line-height: 1.7 !important;
}
.news-list .news-card,
.actualites-page .news-card {
  grid-template-columns: 240px minmax(0, 1fr) !important;
  gap: 22px !important;
  align-items: stretch !important;
}
.news-list .news-card-media,
.actualites-page .news-card-media {
  width: 240px !important;
  min-width: 240px !important;
  max-width: 240px !important;
  height: 160px !important;
  min-height: 160px !important;
  border-radius: 28px !important;
  display: block !important;
}
.news-list .news-card-media img,
.actualites-page .news-card-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}
@media (max-width: 980px) {
  .actualites-page .news-featured {
    grid-template-columns: 1fr !important;
  }
  .actualites-page .news-featured .news-media {
    aspect-ratio: 16 / 10 !important;
  }
  .news-list .news-card,
  .actualites-page .news-card {
    grid-template-columns: 200px minmax(0, 1fr) !important;
  }
  .news-list .news-card-media,
  .actualites-page .news-card-media {
    width: 200px !important;
    min-width: 200px !important;
    max-width: 200px !important;
    height: 136px !important;
    min-height: 136px !important;
  }
}
@media (max-width: 760px) {
  .article-share {
    align-items: flex-start;
  }
  .news-list .news-card,
  .actualites-page .news-card {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .news-list .news-card-media,
  .actualites-page .news-card-media {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 200px !important;
    min-height: 200px !important;
  }
}


/* v38 actualites layout + side news image fill */
.actualites-page-band h1 {
  letter-spacing: 0 !important;
}

.actualites-page .news-featured.news-featured-split {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  align-items: stretch !important;
  gap: 34px !important;
}

.actualites-page .news-featured.news-featured-split .news-media,
.actualites-page .news-featured.news-featured-split .news-content {
  width: 100% !important;
  min-width: 0 !important;
}

.actualites-page .news-featured.news-featured-split .news-media {
  min-height: 0 !important;
  height: 100% !important;
  aspect-ratio: 16 / 10 !important;
  border-radius: 32px !important;
  overflow: hidden !important;
}

.actualites-page .news-featured.news-featured-split .news-media img,
.actualites-page .news-featured.news-featured-split .news-media-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.actualites-page .news-featured.news-featured-split .news-media img {
  object-fit: cover !important;
}

.actualites-page .news-featured.news-featured-split .news-content {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  padding: 4px 0 !important;
}

.actualites-page .news-featured.news-featured-split .news-content h3 {
  margin: 0 0 18px !important;
  font-size: clamp(34px, 3.2vw, 52px) !important;
  line-height: 1.12 !important;
}

.actualites-page .news-featured.news-featured-split .news-content p {
  margin: 0 !important;
  font-size: 19px !important;
  line-height: 1.75 !important;
}

.news-list-side,
.actualites-page .news-list-grid {
  gap: 24px !important;
}

.news-list-side .news-card,
.actualites-page .news-card {
  display: grid !important;
  grid-template-columns: 220px minmax(0, 1fr) !important;
  align-items: stretch !important;
  gap: 18px !important;
}

.news-list-side .news-card-media,
.actualites-page .news-card-media {
  height: 100% !important;
  min-height: 170px !important;
  border-radius: 24px !important;
  overflow: hidden !important;
  background: #eef1f7 !important;
}

.news-list-side .news-card-media-link,
.actualites-page .news-card-media-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.news-list-side .news-card-media img,
.actualites-page .news-card-media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.news-list-side .news-card-content,
.actualites-page .news-card-content {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-width: 0 !important;
}

.news-list-side .news-card-content h4,
.actualites-page .news-card-content h4 {
  margin: 0 !important;
  line-height: 1.18 !important;
}

@media (max-width: 1100px) {
  .actualites-page .news-featured.news-featured-split {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }
  .actualites-page .news-featured.news-featured-split .news-media {
    aspect-ratio: 16 / 9 !important;
  }
}

@media (max-width: 760px) {
  .news-list-side .news-card,
  .actualites-page .news-card {
    grid-template-columns: 1fr !important;
  }

  .news-list-side .news-card-media,
  .actualites-page .news-card-media {
    min-height: 210px !important;
  }
}


/* v39 menu + actualites side cards + article page */
.news-layout,
.actualites-page .news-list-grid,
.article-related-grid {
  min-width: 0;
}

.news-list-side .news-card,
.actualites-page .news-card,
.article-related-grid .news-card {
  display: grid !important;
  grid-template-columns: 250px minmax(0, 1fr) !important;
  align-items: stretch !important;
  gap: 22px !important;
  min-width: 0 !important;
}

.news-list-side .news-card-media,
.actualites-page .news-card-media,
.article-related-grid .news-card-media {
  align-self: stretch !important;
  display: flex !important;
  min-width: 250px !important;
  width: 250px !important;
  max-width: 250px !important;
  min-height: 100% !important;
  height: auto !important;
  border-radius: 26px !important;
  overflow: hidden !important;
  background: #eef1f7 !important;
}

.news-list-side .news-card-media-link,
.actualites-page .news-card-media-link,
.article-related-grid .news-card-media-link {
  flex: 1 1 auto !important;
  display: block !important;
  min-height: 100% !important;
}

.news-list-side .news-card-media img,
.actualites-page .news-card-media img,
.article-related-grid .news-card-media img {
  width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.news-list-side .news-card-content,
.actualites-page .news-card-content,
.article-related-grid .news-card-content {
  padding: 8px 0 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.news-list-side .news-card-content h4,
.actualites-page .news-card-content h4,
.article-related-grid .news-card-content h4 {
  margin: 0 !important;
  font-size: clamp(26px, 1.65vw, 40px) !important;
  line-height: 1.15 !important;
  overflow-wrap: anywhere !important;
}

.news-list-side .news-card-top,
.actualites-page .news-card-top,
.article-related-grid .news-card-top {
  display: flex !important;
  align-items: center !important;
  gap: 10px 12px !important;
  flex-wrap: wrap !important;
  margin-bottom: 12px !important;
}

.news-list-side .news-card-top .news-meta,
.actualites-page .news-card-top .news-meta,
.article-related-grid .news-card-top .news-meta {
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  min-height: 32px !important;
}

.article-page {
  padding: 42px 0 84px !important;
}

.article-shell {
  max-width: none !important;
}

.article-card {
  max-width: none !important;
}

.article-meta-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px 12px !important;
  flex-wrap: wrap !important;
  margin-bottom: 18px !important;
}

.article-meta-row .news-meta {
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  min-height: 32px !important;
}

.article-share-bottom {
  margin-top: 34px !important;
  padding-top: 26px !important;
  border-top: 1px solid rgba(13,19,34,.08) !important;
}

.article-related {
  margin-top: 48px;
}

.article-related-head {
  margin-bottom: 22px;
}

.article-related-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

@media (max-width: 1180px) {
  .news-list-side .news-card,
  .actualites-page .news-card,
  .article-related-grid .news-card {
    grid-template-columns: 220px minmax(0, 1fr) !important;
  }

  .news-list-side .news-card-media,
  .actualites-page .news-card-media,
  .article-related-grid .news-card-media {
    min-width: 220px !important;
    width: 220px !important;
    max-width: 220px !important;
  }
}

@media (max-width: 900px) {
  .article-related-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .news-list-side .news-card,
  .actualites-page .news-card,
  .article-related-grid .news-card {
    grid-template-columns: 1fr !important;
  }

  .news-list-side .news-card-media,
  .actualites-page .news-card-media,
  .article-related-grid .news-card-media {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: 220px !important;
  }
}


/* v40 actualites active menu + titles + related cards */
.news-section .section-head h3 {
  font-size: clamp(34px, 2.55vw, 48px) !important;
}

.actualites-page-band {
  padding: 48px 0 !important;
}

.actualites-page-band h1 {
  font-size: clamp(34px, 4.2vw, 60px) !important;
}

.main-nav a.is-active,
.mobile-menu-nav a.is-active {
  background: rgba(255,255,255,.14) !important;
  color: #fff !important;
}

.news-list-side .news-card,
.actualites-page .news-card {
  grid-template-columns: minmax(0, 240px) minmax(0, 1fr) !important;
  column-gap: 24px !important;
  min-width: 0 !important;
}

.news-list-side .news-card-media,
.actualites-page .news-card-media {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 190px !important;
  height: 100% !important;
  aspect-ratio: 4 / 3 !important;
}

.news-list-side .news-card-media-link,
.actualites-page .news-card-media-link,
.news-list-side .news-card-media img,
.actualites-page .news-card-media img {
  width: 100% !important;
  height: 100% !important;
}

.news-list-side .news-card-content,
.actualites-page .news-card-content {
  min-width: 0 !important;
  overflow: hidden !important;
}

.news-list-side .news-card-content h4,
.actualites-page .news-card-content h4 {
  font-size: clamp(22px, 1.75vw, 34px) !important;
  line-height: 1.18 !important;
}

.article-related-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 24px !important;
}

.article-related-grid .related-card {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}

.article-related-grid .related-card .news-card-media {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 0 !important;
  aspect-ratio: 16 / 10 !important;
  border-radius: 24px !important;
}

.article-related-grid .related-card .news-card-content {
  padding: 16px 4px 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  justify-content: flex-start !important;
}

.article-related-grid .related-card .news-card-top,
.article-related-grid .related-card .news-card-tags {
  display: none !important;
}

.article-related-grid .related-card .news-card-content h4 {
  font-size: clamp(18px, 1.3vw, 24px) !important;
  line-height: 1.25 !important;
}

.article-related-grid .related-card .news-card-content .news-meta {
  margin: 0 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--muted) !important;
}

@media (max-width: 1180px) {
  .article-related-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 980px) {
  .news-list-side .news-card,
  .actualites-page .news-card {
    grid-template-columns: minmax(0, 210px) minmax(0, 1fr) !important;
  }

  .news-list-side .news-card-media,
  .actualites-page .news-card-media {
    aspect-ratio: 1 / 1 !important;
  }
}

@media (max-width: 760px) {
  .news-section .section-head h3 {
    font-size: clamp(28px, 7vw, 36px) !important;
  }

  .actualites-page-band {
    padding: 34px 0 !important;
  }

  .actualites-page-band h1 {
    font-size: clamp(30px, 8vw, 40px) !important;
  }

  .news-list-side .news-card,
  .actualites-page .news-card {
    grid-template-columns: 1fr !important;
  }

  .news-list-side .news-card-media,
  .actualites-page .news-card-media {
    aspect-ratio: 16 / 10 !important;
    min-height: 0 !important;
  }

  .article-related-grid {
    grid-template-columns: 1fr !important;
  }
}


/* v41 fixes */
.news-list-side .news-card,
.actualites-page .news-card {
  display: grid !important;
  grid-template-columns: 240px minmax(0, 1fr) !important;
  align-items: stretch !important;
  column-gap: 20px !important;
}

.news-list-side .news-card-media,
.actualites-page .news-card-media {
  width: 240px !important;
  min-width: 240px !important;
  min-height: 164px !important;
  height: 100% !important;
  overflow: hidden !important;
  border-radius: 26px !important;
  align-self: stretch !important;
}

.news-list-side .news-card-media-link,
.actualites-page .news-card-media-link {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.news-list-side .news-card-media img,
.actualites-page .news-card-media img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.news-list-side .news-card-content,
.actualites-page .news-card-content {
  min-width: 0 !important;
}

.news-list-side .news-card-content h4,
.actualites-page .news-card-content h4 {
  font-size: clamp(1.12rem, 1.55vw, 1.42rem) !important;
  line-height: 1.15 !important;
}

.latest-pagination-page.is-active {
  background: rgb(var(--primary-rgb)) !important;
  color: #fff !important;
  border: 1px solid rgb(var(--primary-rgb)) !important;
  box-shadow: 0 12px 24px rgba(var(--primary-rgb), .24) !important;
}

@media (max-width: 1100px) {
  .news-list-side .news-card,
  .actualites-page .news-card {
    grid-template-columns: 210px minmax(0, 1fr) !important;
  }

  .news-list-side .news-card-media,
  .actualites-page .news-card-media {
    width: 210px !important;
    min-width: 210px !important;
    min-height: 150px !important;
  }
}

@media (max-width: 768px) {
  .news-list-side .news-card,
  .actualites-page .news-card {
    grid-template-columns: 1fr !important;
    row-gap: 14px !important;
  }

  .news-list-side .news-card-media,
  .actualites-page .news-card-media {
    width: 100% !important;
    min-width: 100% !important;
    min-height: 220px !important;
  }
}


/* v45 admin logo path + actualites title size */
.news-section .section-head h3 {
  font-size: 28px !important;
}

.actualites-page .section-head h3,
.actualites-page .news-section .section-head h3 {
  font-size: 28px !important;
}

@media (max-width: 760px) {
  .news-section .section-head h3,
  .actualites-page .section-head h3,
  .actualites-page .news-section .section-head h3 {
    font-size: 28px !important;
  }
}

.hero-vote-button,
.site-player-like {
  border: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 999px;
  padding: 0 16px;
  height: 44px;
  font-weight: 700;
  cursor: pointer;
  transition: transform .18s ease, opacity .18s ease, background-color .18s ease, color .18s ease;
}
.hero-vote-button {
  background: rgba(255,255,255,.14);
  color: #fff;
  backdrop-filter: blur(12px);
}
.hero-vote-button:hover,
.site-player-like:hover { transform: translateY(-1px); }
.hero-vote-button.is-voted,
.site-player-like.is-voted {
  background: rgb(var(--primary-rgb));
  color: #fff;
}
.hero-vote-button:disabled,
.site-player-like:disabled { opacity: .55; cursor: not-allowed; transform: none; }
.site-player-like {
  background: rgba(255,255,255,.08);
  color: #fff;
  min-width: 78px;
  justify-content: center;
}
.classement-track-line { position: relative; }
.classement-position {
  width: 56px;
  min-width: 56px;
  height: 56px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  background: rgba(var(--primary-rgb), .12);
  color: var(--primary);
}
.classement-list .latest-track-line { grid-template-columns: 56px 72px minmax(0,1fr) auto auto; }
@media (max-width: 900px) {
  .hero-meta { flex-wrap: wrap; gap: 12px; }
  .classement-list .latest-track-line { grid-template-columns: 48px 64px minmax(0,1fr); }
  .classement-list .latest-track-line-status,
  .classement-list .latest-track-line-platforms { grid-column: 2 / span 2; }
  .site-player-controls { gap: 10px; }
}


/* v49 fixes */
.actualites-pagination .latest-pagination-page.is-active{
  background: rgb(var(--primary-rgb)) !important;
  color: #fff !important;
  border-color: var(--primary) !important;
  box-shadow: none !important;
}
.actualites-pagination .latest-pagination-page.is-active,
.actualites-pagination .latest-pagination-btn:hover,
.actualites-pagination .latest-pagination-page:hover{
  color: #fff !important;
}
.hero-vote-button,
.site-player-like{
  width: 46px !important;
  min-width: 46px !important;
  height: 46px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  justify-content: center !important;
  gap: 0 !important;
}
.hero-vote-button span,
.site-player-like span{ display:none !important; }
.classement-list .latest-track-line{ grid-template-columns: 56px 72px minmax(0,1fr) auto !important; }
.nav-dropdown{ position:relative; display:flex; align-items:center; }
.nav-dropdown-toggle{
  white-space: normal;
  padding: 10px 14px;
  border-radius: 999px;
  transition: background .22s ease, color .22s ease, transform .22s ease;
  background: transparent;
  border: 0;
  color: inherit;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  display:inline-flex;
  align-items:center;
}
.nav-dropdown-toggle:hover,
.nav-dropdown-toggle.is-active,
.nav-dropdown.is-active .nav-dropdown-toggle{ background: rgba(255,255,255,.14) !important; color: #fff !important; }
.nav-dropdown-toggle i{ font-size:12px; margin-left:6px; }
.nav-dropdown-menu{
  position:absolute;
  top: calc(100% + 10px);
  left: 0;
  min-width: 190px;
  padding: 10px;
  border-radius: 20px;
  background: rgba(10,12,18,.98);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 48px rgba(0,0,0,.28);
  display:none;
  z-index: 40;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{ display:grid; gap:8px; }
.nav-dropdown-menu a{ display:flex; align-items:center; min-height: 44px; padding: 0 14px; border-radius: 14px; }
.nav-dropdown-menu a:hover,
.nav-dropdown-menu a.is-active{ background: rgba(255,255,255,.1) !important; color:#fff !important; }
.mobile-nav-dropdown{ display:grid; gap:10px; }
.mobile-nav-dropdown-toggle{
  min-height: 54px;
  padding: 0 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  color: var(--white);
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-size:17px;
  font-weight:800;
}
.mobile-nav-dropdown-menu{ display:grid; gap:10px; padding-left:14px; }
.mobile-nav-dropdown-menu a{ min-height: 48px; }
.news-list-side .news-card,
.actualites-page .news-card{ grid-template-columns: minmax(0, 260px) minmax(0, 1fr) !important; align-items: stretch !important; }
.news-list-side .news-card-media,
.actualites-page .news-card-media{ width: 100% !important; min-width: 0 !important; height: 100% !important; min-height: 180px !important; }
.news-list-side .news-card-content,
.actualites-page .news-card-content{ min-width: 0 !important; overflow: hidden !important; }
.news-list-side .news-card-content h4,
.actualites-page .news-card-content h4{ font-size: clamp(1rem, 1.25vw, 1.2rem) !important; line-height: 1.2 !important; }
@media (max-width: 1180px){
  .news-list-side .news-card,
  .actualites-page .news-card{ grid-template-columns: minmax(0, 220px) minmax(0, 1fr) !important; }
}
@media (max-width: 768px){
  .news-list-side .news-card,
  .actualites-page .news-card{ grid-template-columns: 1fr !important; }
  .news-list-side .news-card-media,
  .actualites-page .news-card-media{ min-height: 220px !important; }
}


/* v50 vote + hero + pagination fixes */
.actualites-pagination .latest-pagination-page.is-active{
  background: var(--blue) !important;
  color: #fff !important;
  border-color: var(--blue) !important;
}
.hero-content{ position: relative; }
.hero-text{ position: relative; }
.hero-actions{
  position: absolute;
  right: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.hero-share-links{ display:flex; align-items:center; gap:10px; }
.hero-share-link,
.hero-vote-button,
.live-badge{
  background: rgba(255,255,255,.14) !important;
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
}
.hero-share-link{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration:none;
  transition: transform .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
}
.hero-share-link:hover{ transform: translateY(-1px); color:#fff; background: rgba(var(--primary-rgb), .8); border-color: rgba(var(--primary-rgb), .8); }
.live-badge{ padding: 0 16px; min-height: 40px; border-radius: 999px; display:inline-flex; align-items:center; }
.live-badge span{ color:#fff; }
.hero-vote-button, .site-player-like{ width:44px; min-width:44px; justify-content:center; padding:0; }
.hero-vote-button.is-voted, .site-player-like.is-voted{ background: var(--blue) !important; border-color: var(--blue) !important; color:#fff !important; opacity:1 !important; }
.hero-vote-button:disabled.is-voted, .site-player-like:disabled.is-voted{ opacity:1 !important; }
@media (max-width: 980px){ .hero-actions{ position: static; margin-top: 16px; } }

.news-list-side .news-card,
.actualites-page .news-card{ grid-template-columns: minmax(0, 240px) minmax(0, 1fr) !important; align-items: stretch !important; column-gap: 18px !important; }
.news-list-side .news-card-media,
.actualites-page .news-card-media{ height: 180px !important; min-height: 180px !important; overflow: hidden !important; border-radius: 28px !important; }
.news-list-side .news-card-media-link,
.actualites-page .news-card-media-link{ display:block !important; width:100% !important; height:100% !important; }
.news-list-side .news-card-media img,
.actualites-page .news-card-media img{ width:100% !important; height:100% !important; object-fit: cover !important; object-position:center center !important; display:block !important; }
.news-list-side .news-card-content,
.actualites-page .news-card-content{ position:relative; z-index:1; min-width:0 !important; }
@media (max-width: 1180px){
  .news-list-side .news-card, .actualites-page .news-card{ grid-template-columns: minmax(0, 210px) minmax(0, 1fr) !important; }
}
@media (max-width: 768px){
  .news-list-side .news-card, .actualites-page .news-card{ grid-template-columns: 1fr !important; }
  .news-list-side .news-card-media, .actualites-page .news-card-media{ height:220px !important; min-height:220px !important; }
}


/* v51 hero and ranking fixes */
.hero-content{ position:relative !important; }
.hero-main{ width:100% !important; }
.hero-text{ position:static !important; }
.hero-actions{
  position:absolute !important;
  right:0 !important;
  bottom:18px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:12px !important;
  z-index:6 !important;
}
.hero-share-links{ display:flex !important; align-items:center !important; gap:10px !important; }
.hero-vote-button{ order:-1; }
@media (max-width: 980px){
  .hero-actions{ position:static !important; margin-top:18px !important; justify-content:flex-start !important; }
}


/* v52 admin ranking + hero actions fixes */
.hero-main{
  position: relative !important;
  padding-right: 360px !important;
  padding-bottom: 86px !important;
}
.hero-text{
  max-width: 620px !important;
}
.hero-actions{
  position: absolute !important;
  right: 0 !important;
  bottom: 16px !important;
  left: auto !important;
  width: auto !important;
  z-index: 10 !important;
}
.hero-vote-button{
  order: -1 !important;
}
@media (max-width: 1180px){
  .hero-main{
    padding-right: 0 !important;
    padding-bottom: 90px !important;
  }
  .hero-text{
    max-width: none !important;
  }
}
@media (max-width: 980px){
  .hero-main{
    padding-bottom: 0 !important;
  }
  .hero-actions{
    position: static !important;
    margin-top: 18px !important;
    justify-content: flex-start !important;
  }
}


/* v54 hero actions + ranking summary fixes */
.hero-content{position:relative !important;}
.hero-main{padding-right:0 !important;padding-bottom:0 !important;}
.hero-text{max-width:640px !important;}
.hero-actions{position:absolute !important;right:0 !important;bottom:24px !important;display:flex !important;align-items:center !important;justify-content:flex-end !important;gap:12px !important;z-index:20 !important;}
.hero-vote-button{order:-1 !important;}
@media (max-width: 980px){.hero-actions{position:static !important;margin-top:18px !important;justify-content:flex-start !important;}}


/* v56 fixes */
.hero-main{position:relative !important;}
.hero-text{max-width:calc(100% - 280px) !important;}
.hero-text h1,
.hero-text h2{max-width:100% !important;}
.hero-actions{bottom:112px !important; right:0 !important;}
@media (max-width: 1180px){
  .hero-text{max-width:100% !important;}
  .hero-actions{bottom:88px !important;}
}
@media (max-width: 980px){
  .hero-actions{bottom:auto !important;}
}
.nav-dropdown{position:relative; display:flex; align-items:center; padding-bottom:14px; margin-bottom:-14px;}
.nav-dropdown-menu{top:calc(100% + 2px) !important;}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu,
.nav-dropdown.is-open .nav-dropdown-menu{display:grid; gap:8px;}
.classement-empty-state{display:grid; gap:6px; padding:22px 24px; border-radius:24px; background:rgba(255,255,255,.92); box-shadow:0 18px 48px rgba(13,19,34,.08); text-align:center; color:var(--blue);} 
.classement-empty-state strong{font-size:18px; font-weight:800; color:var(--blue);} 
.classement-empty-state span{font-size:14px; color:rgba(13,19,34,.72);} 

/* v57 hero actions alignment fix */
.hero-main{position:relative !important;}
.hero-actions{
  position:absolute !important;
  right:0 !important;
  bottom:58px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:12px !important;
  z-index:20 !important;
}
.hero-vote-button{order:-1 !important;}
@media (max-width: 1180px){
  .hero-actions{bottom:52px !important;}
}
@media (max-width: 980px){
  .hero-actions{position:static !important; margin-top:18px !important; justify-content:flex-start !important;}
}


/* v59 final alignment fixes */
.news-list .news-card,
.actualites-page .news-card {
  align-items: start !important;
}
.news-list .news-card-media,
.actualites-page .news-card-media {
  align-self: start !important;
}
.news-list .news-card-content,
.actualites-page .news-card-content {
  align-self: start !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  padding-top: 2px !important;
}
.news-list .news-card-top,
.actualites-page .news-card-top {
  align-items: center !important;
  margin-bottom: 12px !important;
}
.hero-actions {
  bottom: 60px !important;
}
@media (max-width: 980px) {
  .hero-actions {
    bottom: auto !important;
  }
}
.classement-empty-state {
  min-height: 120px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  padding: 32px 20px;
  border-radius: 24px;
  background: rgba(255,255,255,.9);
  box-shadow: 0 18px 48px rgba(13,19,34,.08);
}
.classement-empty-state strong {
  font-size: 20px;
  color: var(--blue);
}
.classement-empty-state span {
  color: rgba(13,19,34,.68);
}
.site-header .nav-item.has-dropdown:hover .dropdown-menu,
.site-header .nav-item.has-dropdown:focus-within .dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}
.site-header .nav-item.has-dropdown .dropdown-menu {
  transition: opacity .16s ease, transform .16s ease !important;
}

/* v60 reduce vertical spacing for homepage side news */
.news-section .news-list-side {
  gap: 14px !important;
}
.news-section .news-list-side .news-card {
  margin: 0 !important;
}
@media (max-width: 980px) {
  .news-section .news-list-side {
    gap: 18px !important;
  }
}


.article-source-cta{display:flex;justify-content:center;align-items:center;margin-top:22px;}
.article-source-cta .btn-primary{margin-inline:auto;}




.maintenance-page-body{min-height:100vh;background:#070b14;color:#fff;overflow-x:hidden;}
.maintenance-page{position:relative;min-height:100vh;padding:36px 0 128px;isolation:isolate;display:flex;flex-direction:column;justify-content:center;}
.maintenance-bg{position:absolute;inset:0;background-position:center;background-size:cover;filter:blur(30px);transform:scale(1.1);opacity:.85;z-index:-3;}
.maintenance-overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(7,11,20,.70) 0%, rgba(7,11,20,.55) 38%, rgba(7,11,20,.82) 100%);z-index:-2;}
.maintenance-content-shell{padding:20px 0 34px;}
.maintenance-topzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;min-height:calc(100vh - 240px);}
.maintenance-logo-outside{display:flex;justify-content:center;align-items:center;flex-direction:column;gap:8px;min-height:88px;}
.maintenance-logo-outside.has-fallback .maintenance-logo{display:none;}
.maintenance-logo{display:block;max-width:min(460px,78vw);max-height:144px;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 18px 34px rgba(0,0,0,.30));}
.maintenance-logo-fallback{display:none;font-size:clamp(2rem,5vw,3rem);font-weight:900;letter-spacing:-.03em;color:#fff;text-shadow:0 10px 30px rgba(0,0,0,.28);}
.maintenance-logo-outside.has-fallback .maintenance-logo-fallback{display:block;}
.maintenance-card{width:min(100%,780px);padding:30px 38px;border-radius:34px;background:rgba(9,14,24,.50);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 28px 80px rgba(0,0,0,.24);text-align:center;}
.maintenance-station-name{display:inline-flex;align-items:center;justify-content:center;padding:9px 16px;border-radius:999px;background:rgba(var(--primary-rgb),.18);border:1px solid rgba(var(--primary-rgb),.26);color:#fff;font-weight:800;font-size:.92rem;margin-bottom:14px;letter-spacing:.04em;text-transform:uppercase;}
.maintenance-copy h1{margin:0 0 12px;font-size:clamp(2.1rem,4vw,3.45rem);line-height:1.03;color:#fff;}
.maintenance-message{max-width:640px;margin:0 auto;color:rgba(255,255,255,.9);line-height:1.8;font-size:1.05rem;}
.maintenance-bottom-player{position:fixed;left:0;right:0;bottom:0;z-index:30;background:rgba(8,12,22,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.10);box-shadow:0 -16px 40px rgba(0,0,0,.18);}
.maintenance-bottom-player-inner{display:grid;grid-template-columns:110px minmax(0,1fr) minmax(250px,360px);gap:20px;align-items:center;padding:14px 0;}
.maintenance-player-cover-btn{position:relative;width:110px;height:110px;padding:0;border:none;background:none;border-radius:26px;cursor:pointer;overflow:hidden;box-shadow:0 16px 34px rgba(0,0,0,.22);}
.maintenance-player-cover{margin-left:20px;width:100%;height:100%;display:block;object-fit:cover;border-radius:26px;}
.maintenance-cover-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg, rgba(10,16,30,.08), rgba(10,16,30,.48));transition:.22s ease;}
.maintenance-cover-overlay::before{content:'';width:64px;height:64px;border-radius:999px;background:linear-gradient(135deg,#ff3b30,#ef4444);border:2px solid rgba(255,255,255,.18);box-shadow:0 12px 28px rgba(0,0,0,.25);transition:.22s ease;}
.maintenance-cover-overlay i{position:absolute;z-index:1;font-size:1.6rem;color:#fff;transform:translateX(2px);}
.maintenance-bottom-player.is-playing .maintenance-cover-overlay::before{background:rgba(180,190,205,.46);border-color:rgba(255,255,255,.20);box-shadow:0 10px 24px rgba(0,0,0,.18);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
.maintenance-bottom-player.is-playing .maintenance-cover-overlay i{transform:none;}
.maintenance-nowplaying-block{display:grid;gap:7px;min-width:0;}
.maintenance-nowplaying-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.62);font-weight:800;}
.maintenance-nowplaying-block strong,.maintenance-nowplaying-block span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.maintenance-nowplaying-block strong{font-size:1.12rem;color:#fff;}
.maintenance-nowplaying-block span{font-size:.98rem;color:rgba(255,255,255,.84);}
.maintenance-player-fields{display:grid;gap:8px;min-width:0;}
.maintenance-player-fields label{font-size:.88rem;font-weight:700;color:rgba(255,255,255,.86);}
.maintenance-public-select-wrap{position:relative;}
.maintenance-public-select-wrap select{appearance:none;width:100%;min-height:54px;border-radius:18px;border:1px solid rgba(255,255,255,.14);padding:0 44px 0 16px;background:rgba(255,255,255,.10);color:#fff;font-weight:700;}
.maintenance-public-select-wrap i{position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:rgba(255,255,255,.78);}
.maintenance-ip-note{position:relative;z-index:2;margin:14px auto 0;color:rgba(255,255,255,.78);font-size:.92rem;text-align:center;}
.maintenance-bottom-player.is-track-updating .maintenance-nowplaying-block,
.maintenance-bottom-player.is-track-updating .maintenance-player-cover-btn{animation:maintenancePulse .7s ease;}
@media (max-width: 900px){
  .maintenance-page{padding-bottom:200px;}
  .maintenance-card{padding:28px 20px;border-radius:28px;}
  .maintenance-bottom-player-inner{grid-template-columns:92px minmax(0,1fr);gap:14px;}
  .maintenance-player-cover-btn{width:92px;height:92px;border-radius:22px;}
  .maintenance-player-cover{margin-left:20px;border-radius:22px;}
  .maintenance-cover-overlay::before{width:54px;height:54px;}
  .maintenance-player-fields{grid-column:1 / -1;}
}
@media (max-width: 640px){
  .maintenance-content-shell{padding-top:10px;}
  .maintenance-topzone{min-height:calc(100vh - 270px);gap:18px;}
  .maintenance-logo{max-width:min(320px,80vw);max-height:104px;}
  .maintenance-card{padding:24px 18px 26px;}
  .maintenance-copy h1{font-size:clamp(1.7rem, 9vw, 2.4rem);}
  .maintenance-message{font-size:.98rem;line-height:1.65;}
  .maintenance-bottom-player-inner{grid-template-columns:92px minmax(0,1fr);padding:14px 0 16px;}
  .maintenance-player-cover-btn{width:92px;height:92px;border-radius:24px;}
  .maintenance-player-cover{margin-left:20px;border-radius:24px;}
  .maintenance-cover-overlay::before{width:56px;height:56px;}
  .maintenance-cover-overlay i{font-size:1.45rem;}
}
@keyframes maintenancePulse{0%{transform:translateY(0);opacity:1;}50%{transform:translateY(-2px);opacity:.78;}100%{transform:translateY(0);opacity:1;}}
@media (max-width: 860px){
  .maintenance-page{padding-bottom:200px;}
  .maintenance-card{padding:28px 20px;border-radius:28px;}
  .maintenance-bottom-player-inner{grid-template-columns:96px minmax(0,1fr);gap:16px;}
  .maintenance-player-cover-btn{width:96px;height:96px;border-radius:28px;}
  .maintenance-player-cover{margin-left:20px;border-radius:22px;}
  .maintenance-cover-overlay::before{width:56px;height:56px;}
  .maintenance-player-fields{grid-column:1 / -1;}
}
@media (max-width: 640px){
  .maintenance-content-shell{padding-top:10px;}
  .maintenance-topzone{min-height:calc(100vh - 270px);gap:18px;}
  .maintenance-logo{max-width:min(320px,78vw);max-height:96px;}
  .maintenance-card{padding:24px 18px 26px;}
  .maintenance-copy h1{font-size:clamp(1.7rem, 9vw, 2.4rem);}
  .maintenance-message{font-size:.98rem;line-height:1.65;}
  .maintenance-bottom-player-inner{grid-template-columns:84px minmax(0,1fr);padding:14px 0 16px;}
  .maintenance-player-cover-btn{width:84px;height:84px;border-radius:24px;}
  .maintenance-player-cover{margin-left:20px;border-radius:24px;}
  .maintenance-cover-overlay::before{width:50px;height:50px;}
  .maintenance-cover-overlay i{font-size:1.28rem;}
}

/* Maintenance page refinements */

.maintenance-topzone{gap:18px;}
.maintenance-logo-outside{margin-bottom:10px;min-height:92px;display:flex;align-items:center;justify-content:center;position:relative;z-index:3;}
.maintenance-logo-outside.has-fallback{min-height:56px;}
.maintenance-logo{display:block;max-width:min(300px,52vw);max-height:90px;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 14px 24px rgba(0,0,0,.22));}
.maintenance-card{width:min(100%,720px);padding:28px 34px 30px;background:rgba(8,12,20,.52);}
.maintenance-nowplaying-block{gap:2px;align-content:center;}
.maintenance-live-badge{display:inline-flex;align-items:center;justify-content:center;width:max-content;padding:5px 10px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.10);color:#fff;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;line-height:1;}
.maintenance-bottom-player-inner{grid-template-columns:72px minmax(0,1fr) minmax(240px,340px);gap:16px;padding:10px 0;}
.maintenance-player-cover-btn{width:72px;height:72px;border-radius:18px;box-shadow:0 12px 26px rgba(0,0,0,.18);}
.maintenance-player-cover{margin-left:20px;border-radius:18px;}
.maintenance-cover-overlay{background:linear-gradient(180deg, rgba(10,16,30,.04), rgba(10,16,30,.26));}
.maintenance-cover-overlay::before{width:44px;height:44px;background:#ef4444;border:1px solid rgba(255,255,255,.18);box-shadow:0 10px 22px rgba(0,0,0,.24);}
.maintenance-cover-overlay i{font-size:1.05rem;transform:translateX(1px);}
.maintenance-bottom-player.is-playing .maintenance-cover-overlay::before{background:linear-gradient(180deg, rgba(255,255,255,.30), rgba(255,255,255,.16));border-color:rgba(255,255,255,.28);box-shadow:0 10px 24px rgba(0,0,0,.16);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);}
.maintenance-bottom-player.is-playing .maintenance-cover-overlay i{transform:none;}
.maintenance-nowplaying-block strong{font-size:1.22rem;line-height:1.02;margin-top:1px;}
.maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){font-size:.95rem;color:rgba(255,255,255,.82);line-height:1.02;}
@media (max-width: 980px) {
  .maintenance-bottom-player-inner{grid-template-columns:72px minmax(0,1fr);}
  .maintenance-player-cover-btn{width:72px;height:72px;}
  .maintenance-player-cover{margin-left:20px;border-radius:18px;}
  .maintenance-cover-overlay::before{width:44px;height:44px;}
}
@media (max-width: 640px) {
  .maintenance-logo{max-width:min(240px,72vw);max-height:72px;}
  .maintenance-card{padding:22px 18px 24px;}
  .maintenance-bottom-player-inner{grid-template-columns:68px minmax(0,1fr);gap:12px;}
  .maintenance-player-cover-btn{width:68px;height:68px;border-radius:16px;}
  .maintenance-player-cover{margin-left:20px;border-radius:16px;}
  .maintenance-cover-overlay::before{width:42px;height:42px;}
  .maintenance-nowplaying-block strong{font-size:1.08rem;}
  .maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){font-size:.9rem;}
}
.maintenance-topzone{gap:18px;}
.maintenance-logo-outside{margin-bottom:4px; min-height:72px;}
.maintenance-logo{max-width:min(340px,62vw);max-height:96px;}
.maintenance-card{width:min(100%,720px);padding:28px 34px 30px;background:rgba(8,12,20,.52);}
.maintenance-nowplaying-block{gap:8px;}
.maintenance-live-badge{display:inline-flex;align-items:center;gap:8px;width:max-content;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.10);color:#fff;font-size:.76rem;letter-spacing:.08em;}
.maintenance-live-badge i{font-size:.55rem;color:#ff3b30;}
.maintenance-bottom-player-inner{grid-template-columns:88px minmax(0,1fr) minmax(240px,340px);gap:18px;padding:12px 0;}
.maintenance-player-cover-btn{width:88px;height:88px;border-radius:22px;}
.maintenance-player-cover{margin-left:20px;border-radius:22px;}
.maintenance-cover-overlay::before{width:58px;height:58px;background:#ff3b30;border:2px solid rgba(255,255,255,.16);}
.maintenance-cover-overlay i{font-size:1.45rem;transform:translateX(2px);}
.maintenance-bottom-player.is-playing .maintenance-cover-overlay::before{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.22);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);}
.maintenance-nowplaying-block strong{font-size:1.3rem;line-height:1.15;}
.maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){font-size:1.02rem;color:rgba(255,255,255,.82);}
@media (max-width: 900px){
  .maintenance-bottom-player-inner{grid-template-columns:84px minmax(0,1fr);}
  .maintenance-player-cover-btn{width:84px;height:84px;}
  .maintenance-player-cover{margin-left:20px;border-radius:20px;}
  .maintenance-cover-overlay::before{width:54px;height:54px;}
}
@media (max-width: 640px){
  .maintenance-logo{max-width:min(280px,74vw);max-height:84px;}
  .maintenance-card{padding:22px 18px 24px;}
  .maintenance-bottom-player-inner{grid-template-columns:78px minmax(0,1fr);gap:14px;}
  .maintenance-player-cover-btn{width:78px;height:78px;border-radius:18px;}
  .maintenance-player-cover{margin-left:20px;border-radius:18px;}
  .maintenance-cover-overlay::before{width:50px;height:50px;}
  .maintenance-nowplaying-block strong{font-size:1.12rem;}
}


/* maintenance public final fixes */
.maintenance-logo-outside{margin-bottom:10px;min-height:96px;}
.maintenance-logo{display:block;max-width:min(320px,58vw);max-height:92px;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 14px 24px rgba(0,0,0,.22));}
.maintenance-logo-svg svg{display:block;max-width:100%;max-height:92px;width:auto;height:auto;overflow:visible;}
.maintenance-logo-fallback{font-size:clamp(1.7rem,4vw,2.6rem);}
.maintenance-live-badge{padding:5px 10px;font-size:.64rem;letter-spacing:.04em;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.08);}
.maintenance-bottom-player-inner{grid-template-columns:64px minmax(0,1fr) minmax(240px,340px);gap:14px;padding:10px 0;}
.maintenance-player-cover-btn{width:64px;height:64px;border-radius:16px;box-shadow:0 10px 22px rgba(0,0,0,.18);}
.maintenance-player-cover{margin-left:20px;border-radius:16px;}
.maintenance-cover-overlay::before{width:34px;height:34px;background:#ff3b30;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 18px rgba(0,0,0,.22);}
.maintenance-cover-overlay i{font-size:.82rem;transform:translateX(1px);}
.maintenance-bottom-player.is-playing .maintenance-cover-overlay::before{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.26);backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);}
.maintenance-nowplaying-block{gap:3px;}
.maintenance-nowplaying-block strong{font-size:1.14rem;line-height:1.02;}
.maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){font-size:.92rem;line-height:1.0;color:rgba(255,255,255,.82);}
@media (max-width: 900px){
  .maintenance-bottom-player-inner{grid-template-columns:60px minmax(0,1fr);gap:12px;}
  .maintenance-player-cover-btn{width:60px;height:60px;border-radius:15px;}
  .maintenance-player-cover{margin-left:20px;border-radius:15px;}
  .maintenance-cover-overlay::before{width:32px;height:32px;}
}
@media (max-width: 640px){
  .maintenance-logo{max-width:min(250px,72vw);max-height:74px;}
  .maintenance-logo-svg svg{max-height:74px;}
  .maintenance-bottom-player-inner{grid-template-columns:56px minmax(0,1fr);gap:10px;}
  .maintenance-player-cover-btn{width:56px;height:56px;border-radius:14px;}
  .maintenance-player-cover{margin-left:20px;border-radius:14px;}
  .maintenance-cover-overlay::before{width:30px;height:30px;}
  .maintenance-cover-overlay i{font-size:.76rem;}
  .maintenance-live-badge{font-size:.6rem;padding:4px 8px;}
  .maintenance-nowplaying-block strong{font-size:1.02rem;}
  .maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){font-size:.86rem;}
}


/* maintenance hotfixes */
.maintenance-logo-outside{margin-bottom:14px;min-height:88px;display:flex;align-items:center;justify-content:center;flex-direction:column;}
.maintenance-logo-outside .maintenance-logo{display:none;}
.maintenance-logo-outside.is-loaded .maintenance-logo{display:block;}
.maintenance-logo-fallback{display:none;}
.maintenance-logo-outside.has-fallback .maintenance-logo-fallback{display:block;}
.maintenance-live-badge{padding:3px 8px !important;font-size:.56rem !important;letter-spacing:.03em !important;border-radius:999px;line-height:1 !important;}
.maintenance-bottom-player-inner{grid-template-columns:56px minmax(0,1fr) minmax(220px,320px) !important;gap:12px !important;padding:10px 0 !important;}
.maintenance-player-cover-btn{width:56px !important;height:56px !important;border-radius:14px !important;}
.maintenance-player-cover{margin-left:20px;border-radius:14px !important;}
.maintenance-cover-overlay::before{width:28px !important;height:28px !important;}
.maintenance-cover-overlay i{font-size:.7rem !important;transform:none !important;}
.maintenance-nowplaying-block{gap:2px !important;}
.maintenance-nowplaying-block strong{line-height:1.02 !important;}
.maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){line-height:.96 !important;}
@media (max-width: 900px){
  .maintenance-bottom-player-inner{grid-template-columns:52px minmax(0,1fr) !important;gap:10px !important;}
  .maintenance-player-cover-btn{width:52px !important;height:52px !important;border-radius:13px !important;}
  .maintenance-cover-overlay::before{width:26px !important;height:26px !important;}
}
@media (max-width: 640px){
  .maintenance-logo-outside{min-height:72px;}
  .maintenance-bottom-player-inner{grid-template-columns:48px minmax(0,1fr) !important;gap:9px !important;}
  .maintenance-player-cover-btn{width:48px !important;height:48px !important;border-radius:12px !important;}
  .maintenance-cover-overlay::before{width:24px !important;height:24px !important;}
  .maintenance-cover-overlay i{font-size:.62rem !important;}
  .maintenance-live-badge{padding:3px 7px !important;font-size:.52rem !important;}
}



/* Maintenance fixes */
.maintenance-logo-outside{
  position:relative;
  z-index:3;
  min-height:110px;
  margin-bottom:16px;
}
.maintenance-logo{
  display:block;
  width:auto;
  height:auto;
  max-width:min(340px,72vw);
  max-height:110px;
  object-fit:contain;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.22));
}
.maintenance-logo-outside .maintenance-logo{display:block !important;}
.maintenance-logo-outside.has-fallback .maintenance-logo{display:none !important;}
.maintenance-logo-outside.is-loaded .maintenance-logo-fallback, .maintenance-logo-outside .maintenance-logo-fallback{display:none !important;}
.maintenance-logo-outside.has-fallback .maintenance-logo-fallback{display:block !important;}

.maintenance-bottom-player-inner{
  grid-template-columns:64px minmax(0,1fr) minmax(220px,320px);
  gap:14px;
  padding:10px 0;
}
.maintenance-player-cover-btn{
  width:64px;
  height:64px;
  border-radius:16px;
  box-shadow:0 10px 22px rgba(0,0,0,.18);
}
.maintenance-player-cover{margin-left:20px;
  border-radius:16px;
}
.maintenance-cover-overlay{
  background:linear-gradient(180deg, rgba(10,16,30,.02), rgba(10,16,30,.20));
}
.maintenance-cover-overlay::before{
  width:34px;
  height:34px;
  background:#ef4444;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 8px 18px rgba(0,0,0,.22);
}
.maintenance-cover-overlay i{
  font-size:.82rem;
  transform:translateX(1px);
}
.maintenance-bottom-player.is-playing .maintenance-cover-overlay::before{
  background:linear-gradient(180deg, rgba(255,255,255,.24), rgba(255,255,255,.12));
  border-color:rgba(255,255,255,.24);
  box-shadow:0 8px 18px rgba(0,0,0,.18);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.maintenance-live-badge{
  padding:3px 8px;
  font-size:.56rem;
  letter-spacing:.04em;
  border-radius:999px;
}
.maintenance-nowplaying-block{
  gap:4px;
}
.maintenance-nowplaying-block strong{
  font-size:1.08rem;
  line-height:1;
}
.maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){
  font-size:.88rem;
  line-height:.98;
}
@media (max-width:980px){
  .maintenance-bottom-player-inner{
    grid-template-columns:64px minmax(0,1fr);
    gap:12px;
  }
  .maintenance-player-cover-btn{
    width:64px;
    height:64px;
    border-radius:16px;
  }
  .maintenance-player-cover{margin-left:20px;border-radius:16px;}
  .maintenance-cover-overlay::before{
    width:34px;
    height:34px;
  }
}


/* Maintenance hotfixes */
.maintenance-logo{max-width:min(340px,64vw);max-height:92px;}
.maintenance-logo-svg{display:flex;align-items:center;justify-content:center;line-height:0;}
.maintenance-logo-svg svg{display:block;max-width:min(340px,64vw);max-height:92px;width:auto;height:auto;}
.maintenance-live-badge{padding:4px 8px !important;font-size:.62rem !important;letter-spacing:.04em !important;}
.maintenance-nowplaying-block{gap:1px !important;}
.maintenance-player-cover-btn{width:64px !important;height:64px !important;border-radius:16px !important;}
.maintenance-player-cover{margin-left:20px;border-radius:16px !important;}
.maintenance-cover-overlay::before{width:36px !important;height:36px !important;}
.maintenance-cover-overlay i{font-size:.92rem !important;}
.maintenance-bottom-player-inner{grid-template-columns:64px minmax(0,1fr) minmax(240px,340px) !important;gap:14px !important;}
@media (max-width: 720px){
  .maintenance-logo,.maintenance-logo-svg svg{max-width:min(260px,70vw);max-height:72px;}
  .maintenance-player-cover-btn{width:58px !important;height:58px !important;}
  .maintenance-cover-overlay::before{width:32px !important;height:32px !important;}
  .maintenance-cover-overlay i{font-size:.82rem !important;}
}


/* Maintenance public final fixes */
.maintenance-logo-outside{
  margin-bottom:14px !important;
  min-height:88px !important;
}
.maintenance-logo,
.maintenance-logo-object{
  display:block !important;
  width:min(320px,58vw) !important;
  height:90px !important;
  max-width:min(320px,58vw) !important;
  max-height:90px !important;
  margin:0 auto !important;
  object-fit:contain !important;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.24)) !important;
}
.maintenance-logo-object{background:transparent !important;overflow:visible !important;border:0 !important;}
.maintenance-logo-fallback{display:none !important;}
.maintenance-logo-outside.has-fallback .maintenance-logo-fallback{display:block !important;}
.maintenance-logo-outside.has-fallback .maintenance-logo,
.maintenance-logo-outside.has-fallback .maintenance-logo-object{display:none !important;}
.maintenance-live-badge{
  padding:2px 7px !important;
  font-size:.54rem !important;
  letter-spacing:.03em !important;
  line-height:1 !important;
}
.maintenance-bottom-player-inner{
  grid-template-columns:52px minmax(0,1fr) minmax(220px,320px) !important;
  gap:12px !important;
}
.maintenance-player-cover-btn{
  width:52px !important;
  height:52px !important;
  border-radius:14px !important;
}
.maintenance-player-cover{margin-left:20px;border-radius:14px !important;}
.maintenance-cover-overlay::before{
  width:28px !important;
  height:28px !important;
}
.maintenance-cover-overlay i{
  font-size:.72rem !important;
}
.maintenance-nowplaying-block{gap:0 !important;}
.maintenance-nowplaying-block strong{line-height:1.02 !important;}
.maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){line-height:1 !important;}
@media (max-width: 720px){
  .maintenance-logo,.maintenance-logo-object{width:min(240px,72vw) !important;height:72px !important;max-width:min(240px,72vw) !important;max-height:72px !important;}
  .maintenance-bottom-player-inner{grid-template-columns:48px minmax(0,1fr) !important;}
  .maintenance-player-cover-btn{width:48px !important;height:48px !important;border-radius:12px !important;}
  .maintenance-cover-overlay::before{width:25px !important;height:25px !important;}
  .maintenance-cover-overlay i{font-size:.66rem !important;}
  .maintenance-live-badge{padding:2px 6px !important;font-size:.5rem !important;}
}


/* Maintenance flux picker + volume controls */
.maintenance-player-actions{display:flex;align-items:center;justify-content:flex-end;gap:14px;min-width:0;height:100%;}
.maintenance-player-fields--custom{min-width:260px;max-width:360px;}
.maintenance-flux-picker{position:relative;min-width:260px;}
.maintenance-flux-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:18px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.08));box-shadow:inset 0 1px 0 rgba(255,255,255,.07);color:#fff;cursor:pointer;min-height:56px;}
.maintenance-flux-trigger-main,.maintenance-flux-option-main{display:flex;align-items:center;gap:12px;min-width:0;}
.maintenance-flux-trigger-text,.maintenance-flux-option-text{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:800;color:#fff;}
.maintenance-flux-trigger-icon{width:18px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.8);transition:transform .2s ease;}
.maintenance-flux-picker.is-open .maintenance-flux-trigger-icon{transform:rotate(180deg);}
.maintenance-flux-thumb{width:38px;height:38px;border-radius:12px;overflow:hidden;flex:0 0 38px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);}
.maintenance-flux-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.maintenance-flux-dropdown{position:absolute;left:0;right:0;bottom:calc(100% + 12px);padding:12px;border-radius:22px;border:1px solid rgba(255,255,255,.12);background:rgba(4,8,18,.94);box-shadow:0 24px 54px rgba(0,0,0,.34);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:10px;z-index:35;max-height:min(360px,50vh);overflow:auto;}
.maintenance-flux-option{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:none;border-radius:18px;background:transparent;color:#fff;cursor:pointer;text-align:left;transition:background .18s ease, box-shadow .18s ease;}
.maintenance-flux-option:hover{background:rgba(255,255,255,.06);}
.maintenance-flux-option.is-selected{background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.10));box-shadow:inset 0 0 0 1px rgba(255,255,255,.10);}
.maintenance-flux-option-check{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);color:#fff;opacity:0;transform:scale(.9);transition:opacity .18s ease, transform .18s ease;}
.maintenance-flux-option.is-selected .maintenance-flux-option-check{opacity:1;transform:scale(1);}
.maintenance-volume-controls{display:flex;align-items:center;gap:10px;min-width:142px;}
.maintenance-volume-btn{width:44px;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.10);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 44px;}
.maintenance-volume-range{width:88px;accent-color:#ff4d4d;cursor:pointer;}
@media (max-width: 980px){
  .maintenance-bottom-player-inner{grid-template-columns:56px minmax(0,1fr) !important;}
  .maintenance-player-actions{grid-column:1 / -1;justify-content:space-between;align-items:center;}
  .maintenance-player-fields--custom{min-width:0;max-width:none;flex:1 1 auto;}
  .maintenance-flux-picker{min-width:0;}
}
@media (max-width: 640px){
  .maintenance-player-actions{flex-direction:column;align-items:stretch;gap:10px;}
  .maintenance-volume-controls{justify-content:flex-end;min-width:0;}
  .maintenance-flux-trigger{min-height:52px;padding:9px 12px;}
  .maintenance-flux-thumb{width:34px;height:34px;flex-basis:34px;}
}


/* Maintenance selector interaction fixes */
.maintenance-flux-dropdown[hidden]{display:none !important;}
.maintenance-volume-btn{border-radius:999px !important;width:40px !important;height:40px !important;flex-basis:40px !important;}
.maintenance-volume-btn.is-muted{background:rgba(255,255,255,.06) !important;}
.maintenance-volume-range{width:96px;}
.maintenance-flux-trigger,.maintenance-flux-option{user-select:none;}
.maintenance-player-fields--custom{position:relative;z-index:40;}

/* Maintenance volume vertical alignment hotfix */
.maintenance-player-actions,.maintenance-player-fields--custom,.maintenance-flux-picker,.maintenance-flux-trigger,.maintenance-volume-controls{align-self:center;}
.maintenance-volume-controls{display:flex !important;align-items:center !important;justify-content:center;align-self:center !important;height:56px;}
.maintenance-volume-btn{display:inline-flex !important;align-items:center !important;justify-content:center !important;align-self:center !important;margin:0 !important;}
.maintenance-volume-range{display:block;align-self:center !important;margin:0 !important;position:relative;top:0;}
@media (max-width: 980px){
  .maintenance-player-actions{align-items:center !important;}
  .maintenance-volume-controls{justify-content:flex-end;align-items:center !important;}
}

/* Maintenance player bar final alignment tweaks */
.maintenance-bottom-player-inner{
  grid-template-columns:72px minmax(0,1fr) auto !important;
  gap:16px !important;
  align-items:center !important;
}
.maintenance-player-cover-btn{
  width:72px !important;
  height:72px !important;
  border-radius:18px !important;
}
.maintenance-player-cover{margin-left:20px;border-radius:18px !important;}
.maintenance-nowplaying-block{
  gap:2px !important;
  align-content:center !important;
}
.maintenance-nowplaying-block strong{
  font-size:1.2rem !important;
  line-height:1.04 !important;
}
.maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){
  font-size:.98rem !important;
  line-height:1.02 !important;
}
.maintenance-player-actions{
  margin-left:auto !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:14px !important;
  width:auto !important;
}
.maintenance-volume-controls{
  order:1 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;
  min-width:auto !important;
  height:44px !important;
}
.maintenance-player-fields--custom,
.maintenance-flux-picker{
  order:2 !important;
}
.maintenance-flux-trigger{
  min-width:260px !important;
}
.maintenance-volume-btn{
  width:40px !important;
  height:40px !important;
  flex:0 0 40px !important;
  border-radius:999px !important;
}
.maintenance-volume-range{
  width:0 !important;
  min-width:0 !important;
  opacity:0 !important;
  overflow:hidden !important;
  margin:0 !important;
  pointer-events:none !important;
  transition:width .18s ease, opacity .18s ease !important;
}
.maintenance-volume-controls:hover .maintenance-volume-range,
.maintenance-volume-controls:focus-within .maintenance-volume-range{
  width:88px !important;
  opacity:1 !important;
  pointer-events:auto !important;
}
@media (max-width: 900px){
  .maintenance-bottom-player-inner{
    grid-template-columns:64px minmax(0,1fr) !important;
  }
  .maintenance-player-actions{
    grid-column:1 / -1 !important;
    width:100% !important;
    justify-content:flex-end !important;
  }
  .maintenance-flux-trigger{min-width:220px !important;}
}


/* Maintenance socials + badge spacing */
.maintenance-socials-wrap{display:flex;justify-content:center;margin-top:26px;margin-bottom:112px;}
.maintenance-socials{display:flex;flex-direction:column;align-items:center;gap:14px;padding:2px 0 0;}
.maintenance-socials h2{margin:0;font-size:.86rem;font-weight:800;letter-spacing:.18em;color:rgba(255,255,255,.82);}
.maintenance-socials-grid{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;}
.maintenance-social-btn{width:48px;height:48px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.16);background:rgba(10,16,30,.48);box-shadow:0 10px 26px rgba(0,0,0,.18);color:#fff;text-decoration:none;transition:transform .18s ease, background .18s ease, border-color .18s ease;}
.maintenance-social-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.26);}
.maintenance-social-btn i{font-size:1rem;}
.maintenance-nowplaying-label.maintenance-live-badge{margin-bottom:8px;padding:4px 10px;font-size:.68rem;letter-spacing:.06em;}
@media (max-width: 767px){
  .maintenance-socials-wrap{margin-top:18px;margin-bottom:104px;}
  .maintenance-socials{gap:12px;}
  .maintenance-social-btn{width:44px;height:44px;}
  .maintenance-social-btn i{font-size:.95rem;}
  .maintenance-nowplaying-label.maintenance-live-badge{margin-bottom:6px;font-size:.64rem;}
}

/* Maintenance public fixes: socials above player + slightly larger live badge */
.maintenance-page{
  padding-bottom: 252px !important;
}
.maintenance-socials-wrap{
  margin-top: 18px !important;
  margin-bottom: 156px !important;
  position: relative;
  z-index: 4;
}
.maintenance-socials{
  gap: 12px !important;
}
.maintenance-nowplaying-label.maintenance-live-badge,
.maintenance-live-badge{
  padding: 5px 12px !important;
  font-size: .74rem !important;
  letter-spacing: .05em !important;
  line-height: 1 !important;
}
@media (max-width: 900px){
  .maintenance-page{
    padding-bottom: 272px !important;
  }
  .maintenance-socials-wrap{
    margin-top: 16px !important;
    margin-bottom: 168px !important;
  }
  .maintenance-nowplaying-label.maintenance-live-badge,
  .maintenance-live-badge{
    padding: 5px 11px !important;
    font-size: .7rem !important;
  }
}
@media (max-width: 640px){
  .maintenance-page{
    padding-bottom: 292px !important;
  }
  .maintenance-socials-wrap{
    margin-bottom: 182px !important;
  }
  .maintenance-social-btn{
    width: 44px !important;
    height: 44px !important;
  }
  .maintenance-nowplaying-label.maintenance-live-badge,
  .maintenance-live-badge{
    padding: 4px 10px !important;
    font-size: .68rem !important;
  }
}

/* Maintenance public final tweak: socials lower, centered live block, taller player */
.maintenance-content-shell{
  position: relative;
  z-index: 4;
}
.maintenance-socials-wrap{
  margin-top: 34px !important;
  margin-bottom: 152px !important;
}
.maintenance-socials{
  padding-top: 6px !important;
}

.maintenance-bottom-player{
  min-height: 104px;
}
.maintenance-bottom-player-inner{
  grid-template-columns: 74px minmax(0,1fr) minmax(240px,340px) !important;
  gap: 16px !important;
  align-items: center !important;
  padding: 14px 0 !important;
}
.maintenance-player-cover-btn{
  width: 74px !important;
  height: 74px !important;
  border-radius: 18px !important;
  align-self: center !important;
}
.maintenance-player-cover{margin-left:20px;
  border-radius: 18px !important;
}
.maintenance-cover-overlay::before{
  width: 40px !important;
  height: 40px !important;
}
.maintenance-cover-overlay i{
  font-size: .98rem !important;
}
.maintenance-nowplaying-block{
  min-height: 74px;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-self: center !important;
  gap: 4px !important;
}
.maintenance-nowplaying-label.maintenance-live-badge,
.maintenance-live-badge{
  margin-bottom: 4px !important;
  padding: 5px 12px !important;
  font-size: .76rem !important;
}
.maintenance-nowplaying-block strong{
  font-size: 1.16rem !important;
  line-height: 1.08 !important;
}
.maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){
  font-size: .96rem !important;
  line-height: 1.08 !important;
}

@media (max-width: 900px){
  .maintenance-socials-wrap{
    margin-top: 28px !important;
    margin-bottom: 158px !important;
  }
  .maintenance-bottom-player{
    min-height: 112px;
  }
  .maintenance-bottom-player-inner{
    grid-template-columns: 82px minmax(0,1fr) !important;
    gap: 14px !important;
    padding: 14px 0 16px !important;
  }
  .maintenance-player-cover-btn{
    width: 82px !important;
    height: 82px !important;
    border-radius: 20px !important;
  }
  .maintenance-player-cover{margin-left:20px;
    border-radius: 20px !important;
  }
  .maintenance-cover-overlay::before{
    width: 46px !important;
    height: 46px !important;
  }
  .maintenance-nowplaying-block{
    min-height: 82px;
  }
  .maintenance-nowplaying-label.maintenance-live-badge,
  .maintenance-live-badge{
    font-size: .72rem !important;
    padding: 5px 11px !important;
  }
}

@media (max-width: 640px){
  .maintenance-page{
    padding-bottom: 304px !important;
  }
  .maintenance-socials-wrap{
    margin-top: 12px !important;
    margin-bottom: 176px !important;
  }
  .maintenance-bottom-player{
    min-height: 116px;
  }
  .maintenance-bottom-player-inner{
    grid-template-columns: 86px minmax(0,1fr) !important;
    gap: 14px !important;
    padding: 15px 0 17px !important;
  }
  .maintenance-player-cover-btn{
    width: 86px !important;
    height: 86px !important;
    border-radius: 20px !important;
  }
  .maintenance-player-cover{margin-left:20px;
    border-radius: 20px !important;
  }
  .maintenance-cover-overlay::before{
    width: 48px !important;
    height: 48px !important;
  }
  .maintenance-cover-overlay i{
    font-size: 1.02rem !important;
  }
  .maintenance-nowplaying-block{
    min-height: 86px;
    gap: 3px !important;
  }
  .maintenance-nowplaying-label.maintenance-live-badge,
  .maintenance-live-badge{
    font-size: .7rem !important;
    padding: 5px 10px !important;
  }
  .maintenance-nowplaying-block strong{
    font-size: 1.1rem !important;
  }
  .maintenance-nowplaying-block span:not(.maintenance-nowplaying-label){
    font-size: .92rem !important;
  }
}


/* maintenance socials position final */
.maintenance-socials-wrap{margin-top:12px !important;}
@media (max-width: 900px){
  .maintenance-socials-wrap{margin-top:10px !important;}
}
@media (max-width: 640px){
  .maintenance-socials-wrap{margin-top:8px !important;}
}

/* maintenance socials truly under card */
.maintenance-content-shell{display:flex !important;align-items:center !important;justify-content:center !important;min-height:calc(100vh - 150px) !important;padding:20px 0 36px !important;}
.maintenance-topzone{min-height:auto !important;gap:0 !important;}
.maintenance-card{margin-bottom:0 !important;}
.maintenance-socials-wrap{width:100% !important;display:flex !important;justify-content:center !important;margin-top:clamp(34px,7vh,72px) !important;margin-bottom:0 !important;position:relative !important;z-index:4 !important;}
.maintenance-socials{padding-top:0 !important;}
.maintenance-page{justify-content:flex-start !important;padding-bottom:170px !important;}
@media (max-width: 900px){
  .maintenance-content-shell{min-height:calc(100vh - 170px) !important;padding-bottom:30px !important;}
  .maintenance-socials-wrap{margin-top:clamp(28px,6vh,56px) !important;}
  .maintenance-page{padding-bottom:190px !important;}
}
@media (max-width: 640px){
  .maintenance-content-shell{min-height:calc(100vh - 182px) !important;padding-top:10px !important;padding-bottom:24px !important;}
  .maintenance-socials-wrap{margin-top:26px !important;}
  .maintenance-page{padding-bottom:204px !important;}
}


/* maintenance card transparency + red badge override */
.maintenance-card{
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.maintenance-station-name{
  background: #d91f26 !important;
  border: 1px solid #ff4d55 !important;
  color: #ffffff !important;
  box-shadow: 0 10px 24px rgba(217,31,38,.28) !important;
}


/* Maintenance page final layout fixes */
html, body.maintenance-page-body {
  height: 100%;
}
body.maintenance-page-body {
  min-height: 100vh !important;
  height: 100vh !important;
  overflow: hidden !important;
}
body.maintenance-page-body .site-shell,
body.maintenance-page-body .site-main {
  min-height: 100vh;
}
.maintenance-page {
  min-height: 100vh !important;
  height: 100vh !important;
  padding: 24px 0 112px !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}
.maintenance-content-shell {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  padding: 0 !important;
  overflow: hidden;
}
.maintenance-topzone {
  min-height: 0 !important;
  height: 100%;
  gap: 34px !important;
}
.maintenance-logo-outside {
  margin-bottom: 8px !important;
}
.maintenance-card {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.maintenance-station-name {
  background: #d61f2c !important;
  color: #fff !important;
  border: none !important;
  box-shadow: none !important;
}


/* Top bar module */
.site-topbar {
  position: relative;
  z-index: 70;
  overflow: hidden;
  background:
    linear-gradient(0deg, rgba(0, 0, 0, .18), rgba(0, 0, 0, .18)),
    rgba(var(--primary-rgb), .96);
  color: #fff;
  box-shadow: 0 8px 22px rgba(15, 23, 42, .12);
}
.site-topbar::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.12));
  pointer-events: none;
}
.site-topbar-inner {
  position: relative;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 4px;
  padding-bottom: 4px;
}
.site-topbar-content {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;
}
.site-topbar-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.16);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  white-space: nowrap;
}
.site-topbar-text {
  font-size: 13px;
  line-height: 1.3;
  font-weight: 700;
}
.site-topbar-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 30px;
  flex: 0 0 auto;
  padding: 4px 18px;
  border-radius: 999px;
  background: rgba(0, 0, 0, .18);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  transition: transform .22s ease, background-color .22s ease, border-color .22s ease;
}
.site-topbar-button:hover {
  transform: translateY(-1px);
  background: rgba(0, 0, 0, .28);
  border-color: rgba(255,255,255,.28);
}
@media (max-width: 900px) {
  .site-topbar-inner {
    align-items: flex-start;
    flex-direction: column;
  }
  .site-topbar-button {
    width: 100%;
  }
}
@media (max-width: 640px) {
  .site-topbar-inner {
    min-height: 0;
    gap: 8px;
    padding-top: 6px;
    padding-bottom: 6px;
  }
  .site-topbar-content {
    align-items: flex-start;
    flex-direction: column;
    gap: 7px;
  }
  .site-topbar-text {
    font-size: 12px;
  }
  .site-topbar-button {
    min-height: 28px;
    padding: 4px 16px;
    font-size: 12px;
  }
}

/* HEADER PADDING FIX */
header, .header, .site-header {
  padding-top: 24px !important;
  padding-bottom: 24px !important;
}


/* Top bar darker overlay */
.top-bar::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.25);
  pointer-events: none;
}

.top-bar {
  position: relative;
  overflow: hidden;
}


/* FORCE TOPBAR DARK OVERLAY (ALL POSSIBLE SELECTORS) */
.top-bar,
.topbar,
.header-topbar,
.top-bar-container {
  position: relative !important;
  overflow: hidden !important;
}

.top-bar::after,
.topbar::after,
.header-topbar::after,
.top-bar-container::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: rgba(0,0,0,0.35) !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

.top-bar > *,
.topbar > *,
.header-topbar > *,
.top-bar-container > * {
  position: relative;
  z-index: 2;
}


/* Darker topbar overlay */
.site-topbar,
.top-bar,
.topbar {
  position: relative !important;
}

.site-topbar::after,
.top-bar::after,
.topbar::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5) !important;
  pointer-events: none;
  z-index: 1;
}

.site-topbar > *,
.top-bar > *,
.topbar > * {
  position: relative;
  z-index: 2;
}


/* Balanced topbar overlay */
.site-topbar::after,
.top-bar::after,
.topbar::after {
  background: rgba(0,0,0,0.35) !important;
}


/* Lighter topbar overlay */
.site-topbar::after,
.top-bar::after,
.topbar::after {
  background: rgba(0,0,0,0.2) !important;
}


/* Team module */
.team-page {
  padding: 34px 0 84px;
}
.team-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 20px;
}
.team-card {
  background: #fff;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 18px 60px rgba(15, 23, 42, .08);
}
.team-card-link {
  display: block;
  color: inherit;
  text-decoration: none;
  height: 100%;
}
.team-card-media {
  aspect-ratio: 1 / 1;
  background: #eff3fb;
  overflow: hidden;
}
.team-card-media img,
.team-member-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.team-card-placeholder,
.team-member-placeholder {
  width: 100%;
  height: 100%;
  min-height: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, rgba(var(--primary-rgb), .12), rgba(15, 23, 42, .08));
  color: rgba(15, 23, 42, .42);
  font-size: 52px;
}
.team-card-body {
  padding: 16px 16px 18px;
  text-align: center;
}
.team-card-body h2 {
  margin: 0 0 6px;
  font-size: clamp(18px, 1.55vw, 24px);
  font-weight: 800;
  line-height: 1.2;
}
.team-card-body p {
  display: block;
  margin: 0;
  color: #5b6473;
  font-size: 14px;
  line-height: 1.45;
}
.team-member-page {
  padding: 34px 0 84px;
}
.team-back-link {
  margin-bottom: 24px;
}
.team-member-card {
  display: grid;
  gap: 28px;
}
.team-member-top {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 32px;
  align-items: start;
}
.team-member-cover {
  border-radius: 32px;
  overflow: hidden;
  background: #eff3fb;
  aspect-ratio: 1 / 1;
  box-shadow: 0 20px 60px rgba(15, 23, 42, .10);
}
.team-member-content {
  background: #fff;
  border-radius: 32px;
  padding: 30px;
  box-shadow: 0 18px 60px rgba(15, 23, 42, .08);
}
.team-member-content h2 {
  margin: 0 0 8px;
  font-size: clamp(34px, 4.2vw, 56px);
  line-height: 1.02;
}
.team-member-role {
  margin: 0 0 18px;
  color: #586274;
  font-size: 19px;
  line-height: 1.5;
}
.team-member-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 24px;
}
.team-member-socials a {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--primary-rgb), .08);
  color: var(--secondary);
  font-size: 18px;
}
.team-member-description {
  color: #273244;
  font-size: 17px;
  line-height: 1.85;
}
.team-member-shows .panel-card {
  border-radius: 28px;
}
.team-show-list {
  display: grid;
  gap: 12px;
}
.team-show-item {
  background: rgba(var(--primary-rgb), .07);
  border: 1px solid rgba(var(--primary-rgb), .10);
  color: #142033;
  border-radius: 18px;
  padding: 16px 18px;
  font-weight: 700;
}
.team-empty-state {
  text-align: center;
}
@media (max-width: 1180px) {
  .team-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 980px) {
  .team-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .team-member-top {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 640px) {
  .team-grid {
    grid-template-columns: 1fr;
  }
  .team-card-body {
    padding: 16px 16px 18px;
  }
  .team-member-content {
    padding: 22px;
    border-radius: 26px;
  }
  .team-member-cover {
    border-radius: 26px;
  }
}


/* Team module overrides */
.team-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 20px;
}
.team-card {
  border-radius: 24px;
}
.team-card-body {
  padding: 14px 14px 18px;
  text-align: center;
}
.team-card-body h2 {
  margin: 0 0 4px;
  font-size: clamp(18px, 1.35vw, 22px);
  font-weight: 800;
}
.team-card-body p {
  font-size: 14px;
  line-height: 1.45;
}
.team-member-band-subtitle {
  display: inline-block;
  margin-top: 2px;
  color: rgba(255,255,255,.9);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.05;
}
.team-member-card {
  gap: 24px;
}
.team-member-main {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 34px;
  align-items: start;
  border-radius: 30px;
}
.team-member-aside {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.team-member-cover {
  border-radius: 28px;
}
.team-member-content {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  padding: 0;
  min-height: 100%;
}
.team-member-role {
  display: none;
}
.team-member-socials--stacked {
  justify-content: center;
  margin-bottom: 0;
}
.team-member-description {
  font-size: 17px;
  line-height: 1.9;
}
.team-member-description--empty {
  color: #64748b;
  font-style: italic;
}
.team-member-shows.panel-card {
  border-radius: 28px;
}
.team-show-list--placeholder {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.team-show-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 18px 18px;
}
.team-show-item span {
  color: #64748b;
  font-size: 14px;
  font-weight: 600;
}
@media (max-width: 1200px) {
  .team-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 980px) {
  .team-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .team-member-main {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 760px) {
  .team-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .team-show-list--placeholder {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 520px) {
  .team-grid {
    grid-template-columns: 1fr;
  }
}


.team-member-email {
  margin-top: 14px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #1f2b3d;
  font-weight: 700;
  word-break: break-word;
}

.team-member-email i {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--primary-rgb), .08);
  color: var(--text);
}





/* Team member socials: rely on PHP output only */
.team-member-socials[data-team-socials="member"] {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.team-member-socials[data-team-socials="member"] a {
  display: inline-flex !important;
}


/* Team member socials real fix */
.team-member-socials[data-team-socials="member"] {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.team-member-socials[data-team-socials="member"] a {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--primary-rgb), .08);
  color: var(--secondary);
  text-decoration: none;
}
.team-member-socials[data-team-socials="member"] a i {
  font-size: 18px;
  line-height: 1;
}


/* Team member social buttons: only explicit filled member links */
.team-member-socials[data-team-socials="member"] {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.team-member-socials[data-team-socials="member"] a {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--primary-rgb), .08);
  color: var(--secondary);
  text-decoration: none;
}
.team-member-socials[data-team-socials="member"] .team-member-social-icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.team-member-socials[data-team-socials="member"] .team-member-social-icon svg {
  width: 18px;
  height: 18px;
  display: block;
}


/* Explicit team member social buttons */
.team-member-socials[data-team-socials="member"] {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.team-member-socials[data-team-socials="member"] .team-member-social-btn {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--primary-rgb), .08);
  color: var(--secondary);
  text-decoration: none;
}
.team-member-socials[data-team-socials="member"] .team-member-social-btn i {
  font-size: 18px;
  line-height: 1;
}


/* REAL FIX spacing prénom / titre */
.page-title-band h1 {
  line-height: 1.1 !important;
  margin-bottom: 0 !important;
}

.team-member-band-subtitle {
  display: block !important;
  margin-top: -4px !important;
  font-size: 18px !important;
  line-height: 1.05 !important;
}


/* Balanced spacing prénom / titre */
.team-member-band-subtitle {
  margin-top: -1px !important;
  line-height: 1.1 !important;
}


/* More spacing prénom / titre */
.team-member-band-subtitle {
  margin-top: 2px !important;
  line-height: 1.15 !important;
}


/* Admin shows module */
.panel-card-head--split {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.inline-filter-form {
  display: flex;
  align-items: center;
  gap: 12px;
}
.inline-filter-form label {
  margin: 0;
  white-space: nowrap;
}
.empty-state-box {
  border: 1px dashed rgba(var(--primary-rgb), .18);
  border-radius: 22px;
  padding: 26px 22px;
  text-align: center;
  color: #607089;
  background: #fafbff;
}
.table-responsive {
  width: 100%;
  overflow-x: auto;
}
.admin-table {
  width: 100%;
  border-collapse: collapse;
}
.admin-table th,
.admin-table td {
  padding: 16px 14px;
  border-bottom: 1px solid #e8edf5;
  text-align: left;
  vertical-align: middle;
}
.admin-table th {
  color: #243248;
  font-size: 14px;
}
.table-subline {
  margin-top: 6px;
  color: #66768d;
  font-size: 14px;
}
.table-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.btn-small {
  padding: 10px 14px;
  font-size: 13px;
}
.btn-danger-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  border: 1px solid rgba(225, 60, 60, .22);
  color: #c63e3e;
  background: #fff;
  font-weight: 700;
}
.panel-card-wide {
  max-width: none;
}
.show-form .form-grid-2,
.show-form .panel-subcard,
.show-form .form-actions {
  margin-top: 22px;
}
.panel-subcard {
  border: 1px solid #e8edf5;
  border-radius: 24px;
  padding: 22px;
  background: #fff;
}
.panel-subcard h3 {
  margin: 0 0 16px;
}
.host-choice-group {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.host-choice {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
}
.switch-line {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
}
.switch-label {
  margin: 0;
  font-weight: 700;
}
.switch-toggle {
  position: relative;
  display: inline-flex;
  width: 58px;
  height: 34px;
}
.switch-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}
.switch-toggle span {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: #d5ddea;
  transition: .2s ease;
}
.switch-toggle span::after {
  content: "";
  position: absolute;
  width: 26px;
  height: 26px;
  left: 4px;
  top: 4px;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
  transition: .2s ease;
}
.switch-toggle input:checked + span {
  background: var(--blue);
}
.switch-toggle input:checked + span::after {
  transform: translateX(24px);
}
.show-image-preview {
  margin-top: 18px;
}
.show-image-preview img {
  width: 160px;
  height: 160px;
  object-fit: cover;
  border-radius: 20px;
  border: 1px solid #e8edf5;
}
@media (max-width: 860px) {
  .panel-card-head--split,
  .inline-filter-form,
  .switch-line {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Page programmes */
.programmes-page{padding:42px 0 110px}.programmes-shell{background:#fff;border:1px solid var(--line,#e4e9f3);border-radius:28px;padding:24px;box-shadow:0 20px 50px rgba(15,23,42,.07)}.programmes-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}.programmes-week-nav{display:flex;align-items:center;gap:12px}.programmes-week-nav a{width:42px;height:42px;border:1px solid #dce6f5;border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--black);text-decoration:none;background:#fff}.programmes-week-nav strong{font-size:16px;color:var(--black)}.programmes-day-select select{height:44px;border:1px solid #dce6f5;border-radius:14px;background:#fff;padding:0 14px;font-weight:800;color:var(--black)}.programmes-grid{display:grid;grid-template-columns:repeat(var(--program-days,7),minmax(180px,1fr));gap:14px;overflow-x:auto;padding-bottom:4px}.programme-day{min-width:180px;border:1px solid #e2eaf6;border-radius:22px;background:#f8fbff;overflow:hidden}.programme-day header{height:58px;background:linear-gradient(135deg,var(--blue),var(--black));color:#fff;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 14px}.programme-day header strong{font-size:15px}.programme-day header span{font-size:12px;font-weight:900;opacity:.88}.programme-day-list{padding:12px;display:flex;flex-direction:column;gap:12px;min-height:320px}.programme-empty{min-height:88px;border:1px dashed #cdd8eb;border-radius:18px;display:flex;align-items:center;justify-content:center;text-align:center;color:#718096;font-weight:800;font-size:13px;padding:12px}.programme-card{background:#fff;border:1px solid #dfe8f5;border-radius:20px;padding:10px;display:flex;gap:10px;align-items:center;box-shadow:0 12px 26px rgba(15,23,42,.06)}.programme-card-photo{width:54px;height:54px;border-radius:16px;overflow:hidden;background:#eef4ff;flex:0 0 54px;display:flex;align-items:center;justify-content:center;color:var(--blue)}.programme-card-photo img{width:100%;height:100%;object-fit:cover}.programme-card-body{min-width:0}.programme-card-time{display:inline-flex;font-size:12px;font-weight:900;color:var(--blue);margin-bottom:3px}.programme-card h2{font-size:15px;margin:0;color:var(--black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.programme-card p{font-size:12px;font-weight:800;color:#64748b;margin:4px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.programme-card p i{margin-right:4px}@media(max-width:900px){.programmes-shell{padding:16px;border-radius:22px}.programmes-grid{grid-template-columns:1fr}.programme-day{min-width:100%}.programmes-week-nav{width:100%;justify-content:space-between}.programmes-week-nav strong{text-align:center;font-size:14px}.programmes-day-select{width:100%}.programmes-day-select select{width:100%}}

/* Programmes showcase */
.programmes-showcase-page{padding:42px 0 110px;background:#f3f4f6}.programmes-showcase-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(320px,.95fr);gap:24px;align-items:stretch}.programmes-featured{min-height:430px;border-radius:0;overflow:hidden;background-size:cover;background-position:center;display:grid;grid-template-columns:minmax(220px,.78fr) minmax(300px,1fr);align-items:center;color:#fff;position:relative}.programmes-featured:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(255,255,255,.16),transparent 55%);pointer-events:none}.programmes-featured-photo{height:100%;display:flex;align-items:flex-end;justify-content:center;position:relative;z-index:1;overflow:hidden}.programmes-featured-photo img{max-width:100%;height:92%;object-fit:contain;object-position:bottom center;filter:drop-shadow(0 20px 35px rgba(0,0,0,.22))}.programmes-featured-photo i{font-size:86px;opacity:.8;margin-bottom:120px}.programmes-featured-content{position:relative;z-index:2;padding:48px 54px 48px 12px}.programmes-kicker{font-size:13px;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:#fff;opacity:.86}.programmes-featured-content h2{font-size:clamp(42px,5vw,78px);line-height:.92;text-transform:uppercase;margin:12px 0 10px;color:#fff;font-weight:950;letter-spacing:-.04em}.programmes-featured-content p{margin:0 0 18px;font-size:16px;font-weight:850;text-transform:uppercase;color:#fff}.programmes-listen-btn{display:inline-flex;align-items:center;gap:9px;height:44px;padding:0 22px;background:rgba(15,23,42,.82);color:#fff;text-decoration:none;text-transform:uppercase;font-weight:950}.programmes-today-list{background:#fff;display:flex;flex-direction:column;min-height:430px}.programmes-day-nav{height:86px;display:grid;grid-template-columns:54px 1fr 54px;align-items:center;text-align:center;background:#f2f2f2}.programmes-day-nav a{display:flex;align-items:center;justify-content:center;color:#050505;font-size:30px;text-decoration:none}.programmes-day-nav strong{display:block;font-size:27px;line-height:1;text-transform:uppercase;font-weight:950;color:#3b3b3b}.programmes-day-nav span{display:block;margin-top:5px;font-size:13px;color:var(--blue,#ef3b2d);font-weight:950;text-transform:uppercase}.programmes-day-lines{background:#fff}.programmes-line{min-height:51px;border-bottom:1px solid rgba(0,0,0,.7);display:grid;grid-template-columns:70px 1fr;align-items:center;gap:14px;padding:0 24px;color:#333}.programmes-line time{font-size:14px;color:#444}.programmes-line strong{font-size:16px;text-transform:uppercase;font-weight:950;letter-spacing:-.02em}.programmes-line.is-active time,.programmes-line.is-active strong{color:var(--blue,#ef3b2d)}.programmes-line-empty{height:160px;display:flex;align-items:center;justify-content:center;font-weight:900;color:#667085}.programmes-mosaic{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;margin-top:24px}.programmes-tile{height:260px;position:relative;overflow:hidden;background:#ddd;color:#fff;display:flex;align-items:flex-end}.programmes-tile:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.58),rgba(0,0,0,.04) 58%)}.programmes-tile>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.programmes-tile-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--blue,#ef3b2d),#111);font-size:64px}.programmes-tile>div:last-child{position:relative;z-index:2;padding:22px}.programmes-tile h3{margin:0;color:#fff;text-transform:uppercase;font-size:34px;line-height:.95;font-weight:950;letter-spacing:-.05em}.programmes-tile p{margin:8px 0 0;color:#fff;text-transform:uppercase;font-weight:850}@media(max-width:1100px){.programmes-showcase-layout{grid-template-columns:1fr}.programmes-featured{min-height:360px}.programmes-mosaic{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:700px){.programmes-showcase-page{padding-top:24px}.programmes-featured{grid-template-columns:1fr;min-height:420px}.programmes-featured-photo{height:210px}.programmes-featured-photo img{height:100%}.programmes-featured-content{padding:22px;text-align:center}.programmes-featured-content h2{font-size:42px}.programmes-day-nav strong{font-size:22px}.programmes-line{grid-template-columns:58px 1fr;padding:0 14px}.programmes-mosaic{grid-template-columns:1fr;gap:16px}.programmes-tile{height:230px}}

/* Correctifs programmes : émission en cours sans logo + navigation sans remontée */
#programmes-showcase{scroll-margin-top:110px;}
.programmes-showcase-page .programmes-featured.no-photo{
    min-height:430px;
    display:flex;
    align-items:center;
    background:
        radial-gradient(circle at 18% 24%, rgba(255,255,255,.18), transparent 28%),
        radial-gradient(circle at 86% 74%, rgba(255,255,255,.10), transparent 30%),
        linear-gradient(135deg, var(--blue,#ef3b2d), #141414 78%);
}
.programmes-showcase-page .programmes-featured.no-photo:after{
    content:"";
    position:absolute;
    inset:0;
    background:repeating-radial-gradient(circle at 16% 82%, rgba(255,255,255,.10) 0 2px, transparent 2px 42px);
    opacity:.35;
    pointer-events:none;
}
.programmes-showcase-page .programmes-featured.no-photo .programmes-featured-content{
    width:100%;
    max-width:760px;
    padding:56px 64px;
}
.programmes-showcase-page .programmes-featured.no-photo .programmes-kicker{
    display:inline-flex;
    align-items:center;
    min-height:28px;
    padding:0 12px;
    border-radius:999px;
    background:rgba(255,255,255,.16);
    backdrop-filter:blur(8px);
}
.programmes-showcase-page .programmes-featured.no-photo .programmes-featured-content h2{
    max-width:720px;
    font-size:clamp(44px,5.4vw,82px);
}
.programmes-showcase-page .programmes-featured.no-photo .programmes-featured-content p{
    max-width:560px;
    font-size:17px;
    opacity:.94;
}
.programmes-showcase-page .programmes-featured.has-photo{
    background-size:cover;
    background-position:center;
}
@media(max-width:700px){
    #programmes-showcase{scroll-margin-top:82px;}
    .programmes-showcase-page .programmes-featured.no-photo{min-height:330px;text-align:center;justify-content:center;}
    .programmes-showcase-page .programmes-featured.no-photo .programmes-featured-content{padding:34px 22px;}
}

/* Programmes showcase v14 */
.programmes-showcase-layout{align-items:stretch}.programmes-featured{border-radius:28px;overflow:hidden;background:linear-gradient(135deg,var(--blue,#ef3b2d),#191919);box-shadow:0 18px 44px rgba(15,23,42,.14)}.programmes-featured.no-photo{grid-template-columns:1fr;min-height:360px}.programmes-featured.no-photo:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 20%,rgba(255,255,255,.18),transparent 30%),linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,0));pointer-events:none}.programmes-featured-content{padding:48px 54px;max-width:720px}.programmes-featured.no-photo .programmes-featured-content{padding-left:58px}.programmes-kicker{display:inline-flex;align-items:center;min-height:30px;padding:0 14px;border-radius:999px;background:rgba(255,255,255,.18);backdrop-filter:blur(8px);font-size:12px}.programmes-featured-content h2{font-size:clamp(34px,4.2vw,58px);line-height:1;letter-spacing:-.04em}.programmes-featured-content p{font-size:15px;letter-spacing:.01em;opacity:.94}.programmes-listen-btn{border:0;border-radius:999px;cursor:pointer;height:46px;padding:0 24px;background:#111827;color:#fff}.programmes-listen-btn .programmes-listen-wave{display:none;align-items:center;gap:3px;height:18px}.programmes-listen-wave em{display:block;width:4px;height:9px;border-radius:999px;background:#fff;animation:programmesWave .72s ease-in-out infinite}.programmes-listen-wave em:nth-child(2){animation-delay:.12s}.programmes-listen-wave em:nth-child(3){animation-delay:.24s}.programmes-listen-btn.is-playing .programmes-listen-play{display:none}.programmes-listen-btn.is-playing .programmes-listen-wave{display:inline-flex}.programmes-today-list{border-radius:28px;overflow:hidden;box-shadow:0 18px 44px rgba(15,23,42,.10)}@keyframes programmesWave{0%,100%{height:8px}50%{height:18px}}
@media(max-width:700px){.programmes-featured,.programmes-today-list{border-radius:22px}.programmes-featured-content,.programmes-featured.no-photo .programmes-featured-content{padding:28px 22px}.programmes-featured-content h2{font-size:34px}}

.hero-program-live{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}
.hero-program-live em{font-style:normal;font-weight:800;opacity:.9}
.hero-program-time{display:inline-flex;align-items:center;justify-content:center;margin-right:8px;padding:6px 10px;border-radius:999px;background:var(--primary,#ef4444);color:#fff;font-size:12px;font-weight:900;line-height:1}
.programmes-time-badge{display:inline-flex;align-items:center;justify-content:center;width:max-content;margin:0 0 8px;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.18);color:#fff;font-size:13px;font-weight:950;line-height:1;backdrop-filter:blur(8px)}

/* Programmes - mosaïque des émissions */
.programmes-mosaic-section{margin-top:34px;}
.programmes-mosaic-title{margin:0 0 18px;color:#111827;font-size:clamp(24px,3vw,38px);line-height:1.05;font-weight:950;letter-spacing:-.04em;}
.programmes-mosaic{margin-top:0;}
.programmes-tile{border-radius:26px;isolation:isolate;box-shadow:0 18px 40px rgba(15,23,42,.10);}
.programmes-tile>img,.programmes-tile-placeholder{border-radius:inherit;transition:transform .35s ease,filter .35s ease;}
.programmes-tile:after{z-index:1;background:linear-gradient(0deg,rgba(0,0,0,.56) 0%,rgba(0,0,0,.28) 34%,rgba(0,0,0,.04) 62%,rgba(0,0,0,0) 100%);transition:background .3s ease;}
.programmes-tile-caption{position:relative;z-index:2;padding:22px;transform:translateY(22px);transition:transform .28s ease;}
.programmes-tile h3{margin:0;color:#fff;text-transform:uppercase;font-size:clamp(26px,3vw,34px);line-height:.95;font-weight:950;letter-spacing:-.05em;text-shadow:0 2px 18px rgba(0,0,0,.32);}
.programmes-tile p{margin:10px 0 0;color:rgba(255,255,255,.92);text-transform:uppercase;font-size:13px;line-height:1.25;font-weight:650;letter-spacing:.03em;opacity:0;transform:translateY(8px);transition:opacity .24s ease,transform .24s ease;}
.programmes-tile p span{display:block;margin-bottom:2px;font-size:10px;font-weight:800;letter-spacing:.14em;opacity:.72;}
.programmes-tile:hover>img,.programmes-tile:hover .programmes-tile-placeholder{transform:scale(1.045);filter:saturate(1.05) contrast(1.02);}
.programmes-tile:hover:after{background:linear-gradient(0deg,rgba(0,0,0,.68) 0%,rgba(0,0,0,.36) 42%,rgba(0,0,0,.05) 72%,rgba(0,0,0,0) 100%);}
.programmes-tile:hover .programmes-tile-caption{transform:translateY(0);}
.programmes-tile:hover p{opacity:1;transform:translateY(0);}
.programmes-tile:not(:has(p)) .programmes-tile-caption{transform:translateY(0);}
@media(max-width:700px){.programmes-mosaic-section{margin-top:26px}.programmes-mosaic-title{font-size:26px;margin-bottom:14px}.programmes-tile{border-radius:22px}.programmes-tile-caption{transform:translateY(0)}.programmes-tile p{opacity:1;transform:none}}

/* Correctifs v19 : hero programme + bloc émission en cours */
.hero-meta{
  align-items:center !important;
  gap:9px !important;
}
.hero-meta .hero-program-time{
  display:none !important;
  align-items:center !important;
  justify-content:center !important;
  flex:0 0 auto !important;
  min-height:26px !important;
  margin:0 !important;
  padding:6px 11px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.18) !important;
  border:1px solid rgba(255,255,255,.20) !important;
  color:#fff !important;
  font-size:12px !important;
  font-weight:950 !important;
  line-height:1 !important;
  letter-spacing:.02em !important;
  vertical-align:middle !important;
  backdrop-filter:blur(8px) !important;
}
.hero-meta .hero-program-time.is-visible{
  display:inline-flex !important;
}
.hero-program-live{
  min-height:26px !important;
  line-height:1.15 !important;
}
.hero-program-live span,
.hero-program-live em{
  line-height:1.15 !important;
}

.programmes-showcase-page .programmes-featured,
.programmes-showcase-page .programmes-featured.no-photo,
.programmes-showcase-page .programmes-featured.has-photo{
  grid-template-columns:1fr !important;
  min-height:360px !important;
  border-radius:30px !important;
  background:linear-gradient(135deg,var(--programme-bg-start,#ef4444),var(--programme-bg-end,#111827)) !important;
  background-image:linear-gradient(135deg,var(--programme-bg-start,#ef4444),var(--programme-bg-end,#111827)) !important;
}
.programmes-showcase-page .programmes-featured-photo{
  display:none !important;
}
.programmes-showcase-page .programmes-featured:before{
  background:radial-gradient(circle at 14% 22%,rgba(255,255,255,.18),transparent 34%),radial-gradient(circle at 78% 18%,rgba(255,255,255,.11),transparent 28%) !important;
}
.programmes-showcase-page .programmes-featured.no-photo:after,
.programmes-showcase-page .programmes-featured.has-photo:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,.10),rgba(0,0,0,.30));
  pointer-events:none;
}
.programmes-showcase-page .programmes-featured-content,
.programmes-showcase-page .programmes-featured.no-photo .programmes-featured-content{
  position:relative;
  z-index:2;
  max-width:760px !important;
  padding:56px 64px !important;
}
.programmes-showcase-page .programmes-kicker{
  display:none !important;
}
.programmes-showcase-page .programmes-time-badge{
  margin:0 0 16px !important;
  padding:8px 14px !important;
  border:1px solid rgba(255,255,255,.18) !important;
  background:rgba(255,255,255,.18) !important;
}
.programmes-showcase-page .programmes-featured-content h2{
  font-size:clamp(38px,4.2vw,62px) !important;
  margin:0 0 12px !important;
}
.programmes-showcase-page .programmes-featured-content p{
  margin-bottom:22px !important;
}
@media(max-width:700px){
  .programmes-showcase-page .programmes-featured,
  .programmes-showcase-page .programmes-featured.no-photo,
  .programmes-showcase-page .programmes-featured.has-photo{min-height:310px !important;border-radius:22px !important;}
  .programmes-showcase-page .programmes-featured-content,
  .programmes-showcase-page .programmes-featured.no-photo .programmes-featured-content{padding:34px 24px !important;}
}

/* Correctifs v21 : avec en minuscule + animateur sur une seule ligne */
.hero-program-live em,
.programmes-showcase-page .programmes-featured-content p{
  text-transform:none !important;
}
.programmes-tile p{
  text-transform:none !important;
  white-space:nowrap !important;
}
.programmes-tile p span{
  display:inline !important;
  margin:0 4px 0 0 !important;
  font-size:inherit !important;
  letter-spacing:inherit !important;
  font-weight:650 !important;
  opacity:1 !important;
}

/* Correctifs v22 : réduction des espaces autour de "avec" */
.hero-program-live{
  gap:4px !important;
}
.hero-program-live em{
  margin-left:0 !important;
}
.programmes-showcase-page .programmes-featured-content h2{
  margin-bottom:4px !important;
}
.programmes-showcase-page .programmes-featured-content p{
  margin-top:0 !important;
}
.programmes-tile p span{
  margin-right:0 !important;
}

/* Correctifs v24 : mosaïque programmes, texte sous l'image */
.programmes-showcase-page .programmes-tile{
  height:auto !important;
  min-height:0 !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  justify-content:flex-start !important;
  overflow:hidden !important;
  background:#fff !important;
  color:#111827 !important;
}
.programmes-showcase-page .programmes-tile:after{
  display:none !important;
  content:none !important;
}
.programmes-showcase-page .programmes-tile>img{
  position:relative !important;
  inset:auto !important;
  display:block !important;
  width:100% !important;
  height:210px !important;
  object-fit:cover !important;
  border-radius:0 !important;
  transform:none !important;
}
.programmes-showcase-page .programmes-tile-placeholder{
  position:relative !important;
  inset:auto !important;
  width:100% !important;
  height:210px !important;
  border-radius:0 !important;
  transform:none !important;
}
.programmes-showcase-page .programmes-tile-caption,
.programmes-showcase-page .programmes-tile>div:last-child{
  position:relative !important;
  z-index:1 !important;
  padding:18px 20px 20px !important;
  transform:none !important;
  background:#fff !important;
}
.programmes-showcase-page .programmes-tile h3{
  color:#111827 !important;
  text-shadow:none !important;
  font-size:clamp(24px,2.4vw,31px) !important;
}
.programmes-showcase-page .programmes-tile p{
  margin:7px 0 0 !important;
  color:#64748b !important;
  opacity:1 !important;
  transform:none !important;
  white-space:nowrap !important;
}
.programmes-showcase-page .programmes-tile:hover>img,
.programmes-showcase-page .programmes-tile:hover .programmes-tile-placeholder{
  transform:none !important;
  filter:none !important;
}
@media(max-width:700px){
  .programmes-showcase-page .programmes-tile>img,
  .programmes-showcase-page .programmes-tile-placeholder{height:190px !important;}
}

/* Correctifs v25 : titres des émissions de la mosaïque plus petits et sans majuscules forcées */
.programmes-showcase-page .programmes-tile h3{
  text-transform:none !important;
  font-size:clamp(19px,1.8vw,24px) !important;
  line-height:1.12 !important;
  letter-spacing:-.025em !important;
}

/* Correctifs v26 : bloc live + modal émissions programmes */
.programmes-showcase-page .programmes-featured-content p{
  font-size:15px !important;
  font-weight:600 !important;
  letter-spacing:0 !important;
  opacity:.92 !important;
}
.programmes-showcase-page .programmes-tile{cursor:pointer;}
.programmes-show-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:24px;}
.programmes-show-modal.is-open{display:flex;}
.programmes-show-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.62);backdrop-filter:blur(8px);}
.programmes-show-modal-card{position:relative;z-index:1;width:min(520px,100%);overflow:hidden;border-radius:28px;background:#fff;box-shadow:0 30px 80px rgba(15,23,42,.35);}
.programmes-show-modal-close{position:absolute;top:14px;right:14px;z-index:3;width:40px;height:40px;border:0;border-radius:999px;background:rgba(15,23,42,.82);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.programmes-show-modal-image img{display:block;width:100%;height:260px;object-fit:cover;}
.programmes-show-modal-placeholder{height:230px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--blue,#ef3b2d),#111827);color:#fff;font-size:64px;}
.programmes-show-modal-body{padding:24px 26px 28px;}
.programmes-show-modal-body h2{margin:0;color:#111827;font-size:clamp(26px,3vw,36px);line-height:1.05;font-weight:900;letter-spacing:-.035em;}
.programmes-show-modal-host{margin:9px 0 0;color:#64748b;font-size:15px;font-weight:600;}
.programmes-show-modal-description{margin:12px 0 0;color:#475569;font-size:15px;line-height:1.45;font-weight:500;}
.programmes-show-modal-next{margin-top:20px;padding:15px 16px;border-radius:18px;background:#f1f5f9;}
.programmes-show-modal-next span{display:block;margin-bottom:5px;color:#64748b;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;}
.programmes-show-modal-next strong{display:block;color:#111827;font-size:16px;font-weight:850;}
@media(max-width:700px){.programmes-show-modal{padding:16px}.programmes-show-modal-card{border-radius:22px}.programmes-show-modal-image img,.programmes-show-modal-placeholder{height:210px}.programmes-show-modal-body{padding:20px}}

/* Correctifs v28 : hover mosaïque programmes + filtre radio grille admin */
.programmes-showcase-page .programmes-tile{
  transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease !important;
  border:1px solid rgba(15,23,42,.08) !important;
}
.programmes-showcase-page .programmes-tile>img,
.programmes-showcase-page .programmes-tile-placeholder{
  transition:transform .35s ease, filter .35s ease !important;
  transform-origin:center center !important;
}
.programmes-showcase-page .programmes-tile:hover,
.programmes-showcase-page .programmes-tile:focus-visible{
  transform:translateY(-6px) !important;
  box-shadow:0 24px 52px rgba(15,23,42,.18) !important;
  border-color:rgba(15,23,42,.14) !important;
}
.programmes-showcase-page .programmes-tile:hover>img,
.programmes-showcase-page .programmes-tile:hover .programmes-tile-placeholder,
.programmes-showcase-page .programmes-tile:focus-visible>img,
.programmes-showcase-page .programmes-tile:focus-visible .programmes-tile-placeholder{
  transform:scale(1.055) !important;
  filter:saturate(1.08) contrast(1.04) brightness(.96) !important;
}
.programmes-showcase-page .programmes-tile-caption{
  transition:background .24s ease, transform .24s ease !important;
}
.programmes-showcase-page .programmes-tile:hover .programmes-tile-caption,
.programmes-showcase-page .programmes-tile:focus-visible .programmes-tile-caption{
  background:#f8fafc !important;
}

.schedule-admin-card{position:relative !important;padding-top:76px !important;}
.schedule-radio-filter{
  position:absolute !important;
  top:22px !important;
  right:22px !important;
  display:flex !important;
  align-items:flex-end !important;
  gap:10px !important;
  margin:0 !important;
  z-index:2 !important;
}
.schedule-radio-filter label,
.schedule-day-select label{
  display:block !important;
  margin:0 0 6px !important;
  font-size:12px !important;
  font-weight:800 !important;
  color:#64748b !important;
}
.schedule-radio-filter select,
.schedule-toolbar select{
  min-height:44px !important;
  border:1px solid rgba(15,23,42,.12) !important;
  border-radius:14px !important;
  padding:0 38px 0 14px !important;
  background:#fff !important;
  color:#0f172a !important;
  font-weight:750 !important;
}
.schedule-toolbar{
  width:100% !important;
  display:flex !important;
  align-items:flex-end !important;
  justify-content:center !important;
  gap:18px !important;
  margin:0 auto 24px !important;
  text-align:center !important;
}
.schedule-week-nav{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:14px !important;
}
.schedule-week-nav strong{white-space:nowrap !important;}
.schedule-day-select{min-width:210px !important;text-align:left !important;}
@media(max-width:900px){
  .schedule-admin-card{padding-top:20px !important;}
  .schedule-radio-filter{position:static !important;justify-content:flex-end !important;margin-bottom:18px !important;}
  .schedule-toolbar{flex-direction:column !important;align-items:center !important;}
  .schedule-week-nav{flex-wrap:wrap !important;}
  .schedule-week-nav strong{white-space:normal !important;}
}

/* Slider hero addition */
.site-hero-slider{position:relative;overflow:hidden;background-color:var(--blue);}
.site-hero-slider > .container.hero-content{transition:opacity .45s ease, transform .45s ease;}
.site-hero-slider.is-showing-extra > .container.hero-content{opacity:0;transform:translateY(12px);pointer-events:none;}
.hero-slide-layer{position:absolute;inset:0;z-index:3;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .45s ease, visibility .45s ease;}
.site-hero-slider.is-showing-extra .hero-slide-layer{opacity:1;visibility:visible;}
.hero-extra-slide{position:absolute;inset:0;background-color:var(--blue);background-size:cover;background-position:center;opacity:0;transform:scale(1.02);transition:opacity .6s ease, transform .8s ease;display:flex;align-items:center;}
.hero-extra-slide.is-active{opacity:1;transform:scale(1);pointer-events:auto;}
.hero-extra-slide .hero-overlay{z-index:1;}
.hero-extra-slide-content{position:relative;z-index:2;color:#fff;padding-top:30px;text-shadow:0 12px 30px rgba(0,0,0,.25);}
.hero-extra-slide-content h2{font-size:clamp(2.4rem,7vw,5.8rem);line-height:.98;margin:0 0 16px;font-weight:760;letter-spacing:-.045em;max-width:850px;}
.hero-extra-slide-content p{font-size:clamp(1rem,2vw,1.45rem);line-height:1.45;margin:0 0 28px;font-weight:700;max-width:720px;}
.hero-extra-slide-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.hero-extra-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 22px;border-radius:999px;text-decoration:none;font-weight:900;box-shadow:0 14px 34px rgba(0,0,0,.18);}
.hero-extra-btn-primary{background:#fff;color:var(--blue);}
.hero-extra-btn-secondary{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.34);backdrop-filter:blur(12px);}
.hero-slider-dots{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);z-index:7;display:flex;gap:9px;align-items:center;}
.hero-slider-dots button{width:9px;height:9px;border-radius:999px;border:0;background:rgba(255,255,255,.45);padding:0;cursor:pointer;transition:.25s ease;}
.hero-slider-dots button.is-active{width:28px;background:#fff;}
@media(max-width:760px){.hero-extra-slide-content{padding:90px 22px 110px}.hero-extra-slide-content h2{font-size:clamp(2.2rem,12vw,4rem)}.hero-extra-slide-actions{align-items:stretch}.hero-extra-btn{width:100%;}.hero-slider-dots{bottom:18px}}

/* Slider admin ordering */
.hero-extra-slide-content h2{font-size:clamp(2rem,5.4vw,4.7rem);font-weight:680;}
.admin-slides-toolbar{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap;}
.admin-slides-table th.admin-table-actions-head{text-align:right;}
.admin-slides-table td.admin-table-actions-cell{text-align:right;}
.admin-slides-table .table-actions--end{justify-content:flex-end;display:flex;gap:8px;align-items:center;}
.admin-slides-table tr[draggable="true"]{cursor:grab;transition:background .18s ease, opacity .18s ease, transform .18s ease;}
.admin-slides-table tr[draggable="true"].is-dragging{opacity:.55;background:#f5f7ff;cursor:grabbing;}
.slide-drag-handle{width:34px;height:34px;border:0;border-radius:12px;background:#f2f5fb;color:#607089;display:inline-flex;align-items:center;justify-content:center;margin-right:10px;cursor:grab;vertical-align:middle;}
.slide-drag-handle:active{cursor:grabbing;}
.slide-order-number{font-weight:800;color:#111827;vertical-align:middle;}
.slide-sort-note{margin:14px 0 0;text-align:right;}

/* Correctifs slider v36 */
.hero-extra-slide-content h2{font-size:clamp(1.85rem,4.8vw,4.25rem);font-weight:620;letter-spacing:-.035em;}
.hero-extra-slide-actions{gap:14px;}
.hero-extra-btn{min-height:50px;padding:0 26px;border-radius:18px;font-weight:850;letter-spacing:-.015em;border:1px solid rgba(255,255,255,.38);box-shadow:0 16px 38px rgba(0,0,0,.18);transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease;}
.hero-extra-btn:hover{transform:translateY(-2px);box-shadow:0 22px 46px rgba(0,0,0,.24);}
.hero-extra-btn-primary{background:#fff;color:var(--blue);border-color:#fff;}
.hero-extra-btn-secondary{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.42);backdrop-filter:blur(14px);}
.hero-extra-btn-secondary:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.62);}
.admin-slides-table td:nth-child(3){white-space:nowrap;}
.slide-drag-handle{width:42px;height:42px;border:1px solid #dce4f2;border-radius:14px;background:#f8faff;color:#71809a;display:inline-flex;align-items:center;justify-content:center;margin-right:12px;cursor:grab;vertical-align:middle;box-shadow:0 8px 18px rgba(15,23,42,.06);appearance:none;-webkit-appearance:none;}
.slide-drag-handle:hover{background:#eef4ff;color:#ef3f46;border-color:#cfdcf3;}
.slide-drag-dots{width:18px;height:22px;display:block;background-image:radial-gradient(currentColor 1.7px,transparent 1.9px);background-size:8px 8px;background-position:0 0;opacity:.95;}
.slide-order-number{display:inline-flex;align-items:center;justify-content:center;min-width:22px;color:#6b7890;font-weight:800;}
@media(max-width:760px){.hero-extra-slide-content h2{font-size:clamp(2rem,10vw,3.5rem);}.hero-extra-btn{border-radius:16px;}}

/* Correctifs slider v37 */
.admin-slides-table td:nth-child(3){white-space:nowrap;}
.slide-order-control{display:inline-flex;align-items:center;gap:10px;}
.slide-drag-handle{width:42px;height:42px;border:1px solid #dce4f2;border-radius:14px;background:#f8faff;color:#71809a;display:inline-flex;align-items:center;justify-content:center;margin:0;cursor:grab;vertical-align:middle;box-shadow:0 8px 18px rgba(15,23,42,.06);appearance:none;-webkit-appearance:none;padding:0;font-size:17px;line-height:1;}
.slide-drag-handle i{display:block;font-size:17px;line-height:1;color:inherit;pointer-events:none;}
.slide-drag-handle:hover{background:#eef4ff;color:#ef3f46;border-color:#cfdcf3;}
.slide-drag-handle:active{cursor:grabbing;transform:scale(.98);}
.slide-drag-dots{display:none!important;background:none!important;}
.slide-order-number{display:inline-flex;align-items:center;justify-content:center;min-width:22px;color:#6b7890;font-weight:800;}
.hero-extra-slide-actions{gap:14px;}
.hero-extra-btn{min-height:50px;padding:0 28px;border-radius:999px;font-weight:850;letter-spacing:-.015em;border:1px solid rgba(255,255,255,.42);box-shadow:0 18px 42px rgba(0,0,0,.20);transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease;}
.hero-extra-btn:hover{transform:translateY(-2px);box-shadow:0 24px 50px rgba(0,0,0,.26);}
.hero-extra-btn-primary{background:#fff;color:var(--blue);border-color:#fff;}
.hero-extra-btn-secondary{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.45);backdrop-filter:blur(14px);}
.hero-extra-btn-secondary:hover{background:rgba(255,255,255,.24);border-color:rgba(255,255,255,.68);}

/* Correctif slider v38 - poignée de drag toujours visible sans dépendre de Font Awesome */
.admin-slides-table .slide-order-control{display:inline-flex!important;align-items:center!important;gap:10px!important;}
.admin-slides-table .slide-drag-handle{width:42px!important;height:42px!important;min-width:42px!important;min-height:42px!important;border:1px solid #dce4f2!important;border-radius:14px!important;background:#f8faff!important;color:#71809a!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;margin:0!important;padding:0!important;cursor:grab!important;box-shadow:0 8px 18px rgba(15,23,42,.06)!important;opacity:1!important;visibility:visible!important;appearance:none!important;-webkit-appearance:none!important;}
.admin-slides-table .slide-drag-handle:hover{background:#eef4ff!important;color:#ef3f46!important;border-color:#cfdcf3!important;}
.admin-slides-table .slide-drag-handle:active{cursor:grabbing!important;transform:scale(.98)!important;}
.admin-slides-table .slide-drag-dots{width:20px!important;height:24px!important;display:block!important;flex:0 0 20px!important;background-image:radial-gradient(currentColor 2px,transparent 2.2px)!important;background-size:8px 8px!important;background-position:0 0!important;background-repeat:repeat!important;opacity:1!important;}

/* Correctifs slider v39 - boutons arrondis + poignée drag en icône simple */
.hero-extra-slide-actions .hero-extra-btn{border-radius:999px!important;}
@media(max-width:760px){.hero-extra-slide-actions .hero-extra-btn{border-radius:999px!important;}}
.admin-slides-table .slide-order-control{display:inline-flex!important;align-items:center!important;gap:10px!important;}
.admin-slides-table .slide-drag-handle{width:24px!important;height:34px!important;min-width:24px!important;min-height:34px!important;border:0!important;border-radius:0!important;background:transparent!important;color:#7b8798!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;margin:0!important;padding:0!important;cursor:grab!important;box-shadow:none!important;opacity:1!important;visibility:visible!important;appearance:none!important;-webkit-appearance:none!important;}
.admin-slides-table .slide-drag-handle:hover{background:transparent!important;color:#ef3f46!important;border-color:transparent!important;}
.admin-slides-table .slide-drag-handle:active{cursor:grabbing!important;transform:none!important;}
.admin-slides-table .slide-drag-dots{width:18px!important;height:24px!important;display:block!important;flex:0 0 18px!important;background-image:radial-gradient(currentColor 2px,transparent 2.2px)!important;background-size:8px 8px!important;background-position:center!important;background-repeat:repeat!important;opacity:1!important;}

/* Correctifs slider v40 - drag en icône seule + actions en bout de ligne */
.admin-slides-table th.admin-table-actions-head,
.admin-slides-table td.admin-table-actions-cell{text-align:right!important;}
.admin-slides-table td.admin-table-actions-cell{width:1%!important;white-space:nowrap!important;}
.admin-slides-table td.admin-table-actions-cell .table-actions,
.admin-slides-table td.admin-table-actions-cell .table-actions--end,
.admin-slides-table td.admin-table-actions-cell .table-actions--articles{width:100%!important;display:flex!important;align-items:center!important;justify-content:flex-end!important;flex-wrap:nowrap!important;gap:8px!important;margin-left:auto!important;}
.admin-slides-table td.admin-table-actions-cell form{display:inline-flex!important;margin:0!important;}
.admin-slides-table .slide-order-control{display:inline-flex!important;align-items:center!important;gap:10px!important;}
.admin-slides-table .slide-drag-handle{width:22px!important;height:30px!important;min-width:22px!important;min-height:30px!important;border:0!important;border-radius:0!important;background:transparent!important;color:#7b8798!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;margin:0!important;padding:0!important;cursor:grab!important;box-shadow:none!important;opacity:1!important;visibility:visible!important;appearance:none!important;-webkit-appearance:none!important;}
.admin-slides-table .slide-drag-handle i{display:block!important;font-size:18px!important;line-height:1!important;color:inherit!important;pointer-events:none!important;}
.admin-slides-table .slide-drag-handle:hover{background:transparent!important;color:#ef3f46!important;}
.admin-slides-table .slide-drag-handle:active{cursor:grabbing!important;transform:none!important;}
.admin-slides-table .slide-drag-dots{display:none!important;}

/* Correctif v46 : photo de l’émission en cours en fond du bloc programmes */
.programmes-showcase-page .programmes-featured.has-photo{
  background-image:linear-gradient(90deg,rgba(0,0,0,.66),rgba(0,0,0,.28)),var(--programme-photo),linear-gradient(135deg,var(--programme-bg-start,#ef4444),var(--programme-bg-end,#111827)) !important;
  background-size:cover,cover,cover !important;
  background-position:center,center,center !important;
  background-repeat:no-repeat !important;
}
.programmes-showcase-page .programmes-featured.has-photo:before{background:radial-gradient(circle at 14% 22%,rgba(255,255,255,.16),transparent 34%) !important;}
.programmes-showcase-page .programmes-featured.has-photo:after{background:linear-gradient(90deg,rgba(0,0,0,.12),rgba(0,0,0,.36)) !important;}

/* Correction lisibilité bouton écouter - bloc émission en cours */
.programmes-featured .programmes-listen-btn{
  background:rgba(255,255,255,.96)!important;
  color:#111827!important;
  border:2px solid rgba(255,255,255,.98)!important;
  box-shadow:0 16px 36px rgba(0,0,0,.34), 0 0 0 1px rgba(17,24,39,.10)!important;
  min-height:50px!important;
  padding:0 28px!important;
  font-size:15px!important;
  letter-spacing:.02em!important;
  text-shadow:none!important;
  backdrop-filter:blur(10px)!important;
}
.programmes-featured .programmes-listen-btn:hover{
  transform:translateY(-1px);
  background:#fff!important;
  box-shadow:0 20px 42px rgba(0,0,0,.40), 0 0 0 1px rgba(17,24,39,.12)!important;
}
.programmes-featured .programmes-listen-btn i,
.programmes-featured .programmes-listen-btn span{
  color:inherit!important;
}
.programmes-featured .programmes-listen-wave em{
  background:#111827!important;
}
@media(max-width:700px){
  .programmes-featured .programmes-listen-btn{
    min-height:48px!important;
    padding:0 24px!important;
    font-size:14px!important;
  }
}

/* Header listen button + footer/player spacing fix */
.header-actions .header-listen-btn {
  min-width: 118px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: linear-gradient(135deg, rgba(var(--primary-rgb), .96), rgba(255,255,255,.18));
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 0 16px;
  font-family: inherit;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
  transition: transform .22s ease, filter .22s ease, background .22s ease;
}
.header-actions .header-listen-btn:hover { transform: translateY(-2px); filter: brightness(1.08); }
.header-actions .header-listen-btn.is-playing i::before { content: "\f04c"; }
body.has-player-bar { padding-bottom: 104px; }
body.has-player-bar .site-footer { margin-bottom: 0; }
@media (max-width: 980px) {
  body.has-player-bar { padding-bottom: 92px; }
}

/* Correctif v48 : player collé au footer + bouton lecture header rond */
.site-player-bar{
  left:0!important;
  right:0!important;
  bottom:0!important;
  width:100%!important;
  max-width:none!important;
  transform:translateY(110%)!important;
}
.site-player-bar.is-active{
  transform:translateY(0)!important;
}
.site-player-inner{
  border-radius:0!important;
  border-left:0!important;
  border-right:0!important;
  border-bottom:0!important;
}
body.has-player-bar{
  padding-bottom:90px!important;
}
body.has-player-bar .site-footer{
  margin-bottom:0!important;
}
.header-actions .header-listen-btn{
  width:46px!important;
  min-width:46px!important;
  height:46px!important;
  padding:0!important;
  border-radius:999px!important;
  border:0!important;
  background:rgb(var(--primary-rgb))!important;
  background-image:none!important;
  color:#fff!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:0!important;
  box-shadow:0 12px 28px rgba(0,0,0,.22)!important;
}
.header-actions .header-listen-btn:hover{
  transform:translateY(-2px)!important;
  filter:brightness(1.06)!important;
}
.header-listen-play{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}
.header-listen-play i{
  font-size:15px;
  margin-left:2px;
}
.header-listen-wave{
  display:none;
  align-items:center;
  justify-content:center;
  gap:3px;
  height:18px;
}
.header-listen-wave em{
  display:block;
  width:4px;
  height:8px;
  border-radius:999px;
  background:#fff;
  animation:headerListenWave .72s ease-in-out infinite;
}
.header-listen-wave em:nth-child(2){animation-delay:.12s;}
.header-listen-wave em:nth-child(3){animation-delay:.24s;}
.header-listen-btn.is-playing .header-listen-play{display:none;}
.header-listen-btn.is-playing .header-listen-wave{display:inline-flex;}
@keyframes headerListenWave{0%,100%{height:8px}50%{height:18px}}
@media(max-width:860px){
  .site-player-bar{width:100%!important;bottom:0!important;}
  body.has-player-bar{padding-bottom:82px!important;}
  .header-actions .header-listen-btn{width:42px!important;min-width:42px!important;height:42px!important;}
}

/* Multiflux player + latest title filters */
.site-player-flux {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
}
.site-player-flux select {
  max-width: 190px;
  border: 0;
  outline: 0;
  background: transparent;
  color: #fff;
  font-weight: 800;
  font-size: 13px;
  cursor: pointer;
}
.site-player-flux select option { color: #111827; }
.latest-flux-tabs {
  display: flex;
  flex-wrap: wrap;
  column-gap: 16px;
  row-gap: 12px;
  margin: 0 0 24px;
}
.latest-flux-tab {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 20px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(17,24,39,.1);
  color: #111827;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
}
.latest-flux-tab.is-active {
  background: rgb(var(--primary-rgb));
  color: #fff;
  border-color: rgb(var(--primary-rgb));
}
@media (max-width: 860px) {
  .site-player-inner { gap: 10px !important; }
  .site-player-controls { gap: 10px !important; flex-wrap: wrap; justify-content: flex-end; }
  .site-player-flux { order: -1; min-height: 36px; padding: 0 10px; }
  .site-player-flux select { max-width: 130px; font-size: 12px; }
}

/* Selecteur de flux player - version custom */
.site-player-flux{
  position:relative;
  min-width:0;
  height:42px;
  padding:0;
  gap:0;
  overflow:visible;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.20);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 10px 28px rgba(0,0,0,.14);
}
.site-player-flux > .fa-tower-broadcast{
  width:42px;
  height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  opacity:.95;
}
.site-player-flux.site-player-flux--custom select{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  opacity:0!important;
  pointer-events:none!important;
}
.site-player-flux-trigger{
  height:42px;
  max-width:210px;
  min-width:145px;
  display:inline-flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:0 13px 0 0;
  border:0;
  background:transparent;
  color:#fff;
  cursor:pointer;
  font:inherit;
}
.site-player-flux-trigger-text{
  display:block;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:13px;
  font-weight:850;
  letter-spacing:-.01em;
}
.site-player-flux-chevron{
  font-size:10px;
  opacity:.72;
  transition:transform .18s ease, opacity .18s ease;
}
.site-player-flux.is-open .site-player-flux-chevron{transform:rotate(180deg);opacity:1;}
.site-player-flux-menu{
  position:absolute;
  right:0;
  bottom:calc(100% + 10px);
  width:max-content;
  min-width:210px;
  max-width:min(280px,calc(100vw - 24px));
  padding:7px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(20,21,27,.96);
  box-shadow:0 18px 45px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  z-index:9999;
}
.site-player-flux-menu[hidden]{display:none!important;}
.site-player-flux-option{
  width:100%;
  min-height:38px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:0 11px;
  border:0;
  border-radius:13px;
  background:transparent;
  color:#fff;
  cursor:pointer;
  text-align:left;
  font-size:13px;
  font-weight:800;
  white-space:nowrap;
}
.site-player-flux-option:hover{background:rgba(255,255,255,.09);}
.site-player-flux-option i{font-size:12px;opacity:0;transform:scale(.85);transition:opacity .15s ease, transform .15s ease;}
.site-player-flux-option.is-selected{background:rgba(255,255,255,.13);}
.site-player-flux-option.is-selected i{opacity:1;transform:scale(1);}
@media (max-width:860px){
  .site-player-flux{height:38px;}
  .site-player-flux > .fa-tower-broadcast{width:38px;height:38px;}
  .site-player-flux-trigger{height:38px;min-width:118px;max-width:150px;padding-right:11px;}
  .site-player-flux-trigger-text{font-size:12px;}
  .site-player-flux-menu{right:auto;left:0;min-width:190px;}
}

/* Correctif v49 : sélecteur de flux player propre, sans bordure native ni focus bleu */
.site-player-controls .site-player-flux{
  position:relative!important;
  overflow:visible!important;
  height:44px!important;
  min-width:0!important;
  max-width:min(238px,42vw)!important;
  padding:0 12px 0 0!important;
  gap:0!important;
  border-radius:999px!important;
  border:1px solid rgba(255,255,255,.18)!important;
  background:rgba(255,255,255,.12)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10), 0 10px 25px rgba(0,0,0,.16)!important;
  color:#fff!important;
}
.site-player-controls .site-player-flux > .fa-tower-broadcast{
  flex:0 0 42px!important;
  width:42px!important;
  height:42px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  margin:0!important;
  color:#fff!important;
  opacity:.94!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.08)!important;
}
.site-player-controls .site-player-flux select{
  -webkit-appearance:none!important;
  appearance:none!important;
  height:42px!important;
  min-width:130px!important;
  max-width:170px!important;
  margin:0!important;
  padding:0 28px 0 0!important;
  border:0!important;
  outline:0!important;
  box-shadow:none!important;
  background:transparent!important;
  color:#fff!important;
  font-family:inherit!important;
  font-size:13px!important;
  font-weight:850!important;
  line-height:42px!important;
  letter-spacing:-.01em!important;
  white-space:nowrap!important;
  text-overflow:ellipsis!important;
  cursor:pointer!important;
}
.site-player-controls .site-player-flux select:focus,
.site-player-controls .site-player-flux select:focus-visible{
  outline:0!important;
  border:0!important;
  box-shadow:none!important;
}
.site-player-controls .site-player-flux:not(.site-player-flux--custom)::after{
  content:"\f078";
  font-family:"Font Awesome 6 Free";
  font-weight:900;
  position:absolute;
  right:13px;
  top:50%;
  transform:translateY(-50%);
  font-size:10px;
  color:rgba(255,255,255,.78);
  pointer-events:none;
}
.site-player-controls .site-player-flux select option{
  background:#1c1e26!important;
  color:#fff!important;
}
.site-player-controls .site-player-flux.site-player-flux--custom{
  padding-right:0!important;
}
.site-player-controls .site-player-flux.site-player-flux--custom select{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  min-width:0!important;
  max-width:none!important;
  opacity:0!important;
  pointer-events:none!important;
}
.site-player-controls .site-player-flux-trigger{
  height:42px!important;
  min-width:140px!important;
  max-width:174px!important;
  padding:0 13px 0 0!important;
  border:0!important;
  outline:0!important;
  box-shadow:none!important;
  background:transparent!important;
}
.site-player-controls .site-player-flux-trigger:focus,
.site-player-controls .site-player-flux-trigger:focus-visible{
  outline:0!important;
  box-shadow:none!important;
}
.site-player-controls .site-player-flux-menu{
  z-index:10050!important;
}
@media(max-width:860px){
  .site-player-controls .site-player-flux{height:40px!important;max-width:172px!important;padding-right:10px!important;}
  .site-player-controls .site-player-flux > .fa-tower-broadcast{width:38px!important;height:38px!important;flex-basis:38px!important;}
  .site-player-controls .site-player-flux select{height:38px!important;line-height:38px!important;min-width:94px!important;max-width:118px!important;font-size:12px!important;padding-right:23px!important;}
  .site-player-controls .site-player-flux-trigger{height:38px!important;min-width:104px!important;max-width:124px!important;}
  .site-player-controls .site-player-flux-trigger-text{font-size:12px!important;}
}

/* Correctif selecteur flux : le menu doit sortir au-dessus de la player bar */
.site-player-bar{
  overflow:visible!important;
  z-index:10000!important;
}
.site-player-inner,
.site-player-inner.container{
  overflow:visible!important;
}
.site-player-inner::before,
.site-player-inner::after{
  pointer-events:none!important;
}
.site-player-controls,
.site-player-flux,
.site-player-flux--custom{
  overflow:visible!important;
}
.site-player-controls .site-player-flux-menu,
.site-player-flux-menu{
  position:absolute!important;
  right:0!important;
  left:auto!important;
  bottom:calc(100% + 12px)!important;
  display:block;
  z-index:10080!important;
  max-height:min(280px, calc(100vh - 130px));
  overflow-y:auto!important;
}
.site-player-flux-menu[hidden]{display:none!important;}
@media(max-width:860px){
  .site-player-controls .site-player-flux-menu,
  .site-player-flux-menu{
    right:auto!important;
    left:0!important;
    bottom:calc(100% + 10px)!important;
    max-width:calc(100vw - 24px)!important;
  }
}

/* Correctif player bar : décale légèrement le nom du flux vers la droite */
.site-player-controls .site-player-flux-trigger-text,
.site-player-flux-trigger-text{
  padding-left:7px!important;
}
.site-player-controls .site-player-flux select{
  padding-left:7px!important;
}

.latest-titles-page.is-loading-tabs .latest-tracks-page-shell {
  opacity: .55;
  pointer-events: none;
  transition: opacity .18s ease;
}

/* Ajustement page derniers titres : onglets plus bas + URL propre */
.latest-titles-page .latest-flux-tabs {
  margin-top: 28px !important;
  margin-bottom: 26px !important;
}
@media (max-width: 860px) {
  .latest-titles-page .latest-flux-tabs {
    margin-top: 22px !important;
  }
}

/* Player bar : cover du flux dans le sélecteur */
.site-player-controls .site-player-flux .site-player-flux-cover,
.site-player-flux .site-player-flux-cover{
  flex:0 0 42px!important;
  width:42px!important;
  height:42px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  margin:0!important;
  border-radius:999px!important;
  overflow:hidden!important;
  background:rgba(255,255,255,.12)!important;
  color:#fff!important;
}
.site-player-controls .site-player-flux .site-player-flux-cover img,
.site-player-flux .site-player-flux-cover img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
}
.site-player-controls .site-player-flux .site-player-flux-cover i,
.site-player-flux .site-player-flux-cover i{font-size:15px!important;opacity:.9!important;}
.site-player-controls .site-player-flux > .fa-tower-broadcast{display:none!important;}
.site-player-flux-option-main{display:flex;align-items:center;gap:10px;min-width:0;}
.site-player-flux-option-main > span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.site-player-flux-option-cover{width:30px;height:30px;flex:0 0 30px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,.12);display:inline-flex;align-items:center;justify-content:center;color:#fff;}
.site-player-flux-option-cover img{width:100%;height:100%;object-fit:cover;display:block;}
.site-player-flux-option-cover i{font-size:12px;opacity:.9;}
.site-player-flux-option > i.fa-check{flex:0 0 auto;}
@media(max-width:860px){
  .site-player-controls .site-player-flux .site-player-flux-cover,
  .site-player-flux .site-player-flux-cover{width:38px!important;height:38px!important;flex-basis:38px!important;}
}

/* Actualités : filtres catégories en onglets */
.actualites-category-tabs{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0 0 24px;padding:8px 0 2px}.actualites-cat-tab{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:9px 16px;border-radius:999px;border:1px solid rgba(15,23,42,.12);background:#fff;color:#101827;font-weight:800;font-size:14px;text-decoration:none;box-shadow:0 10px 28px rgba(15,23,42,.06);transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease}.actualites-cat-tab:hover{transform:translateY(-1px);box-shadow:0 14px 34px rgba(15,23,42,.1)}.actualites-cat-tab.is-active{background:rgb(var(--primary-rgb));border-color:rgb(var(--primary-rgb));color:#fff}.actualites-cat-more{width:38px;padding:0;cursor:pointer}.actualites-active-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:-8px 0 24px}.actualites-active-filter{display:inline-flex;align-items:center;gap:8px;border-radius:999px;background:rgba(var(--primary-rgb),.10);color:rgb(var(--primary-rgb));padding:7px 12px;font-weight:800;font-size:13px;text-decoration:none}.actualites-clear-filters{font-weight:800;font-size:13px;color:#64748b;text-decoration:none}.actualites-filter-link{cursor:pointer;text-decoration:none}.actualites-category-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:22px}.actualites-category-modal[hidden]{display:none}.actualites-category-modal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.58);backdrop-filter:blur(8px)}.actualites-category-modal-card{position:relative;z-index:1;width:min(680px,100%);max-height:min(720px,88vh);overflow:auto;background:#fff;border-radius:28px;box-shadow:0 28px 80px rgba(2,6,23,.30);padding:22px}.actualites-category-modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.actualites-category-modal-head strong{font-size:22px;color:#0f172a}.actualites-category-modal-head button{width:40px;height:40px;border:0;border-radius:999px;background:#f1f5f9;color:#0f172a;cursor:pointer}.actualites-category-modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.actualites-category-choice{display:flex;align-items:center;gap:10px;border:1px solid rgba(15,23,42,.10);border-radius:16px;padding:12px 14px;font-weight:800;cursor:pointer;background:#fff}.actualites-category-choice input{accent-color:rgb(var(--primary-rgb));width:18px;height:18px}.actualites-category-modal-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:20px}.actualites-category-modal-actions button{border:0;border-radius:999px;background:rgb(var(--primary-rgb));color:#fff;font-weight:900;padding:12px 20px;cursor:pointer}.actualites-modal-reset{font-weight:800;color:#64748b;text-decoration:none}@media(max-width:700px){.actualites-category-modal-grid{grid-template-columns:1fr}.actualites-category-modal-card{border-radius:22px;padding:18px}.actualites-cat-tab{font-size:13px;padding:8px 13px}}

/* Actualités : remplir la ligne de catégories avant le bouton + */
.actualites-category-tabs{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:nowrap;
  width:100%;
  overflow:hidden;
}
.actualites-category-tabs-list{
  display:flex;
  align-items:center;
  gap:10px;
  flex:1 1 auto;
  min-width:0;
  overflow:hidden;
  white-space:nowrap;
}
.actualites-category-tabs-list .actualites-cat-tab{
  flex:0 0 auto;
}
.actualites-cat-more{
  flex:0 0 38px;
}
@media(max-width:700px){
  .actualites-category-tabs{gap:8px;}
  .actualites-category-tabs-list{gap:8px;}
  .actualites-cat-more{flex-basis:36px;width:36px;min-width:36px;}
}

/* Actualités : ne jamais couper un badge de catégorie */
.actualites-category-tabs-list .actualites-cat-tab[hidden]{display:none!important;}

/* Admin actualités : recherche live par titre */
.articles-title-search-form{min-width:min(360px,100%);}
.admin-search-input-wrap{position:relative;display:flex;align-items:center;min-width:min(320px,100%);}
.admin-search-input-wrap i{position:absolute;left:14px;color:#94a3b8;font-size:14px;pointer-events:none;}
.admin-search-input-wrap input[type="search"]{width:100%;height:44px;border:1px solid rgba(148,163,184,.35);border-radius:16px;background:#fff;padding:0 14px 0 40px;font-weight:800;color:#0f172a;outline:none;box-shadow:0 12px 32px rgba(15,23,42,.05);}
.admin-search-input-wrap input[type="search"]:focus{border-color:rgb(var(--primary-rgb));box-shadow:0 0 0 4px rgba(var(--primary-rgb),.12);}
@media(max-width:760px){.articles-title-search-form,.admin-search-input-wrap{width:100%;min-width:0;}}

/* Actualités : laisser respirer l'ombre des badges au hover */
.actualites-category-tabs{
  overflow:visible!important;
  padding:14px 0 14px!important;
  margin:-6px 0 18px!important;
}
.actualites-category-tabs-list{
  padding:14px 4px!important;
  margin:-14px -4px!important;
  overflow:hidden!important;
}
.actualites-category-tabs-list .actualites-cat-tab{
  position:relative;
  z-index:1;
}
.actualites-category-tabs-list .actualites-cat-tab:hover,
.actualites-cat-more:hover{
  z-index:3;
}

/* Horoscope */
.horoscope-home-section { padding-top: 10px; }
.horoscope-slider-wrap { position: relative; display: flex; align-items: center; gap: 14px; margin-top: 18px; }
.horoscope-slider-track { display: flex; gap: 16px; overflow: hidden; scroll-behavior: smooth; flex: 1; padding: 8px 2px 14px; }
.horoscope-sign-card { flex: 0 0 150px; min-height: 132px; border: 1px solid rgba(15,23,42,.10); border-radius: 26px; background: #fff; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; text-decoration: none; color: var(--text, #111827); box-shadow: 0 16px 40px rgba(15,23,42,.08); transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.horoscope-sign-card:hover, .horoscope-sign-card.is-active { transform: translateY(-4px); box-shadow: 0 22px 54px rgba(var(--primary-rgb, 92,124,230), .18); border-color: rgba(var(--primary-rgb, 92,124,230), .30); }
.horoscope-sign-icon { width: 58px; height: 58px; border-radius: 22px; display: grid; place-items: center; font-size: 34px; background: rgba(var(--primary-rgb, 92,124,230), .10); }
.horoscope-sign-card strong { font-size: 14px; font-weight: 900; }
.horoscope-nav { width: 46px; height: 46px; border-radius: 16px; border: 1px solid rgba(15,23,42,.10); background: #fff; color: var(--text, #111827); display: grid; place-items: center; cursor: pointer; box-shadow: 0 16px 40px rgba(15,23,42,.08); flex: 0 0 auto; }
.horoscope-nav:hover { color: var(--primary, #5c7ce6); transform: translateY(-2px); }
.horoscope-page .compact-page-hero { padding: 90px 0 54px; background: linear-gradient(135deg, rgba(var(--primary-rgb,92,124,230),.18), rgba(255,255,255,.96)); }
.horoscope-detail-card { background: #fff; border: 1px solid rgba(15,23,42,.08); border-radius: 34px; padding: 30px; box-shadow: 0 20px 60px rgba(15,23,42,.08); }
.horoscope-detail-head { display: flex; align-items: center; gap: 18px; margin-bottom: 24px; }
.horoscope-big-icon { width: 86px; height: 86px; border-radius: 30px; display: grid; place-items: center; font-size: 52px; background: rgba(var(--primary-rgb,92,124,230),.10); }
.horoscope-theme-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.horoscope-theme-card { border: 1px solid rgba(15,23,42,.08); border-radius: 24px; padding: 20px; background: #f8fafc; }
.horoscope-theme-card h3 { margin: 0 0 10px; font-size: 15px; font-weight: 900; }
.horoscope-theme-card p { margin: 0; color: #475569; line-height: 1.55; font-weight: 650; }
.horoscope-admin-checks { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin: 18px 0 18px; }
.admin-check-card { display: flex; align-items: center; gap: 12px; border: 1px solid rgba(15,23,42,.10); border-radius: 18px; background: #fff; padding: 14px 16px; font-weight: 850; cursor: pointer; }
.admin-check-card input { width: 18px; height: 18px; accent-color: var(--primary, #5c7ce6); }
.refresh-check { margin-top: 8px; }
@media (max-width: 900px) { .horoscope-theme-grid, .horoscope-admin-checks { grid-template-columns: 1fr; } .horoscope-sign-card { flex-basis: 128px; } .horoscope-nav { width: 42px; height: 42px; } }


/* Corrections horoscope + player global */
.horoscope-page-band{margin-bottom:0;}
.horoscope-page .compact-page-hero{display:none!important;}
.horoscope-detail-section{padding-top:56px;}
.horoscope-slider-wrap{filter:none!important;}
.horoscope-slider-track{padding:8px 2px 10px;}
.horoscope-sign-card{box-shadow:none!important;background:#fff;border-color:rgba(15,23,42,.10);}
.horoscope-sign-card:hover,.horoscope-sign-card.is-active{box-shadow:none!important;transform:translateY(-3px);border-color:rgba(var(--primary-rgb,92,124,230),.42);}
.horoscope-sign-icon,.horoscope-big-icon{background:linear-gradient(135deg,rgba(var(--primary-rgb,92,124,230),.12),rgba(var(--primary-rgb,92,124,230),.04));color:var(--primary,#ef4444);font-family:"Times New Roman",serif;font-weight:700;text-shadow:none;}
.horoscope-sign-icon{border-radius:50%;font-size:36px;border:1px solid rgba(var(--primary-rgb,92,124,230),.16);}
.horoscope-big-icon{border-radius:50%;font-size:56px;border:1px solid rgba(var(--primary-rgb,92,124,230),.16);}
.horoscope-nav{box-shadow:none!important;}


/* Ajustements horoscope : visuels SVG, interlignage et player global */
.horoscope-detail-head{gap:16px;margin-bottom:22px;}
.horoscope-detail-head .eyebrow{display:block;margin:0 0 8px;line-height:1;font-size:12px;letter-spacing:.16em;}
.horoscope-detail-head h2{margin:0 0 8px;line-height:1.08;font-size:28px;font-weight:900;}
.horoscope-detail-head p{margin:0;line-height:1.2;color:#334155;font-weight:650;}
.horoscope-other-title{margin:34px 0 4px;font-size:22px;font-weight:900;color:var(--text,#111827);}
.horoscope-sign-icon,.horoscope-big-icon{font-family:inherit!important;text-shadow:none!important;color:var(--primary,#ef4444);}
.horoscope-sign-icon{width:62px;height:62px;border-radius:22px;background:linear-gradient(135deg,rgba(var(--primary-rgb,92,124,230),.12),rgba(255,255,255,.96));}
.horoscope-big-icon{width:84px;height:84px;border-radius:26px;background:linear-gradient(135deg,rgba(var(--primary-rgb,92,124,230),.14),rgba(255,255,255,.98));}
.horoscope-zodiac-svg{width:100%;height:100%;display:block;color:var(--primary,#ef4444);}
.horoscope-zodiac-svg .astro-line{fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;opacity:.42;}
.horoscope-zodiac-svg .astro-dots circle{fill:currentColor;opacity:.95;}
.horoscope-zodiac-svg text{font-family:Albert Sans,system-ui,sans-serif;font-size:22px;font-weight:900;fill:currentColor;opacity:.92;}
.horoscope-big-icon .horoscope-zodiac-svg text{font-size:24px;}
.horoscope-slider-wrap{box-shadow:none!important;filter:none!important;}
.horoscope-slider-track{box-shadow:none!important;filter:none!important;}
@media(max-width:700px){.horoscope-detail-head{align-items:flex-start}.horoscope-other-title{font-size:20px}.horoscope-detail-head h2{font-size:25px}}

/* Horoscope vignettes + grille de choix */
.horoscope-intro-block{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:32px;padding:30px;margin-bottom:22px;box-shadow:0 18px 50px rgba(15,23,42,.06)}
.horoscope-intro-block h2{margin:8px 0 8px;font-size:32px;line-height:1.05;font-weight:950;color:var(--text,#111827)}
.horoscope-intro-block p{margin:0;color:#64748b;font-weight:650;line-height:1.45}
.horoscope-sign-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;margin-top:18px}
.horoscope-sign-grid-small{margin-top:16px}
.horoscope-grid-card{min-height:144px;flex:initial!important;width:100%;box-shadow:none!important;background:linear-gradient(180deg,#fff,#fbfdff);position:relative;overflow:hidden}
.horoscope-grid-card:before{content:"";position:absolute;inset:auto -20% -50% -20%;height:78px;background:radial-gradient(circle,rgba(var(--primary-rgb,92,124,230),.16),transparent 70%);pointer-events:none}
.horoscope-grid-card:hover,.horoscope-grid-card.is-active{box-shadow:none!important;transform:translateY(-4px);background:#fff;border-color:rgba(var(--primary-rgb,92,124,230),.42)}
.horoscope-sign-icon,.horoscope-big-icon{overflow:hidden;color:var(--primary,#ef4444);background:linear-gradient(135deg,rgba(var(--primary-rgb,92,124,230),.13),rgba(255,255,255,.98))!important;border:1px solid rgba(var(--primary-rgb,92,124,230),.16)!important}
.horoscope-zodiac-svg{width:100%;height:100%;display:block;color:var(--primary,#ef4444)}
.horoscope-zodiac-svg .zodiac-bg{fill:url(#astroGlowbelier);opacity:1}
.horoscope-zodiac-svg .zodiac-ring{fill:none;stroke:currentColor;stroke-width:1.8;opacity:.17}
.horoscope-zodiac-svg .zodiac-spark{fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;opacity:.32}
.horoscope-zodiac-svg .zodiac-glyph{font-family:Georgia,'Times New Roman',serif;font-size:48px;font-weight:700;fill:currentColor;dominant-baseline:auto}
.horoscope-big-icon .horoscope-zodiac-svg .zodiac-glyph{font-size:52px}
.horoscope-theme-card{position:relative;overflow:hidden;padding:22px;background:linear-gradient(135deg,#fff,#f8fafc);box-shadow:none!important}
.horoscope-theme-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--horo-accent,rgba(var(--primary-rgb,92,124,230),.11)),transparent 62%);opacity:.85;pointer-events:none}
.horoscope-theme-card>*{position:relative;z-index:1}
.horoscope-theme-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.horoscope-theme-icon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:var(--horo-accent,rgba(var(--primary-rgb,92,124,230),.12));color:var(--horo-icon,var(--primary,#ef4444));font-size:17px;flex:0 0 auto}
.horoscope-theme-card h3{margin:0!important;font-size:16px;font-weight:950;color:#0f172a}
.horoscope-theme-card p{font-size:14px;color:#475569;line-height:1.58;font-weight:650}
.horoscope-theme-card[data-theme="amour"]{--horo-accent:rgba(244,63,94,.12);--horo-icon:#e11d48}
.horoscope-theme-card[data-theme="argent"]{--horo-accent:rgba(234,179,8,.14);--horo-icon:#a16207}
.horoscope-theme-card[data-theme="sante"]{--horo-accent:rgba(16,185,129,.13);--horo-icon:#059669}
.horoscope-theme-card[data-theme="travail"]{--horo-accent:rgba(59,130,246,.12);--horo-icon:#2563eb}
.horoscope-theme-card[data-theme="famille"]{--horo-accent:rgba(249,115,22,.12);--horo-icon:#ea580c}
.horoscope-theme-card[data-theme="vie_sociale"]{--horo-accent:rgba(168,85,247,.12);--horo-icon:#9333ea}
.horoscope-theme-card[data-theme="citation"]{--horo-accent:rgba(20,184,166,.12);--horo-icon:#0f766e}
.horoscope-theme-card[data-theme="nombre_chance"]{--horo-accent:rgba(34,197,94,.13);--horo-icon:#16a34a}
.horoscope-theme-card[data-theme="clin_oeil"]{--horo-accent:rgba(236,72,153,.12);--horo-icon:#db2777}
@media(max-width:1100px){.horoscope-sign-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:760px){.horoscope-sign-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.horoscope-grid-card{min-height:128px}.horoscope-intro-block h2{font-size:26px}.horoscope-theme-card{padding:18px}}

/* Correction horoscope : signes en carrés violets simples + slider */
.horoscope-page .horoscope-intro-block{display:none!important;}
.horoscope-sign-grid-standalone{margin-top:0!important;}
.horoscope-page .horoscope-sign-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px;}
.horoscope-page .horoscope-sign-card,
.horoscope-slider-wrap .horoscope-sign-card{
    min-height:138px;
    border:0!important;
    border-radius:26px;
    background:linear-gradient(135deg,#7c3aed,#a855f7)!important;
    color:#fff!important;
    box-shadow:none!important;
    overflow:hidden;
    position:relative;
}
.horoscope-page .horoscope-sign-card:before,
.horoscope-slider-wrap .horoscope-sign-card:before{
    content:"";
    position:absolute;
    inset:-45% -35% auto auto;
    width:110px;
    height:110px;
    border-radius:50%;
    background:rgba(255,255,255,.17);
    pointer-events:none;
}
.horoscope-page .horoscope-sign-card:hover,
.horoscope-page .horoscope-sign-card.is-active,
.horoscope-slider-wrap .horoscope-sign-card:hover,
.horoscope-slider-wrap .horoscope-sign-card.is-active{
    transform:translateY(-3px);
    box-shadow:none!important;
    background:linear-gradient(135deg,#6d28d9,#9333ea)!important;
}
.horoscope-page .horoscope-sign-icon,
.horoscope-slider-wrap .horoscope-sign-icon{
    width:62px;
    height:62px;
    border:1px solid rgba(255,255,255,.28)!important;
    background:rgba(255,255,255,.16)!important;
    color:#fff!important;
    border-radius:22px;
    position:relative;
    z-index:1;
}
.horoscope-page .horoscope-sign-card strong,
.horoscope-slider-wrap .horoscope-sign-card strong{
    position:relative;
    z-index:1;
    color:#fff!important;
    font-size:14px;
    font-weight:950;
}
.horoscope-slider-wrap{margin-top:14px!important;box-shadow:none!important;filter:none!important;}
.horoscope-slider-track{display:flex!important;grid-template-columns:none!important;overflow:hidden!important;gap:16px;padding:6px 2px 8px!important;}
.horoscope-slider-track .horoscope-sign-card{flex:0 0 150px!important;width:150px!important;}
.horoscope-page .horoscope-other-title{margin-top:28px;margin-bottom:0;font-size:24px;font-weight:950;color:var(--text,#111827);}
@media(max-width:1100px){.horoscope-page .horoscope-sign-grid{grid-template-columns:repeat(4,minmax(0,1fr));}}
@media(max-width:760px){.horoscope-page .horoscope-sign-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.horoscope-page .horoscope-sign-card{min-height:126px}.horoscope-slider-track .horoscope-sign-card{flex-basis:132px!important;width:132px!important;}}

/* Admin horoscope : filtre aligné à droite + cartes de thèmes */
.horoscope-admin-panel .horoscope-admin-toolbar{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
    flex-wrap:wrap;
    margin-bottom:26px;
}
.horoscope-admin-panel .dedications-list-head h2{margin:0 0 6px;font-size:22px;font-weight:950;color:#111827;}
.horoscope-admin-panel .dedications-list-head .mini-note{margin:0;color:#64748b;font-weight:650;}
.horoscope-radio-filter{margin-left:auto;min-width:280px;}
.horoscope-admin-section-title{margin-bottom:14px;}
.horoscope-admin-section-title .eyebrow{display:block;margin-bottom:6px;color:var(--primary,#ef4444);font-size:11px;letter-spacing:.16em;font-weight:950;text-transform:uppercase;}
.horoscope-admin-section-title h3{margin:0;font-size:24px;line-height:1.1;font-weight:950;color:#111827;}
.horoscope-admin-form .horoscope-admin-checks{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
    margin:16px 0 18px;
}
.horoscope-theme-option,
.horoscope-refresh-option{
    position:relative;
    display:flex!important;
    align-items:center!important;
    gap:14px!important;
    min-height:78px;
    padding:16px!important;
    border-radius:22px!important;
    border:1px solid rgba(148,163,184,.30)!important;
    background:linear-gradient(135deg,#fff,#f8fafc)!important;
    box-shadow:0 14px 34px rgba(15,23,42,.05);
    transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease;
    overflow:hidden;
}
.horoscope-theme-option:before,
.horoscope-refresh-option:before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(135deg,var(--horo-admin-accent,rgba(var(--primary-rgb,92,124,230),.10)),transparent 62%);
    opacity:.9;
    pointer-events:none;
}
.horoscope-theme-option:hover,
.horoscope-refresh-option:hover{
    transform:translateY(-2px);
    border-color:rgba(var(--primary-rgb,92,124,230),.34)!important;
    box-shadow:0 18px 42px rgba(15,23,42,.08);
}
.horoscope-theme-option input,
.horoscope-refresh-option input{
    position:relative;
    z-index:2;
    width:19px!important;
    height:19px!important;
    flex:0 0 auto;
    accent-color:var(--primary,#ef4444);
}
.theme-option-icon{
    position:relative;
    z-index:1;
    width:46px;
    height:46px;
    border-radius:17px;
    display:grid;
    place-items:center;
    background:var(--horo-admin-accent,rgba(var(--primary-rgb,92,124,230),.12));
    color:var(--horo-admin-icon,var(--primary,#ef4444));
    font-size:18px;
    flex:0 0 auto;
}
.theme-option-copy{position:relative;z-index:1;display:flex;flex-direction:column;gap:4px;min-width:0;}
.theme-option-copy strong{font-size:15px;font-weight:950;color:#111827;line-height:1.05;}
.theme-option-copy small{font-size:12px;font-weight:750;color:#64748b;}
.horoscope-refresh-option{max-width:520px;margin-top:2px!important;}
.horoscope-theme-option[data-theme="amour"]{--horo-admin-accent:rgba(244,63,94,.12);--horo-admin-icon:#e11d48;}
.horoscope-theme-option[data-theme="argent"]{--horo-admin-accent:rgba(234,179,8,.15);--horo-admin-icon:#a16207;}
.horoscope-theme-option[data-theme="sante"]{--horo-admin-accent:rgba(16,185,129,.13);--horo-admin-icon:#059669;}
.horoscope-theme-option[data-theme="travail"]{--horo-admin-accent:rgba(59,130,246,.12);--horo-admin-icon:#2563eb;}
.horoscope-theme-option[data-theme="famille"]{--horo-admin-accent:rgba(249,115,22,.12);--horo-admin-icon:#ea580c;}
.horoscope-theme-option[data-theme="vie_sociale"]{--horo-admin-accent:rgba(168,85,247,.12);--horo-admin-icon:#9333ea;}
.horoscope-theme-option[data-theme="citation"]{--horo-admin-accent:rgba(20,184,166,.12);--horo-admin-icon:#0f766e;}
.horoscope-theme-option[data-theme="nombre_chance"]{--horo-admin-accent:rgba(34,197,94,.13);--horo-admin-icon:#16a34a;}
.horoscope-theme-option[data-theme="clin_oeil"]{--horo-admin-accent:rgba(236,72,153,.12);--horo-admin-icon:#db2777;}
.horoscope-refresh-option{--horo-admin-accent:rgba(var(--primary-rgb,92,124,230),.12);--horo-admin-icon:var(--primary,#ef4444);}
@media(max-width:980px){
    .horoscope-radio-filter{width:100%;min-width:0;margin-left:0;}
    .horoscope-admin-form .horoscope-admin-checks{grid-template-columns:1fr;}
    .horoscope-refresh-option{max-width:none;}
}

/* Admin horoscope - bouton synchronisation API en haut */
.horoscope-admin-top-actions{display:flex;justify-content:flex-end;align-items:center;margin:0 0 22px;}
.btn-sync-api{appearance:none;border:0;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:0 18px;border-radius:16px;background:linear-gradient(135deg,var(--primary,#ef4444),rgba(var(--primary-rgb,239,68,68),.78));color:#fff;font-size:14px;font-weight:950;cursor:pointer;box-shadow:0 16px 34px rgba(var(--primary-rgb,239,68,68),.22);transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;}
.btn-sync-api:hover{transform:translateY(-2px);box-shadow:0 20px 42px rgba(var(--primary-rgb,239,68,68),.28);filter:saturate(1.05);}
.btn-sync-api i{font-size:15px;}
.horoscope-refresh-option{display:none!important;}
@media(max-width:760px){.horoscope-admin-top-actions{justify-content:stretch;}.btn-sync-api{width:100%;}}

/* Page membre équipe : description, contacts et émissions liées */
.team-member-about-title {
  margin: 0 0 18px;
  color: #0f172a;
  font-size: clamp(24px, 2vw, 34px);
  font-weight: 900;
  letter-spacing: -0.04em;
}
.team-member-contact-block {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px 18px;
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid rgba(15, 23, 42, .08);
}
.team-member-socials--inline {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  margin: 0;
}
.team-member-shows .team-show-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.team-member-shows .team-show-item {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  min-height: 116px;
  padding: 14px;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 50px rgba(15, 23, 42, .08);
}
.team-show-cover,
.team-show-cover img,
.team-show-cover-placeholder {
  width: 92px;
  height: 92px;
  border-radius: 20px;
}
.team-show-cover {
  overflow: hidden;
  background: rgba(15, 23, 42, .05);
}
.team-show-cover img {
  display: block;
  object-fit: cover;
}
.team-show-cover-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary, #ef4444);
  font-size: 28px;
  background: rgba(239, 68, 68, .1);
}
.team-show-content {
  min-width: 0;
}
.team-show-content strong {
  display: block;
  color: #0f172a;
  font-size: 17px;
  font-weight: 900;
  line-height: 1.15;
}
.team-show-content span {
  display: -webkit-box;
  margin-top: 7px;
  overflow: hidden;
  color: #64748b;
  font-size: 14px;
  font-weight: 650;
  line-height: 1.35;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
@media (max-width: 980px) {
  .team-member-shows .team-show-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 680px) {
  .team-member-contact-block {
    align-items: flex-start;
    flex-direction: column;
  }
  .team-member-shows .team-show-list {
    grid-template-columns: 1fr;
  }
}

/* Correctifs page membre équipe : contacts alignés + émissions comme programmes */
.team-member-about-title{
  font-size:clamp(20px,1.55vw,26px)!important;
  margin-bottom:14px!important;
  letter-spacing:-.025em!important;
}
.team-member-contact-block{
  align-items:center!important;
  gap:12px!important;
}
.team-member-socials--inline,
.team-member-socials[data-team-socials="member"]{
  align-items:center!important;
  justify-content:flex-start!important;
}
.team-member-email{
  margin-top:0!important;
  min-height:46px;
  display:inline-flex!important;
  align-items:center!important;
  gap:10px!important;
  text-decoration:none!important;
  color:#1f2b3d!important;
  font-weight:800!important;
  line-height:1!important;
}
.team-member-email i{
  width:46px!important;
  height:46px!important;
  flex:0 0 46px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:rgba(var(--primary-rgb), .08)!important;
  color:var(--secondary,#111827)!important;
  font-size:18px!important;
}
.team-member-shows.programmes-mosaic-section{
  margin-top:28px;
}
.team-member-shows .programmes-mosaic{
  margin-top:18px;
}
.team-member-shows .programmes-tile{
  cursor:pointer;
}
@media(max-width:680px){
  .team-member-contact-block{align-items:flex-start!important;}
  .team-member-email{min-height:42px;}
  .team-member-email i{width:42px!important;height:42px!important;flex-basis:42px!important;}
}

/* Correctif page membre équipe : retirer le fond du bloc "Émissions de ..." */
.team-member-shows.programmes-showcase-page,
.team-member-shows.programmes-mosaic-section{
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  padding: 0 !important;
}
