/* ================================================================
   Women Voice Radio — Thème violet premium
   Inter | ZERO border-line | Header #2d1833
   TOUTES TAILLES CORRIGÉES — rien de minuscule
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,300;14..32,400;14..32,500;14..32,600;14..32,700;14..32,800;14..32,900&display=swap');

:root {
  --wvr-bg: #f8f4fa;
  --wvr-bg-elev: #ffffff;
  --wvr-bg-panel: #f3edf6;
  --wvr-header-bg: #2d1833;
  --wvr-header-text: #fff;
  --wvr-header-muted: rgba(255,255,255,0.7);
  --wvr-text: #1e0a28;
  --wvr-muted: #5e4269;
  --wvr-accent: #7b2d8e;
  --wvr-accent-light: #9b4dae;
  --wvr-accent-soft: #e8d5ee;
  --wvr-accent-bg: #f0e4f4;
  --wvr-green: #22c55e;
  --wvr-card-shadow: 0 2px 12px rgba(123,45,142,0.08);
  --wvr-font: "Inter","Segoe UI",system-ui,-apple-system,sans-serif;
  --primary: #7b2d8e;
  --color-title: var(--wvr-text);
  --color-text: var(--wvr-muted);
  --duration: 0.15s;
  --main-pad: clamp(1rem,3vw,2rem);
  --playbar-h: 0px;
  --wvr-footer-h: 56px;
  --wvr-radius: 8px;
}

/* RESET */
html { line-height:1.5; -webkit-text-size-adjust:100%; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; height:100%; overflow:hidden; }
*,*::before,*::after { box-sizing:border-box; }
* { margin:0; }
body { font-family:var(--wvr-font); font-size:1.05rem; color:var(--wvr-text); background:var(--wvr-bg); height:100%; overflow:hidden; padding:0; }
a { color:var(--wvr-accent); text-decoration:none; }
a:hover { text-decoration:underline; }
button,input,textarea { font:inherit; color:inherit; border:none; background:none; padding:0; }
button:focus-visible,input:focus-visible,textarea:focus-visible { outline:3px solid var(--wvr-accent-light); outline-offset:2px; }
img { display:block; max-width:100%; }
.player-cover-image { display:none !important; }

/* APP SHELL */
.wvr-app.app {
  position:relative; height:100dvh; max-height:100dvh;
  width:100% !important; max-width:100% !important;
  overflow:hidden !important; display:flex; flex-direction:column;
  background:var(--wvr-bg) !important;
}
.wvr-app.app::after { display:none !important; content:none !important; }

/* ================================================================
   HEADER — compact but READABLE
   ================================================================ */
.wvr-topbrand.header {
  position:relative !important; z-index:10 !important; width:100%; flex-shrink:0;
  padding:0.45rem var(--main-pad);
  background:var(--wvr-header-bg); border:none !important; box-shadow:none !important;
}

.wvr-topbrand-bar {
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; max-width:1400px; margin:0 auto;
}

.wvr-topbrand-logo-block {
  display:flex; align-items:center; gap:0.75rem;
  text-decoration:none !important; color:var(--wvr-header-text); min-width:0;
}

/* LOGO — 56px, bien visible */
.header-logo-img { height:56px; width:auto; flex-shrink:0; }

.wvr-topbrand-logo-text { display:flex; flex-direction:column; gap:0.05rem; min-width:0; }

/* NOM — lisible, uppercase, gras */
.station-name {
  font-size:clamp(1.2rem, 2.5vw, 1.5rem); font-weight:800;
  letter-spacing:0.03em; color:var(--wvr-header-text);
  text-transform:uppercase; line-height:1.2; order:-1;
}

/* SLOGAN — lisible ! pas minuscule */
.station-description {
  font-size:clamp(0.78rem, 1.5vw, 0.9rem); font-weight:500;
  letter-spacing:0.01em; text-transform:none;
  color:var(--wvr-header-muted); line-height:1.3;
}

/* ON AIR — vert, sous le slogan, aligné à gauche */
.wvr-onair-badge {
  display:inline-flex; align-items:center; gap:0.35rem;
  padding:0.22rem 0.7rem; margin-top:0.2rem;
  background:var(--wvr-green); border-radius:100px;
  color:#fff; font-weight:800; font-size:0.68rem;
  letter-spacing:0.12em; text-transform:uppercase;
  width:fit-content;
}
.live-dot { width:7px; height:7px; background:#fff; border-radius:50%; animation:wvr-blink 1.2s ease infinite; }
@keyframes wvr-blink { 50% { opacity:.2; } }

/* SOCIAL BLOCK — aligned bottom with ON AIR badge */
.wvr-topbrand-social-block {
  display:flex; flex-direction:column; align-items:flex-end;
  align-self:flex-end; gap:0.15rem;
}

/* SOCIAL ICONS — header */
.wvr-header-social.player-social {
  position:static !important; display:flex; flex-wrap:wrap; gap:0.45rem;
  justify-content:flex-end; align-items:center;
}
.player-social-item {
  width:44px !important; height:44px !important; min-width:44px;
  border-radius:50% !important; display:flex !important; align-items:center; justify-content:center;
  background:rgba(255,255,255,0.12) !important; box-shadow:none !important; border:none !important;
  transition:background var(--duration);
}
.player-social-item:hover { background:rgba(255,255,255,0.22) !important; }
.player-social .i { stroke:#fff !important; width:22px !important; height:22px !important; }

.player-program { display:none !important; }

@media (max-width:640px) {
  .wvr-topbrand-bar { flex-direction:column; align-items:center; text-align:center; gap:0.4rem; }
  .wvr-topbrand-logo-block { flex-direction:column; text-align:center; align-items:center; }
  .wvr-onair-badge { margin-inline:auto; }
  .wvr-topbrand-social-block { align-items:center; align-self:center; }
  .wvr-header-social.player-social { justify-content:center; }
  .header-logo-img { height:48px; }
}

/* ================================================================
   VERSET DU JOUR — espacement correct, texte LISIBLE
   ================================================================ */
.wvr-verse-bar {
  flex-shrink:0; background:var(--wvr-accent-bg);
  padding:0.6rem var(--main-pad);
}
.wvr-verse-inner { max-width:1400px; margin:0 auto; display:flex; align-items:center; gap:0.75rem; }
.wvr-verse-content { flex:1; min-width:0; }
.wvr-verse-label {
  display:block; font-size:0.72rem; font-weight:800;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--wvr-accent); margin-bottom:0.15rem;
}
.wvr-verse-text {
  font-size:1rem; font-weight:500; font-style:normal;
  line-height:1.45; color:var(--wvr-text); margin:0;
}
.wvr-verse-text strong { font-weight:800; color:var(--wvr-accent); }
.wvr-verse-share {
  flex-shrink:0; height:36px; border-radius:100px;
  display:inline-flex; align-items:center; gap:0.4rem;
  padding:0 0.85rem;
  background:var(--wvr-accent-soft); color:var(--wvr-accent); cursor:pointer;
  transition:background var(--duration);
}
.wvr-verse-share:hover { background:var(--wvr-accent); color:#fff; }
.wvr-verse-share-label {
  font-size:0.78rem; font-weight:700; letter-spacing:0.02em;
}

/* ================================================================
   MAIN — fills remaining space, content centered vertically
   ================================================================ */
.wvr-main {
  flex:1 1 auto; min-height:0;
  overflow-y:auto; overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  padding:1rem var(--main-pad) calc(var(--wvr-footer-h) + 0.75rem);
}

.wvr-grid.song-now { min-height:0; align-items:start; }
.wvr-grid {
  display:grid; grid-template-columns:1fr;
  gap:1rem; max-width:1400px; margin:0 auto; align-items:start;
}
@media (min-width:960px) {
  .wvr-grid {
    grid-template-columns:minmax(0,1fr) minmax(270px,330px);
    gap:1.25rem;
  }
}

#wvrPlayer.player.wvr-col-player {
  position:relative !important; inset:auto !important;
  width:100% !important; height:auto !important;
  max-height:none; min-height:0 !important;
  padding:0 !important; z-index:auto !important;
  overflow:visible !important; display:flex; flex-direction:column;
  align-self:start;
}

/* ================================================================
   SECTION HEADINGS — 1.6rem / 900
   ================================================================ */
.wvr-section-heading {
  font-size:1.6rem; font-weight:900; color:var(--wvr-accent);
  letter-spacing:-0.01em; margin:0 0 0.55rem; flex-shrink:0; line-height:1.2;
}

/* ================================================================
   BROADCAST CARD
   ================================================================ */
.wvr-broadcast-column {
  display:flex; flex-direction:column; gap:0.85rem;
  min-width:0; min-height:0; flex:1 1 auto;
}

.wvr-broadcast-card {
  background:var(--wvr-bg-elev); border-radius:var(--wvr-radius);
  padding:clamp(1rem, 2vw, 1.35rem); width:100%; flex:0 0 auto;
  border:none !important; box-shadow:var(--wvr-card-shadow);
}
.wvr-broadcast-card-inner {
  display:grid; grid-template-columns:minmax(150px, 220px) minmax(0, 1fr);
  gap:clamp(1rem, 2.5vw, 1.75rem); align-items:center;
}

/* Cover — good size */
.wvr-broadcast-art.wvr-cover.player-artwork {
  position:relative !important; display:block !important;
  flex-direction:unset !important; flex:none !important;
  width:100%; max-width:220px !important; margin:0;
  border-radius:var(--wvr-radius); overflow:hidden;
  background:var(--wvr-accent-bg) !important;
  box-shadow:0 4px 18px rgba(123,45,142,0.14) !important;
  aspect-ratio:1/1; align-self:center;
}
.wvr-broadcast-art.wvr-cover.player-artwork img {
  position:absolute !important; inset:0 !important;
  display:block !important; width:100% !important; height:100% !important;
  max-width:none !important; object-fit:cover; aspect-ratio:unset;
}

.wvr-broadcast-main { display:flex; flex-direction:column; gap:0.7rem; min-width:0; justify-content:center; }
.wvr-broadcast-top { display:flex; flex-direction:column; align-items:flex-start; gap:0.1rem; min-width:0; }
.wvr-nowblock { flex:1; min-width:0; text-align:left; padding:0; }

/* TITLE */
#wvrPlayer .song-name.wvr-now-title {
  font-family:var(--wvr-font);
  font-size:clamp(1.25rem, 2.5vw, 1.7rem); font-weight:800;
  line-height:1.2; color:var(--wvr-text) !important;
  text-wrap:balance; margin:0 0 0.15rem; letter-spacing:-0.01em;
}

/* ARTIST — 22px */
#wvrPlayer .song-artist.wvr-now-artist {
  font-size:22px; font-weight:500; letter-spacing:0.01em;
  text-transform:none; color:var(--wvr-muted) !important;
  margin:0; line-height:1.3;
}

/* ================================================================
   PLAY — 65x65
   ================================================================ */
.wvr-broadcast-play.player-button-play {
  width:65px; height:65px; min-width:65px; border-radius:50%; padding:0;
  display:flex; align-items:center; justify-content:center;
  background:var(--wvr-accent) !important; color:#fff !important;
  cursor:pointer; flex-shrink:0; border:none;
  box-shadow:0 4px 18px rgba(123,45,142,0.3);
  transition:background var(--duration); position:relative; z-index:1;
}
.wvr-broadcast-play.player-button-play:hover { background:var(--wvr-accent-light) !important; }
.wvr-broadcast-play.player-button-play.is-active { background:var(--wvr-accent-light) !important; color:#fff !important; }
.wvr-broadcast-play.player-button-play::before,
.wvr-broadcast-play.player-button-play::after { display:none !important; content:none !important; animation:none !important; }
.wvr-broadcast-play .wvr-broadcast-play-icon,
.wvr-broadcast-play svg { width:28px; height:28px; display:block; margin-left:3px; }
.wvr-broadcast-play .i-pause { margin-left:0; }
.wvr-broadcast-play .i-play path,
.wvr-broadcast-play .i-pause path { fill:currentColor; }

/* ================================================================
   EQUALIZER
   ================================================================ */
.wvr-equalizer { display:flex; align-items:flex-end; gap:3px; height:24px; padding:0 3px; opacity:0.25; }
.wvr-equalizer.wvr-eq-active { opacity:1; }
.wvr-eq-bar { display:block; width:4px; background:var(--wvr-accent); border-radius:2px; height:5px; animation:none; }
.wvr-eq-active .wvr-eq-bar { animation:wvr-eq .9s ease-in-out infinite alternate; }
.wvr-eq-active .wvr-eq-bar:nth-child(1) { animation-duration:.7s; }
.wvr-eq-active .wvr-eq-bar:nth-child(2) { animation-duration:.85s; animation-delay:.1s; }
.wvr-eq-active .wvr-eq-bar:nth-child(3) { animation-duration:.65s; animation-delay:.2s; }
.wvr-eq-active .wvr-eq-bar:nth-child(4) { animation-duration:.9s; animation-delay:.05s; }
.wvr-eq-active .wvr-eq-bar:nth-child(5) { animation-duration:.75s; animation-delay:.15s; }
@keyframes wvr-eq { 0% { height:4px; } 100% { height:22px; } }

/* ================================================================
   CONTROLS ROW
   ================================================================ */
.wvr-broadcast-controls-row,
.wvr-broadcast-volume-row {
  display:flex; flex-direction:row; align-items:center;
  gap:0.5rem; width:auto; max-width:420px; min-width:0;
}
.wvr-vol-ico { flex-shrink:0; color:var(--wvr-muted); display:flex; opacity:.5; }
.wvr-broadcast-range.volume-range,
.volume-range {
  flex:1; width:auto; max-width:160px; height:5px; min-width:60px;
  appearance:none; -webkit-appearance:none;
  background:var(--wvr-accent-soft); border-radius:3px; outline:none;
}
.volume-range::-webkit-slider-thumb {
  appearance:none; -webkit-appearance:none; width:16px; height:16px;
  border-radius:50%; background:var(--wvr-accent); cursor:pointer;
  box-shadow:0 1px 6px rgba(123,45,142,0.35);
}
.volume-range::-moz-range-thumb {
  width:16px; height:16px; border-radius:50%; background:var(--wvr-accent);
  border:0; cursor:pointer; box-shadow:0 1px 6px rgba(123,45,142,0.35);
}

/* External links */
.wvr-ext-listen { margin-top:0.3rem; text-align:right; }
.wvr-ext-listen-label {
  font-size:0.72rem; font-weight:700; letter-spacing:0.06em;
  text-transform:uppercase; color:var(--wvr-muted); margin:0 0 0.3rem; opacity:.55;
}
.wvr-player-links { display:flex; flex-wrap:wrap; gap:0.4rem; justify-content:flex-end; align-items:center; }
.wvr-player-link {
  display:inline-flex; align-items:center; justify-content:center; padding:0.25rem;
  border-radius:var(--wvr-radius); background:var(--wvr-accent-bg);
  border:none !important; box-shadow:0 1px 4px rgba(123,45,142,0.06);
  transition:background var(--duration);
}
.wvr-player-link:hover { background:var(--wvr-accent-soft); }
.wvr-player-link img { display:block; height:22px; width:auto; }

/* Mobile broadcast card — horizontal compact, no scroll needed */
@media (max-width:560px) {
  .wvr-broadcast-card-inner {
    grid-template-columns:120px minmax(0,1fr); justify-items:start; text-align:left;
    gap:0.75rem;
  }
  .wvr-broadcast-art.wvr-cover.player-artwork {
    max-width:120px !important; width:120px; margin:0;
  }
  .wvr-broadcast-main { width:100%; align-items:flex-start; gap:0.4rem; }
  .wvr-broadcast-top { align-items:flex-start; text-align:left; }
  .wvr-nowblock { text-align:left; }
  #wvrPlayer .song-name.wvr-now-title { font-size:1.1rem; }
  #wvrPlayer .song-artist.wvr-now-artist { font-size:15px; }
  .wvr-broadcast-play.player-button-play { width:50px; height:50px; min-width:50px; }
  .wvr-broadcast-play .wvr-broadcast-play-icon,
  .wvr-broadcast-play svg { width:22px; height:22px; }
  .wvr-broadcast-controls-row,
  .wvr-broadcast-volume-row { max-width:100%; justify-content:flex-start; }
  .wvr-ext-listen { text-align:left; }
  .wvr-player-links { justify-content:flex-start; }
  .wvr-ext-listen-label { display:none; }
}

/* ================================================================
   HISTORY — covers 82px, text readable
   ================================================================ */
.wvr-recent-section { width:100%; flex:0 0 auto; display:flex; flex-direction:column; }
.wvr-recent-section .wvr-section-heading { margin-bottom:0.45rem; }

.wvr-history-shell {
  display:flex; align-items:center; gap:0.5rem;
  background:var(--wvr-bg-elev); border-radius:var(--wvr-radius);
  padding:0.55rem; flex:0 0 auto; overflow:hidden;
  border:none !important; box-shadow:var(--wvr-card-shadow);
}
.wvr-history-nav {
  flex:0 0 auto; width:36px; min-width:36px; height:36px;
  border-radius:50%; border:none; background:var(--wvr-accent-bg);
  color:var(--wvr-accent); font-size:1.2rem; font-weight:700;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  padding:0; transition:background var(--duration);
}
.wvr-history-nav:hover { background:var(--wvr-accent-soft); }

.wvr-history-viewport {
  flex:1; min-width:0; overflow-x:auto; overflow-y:hidden;
  scroll-behavior:smooth; scrollbar-width:none;
}
.wvr-history-viewport::-webkit-scrollbar { display:none; }

.wvr-history-list {
  display:flex; flex-wrap:nowrap; align-items:center;
  gap:0.55rem; padding:0.1rem; width:max-content;
}
.wvr-history-list:has(> .wvr-history-empty:only-child) { width:100%; justify-content:center; }
.wvr-history-list > .wvr-history-empty:only-child { width:100%; }
.wvr-history-empty { font-size:0.95rem; color:var(--wvr-muted); padding:0.5rem 0; }

.wvr-history-item {
  flex:0 0 auto; width:min(290px, 85vw); scroll-snap-align:start;
  display:flex; align-items:center; gap:0.6rem; padding:0.45rem 0.6rem;
  background:var(--wvr-bg-panel); border-radius:var(--wvr-radius); border:none !important;
}
.wvr-history-meta { min-width:0; flex:1; display:flex; flex-direction:column; gap:0.08rem; }

/* COVER 82px — bien visible */
.wvr-history-cover {
  width:82px; height:82px; min-width:82px;
  object-fit:cover; border-radius:var(--wvr-radius);
  background:var(--wvr-accent-bg); flex-shrink:0;
}
.wvr-history-title {
  font-size:0.95rem; font-weight:700; line-height:1.25; color:var(--wvr-text);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.wvr-history-artist {
  font-size:0.85rem; font-weight:500; color:var(--wvr-muted);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}

/* ================================================================
   SIDEBAR — aligned left with header social icons
   ================================================================ */
.wvr-col-side { align-self:start; min-height:0; }
.wvr-side-stack {
  display:flex; flex-direction:column; gap:0.5rem;
  max-height:100%; overflow-y:auto; overflow-x:hidden; scrollbar-width:none;
}
.wvr-side-stack::-webkit-scrollbar { display:none; }

.wvr-panel {
  background:var(--wvr-bg-elev); padding:0.7rem 0.9rem;
  border-radius:var(--wvr-radius); border:none !important;
  box-shadow:var(--wvr-card-shadow);
}
.wvr-panel-label {
  display:block; font-size:0.78rem; font-weight:800;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--wvr-accent); margin-bottom:0.15rem;
}
.wvr-time-big {
  display:block; font-size:2rem; font-weight:800;
  font-variant-numeric:tabular-nums; color:var(--wvr-text);
}
.wvr-time-sub {
  display:block; font-size:0.88rem; font-weight:500;
  color:var(--wvr-muted); margin-top:0.1rem; text-transform:capitalize;
}
.wvr-weather-line { display:flex; flex-wrap:wrap; align-items:baseline; gap:0.5rem; }
.wvr-weather-temp { font-size:2rem; font-weight:800; color:var(--wvr-text); }
.wvr-weather-desc { font-size:0.95rem; font-weight:500; color:var(--wvr-muted); }
.wvr-weather-hint { display:block; font-size:0.85rem; color:var(--wvr-muted); margin-top:0.1rem; }

/* Nav items */
.wvr-side-nav { display:flex; flex-direction:column; gap:0.3rem; }
.wvr-navhit {
  cursor:pointer; text-align:left; padding:0.6rem 0.85rem;
  font-size:1rem; font-weight:700; color:var(--wvr-text);
  background:var(--wvr-bg-elev); border-radius:var(--wvr-radius);
  border:none !important; box-shadow:var(--wvr-card-shadow);
  transition:background var(--duration);
  display:flex; align-items:center; gap:0.6rem;
}
.wvr-navhit:hover { background:var(--wvr-accent-bg); }
.wvr-nav-ico { flex-shrink:0; color:var(--wvr-accent); stroke:var(--wvr-accent); }

/* ================================================================
   FOOTER — badges + copyright LISIBLE
   ================================================================ */
.wvr-site-footer {
  position:fixed; left:0; right:0; bottom:0; z-index:100;
  background:var(--wvr-bg-elev);
  padding:0.45rem var(--main-pad);
  padding-bottom:max(0.45rem, env(safe-area-inset-bottom, 0px));
  box-shadow:0 -2px 12px rgba(123,45,142,0.07); border:none !important;
}
.wvr-site-footer-inner {
  max-width:1400px; margin:0 auto; display:flex; flex-wrap:wrap;
  align-items:center; justify-content:space-between; gap:0.4rem 1.5rem;
}
.wvr-footer-apps { display:flex; align-items:center; gap:0.6rem; }
.wvr-store-badge { display:inline-block; height:36px; flex-shrink:0; }
.wvr-store-badge img {
  height:36px; width:auto; display:block;
  object-fit:contain;
}
.wvr-footer-secondary { text-align:right; min-width:min(100%, 16rem); }
.wvr-footer-copyright {
  margin:0 0 0.05rem; font-size:0.82rem; font-weight:400; color:#9e8ca6;
}
.wvr-footer-byline {
  margin:0; font-size:0.78rem; font-weight:400; color:#b8a8c0;
}
.wvr-footer-byline a { color:#9e8ca6 !important; text-decoration:none !important; font-weight:500; }
.wvr-footer-byline a:hover { text-decoration:underline !important; }

@media (max-width:640px) {
  .wvr-site-footer-inner { flex-direction:column; align-items:center; text-align:center; gap:0.3rem; }
  .wvr-footer-secondary { text-align:center; width:100%; }
  .wvr-store-badge { height:32px; }
  .wvr-store-badge img { height:32px; }
  :root { --wvr-footer-h: 72px; }
}

/* Hidden */
.footer-app, .footer-tv { display:none !important; }
.offcanvas, .mobile-menu { display:none !important; }
.player-controller { display:none !important; }

/* Alt play */
.wvr-pmain.player-button-play { width:52px; height:52px; border-radius:50%; background:var(--wvr-accent); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; padding:0; }
.wvr-pmain.player-button-play:hover { background:var(--wvr-accent-light); }
.wvr-pmain.player-button-play.is-active { background:var(--wvr-accent-light); color:#fff; }
.wvr-pmain .i-play path, .wvr-pmain .i-pause path { fill:currentColor; }
.wvr-pvol-wrap { position:relative; display:flex; align-items:center; justify-content:center; }
.wvr-volume-drawer { position:absolute; bottom:calc(100% + 12px); right:0; width:min(280px,85vw); padding:0.8rem; background:var(--wvr-bg-elev); border-radius:var(--wvr-radius); border:none !important; box-shadow:0 8px 28px rgba(123,45,142,0.14); }
.wvr-vol-label { display:block; font-size:0.85rem; font-weight:700; margin-bottom:0.4rem; color:var(--wvr-muted); }
.wvr-ext-ico { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--wvr-accent-bg); color:var(--wvr-accent) !important; text-decoration:none !important; font-size:0.65rem; font-weight:800; cursor:pointer; border:none !important; transition:background var(--duration); }
button.wvr-ext-ico { font:inherit; padding:0; }
.wvr-ext-ico:hover { background:var(--wvr-accent-soft); }

/* ================================================================
   DIALOGS
   ================================================================ */
.wvr-dialog { border:none; padding:0; max-width:calc(100vw - 1.5rem); width:min(560px,100%); background:transparent; color:var(--wvr-text); margin:auto; }
.wvr-dialog.wvr-dialog-wide { width:min(640px,100%); }
.wvr-dialog::backdrop { background:rgba(30,10,40,0.6); }
.wvr-dialog-panel {
  background:var(--wvr-bg-elev); padding:1.75rem 1.5rem 1.5rem;
  border-radius:var(--wvr-radius); border:none !important;
  box-shadow:0 20px 60px rgba(45,24,51,0.22);
  position:relative; max-height:85vh; display:flex; flex-direction:column;
}
/* NO scrollbar visible on any dialog */
.wvr-dialog-nooverflow .wvr-dialog-body { overflow:visible; }
.wvr-dialog-panel .wvr-dialog-body { overflow-y:auto; scrollbar-width:none; }
.wvr-dialog-panel .wvr-dialog-body::-webkit-scrollbar { display:none; }
.wvr-dialog-scroll { overflow-y:auto; scrollbar-width:none; }
.wvr-dialog-scroll::-webkit-scrollbar { display:none; }

.wvr-dialog-title { font-size:1.5rem; font-weight:800; margin-bottom:0.85rem; padding-right:2.5rem; color:var(--wvr-text); flex-shrink:0; }
.wvr-dialog-subtitle { font-size:1.05rem; font-weight:800; color:var(--wvr-text); margin:1rem 0 0.4rem; }
.wvr-dialog-body { font-size:0.95rem; line-height:1.65; color:var(--wvr-muted); flex:1 1 auto; }
.wvr-dialog-body p { margin-bottom:0.7rem; }
.wvr-dialog-body p:last-child { margin-bottom:0; }
.wvr-dialog-close {
  position:absolute; top:0.85rem; right:0.85rem; width:38px; height:38px;
  border-radius:50%; cursor:pointer; background:var(--wvr-accent-bg);
  color:var(--wvr-accent); font-size:1.3rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  border:none !important; transition:background var(--duration); z-index:2;
}
.wvr-dialog-close:hover { background:var(--wvr-accent-soft); }

/* ================================================================
   CONTACT FORM
   ================================================================ */
.wvr-contact-form { margin-top:0.5rem; }
.wvr-form-row { display:grid; grid-template-columns:1fr 1fr; gap:0.6rem; }
@media (max-width:480px) { .wvr-form-row { grid-template-columns:1fr; } }
.wvr-form-group { margin-bottom:0.65rem; }
.wvr-form-label { display:block; font-size:0.88rem; font-weight:700; color:var(--wvr-text); margin-bottom:0.25rem; }
.wvr-form-input {
  display:block; width:100%; padding:0.6rem 0.85rem; font-size:0.95rem;
  color:var(--wvr-text); background:var(--wvr-bg);
  border:none !important; border-radius:var(--wvr-radius);
  box-shadow:inset 0 1px 4px rgba(123,45,142,0.08);
  transition:box-shadow var(--duration);
}
.wvr-form-input:focus { box-shadow:inset 0 1px 4px rgba(123,45,142,0.08), 0 0 0 3px var(--wvr-accent-soft); }
.wvr-form-textarea { resize:vertical; min-height:80px; }
.wvr-form-submit {
  display:inline-flex; align-items:center; justify-content:center;
  padding:0.65rem 1.5rem; font-size:0.95rem; font-weight:700;
  color:#fff; background:var(--wvr-accent); border-radius:var(--wvr-radius);
  border:none !important; cursor:pointer; transition:background var(--duration);
}
.wvr-form-submit:hover { background:var(--wvr-accent-light); }
.wvr-form-status { font-size:0.88rem; margin-top:0.5rem; font-weight:600; }
.wvr-form-success { color:#2e7d32; }
.wvr-form-error { color:#c62828; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:959px) {
  .wvr-grid { gap:0.85rem; }
  .wvr-section-heading { font-size:1.4rem; }
  #wvrPlayer .song-artist.wvr-now-artist { font-size:18px; }
}
@media (max-width:560px) {
  .wvr-section-heading { font-size:1.25rem; }
  .wvr-verse-text { font-size:0.92rem; }
  .wvr-dialog-panel { padding:1.25rem 1rem 1rem; max-height:90vh; }
  .wvr-dialog-title { font-size:1.25rem; }
  #wvrPlayer .song-artist.wvr-now-artist { font-size:16px; }
  .wvr-broadcast-play.player-button-play { width:56px; height:56px; min-width:56px; }
}
