/* ============================================================
   UJENAMI — COMPONENTS.CSS
   Tous les composants réutilisables :
   boutons, cards radio/room, modals, formulaires, toggles,
   profil, notifications, room active
   ============================================================ */

/* ── RADIAL BUTTONS ── */
.radial-btn{
  position:absolute;pointer-events:all;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
}
.radial-btn .btn-inner{
  background:var(--white);border:1.5px solid var(--black);border-radius:4px;
  padding:clamp(11px,2vw,16px) clamp(13px,2.2vw,22px);
  font-size:clamp(10px,1.5vw,14px);letter-spacing:0.12em;text-transform:uppercase;
  color:var(--black);font-family:'Georgia',serif;font-weight:300;
  white-space:nowrap;transition:background 0.2s,color 0.2s;text-align:center;
  min-width:clamp(80px,13vw,130px);line-height:1.5;
  box-shadow:0 2px 12px rgba(0,0,0,0.08);
}
.radial-btn.active .btn-inner{background:var(--black);color:var(--white);}

/* ── GENERIC FORM ELEMENTS ── */
.section-label{
  font-size:clamp(8px,1.3vw,11px);letter-spacing:0.3em;
  text-transform:uppercase;color:var(--gray-mid);font-weight:300;text-align:center;
}
.tao-input{
  background:none;border:none;border-bottom:1.5px solid var(--black);
  font-size:clamp(13px,2.2vw,18px);font-family:'Georgia',serif;font-weight:300;
  letter-spacing:0.08em;color:var(--black);text-align:center;
  padding:9px 16px;outline:none;width:80%;max-width:380px;
}
.tao-input::placeholder{color:var(--gray-mid);}
.tao-btn{
  padding:11px 24px;font-family:'Georgia',serif;
  font-size:clamp(9px,1.4vw,12px);letter-spacing:0.15em;text-transform:uppercase;
  cursor:pointer;transition:all 0.2s;border-radius:3px;
}
.tao-o{border:1.5px solid var(--black);background:none;color:var(--black);}
.tao-o:active{background:var(--black);color:var(--white);}
.tao-s{border:none;background:var(--black);color:var(--white);}
.tao-s:active{opacity:0.75;}

/* ── VOICE MODAL ── */
#voiceModal{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(245,245,240,0.98);z-index:600;
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:28px;
}
#voiceModal.show{display:flex;}
.v-circle{
  width:clamp(74px,13vw,112px);height:clamp(74px,13vw,112px);
  border-radius:50%;border:2px solid var(--black);
  display:flex;align-items:center;justify-content:center;
  font-size:clamp(28px,5vw,42px);animation:vb 1.5s ease infinite;
}
@keyframes vb{0%,100%{transform:scale(1);}50%{transform:scale(1.09);}}
.v-text{
  max-width:82%;text-align:center;font-size:clamp(13px,2.3vw,20px);
  color:var(--black);font-weight:300;min-height:52px;
  display:flex;align-items:center;justify-content:center;
}
.v-hint{font-size:11px;color:var(--gray-mid);letter-spacing:0.2em;text-transform:uppercase;}
.v-close{
  padding:12px 32px;border:1.5px solid var(--black);background:none;
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  cursor:pointer;font-family:'Georgia',serif;transition:all 0.2s;
}
.v-close:active{background:var(--black);color:var(--white);}

/* ── COUNTRY MODAL ── */
#countryModal{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:rgba(245,245,240,0.98);z-index:650;
  display:none;flex-direction:column;align-items:center;
  gap:16px;padding:24px 20px;overflow-y:auto;
}
#countryModal.show{display:flex;}
.modal-title{
  font-size:12px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--gray-mid);margin-top:8px;
}
.country-search{
  width:100%;max-width:420px;padding:12px 20px;
  border:1.5px solid var(--black);background:none;
  font-family:'Georgia',serif;font-size:16px;
  outline:none;border-radius:4px;letter-spacing:0.06em;
}
.country-list{
  display:flex;flex-direction:column;gap:4px;
  width:100%;max-width:420px;overflow-y:auto;max-height:55vh;
}
.country-item{
  display:flex;align-items:center;gap:14px;
  padding:11px 16px;cursor:pointer;border-radius:6px;transition:background 0.2s;
}
.country-item:active{background:var(--gray-light);}
.ci-flag{font-size:24px;}
.ci-name{font-size:15px;font-weight:300;letter-spacing:0.06em;}

/* ── USER ACTION MODAL ── */
#uam{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--white);border:1.5px solid var(--black);border-radius:10px;
  padding:22px 28px;z-index:800;display:flex;flex-direction:column;
  gap:10px;align-items:center;min-width:220px;
  box-shadow:0 8px 40px rgba(0,0,0,0.15);
}

/* ── HORIZONTAL SCROLL ── */
.h-scroll{
  display:flex;flex-direction:row;gap:clamp(14px,2.5vw,22px);
  overflow-x:auto;padding:16px 12px 20px;width:100%;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;
}
.h-scroll::-webkit-scrollbar{display:none;}
.scroll-hint{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-size:26px;color:var(--gray-mid);pointer-events:none;opacity:0.55;
  animation:scrollHintAnim 1.5s ease infinite;z-index:5;
}
@keyframes scrollHintAnim{
  0%,100%{transform:translateY(-50%) translateX(0);opacity:0.5;}
  50%{transform:translateY(-50%) translateX(6px);opacity:0.9;}
}
.scroll-wrapper{
  display:flex;flex-direction:column;align-items:center;gap:clamp(10px,2vh,18px);
  width:100%;max-width:min(640px,100%);padding:4px 4px clamp(16px,4vh,32px);
  flex-shrink:0;
}
.scroll-wrapper::-webkit-scrollbar{display:none;}
.scroll-wrapper{scrollbar-width:none;}

/* ── ROOM CARD ── */
.room-card{
  flex-shrink:0;width:clamp(170px,28vw,250px);height:clamp(170px,26vw,230px);
  border:1.5px solid var(--black);border-radius:10px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;background:var(--white);transition:all 0.22s;
  padding:16px 14px;text-align:center;position:relative;gap:8px;
  scroll-snap-align:start;box-shadow:0 2px 16px rgba(0,0,0,0.07);
}
.room-card:active{background:var(--black);}
.room-card:active .rc-name,.room-card:active .rc-theme,
.room-card:active .rc-like,.room-card:active .rc-live{color:var(--white)!important;}
.rc-icon{font-size:clamp(30px,5vw,42px);}
.rc-name{font-size:clamp(11px,1.7vw,15px);letter-spacing:0.08em;color:var(--black);font-weight:300;line-height:1.3;}
.rc-theme{font-size:clamp(8px,1.2vw,11px);color:var(--gray-mid);letter-spacing:0.12em;text-transform:uppercase;}
.rc-like{display:flex;align-items:center;gap:4px;font-size:clamp(11px,1.6vw,14px);color:var(--gray-mid);}
.rc-live{display:flex;align-items:center;gap:5px;font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-mid);}
.live-dot{width:7px;height:7px;background:#E41E20;border-radius:50%;animation:blink 1s ease infinite;}
.fav-s{
  position:absolute;top:8px;right:10px;font-size:28px;cursor:pointer;
  opacity:0.28;color:var(--black);transition:opacity 0.2s,transform 0.15s;line-height:1;
}
.fav-s:active{transform:scale(1.3);}
.fav-s.on{opacity:1;}

/* ── WORLD ROOM LIST ── */
.world-room-item{
  display:flex;align-items:center;gap:14px;padding:16px 18px;
  border:1.5px solid var(--black);border-radius:8px;background:var(--white);
  cursor:pointer;transition:all 0.2s;position:relative;min-height:78px;
  box-shadow:0 2px 10px rgba(0,0,0,0.05);
}
.world-room-item:active{background:var(--gray-light);}
.wri-icon{font-size:30px;flex-shrink:0;}
.wri-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px;}
.wri-name{font-size:clamp(12px,2vw,16px);font-weight:300;letter-spacing:0.08em;color:var(--black);}
.wri-meta{font-size:clamp(9px,1.3vw,12px);color:var(--gray-mid);letter-spacing:0.1em;text-transform:uppercase;}
.wri-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0;}
.wri-fav{font-size:28px;opacity:0.28;cursor:pointer;transition:opacity 0.2s;color:var(--black);line-height:1;}
.wri-fav.on{opacity:1;}
.wri-like{font-size:13px;color:var(--gray-mid);}

/* ── THEME GRID ── */
.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%;max-width:440px;}
.theme-btn{
  border:1.5px solid var(--black);border-radius:10px;padding:16px 10px;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  cursor:pointer;background:var(--white);transition:all 0.2s;
  font-family:'Georgia',serif;font-size:clamp(9px,1.5vw,12px);
  letter-spacing:0.1em;text-transform:uppercase;box-shadow:0 2px 8px rgba(0,0,0,0.05);
}
.theme-btn:active,.theme-btn.sel{background:var(--black);color:var(--white);}
.theme-icon{font-size:clamp(22px,4vw,30px);}

/* ── FILTER PILLS ── */
.filter-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;width:100%;max-width:600px;}
.fpill{
  padding:8px 16px;border:1.5px solid var(--black);border-radius:20px;
  background:none;font-family:'Georgia',serif;font-size:clamp(8px,1.3vw,11px);
  letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;
  transition:all 0.2s;display:flex;align-items:center;gap:5px;
}
.fpill:active,.fpill.sel{background:var(--black);color:var(--white);}

/* ── TOGGLE SWITCH ── */
.toggle-row{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:420px;padding:10px 18px;
  border-bottom:1px solid var(--gray-light);
}
.toggle-label{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray-dark);font-weight:300;}
.toggle-switch{
  width:46px;height:26px;border-radius:13px;background:var(--gray-light);
  position:relative;cursor:pointer;transition:background 0.3s;flex-shrink:0;
}
.toggle-switch.on{background:var(--black);}
.toggle-knob{
  width:20px;height:20px;border-radius:50%;background:white;
  position:absolute;top:3px;left:3px;transition:left 0.3s;
}
.toggle-switch.on .toggle-knob{left:23px;}

/* ── PROFILE ── */
.profile-avatar{
  width:clamp(64px,12vw,94px);height:clamp(64px,12vw,94px);
  border-radius:50%;background:var(--gray-light);border:2px solid var(--black);
  display:flex;align-items:center;justify-content:center;
  font-size:clamp(24px,5vw,38px);cursor:pointer;overflow:hidden;
}
.profile-row{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:420px;padding:13px 18px;border-bottom:1px solid var(--gray-light);
}
.pr-left{display:flex;flex-direction:column;gap:3px;}
.pr-label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-mid);}
.pr-value{font-size:clamp(12px,1.9vw,16px);color:var(--black);font-weight:300;}
.pr-edit{
  font-size:10px;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--gray-mid);cursor:pointer;border:none;background:none;
  font-family:'Georgia',serif;text-decoration:underline;
}

/* ── NOTIFICATIONS ── */
.nab{padding:7px 13px;font-size:9px;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;font-family:'Georgia',serif;border-radius:3px;}

/* ── SPEAKER GRID ── */
.speaker-grid{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;max-width:500px;}
.speaker-item{display:flex;flex-direction:column;align-items:center;gap:6px;width:72px;}
.speaker-av{
  width:52px;height:52px;border-radius:50%;background:var(--gray-light);
  border:2px solid var(--gray-light);display:flex;align-items:center;justify-content:center;
  font-size:22px;transition:border-color 0.3s;
}
.speaker-av.speaking{border-color:var(--black);}
.speaker-av.muted{opacity:0.38;}
.speaker-name{font-size:8px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gray-mid);text-align:center;}

/* ── ROOM ACTIONS ── */
.room-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.ra-btn{
  padding:11px 18px;border:1.5px solid var(--black);background:none;
  font-family:'Georgia',serif;font-size:clamp(8px,1.4vw,12px);letter-spacing:0.12em;
  text-transform:uppercase;cursor:pointer;border-radius:3px;
  transition:all 0.2s;display:flex;align-items:center;gap:6px;
}
.ra-btn:active{background:var(--black);color:var(--white);}
.ra-btn.danger{border-color:#E41E20;color:#E41E20;}
.ra-btn.danger:active{background:#E41E20;color:white;}

/* ── LIVE WAVE BARS ── */
.l-wave{display:flex;align-items:flex-end;gap:3px;height:34px;}
.l-bar{width:4px;background:var(--black);border-radius:2px;animation:lw 1.3s ease infinite;opacity:0.5;}
.l-bar:nth-child(1){animation-delay:0s;} .l-bar:nth-child(2){animation-delay:0.13s;}
.l-bar:nth-child(3){animation-delay:0.26s;} .l-bar:nth-child(4){animation-delay:0.39s;}
.l-bar:nth-child(5){animation-delay:0.52s;} .l-bar:nth-child(6){animation-delay:0.39s;}
.l-bar:nth-child(7){animation-delay:0.26s;}
@keyframes lw{0%,100%{height:4px;}50%{height:26px;}}

/* ── DANGER ZONE ── */

/* ── RESPONSIVE ── */
@media(pointer:coarse){
  .radial-btn .btn-inner{padding:14px 18px;font-size:12px;min-width:88px;}
  .room-card{width:clamp(160px,30vw,240px);height:clamp(160px,28vw,225px);}
  .radio-card{width:clamp(145px,26vw,205px);height:clamp(160px,24vw,205px);}
  .mcb{width:46px;height:46px;font-size:18px;}
}
@media(max-width:400px){
  .pos-right{right:12px;}
  .radial-btn .btn-inner{min-width:66px;font-size:9px;padding:10px 10px;}
}

/* ── RADIAL POSITIONS ── */
.pos-left  {left:clamp(12px,4%,40px);top:50%;transform:translateY(-50%);}
.pos-right {right:clamp(12px,4%,40px);top:50%;transform:translateY(-50%);}
.pos-top   {top:clamp(62px,12%,88px);left:50%;transform:translateX(-50%);}
.pos-tl    {top:clamp(62px,13%,95px);left:clamp(20px,5%,60px);}
.pos-tc    {top:clamp(62px,13%,95px);left:50%;transform:translateX(-50%);}
.pos-tr    {top:clamp(62px,13%,95px);right:clamp(58px,10%,92px);}
.pos-bl    {bottom:clamp(10px,5%,38px);left:clamp(20px,5%,60px);}
.pos-br    {bottom:clamp(10px,5%,38px);right:clamp(58px,10%,92px);}
.pos-bc    {bottom:clamp(10px,5%,38px);left:50%;transform:translateX(-50%);}

/* ═══════════════════════════════════════════════════════════
   AJOUTS v5
   ═══════════════════════════════════════════════════════════ */

/* ── SCROLL hint ── */
.scroll-hint{
  background:linear-gradient(to left, rgba(245,245,240,0.95) 60%, transparent);
  width:40px;right:0;top:0;bottom:0;height:100%;
  transform:none;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
}

/* ── SOURCE BADGES ── */



.np-badge-ai { background:#4a148c;color:#fff; }



/* ═══════════════════════════════════════════════════════════
   v10 — Cards paysage, pays épinglés, Now Playing compact
   ═══════════════════════════════════════════════════════════ */

/* ── CARD RADIO PAYSAGE (radio-card-sm) ── */
.radio-card-sm{
  flex-shrink:0;
  width:clamp(190px,32vw,270px);
  height:80px;
  display:flex;flex-direction:row;align-items:center;
  gap:10px;padding:10px 12px;
  border:1.5px solid transparent;  /* couleur via JS */
  border-radius:10px;
  cursor:pointer;
  /* background défini par JS (couleur tintée) */
  transition:filter 0.2s, transform 0.15s;
  position:relative;
  scroll-snap-align:start;
  box-shadow:0 2px 12px rgba(0,0,0,0.08);
}
.radio-card-sm:active{
  filter:brightness(0.88);
  transform:scale(0.97);
}
.radio-card-sm.playing{ color:white; }

.rcs-left{ flex-shrink:0; }
.rcs-flag{ font-size:28px;line-height:1;
  font-family:'Segoe UI Emoji','Apple Color Emoji','Noto Color Emoji',sans-serif; }
.rcs-body{ flex:1;min-width:0;display:flex;flex-direction:column;gap:3px; }
.rcs-name{
  font-size:clamp(9px,1.4vw,12px);letter-spacing:0.1em;
  text-transform:uppercase;font-weight:300;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.rcs-freq{ font-size:9px;letter-spacing:0.12em;text-transform:uppercase; }
.rcs-right{
  display:flex;flex-direction:column;align-items:flex-end;
  gap:5px;flex-shrink:0;
}
.rcs-fav{
  font-size:20px;opacity:0.3;cursor:pointer;
  transition:opacity 0.2s;line-height:1;
}
.rcs-fav:active{transform:scale(1.3);}
.rcs-fav.on{opacity:1;}
.rcs-like{
  display:flex;align-items:center;gap:4px;
  font-size:14px;cursor:pointer;color:#cc2222;
}
.rcs-like.liked{ font-weight:600; }
.rcs-count{ font-size:10px; }

/* ── PAYS ÉPINGLÉS ── */
.pinned-pills-row{
  display:flex;flex-wrap:wrap;gap:8px;width:100%;
}
.country-pin-pill{
  display:flex;align-items:center;gap:5px;
  padding:7px 10px 7px 12px;
  border:1.5px solid var(--black);border-radius:20px;
  background:none;cursor:pointer;font-family:'Georgia',serif;
  transition:all 0.2s;font-size:12px;
}
.country-pin-pill.sel{background:var(--black);color:var(--white);}
.country-pin-pill:active{opacity:0.7;}
.cp-flag{ font-size:18px; }
.cp-name{ font-size:10px;letter-spacing:0.1em;text-transform:uppercase;font-weight:300; }
.cp-unpin{
  font-size:10px;opacity:0.4;margin-left:2px;
  padding:2px 4px;border-radius:50%;
  transition:opacity 0.2s;
}
.cp-unpin:hover{opacity:1;}

.country-add-btn:active{border-color:var(--black);color:var(--black);}

/* ── NOW PLAYING COMPACT — juste sous la freq bar ── */









.np-lyrics-sm::-webkit-scrollbar{display:none;}

/* Ajuster le padding du contenu pour tenir compte de la NP panel */
/* Quand la radio joue, le contenu doit descendre encore plus */
.np-visible #contentLayer{
  padding-top:calc(var(--mini-h) + 88px + 75px + 16px) !important;
}

/* ═══════════════════════════════════════════════════════════
   UJENAMI EMOJI — Personnages SVG exclusifs + animations
   ═══════════════════════════════════════════════════════════ */

.uje-emoji svg{
  width:100%; height:100%;
  display:block;
  overflow:visible;
}

/* ── Picker Modal ── */
#emojiPickerModal{
  position:fixed;inset:0;z-index:900;
  display:flex;align-items:flex-end;justify-content:center;
}
.ep-backdrop{
  position:absolute;inset:0;
  background:rgba(10,10,10,0.55);
  backdrop-filter:blur(4px);
}

/* ── EMOJI PICKER — Style toggle Playful / Vibe ── */
.ep-style-toggle{
  display:flex;gap:0;
  border:1.5px solid var(--black);border-radius:12px;
  overflow:hidden;width:100%;margin-bottom:2px;
}
.ep-style-btn{
  flex:1;padding:10px 8px;
  background:none;border:none;cursor:pointer;
  font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gray-mid);font-weight:300;transition:all 0.2s;
  font-family:Georgia,serif;
}
.ep-style-btn.active{
  background:var(--black);color:var(--white);font-weight:500;
}
.ep-style-hint{
  font-size:9px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gray-mid);text-align:center;margin-bottom:6px;
  transition:opacity 0.2s;
}

.ep-panel{
  position:relative;z-index:1;
  background:var(--white);
  border-radius:24px 24px 0 0;
  padding:24px 20px 36px;
  width:100%;max-width:540px;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  animation:slideUp 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes slideUp{
  from{transform:translateY(100%);}
  to{transform:translateY(0);}
}
.ep-title{
  font-size:12px;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--gray-mid);font-weight:300;
}
.ep-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:10px;width:100%;
  max-height:55vh;
  overflow-y:auto;
  scrollbar-width:none;
}
.ep-grid::-webkit-scrollbar{display:none;}
.ep-cell{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  cursor:pointer;padding:8px 4px;border-radius:14px;
  border:2px solid transparent;
  transition:all 0.2s;
}
.ep-cell:active{ transform:scale(0.9); }
.ep-cell.selected{
  border-color:var(--black);
  background:var(--gray-light);
}
.ep-svg-wrap{
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
}
.ep-name{
  font-size:9px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--gray-mid);text-align:center;line-height:1.2;
}
.ep-close{
  width:100%;max-width:280px;font-size:11px;
}

/* ── Avatar dans le profil ── */
.profile-avatar .uje-emoji{
  width:100%;height:100%;
}

/* ═══════════════════════════════════════════════════════════
   ANIMATIONS (3 secondes, s'arrêtent automatiquement)
   ═══════════════════════════════════════════════════════════ */

/* Bounce — rebond joyeux */
.anim-bounce{
  animation: emojiBounce 0.4s ease infinite;
  animation-duration: 0.4s;
  animation-iteration-count: 7; /* ~3 secondes */
}
@keyframes emojiBounce{
  0%,100%{ transform:translateY(0) scale(1); }
  30%    { transform:translateY(-12px) scale(1.05); }
  60%    { transform:translateY(-6px) scale(1.02); }
}

/* Pop — apparition pétillante */
.anim-pop{
  animation: emojiPop 0.5s cubic-bezier(0.34,1.56,0.64,1) 6;
}
@keyframes emojiPop{
  0%  { transform:scale(1); }
  40% { transform:scale(1.25); }
  70% { transform:scale(0.95); }
  100%{ transform:scale(1); }
}

/* Wave — ondulation latérale */
.anim-wave{
  animation: emojiWave 0.6s ease-in-out 5;
}
@keyframes emojiWave{
  0%,100%{ transform:rotate(0deg) scale(1); }
  25%    { transform:rotate(-8deg) scale(1.05); }
  75%    { transform:rotate(8deg) scale(1.05); }
}

/* Spin — rotation complète */
.anim-spin{
  animation: emojiSpin 1s cubic-bezier(0.4,0,0.2,1) 3;
}
@keyframes emojiSpin{
  0%  { transform:rotate(0deg)   scale(1); }
  50% { transform:rotate(180deg) scale(1.1); }
  100%{ transform:rotate(360deg) scale(1); }
}

/* Sway — balancement doux */
.anim-sway{
  animation: emojiSway 0.8s ease-in-out alternate 4;
}
@keyframes emojiSway{
  0%  { transform:rotate(-10deg) translateX(-4px); }
  100%{ transform:rotate(10deg)  translateX(4px); }
}

/* Breathe — respiration/pulsation */
.anim-breathe{
  animation: emojiBreathe 1s ease-in-out 3;
}
@keyframes emojiBreathe{
  0%,100%{ transform:scale(1); }
  50%    { transform:scale(1.15); }
}

/* Pulse — battement de cœur */
.anim-pulse{
  animation: emojiPulse 0.35s ease infinite;
  animation-iteration-count: 8;
}
@keyframes emojiPulse{
  0%,100%{ transform:scale(1);    }
  50%    { transform:scale(1.18); }
}

/* Float — flottement lent */
.anim-float{
  animation: emojiFloat 1.2s ease-in-out 2.5;
}
@keyframes emojiFloat{
  0%,100%{ transform:translateY(0);    opacity:1; }
  25%    { transform:translateY(-8px); opacity:1; }
  50%    { transform:translateY(-14px) rotate(5deg); }
  75%    { transform:translateY(-8px); }
}

/* ════════════════════════════════════════════════════════════
   RADIO HUB — Navigation cards + World Top
   ════════════════════════════════════════════════════════════ */

.radio-nav-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  width:100%;max-width:440px;
  align-self:center;
}
.radio-nav-card{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;padding:14px 10px;
  border:1.5px solid var(--gray-light);border-radius:12px;
  cursor:pointer;transition:all 0.2s;
  text-align:center;
}
.radio-nav-card:active{ filter:brightness(0.85); transform:scale(0.97); }
.radio-nav-card.disabled{ opacity:0.45;cursor:not-allowed; }
.rnc-label{
  font-size:clamp(8px,1.3vw,11px);letter-spacing:0.15em;
  text-transform:uppercase;color:var(--black);font-weight:300;
  line-height:1.3;
}

/* ── World Top 10 ── */
.world-top-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  border:1.5px solid transparent;border-radius:10px;
  cursor:pointer;transition:filter 0.2s;
}
.world-top-item:active{ filter:brightness(0.88); }
.wti-rank{
  font-size:clamp(16px,2.5vw,22px);
  font-weight:600;min-width:36px;text-align:center;flex-shrink:0;
}
.wti-flag{ font-size:24px;flex-shrink:0; }
.wti-body{ flex:1;min-width:0;display:flex;flex-direction:column;gap:2px; }
.wti-name{
  font-size:clamp(11px,1.8vw,15px);font-weight:300;
  letter-spacing:0.08em;color:var(--black);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.wti-country{
  font-size:9px;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--gray-mid);
}
.wti-likes{
  font-size:clamp(11px,1.8vw,14px);font-weight:600;flex-shrink:0;
}

/* ════════════════════════════════════════════════════════════
   ROOMS HUB — Create hero, nav grid, live items, top users
   ════════════════════════════════════════════════════════════ */

/* ── Bouton Créer — héroïque ── */
.create-room-hero{
  display:flex;align-items:center;gap:16px;
  width:100%;max-width:500px;
  padding:16px 20px;
  background:var(--black);color:var(--white);
  border:none;border-radius:14px;
  cursor:pointer;
  transition:all 0.2s;
  box-shadow:0 4px 20px rgba(10,10,10,0.18);
}
.create-room-hero:active{transform:scale(0.97);opacity:0.85;}
.crh-icon{
  font-size:32px;font-weight:200;line-height:1;
  width:44px;height:44px;border-radius:50%;
  border:2px solid rgba(255,255,255,0.3);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.crh-text{display:flex;flex-direction:column;gap:3px;text-align:left;}
.crh-title{
  font-size:clamp(14px,2.2vw,18px);letter-spacing:0.1em;
  text-transform:uppercase;font-weight:300;
}
.crh-sub{
  font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  opacity:0.55;
}

/* ── Grille navigation rooms ── */
.rooms-nav-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  width:100%;max-width:500px;
}
.room-nav-card{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  padding:12px 8px;
  border:1.5px solid var(--gray-light);border-radius:12px;
  cursor:pointer;transition:all 0.2s;
  position:relative;
}
.room-nav-card:active{filter:brightness(0.85);transform:scale(0.96);}
.rnc-top{position:relative;display:flex;align-items:center;justify-content:center;}
.rnc-svg{ display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.15)); }
.rnc-svg-wrap{ display:flex;align-items:center;justify-content:center; }
.rnc-badge{
  position:absolute;top:-6px;right:-10px;
  min-width:18px;height:18px;padding:0 4px;
  border-radius:9px;
  font-size:9px;font-weight:600;color:white;
  display:flex;align-items:center;justify-content:center;
  letter-spacing:0;
}
.rnc-label-sm{
  font-size:clamp(7px,1.1vw,10px);letter-spacing:0.12em;
  text-transform:uppercase;color:var(--black);font-weight:300;
  text-align:center;line-height:1.3;
}

/* ── Live Room Item ── */
.live-room-item{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  border:1px solid var(--gray-light);border-radius:10px;
  background:var(--white);cursor:pointer;
  transition:filter 0.2s;
}
.live-room-item:active{filter:brightness(0.9);}
.lri-left{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  min-width:32px;
}
.live-dot-lg{
  width:9px;height:9px;background:#E53935;border-radius:50%;
  animation:blink 1s ease infinite;
}
.lri-rank{
  font-size:11px;letter-spacing:0.1em;
  color:var(--gray-mid);font-weight:600;
}
.lri-icon{font-size:26px;flex-shrink:0;}
.lri-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
.lri-name{
  font-size:clamp(12px,1.9vw,15px);font-weight:300;
  letter-spacing:0.08em;color:var(--black);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.lri-meta{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray-mid);}
.lri-right{
  display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;
}
.lri-fav{font-size:22px;opacity:0.3;cursor:pointer;transition:opacity 0.2s;color:var(--black);line-height:1;}
.lri-fav.on{opacity:1;}

/* ── Top User Item ── */
.top-user-item{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  border:1px solid var(--gray-light);border-radius:10px;
  background:var(--white);
}
.tui-rank{
  font-size:clamp(14px,2.2vw,20px);font-weight:600;
  min-width:36px;text-align:center;flex-shrink:0;
}
.tui-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--gray-light);border:2px solid var(--gray-light);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  flex-shrink:0;
}
.tui-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;}
.tui-name{
  font-size:clamp(12px,1.9vw,15px);font-weight:300;
  letter-spacing:0.08em;color:var(--black);
}
.tui-stats{
  display:flex;gap:8px;flex-wrap:wrap;
  font-size:9px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gray-mid);
}
.tui-follow{
  padding:7px 12px;border:1.5px solid var(--black);background:none;
  font-family:'Georgia',serif;font-size:9px;letter-spacing:0.12em;
  text-transform:uppercase;cursor:pointer;border-radius:16px;
  transition:all 0.2s;flex-shrink:0;
}
.tui-follow:active{background:var(--black);color:var(--white);}
.tui-follow.following{background:var(--black);color:var(--white);border-color:var(--black);}

/* ════════════════════════════════════════════════════════════
   PROFIL — QR Code, Stats, Settings
   ════════════════════════════════════════════════════════════ */

.profile-stats-row{
  display:flex;gap:32px;
}
.pstat{
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.pstat-n{
  font-size:clamp(18px,3vw,24px);font-weight:300;letter-spacing:0.05em;
}
.pstat-l{
  font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-mid);
}

.qr-preview-btn{
  display:flex;align-items:center;gap:10px;
  padding:10px 20px;
  border:1.5px solid var(--black);border-radius:10px;
  background:none;cursor:pointer;font-family:'Georgia',serif;
  transition:all 0.2s;
}
.qr-preview-btn:active{background:var(--black);color:var(--white);}
.qr-icon{font-size:20px;letter-spacing:0;}

/* ── QR MODAL ── */
#qrModal{
  position:fixed;inset:0;z-index:900;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
}
.qr-backdrop{
  position:absolute;inset:0;
  background:rgba(10,10,10,0.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.qr-panel{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  background:var(--white);
  border-radius:24px;
  padding:22px 22px 26px;
  width:min(300px,100%);
  box-shadow:0 24px 64px rgba(0,0,0,0.22);
  animation:popIn 0.35s cubic-bezier(0.34,1.56,0.64,1);
}

/* Card eau + QR */
.qr-card{
  position:relative;
  width:256px;height:290px;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(40,130,210,0.2), 0 1px 4px rgba(0,0,0,0.08);
}
.qr-card > canvas{
  position:absolute;inset:0;width:100%;height:100%;
}

/* QR centré dans la carte */
.qr-code-frame,
.qr-code-wrap-outer{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-52%);
  display:flex;align-items:center;justify-content:center;
  z-index:10;
}
#qrCodeWrap{
  background:rgba(255,255,255,0.97);
  border-radius:14px;
  padding:10px;
  box-shadow:0 3px 16px rgba(0,0,0,0.12);
  position:relative;z-index:2;
}
#qrCodeWrap img,
#qrCodeWrap canvas{ display:block;border-radius:6px; }

/* Logo eau CENTRÉ exactement sur le QR */
.qr-logo-overlay{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:3;
  pointer-events:none;
}
#qrLogoCanvas{ display:block; }

/* Nom + ID */
.qr-user-row{
  position:absolute;bottom:0;left:0;right:0;
  padding:8px 14px 14px;
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.qr-name-label{
  font-size:12px;letter-spacing:0.22em;text-transform:uppercase;
  font-weight:300;color:rgba(10,40,100,0.85);white-space:nowrap;
}
.qr-id-text{
  font-size:8px;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(40,130,210,0.6);
}
.qr-actions{ display:flex;gap:10px;width:100%; }

/* ════════════════════════════════════════════════════════════
   HOME HUB — Écran principal simple et clair
   ════════════════════════════════════════════════════════════ */

.home-hub{
  display:flex;flex-direction:column;
  align-items:center;
  gap:20px;
  padding:8px 0 20px;
  width:100%;
}

/* Greeting */
.home-greeting{
  display:flex;align-items:center;gap:14px;
  width:100%;max-width:480px;
  padding:0 4px;
}
.home-avatar{
  width:52px;height:52px;flex-shrink:0;cursor:pointer;
  border-radius:50%;
  border:2px solid var(--gray-light);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  transition:transform 0.2s;
}
.home-avatar:active{ transform:scale(0.9); }
.home-greeting-text{ display:flex;flex-direction:column;gap:3px; }
.home-hello{
  font-size:clamp(14px,2.2vw,18px);
  font-weight:300;letter-spacing:0.05em;
  color:var(--black);
}
.home-sub{
  font-size:10px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--gray-mid);
}

/* 3 Tuiles */
.home-tiles{
  display:grid;
  grid-template-columns:repeat(2, minmax(var(--tile-min,130px), 1fr));
  gap:clamp(10px,2vw,16px);
  width:100%;max-width:min(480px,100%);
}
/* 3-tile layout: Radio + Rooms on top, Relax full width */
.home-tiles-3{
  grid-template-columns:1fr 1fr;
}
.home-tiles-3 .tile-relax{
  grid-column:1 / -1;
  min-height:clamp(100px,18vw,150px);
  flex-direction:row;
  justify-content:flex-start;
  gap:20px;
  padding:16px 24px;
}
.home-tiles-3 .tile-relax .ht-icon{
  width:clamp(56px,10vw,80px);
  height:clamp(56px,10vw,80px);
  flex-shrink:0;
}
.home-tiles-3 .tile-relax .ht-label-group{
  display:flex;flex-direction:column;gap:4px;text-align:left;
}
.home-tile{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:8px;
  padding:18px 10px 14px;
  border-radius:18px;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:filter 0.18s, transform 0.15s;
  text-align:center;
  min-height:128px;
}
.home-tile:active{
  filter:brightness(0.88);
  transform:scale(0.94);
}
.tile-radio  { background:linear-gradient(145deg,rgba(0,188,212,0.16),rgba(0,150,180,0.06)); border-color:rgba(0,188,212,0.4); }
.tile-rooms  { background:linear-gradient(145deg,rgba(255,152,0,0.18),rgba(230,120,0,0.06)); border-color:rgba(255,152,0,0.45); }
.tile-relax  { background:linear-gradient(145deg,rgba(38,166,154,0.18),rgba(0,105,92,0.08)); border-color:rgba(38,166,154,0.4); }
.tile-profile{ background:linear-gradient(145deg,rgba(120,144,156,0.14),rgba(84,110,122,0.05)); border-color:rgba(120,144,156,0.3); }

.ht-icon{
  font-size:clamp(26px,4.5vw,36px);
  line-height:1;
  width:80px;height:76px;
  display:flex;align-items:center;justify-content:center;
}
.ht-label{
  font-size:clamp(12px,1.8vw,15px);
  letter-spacing:0.15em;
  text-transform:uppercase;
  font-weight:300;
  color:var(--black);
}
.ht-sub{
  font-size:9px;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--gray-mid);
}

/* Now playing bar */
.home-now-playing{
  display:flex;align-items:center;gap:10px;
  width:100%;max-width:480px;
  padding:10px 14px;
  border:1.5px solid var(--gray-light);
  border-radius:10px;
  cursor:pointer;
  background:var(--white);
  transition:background 0.2s;
  font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
}
.home-now-playing:active{ background:var(--gray-light); }

/* ════════════════════════════════════════════════════════════
   DISCOVER — 3 onglets: Pays · Nom · Genre
   ════════════════════════════════════════════════════════════ */

.discover-tabs{
  display:flex;gap:6px;
  width:100%;max-width:480px;
  padding:2px;
  background:var(--gray-light);
  border-radius:12px;
}
.dtab{
  flex:1;padding:8px 6px;
  border:none;background:transparent;
  font-family:'Georgia',serif;
  font-size:clamp(9px,1.4vw,12px);
  letter-spacing:0.1em;text-transform:uppercase;
  cursor:pointer;border-radius:10px;
  transition:all 0.2s;color:var(--gray-mid);
}
.dtab:active{opacity:0.7;}
.dtab.active{
  background:var(--white);
  color:var(--black);
  box-shadow:0 1px 6px rgba(10,10,10,0.1);
}

/* Champ recherche nom */
.radio-search-input{
  width:100%;max-width:480px;
  padding:11px 16px;
  border:1.5px solid var(--black);
  border-radius:10px;
  background:var(--white);
  font-family:'Georgia',serif;
  font-size:14px;
  letter-spacing:0.05em;
  outline:none;
  transition:border-color 0.2s;
}
.radio-search-input:focus{ border-color:#29B6F6; }

/* Genre grid */
.genre-grid{
  display:flex;flex-wrap:wrap;gap:8px;
  justify-content:center;
  width:100%;max-width:480px;
}
.genre-pill{
  padding:8px 14px;
  border:1.5px solid var(--gray-light);
  border-radius:20px;
  background:var(--white);
  font-family:'Georgia',serif;
  font-size:clamp(10px,1.5vw,12px);
  letter-spacing:0.08em;
  cursor:pointer;
  transition:all 0.2s;
  white-space:nowrap;
}
.genre-pill:active{ transform:scale(0.95); }
.genre-pill.sel{
  background:var(--black);
  color:var(--white);
  border-color:var(--black);
}

/* ── LIVE LISTENERS ── */
.rcs-listeners{
  font-size:9px;
  letter-spacing:0.12em;
  color:#e53935;
  animation:listenerPulse 2s ease-in-out infinite;
}
@keyframes listenerPulse{
  0%,100%{opacity:1;}
  50%{opacity:0.55;}
}
.live-dot{
  width:7px;height:7px;
  background:#e53935;border-radius:50%;
  display:inline-block;flex-shrink:0;
  animation:listenerPulse 1.4s ease-in-out infinite;
}

/* ════════════════════════════════════════════════════════════
   RELAX LOUNGE
   ════════════════════════════════════════════════════════════ */
.relax-room{
  display:flex;flex-direction:column;gap:12px;
  width:100%;max-width:560px;
}

/* Image principale */
.relax-img-wrap{
  position:relative;
  width:100%;aspect-ratio:16/9;
  max-height:50vh;
  border-radius:16px;overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,0.2);
}
.relax-img{
  width:100%;height:100%;
  object-fit:cover;
  transition:opacity 0.6s ease;
}
.relax-img-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:12px 14px;
  background:linear-gradient(transparent,rgba(0,0,0,0.72));
}
.relax-location{
  font-size:12px;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(255,255,255,0.9);font-weight:300;
}
.relax-credit{
  font-size:9px;letter-spacing:0.12em;
  color:rgba(255,255,255,0.5);margin-top:2px;
}

/* Navigation prev/next */
.relax-nav-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,0.25);
  backdrop-filter:blur(8px);
  border:none;color:white;font-size:22px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s,transform 0.15s;
  line-height:1;
}
.relax-nav-btn:active{background:rgba(255,255,255,0.5);transform:translateY(-50%) scale(0.9);}
.relax-prev{left:10px;}
.relax-next{right:10px;}

/* Badge catégorie */
.relax-cat-badge{
  position:absolute;top:10px;right:10px;
  padding:4px 10px;border-radius:20px;
  background:rgba(0,0,0,0.45);backdrop-filter:blur(6px);
  font-size:10px;letter-spacing:0.12em;color:white;
}

/* Description IA */
.relax-desc-card{
  background:var(--white);
  border:1.5px solid var(--gray-light);
  border-radius:14px;padding:14px 16px;
  display:flex;flex-direction:column;gap:8px;
}
.relax-desc-header{
  display:flex;align-items:center;gap:8px;
}
.relax-desc-icon{color:#26A69A;font-size:14px;}
.relax-desc-title{
  font-size:10px;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--gray-mid);flex:1;
}
.relax-desc-lang{
  font-size:9px;letter-spacing:0.15em;
  background:#26A69A;color:white;
  padding:2px 8px;border-radius:10px;
}
.relax-desc-text{
  font-size:clamp(15px,2.4vw,18px);
  line-height:1.85;
  color:var(--gray-dark);
  font-style:italic;
  letter-spacing:0.01em;
}
.relax-desc-loading{
  display:flex;align-items:center;gap:8px;
  font-size:11px;letter-spacing:0.1em;color:var(--gray-mid);
}
.relax-spinner{
  width:14px;height:14px;
  border:2px solid var(--gray-light);
  border-top-color:#26A69A;
  border-radius:50%;
  animation:spin 0.8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* Footer */
.relax-footer{
  display:flex;align-items:center;justify-content:space-between;
  font-size:9px;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--gray-mid);padding:0 2px;
}
.relax-listeners{display:flex;align-items:center;gap:6px;}
.relax-timer{color:#26A69A;}

/* ════════════════════════════════════════════════════════════
   EMOJI PICKER — Photo de profil
   ════════════════════════════════════════════════════════════ */

/* Bouton photo */
.ep-photo-btn{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:12px 16px;
  border:1.5px dashed var(--gray-mid);border-radius:12px;
  background:var(--gray-light);
  font-family:'Georgia',serif;font-size:13px;
  letter-spacing:0.08em;cursor:pointer;
  color:var(--black);
  transition:all 0.2s;
}
.ep-photo-btn:active{background:var(--gray-mid);border-style:solid;}

/* Aperçu photo existante */
.ep-photo-preview{
  display:flex;align-items:center;gap:12px;
  padding:8px 12px;
  background:rgba(41,182,246,0.08);
  border:1px solid rgba(41,182,246,0.3);
  border-radius:10px;
  position:relative;
}
.ep-photo-img{
  width:48px;height:48px;
  border-radius:50%;object-fit:cover;
  border:2px solid rgba(41,182,246,0.5);
}
.ep-photo-label{
  font-size:10px;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--gray-mid);
}
.ep-photo-remove{
  position:absolute;top:6px;right:8px;
  width:20px;height:20px;border-radius:50%;
  background:rgba(220,50,50,0.15);border:1px solid rgba(220,50,50,0.3);
  color:#E53935;font-size:11px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
}
.ep-photo-remove:active{background:#E53935;color:white;}

/* Séparateur */
.ep-divider{
  font-size:9px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gray-mid);text-align:center;
  border-top:1px solid var(--gray-light);
  padding-top:10px;margin-top:2px;
}

/* Avatar photo dans le profil / home */
.avatar-photo{
  width:100%;height:100%;
  object-fit:cover;border-radius:50%;
  display:block;
}

/* ════════════════════════════════════════════════════════════
   COUNTRY INLINE SEARCH
   ════════════════════════════════════════════════════════════ */
.country-search-bar{
  width:100%;max-width:480px;
  position:relative;
}
.country-inline-search{
  width:100%;padding:11px 16px;
  border:1.5px solid var(--gray-light);
  border-radius:12px;
  background:var(--white);
  font-family:'Georgia',serif;font-size:14px;
  letter-spacing:0.04em;outline:none;
  transition:border-color 0.2s,box-shadow 0.2s;
  box-sizing:border-box;
}
.country-inline-search:focus{
  border-color:#29B6F6;
  box-shadow:0 0 0 3px rgba(41,182,246,0.12);
}

/* Dropdown résultats */
.country-inline-results{
  width:100%;max-width:480px;
  max-height:260px;overflow-y:auto;
  background:var(--white);
  border:1.5px solid rgba(41,182,246,0.3);
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,0.1);
  margin-top:4px;
}
.cis-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;cursor:pointer;
  border-bottom:1px solid var(--gray-light);
  transition:background 0.15s;
}
.cis-item:last-child{ border-bottom:none; }
.cis-item:active,.cis-item:hover{ background:rgba(41,182,246,0.06); }
.cis-item.pinned{ background:rgba(41,182,246,0.05); }
.cis-flag{ font-size:20px;flex-shrink:0; }
.cis-name{
  flex:1;font-size:13px;letter-spacing:0.04em;color:var(--black);
}
.cis-count{
  font-size:9px;letter-spacing:0.12em;color:#29B6F6;
  background:rgba(41,182,246,0.1);padding:2px 8px;border-radius:10px;
}
.cis-pinned-badge{
  font-size:10px;color:#27ae60;font-weight:bold;
}

/* Station row liste verticale */
.country-station-row{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;
  background:var(--white);
  border-radius:10px;
  border:1.5px solid var(--gray-light);
  border-left:3px solid #0a0a0a;
  cursor:pointer;
  transition:all 0.18s;
}
.country-station-row:active{ background:var(--gray-light);transform:scale(0.98); }
.csr-flag{ font-size:22px;flex-shrink:0; }
.csr-info{ flex:1;min-width:0;display:flex;flex-direction:column;gap:2px; }
.csr-name{
  font-size:12px;letter-spacing:0.08em;color:var(--black);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.csr-freq{ font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-mid); }
.csr-likes{ font-size:10px;color:#cc2222;flex-shrink:0; }

/* ── RESUME BUTTON ── */
@keyframes slideUp{
  from{transform:translateX(-50%) translateY(20px);opacity:0;}
  to{transform:translateX(-50%) translateY(0);opacity:1;}
}
#resumeBtn{ transition:opacity 0.5s ease; }

/* ── H-SCROLL AVEC FLÈCHES ── */
.h-scroll-wrap{
  position:relative;width:100%;
}
.hsa-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.92);
  border:1.5px solid rgba(0,0,0,0.1);
  box-shadow:0 2px 8px rgba(0,0,0,0.12);
  cursor:pointer;z-index:5;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--gray-dark);
  transition:opacity 0.2s,transform 0.15s;
  backdrop-filter:blur(4px);
}
.hsa-btn:active{transform:translateY(-50%) scale(0.88);}
.hsa-btn.hsa-left{ left:-8px; }
.hsa-btn.hsa-right{ right:-8px; }
.hsa-btn.hsa-hidden{ opacity:0;pointer-events:none; }

/* ── BACKGROUND RADIO CREATOR UI ── */
.rbr-toggle input{opacity:0;width:0;height:0;}
.rbr-slider::before{
  content:'';position:absolute;
  width:16px;height:16px;bottom:3px;left:3px;
  background:white;border-radius:50%;transition:0.3s;
}
.rbr-toggle input:checked + .rbr-slider{background:#26A69A;}
.rbr-toggle input:checked + .rbr-slider::before{transform:translateX(16px);}

/* Background radio picker modal */
#bgRadioModal .bgr-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.4);}
.bgr-search:focus{border-color:#26A69A;}
.bgr-station:active,.bgr-station:hover{background:rgba(38,166,154,0.08);}
/* ── RELAX DESCRIPTION — floating draggable card ── */
.relax-desc-card-float{
  position:absolute;
  /* Centered, ~1/3 width */
  left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:clamp(240px,33vw,380px);
  max-height:70vh;
  background:rgba(255,255,255,0.22);
  border-radius:16px;
  z-index:20;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,0.18);
  cursor:grab;
  user-select:none;
  touch-action:none;
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}
.relax-desc-card-float:active{ cursor:grabbing; }

/* Header: drag + title + buttons */
.rdc-header{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;
  background:rgba(255,255,255,0.25);
  border-bottom:1px solid rgba(255,255,255,0.2);
  cursor:grab;
}
.rdc-drag{
  font-size:14px;color:rgba(0,0,0,0.4);cursor:grab;flex-shrink:0;
}
.rdc-title{
  flex:1;font-size:9px;letter-spacing:0.25em;text-transform:uppercase;
  color:#0a0a0a;font-weight:500;
}
.rdc-color,.rdc-collapse{
  background:rgba(0,0,0,0.1);border:none;border-radius:8px;
  width:26px;height:22px;font-size:11px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:#0a0a0a;transition:background 0.15s;flex-shrink:0;
}
.rdc-color:hover,.rdc-collapse:hover{ background:rgba(0,0,0,0.2); }

/* Text body */
.rdc-body{
  padding:12px 14px;
  font-size:clamp(12px,1.5vw,14px);
  line-height:1.7;
  font-style:italic;
  color:#0a0a0a;  /* default dark */
  overflow-y:auto;
  max-height:45vh;
  transition:color 0.2s;
}
.rdc-body.text-white{ color:#ffffff; }

/* Collapsed state */
.relax-desc-card-float.collapsed .rdc-body{ display:none; }
.relax-desc-card-float.collapsed{ cursor:grab; }

/* Bottom info row */
.relax-info-row{
  position:absolute;bottom:0;left:0;right:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:7px 16px;
  background:rgba(255,255,255,0.20);
  z-index:20;
}
.relax-location{
  font-size:clamp(9px,1.3vw,12px);
  letter-spacing:0.18em;text-transform:uppercase;
  color:#0a0a0a;font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:55%;
}
.relax-footer{display:flex;align-items:center;gap:10px;}
.relax-listeners{display:flex;align-items:center;gap:5px;
  font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:#1a1a1a;}
.relax-timer{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:#1a1a1a;opacity:0.8;}

/* ── RELAX RADIO STRIP ── */
.relax-radio-strip{
  position:absolute;
  bottom:36px; /* just above the info row */
  left:0;right:0;
  z-index:20;
  padding:0 8px 6px;
}
.relax-radio-list{
  display:flex;
  flex-direction:row;
  gap:8px;
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  padding:4px 2px;
}
.relax-radio-list::-webkit-scrollbar{display:none;}

.relax-radio-pill{
  display:flex;align-items:center;gap:6px;
  padding:6px 12px;
  border:1.5px solid rgba(255,255,255,0.3);
  border-radius:20px;
  background:rgba(255,255,255,0.18);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  cursor:pointer;
  white-space:nowrap;
  flex-shrink:0;
  transition:all 0.2s;
  font-family:inherit;
}
.relax-radio-pill:active{transform:scale(0.95);}
.relax-radio-pill.playing{
  box-shadow:0 0 12px rgba(255,255,255,0.3);
}
.rrp-flag{ font-size:14px; }
.rrp-name{
  font-size:10px;letter-spacing:0.1em;
  color:white;font-weight:500;
  max-width:120px;overflow:hidden;text-overflow:ellipsis;
}
.rrp-eq{
  font-size:10px;color:white;opacity:0.9;
}
.relax-radio-loading{
  font-size:10px;letter-spacing:0.15em;color:rgba(255,255,255,0.55);
  padding:8px 4px;text-transform:uppercase;
}

/* ── RELAX ROOM — FULLSCREEN ── */
.relax-fullscreen{
  position:fixed;
  inset:0;
  z-index:15;
  overflow:hidden;
}

/* Emoji background — centered, large, soft */
.relax-bg-emoji{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:clamp(80px,20vw,140px);
  opacity:0.35;
  pointer-events:none;
  z-index:1;
}

/* Real photo — inset with border radius */
.relax-photo{
  position:absolute;
  inset:clamp(6px,1.5vw,14px);
  width:calc(100% - 2*clamp(6px,1.5vw,14px));
  height:calc(100% - 2*clamp(6px,1.5vw,14px));
  object-fit:cover;
  z-index:2;
  border-radius:clamp(8px,1.5vw,18px);
  transition:opacity 0.6s ease;
  box-shadow:0 4px 32px rgba(0,0,0,0.3);
}

/* Top bar: counter + category */
.relax-top-bar{
  position:absolute;top:calc(var(--mini-h) + 12px);left:0;right:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 14px;
  z-index:10;
  pointer-events:none;
}
.relax-counter{
  font-size:10px;letter-spacing:0.15em;color:rgba(255,255,255,0.75);
  background:rgba(0,0,0,0.2);
  padding:4px 10px;border-radius:12px;
}

/* Nav arrows */
.relax-nav-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,0.18);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.3);
  color:white;font-size:24px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  z-index:10;transition:background 0.2s,transform 0.15s;
  line-height:1;
}
.relax-nav-btn:active{background:rgba(255,255,255,0.4);transform:translateY(-50%) scale(0.9);}
/* Arrows on right side — avoids nav bar on left */
.relax-prev{right:64px;}
.relax-next{right:12px;}

/* Category badge */
.relax-cat-badge{
  font-size:10px;letter-spacing:0.12em;color:white;
  background:rgba(0,0,0,0.25);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:5px 12px;border-radius:20px;
  pointer-events:none;
}

/* Bottom overlay — just enough for text, no tall gradient */
.relax-bottom-overlay{
  position:absolute;
  bottom:80px;left:0;right:0;
  /* Clear radio strip + info row */
  background:transparent;
  padding:0;
  z-index:9;
  display:flex;flex-direction:column;gap:0;
  pointer-events:none;
}

/* Location + footer row — compact single line at very bottom */
.relax-info-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 16px;
  background:rgba(255,255,255,0.20);
  backdrop-filter:blur(0px);
  pointer-events:auto;
}

/* Location title — dark text, compact */
.relax-location{
  font-size:clamp(10px,1.5vw,13px);
  letter-spacing:0.18em;text-transform:uppercase;
  color:#0a0a0a;font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:60%;
}

/* Description pill — compact, auto-height, slightly white bg */
.relax-desc-pill{
  margin:0 12px 4px;
  background:rgba(255,255,255,0.20);
  border-radius:12px 12px 0 0;
  padding:10px 14px 8px;
  pointer-events:auto;
}

/* Description text — dark, readable */
.relax-desc-text{
  font-size:clamp(12px,1.6vw,14px);
  line-height:1.65;
  color:#0d0d0d;
  font-style:italic;
  letter-spacing:0.01em;
  /* Max 3 lines then ellipsis */
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Footer — listeners + timer */
.relax-footer{
  display:flex;align-items:center;justify-content:space-between;
  font-size:9px;letter-spacing:0.15em;text-transform:uppercase;
  color:#1a1a1a;
  padding:0 4px;
}
.relax-listeners{display:flex;align-items:center;gap:5px;}
.relax-timer{opacity:0.8;}
.relax-credit{display:none;}

/* Spinner (white on dark) */
.relax-desc-loading{
  display:flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:0.1em;color:rgba(255,255,255,0.6);
}
.relax-spinner{
  width:14px;height:14px;flex-shrink:0;
  border:2px solid rgba(255,255,255,0.25);
  border-top-color:white;
  border-radius:50%;
  animation:spin 0.8s linear infinite;
}

/* ═══════════════════════════════════════════════════════════
   AJOUTS v5
   ═══════════════════════════════════════════════════════════ */

/* ── SCROLL hint ── */
.scroll-hint{
  background:linear-gradient(to left, rgba(245,245,240,0.95) 60%, transparent);
  width:40px;right:0;top:0;bottom:0;height:100%;
  transform:none;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;
}

/* ── SOURCE BADGES ── */



.np-badge-ai { background:#4a148c;color:#fff; }



/* ═══════════════════════════════════════════════════════════
   v10 — Cards paysage, pays épinglés, Now Playing compact
   ═══════════════════════════════════════════════════════════ */

/* ── CARD RADIO PAYSAGE (radio-card-sm) ── */
.radio-card-sm{
  flex-shrink:0;
  width:clamp(190px,32vw,270px);
  height:80px;
  display:flex;flex-direction:row;align-items:center;
  gap:10px;padding:10px 12px;
  border:1.5px solid transparent;  /* couleur via JS */
  border-radius:10px;
  cursor:pointer;
  /* background défini par JS (couleur tintée) */
  transition:filter 0.2s, transform 0.15s;
  position:relative;
  scroll-snap-align:start;
  box-shadow:0 2px 12px rgba(0,0,0,0.08);
}
.radio-card-sm:active{
  filter:brightness(0.88);
  transform:scale(0.97);
}
.radio-card-sm.playing{ color:white; }

.rcs-left{ flex-shrink:0; }
.rcs-flag{ font-size:28px;line-height:1;
  font-family:'Segoe UI Emoji','Apple Color Emoji','Noto Color Emoji',sans-serif; }
.rcs-body{ flex:1;min-width:0;display:flex;flex-direction:column;gap:3px; }
.rcs-name{
  font-size:clamp(9px,1.4vw,12px);letter-spacing:0.1em;
  text-transform:uppercase;font-weight:300;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.rcs-freq{ font-size:9px;letter-spacing:0.12em;text-transform:uppercase; }
.rcs-right{
  display:flex;flex-direction:column;align-items:flex-end;
  gap:5px;flex-shrink:0;
}
.rcs-fav{
  font-size:20px;opacity:0.3;cursor:pointer;
  transition:opacity 0.2s;line-height:1;
}
.rcs-fav:active{transform:scale(1.3);}
.rcs-fav.on{opacity:1;}
.rcs-like{
  display:flex;align-items:center;gap:4px;
  font-size:14px;cursor:pointer;color:#cc2222;
}
.rcs-like.liked{ font-weight:600; }
.rcs-count{ font-size:10px; }

/* ── PAYS ÉPINGLÉS ── */
.pinned-pills-row{
  display:flex;flex-wrap:wrap;gap:8px;width:100%;
}
.country-pin-pill{
  display:flex;align-items:center;gap:5px;
  padding:7px 10px 7px 12px;
  border:1.5px solid var(--black);border-radius:20px;
  background:none;cursor:pointer;font-family:'Georgia',serif;
  transition:all 0.2s;font-size:12px;
}
.country-pin-pill.sel{background:var(--black);color:var(--white);}
.country-pin-pill:active{opacity:0.7;}
.cp-flag{ font-size:18px; }
.cp-name{ font-size:10px;letter-spacing:0.1em;text-transform:uppercase;font-weight:300; }
.cp-unpin{
  font-size:10px;opacity:0.4;margin-left:2px;
  padding:2px 4px;border-radius:50%;
  transition:opacity 0.2s;
}
.cp-unpin:hover{opacity:1;}

.country-add-btn:active{border-color:var(--black);color:var(--black);}

/* ── NOW PLAYING COMPACT — juste sous la freq bar ── */









.np-lyrics-sm::-webkit-scrollbar{display:none;}

/* Ajuster le padding du contenu pour tenir compte de la NP panel */
/* Quand la radio joue, le contenu doit descendre encore plus */
.np-visible #contentLayer{
  padding-top:calc(var(--mini-h) + 88px + 75px + 16px) !important;
}

/* ═══════════════════════════════════════════════════════════
   UJENAMI EMOJI — Personnages SVG exclusifs + animations
   ═══════════════════════════════════════════════════════════ */

.uje-emoji svg{
  width:100%; height:100%;
  display:block;
  overflow:visible;
}

/* ── Picker Modal ── */
#emojiPickerModal{
  position:fixed;inset:0;z-index:900;
  display:flex;align-items:flex-end;justify-content:center;
}
.ep-backdrop{
  position:absolute;inset:0;
  background:rgba(10,10,10,0.55);
  backdrop-filter:blur(4px);
}
.ep-panel{
  position:relative;z-index:1;
  background:var(--white);
  border-radius:24px 24px 0 0;
  padding:24px 20px 36px;
  width:100%;max-width:540px;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  animation:slideUp 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes slideUp{
  from{transform:translateY(100%);}
  to{transform:translateY(0);}
}
.ep-title{
  font-size:12px;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--gray-mid);font-weight:300;
}
.ep-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:10px;width:100%;
  max-height:55vh;
  overflow-y:auto;
  scrollbar-width:none;
}
.ep-grid::-webkit-scrollbar{display:none;}
.ep-cell{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  cursor:pointer;padding:8px 4px;border-radius:14px;
  border:2px solid transparent;
  transition:all 0.2s;
}
.ep-cell:active{ transform:scale(0.9); }
.ep-cell.selected{
  border-color:var(--black);
  background:var(--gray-light);
}
.ep-svg-wrap{
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
}
.ep-name{
  font-size:9px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--gray-mid);text-align:center;line-height:1.2;
}
.ep-close{
  width:100%;max-width:280px;font-size:11px;
}

/* ── Avatar dans le profil ── */
.profile-avatar .uje-emoji{
  width:100%;height:100%;
}

/* ═══════════════════════════════════════════════════════════
   ANIMATIONS (3 secondes, s'arrêtent automatiquement)
   ═══════════════════════════════════════════════════════════ */

/* Bounce — rebond joyeux */
.anim-bounce{
  animation: emojiBounce 0.4s ease infinite;
  animation-duration: 0.4s;
  animation-iteration-count: 7; /* ~3 secondes */
}
@keyframes emojiBounce{
  0%,100%{ transform:translateY(0) scale(1); }
  30%    { transform:translateY(-12px) scale(1.05); }
  60%    { transform:translateY(-6px) scale(1.02); }
}

/* Pop — apparition pétillante */
.anim-pop{
  animation: emojiPop 0.5s cubic-bezier(0.34,1.56,0.64,1) 6;
}
@keyframes emojiPop{
  0%  { transform:scale(1); }
  40% { transform:scale(1.25); }
  70% { transform:scale(0.95); }
  100%{ transform:scale(1); }
}

/* Wave — ondulation latérale */
.anim-wave{
  animation: emojiWave 0.6s ease-in-out 5;
}
@keyframes emojiWave{
  0%,100%{ transform:rotate(0deg) scale(1); }
  25%    { transform:rotate(-8deg) scale(1.05); }
  75%    { transform:rotate(8deg) scale(1.05); }
}

/* Spin — rotation complète */
.anim-spin{
  animation: emojiSpin 1s cubic-bezier(0.4,0,0.2,1) 3;
}
@keyframes emojiSpin{
  0%  { transform:rotate(0deg)   scale(1); }
  50% { transform:rotate(180deg) scale(1.1); }
  100%{ transform:rotate(360deg) scale(1); }
}

/* Sway — balancement doux */
.anim-sway{
  animation: emojiSway 0.8s ease-in-out alternate 4;
}
@keyframes emojiSway{
  0%  { transform:rotate(-10deg) translateX(-4px); }
  100%{ transform:rotate(10deg)  translateX(4px); }
}

/* Breathe — respiration/pulsation */
.anim-breathe{
  animation: emojiBreathe 1s ease-in-out 3;
}
@keyframes emojiBreathe{
  0%,100%{ transform:scale(1); }
  50%    { transform:scale(1.15); }
}

/* Pulse — battement de cœur */
.anim-pulse{
  animation: emojiPulse 0.35s ease infinite;
  animation-iteration-count: 8;
}
@keyframes emojiPulse{
  0%,100%{ transform:scale(1);    }
  50%    { transform:scale(1.18); }
}

/* Float — flottement lent */
.anim-float{
  animation: emojiFloat 1.2s ease-in-out 2.5;
}
@keyframes emojiFloat{
  0%,100%{ transform:translateY(0);    opacity:1; }
  25%    { transform:translateY(-8px); opacity:1; }
  50%    { transform:translateY(-14px) rotate(5deg); }
  75%    { transform:translateY(-8px); }
}

/* ════════════════════════════════════════════════════════════
   RADIO HUB — Navigation cards + World Top
   ════════════════════════════════════════════════════════════ */

.radio-nav-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  width:100%;max-width:440px;
  align-self:center;
}
.radio-nav-card{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;padding:14px 10px;
  border:1.5px solid var(--gray-light);border-radius:12px;
  cursor:pointer;transition:all 0.2s;
  text-align:center;
}
.radio-nav-card:active{ filter:brightness(0.85); transform:scale(0.97); }
.radio-nav-card.disabled{ opacity:0.45;cursor:not-allowed; }
.rnc-label{
  font-size:clamp(8px,1.3vw,11px);letter-spacing:0.15em;
  text-transform:uppercase;color:var(--black);font-weight:300;
  line-height:1.3;
}

/* ── World Top 10 ── */
.world-top-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;
  border:1.5px solid transparent;border-radius:10px;
  cursor:pointer;transition:filter 0.2s;
}
.world-top-item:active{ filter:brightness(0.88); }
.wti-rank{
  font-size:clamp(16px,2.5vw,22px);
  font-weight:600;min-width:36px;text-align:center;flex-shrink:0;
}
.wti-flag{ font-size:24px;flex-shrink:0; }
.wti-body{ flex:1;min-width:0;display:flex;flex-direction:column;gap:2px; }
.wti-name{
  font-size:clamp(11px,1.8vw,15px);font-weight:300;
  letter-spacing:0.08em;color:var(--black);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.wti-country{
  font-size:9px;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--gray-mid);
}
.wti-likes{
  font-size:clamp(11px,1.8vw,14px);font-weight:600;flex-shrink:0;
}

/* ════════════════════════════════════════════════════════════
   ROOMS HUB — Create hero, nav grid, live items, top users
   ════════════════════════════════════════════════════════════ */

/* ── Bouton Créer — héroïque ── */
.create-room-hero{
  display:flex;align-items:center;gap:16px;
  width:100%;max-width:500px;
  padding:16px 20px;
  background:var(--black);color:var(--white);
  border:none;border-radius:14px;
  cursor:pointer;
  transition:all 0.2s;
  box-shadow:0 4px 20px rgba(10,10,10,0.18);
}
.create-room-hero:active{transform:scale(0.97);opacity:0.85;}
.crh-icon{
  font-size:32px;font-weight:200;line-height:1;
  width:44px;height:44px;border-radius:50%;
  border:2px solid rgba(255,255,255,0.3);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.crh-text{display:flex;flex-direction:column;gap:3px;text-align:left;}
.crh-title{
  font-size:clamp(14px,2.2vw,18px);letter-spacing:0.1em;
  text-transform:uppercase;font-weight:300;
}
.crh-sub{
  font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  opacity:0.55;
}

/* ── Grille navigation rooms ── */
.rooms-nav-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  width:100%;max-width:500px;
}
.room-nav-card{
  display:flex;flex-direction:column;align-items:center;gap:5px;
  padding:12px 8px;
  border:1.5px solid var(--gray-light);border-radius:12px;
  cursor:pointer;transition:all 0.2s;
  position:relative;
}
.room-nav-card:active{filter:brightness(0.85);transform:scale(0.96);}
.rnc-top{position:relative;display:flex;align-items:center;justify-content:center;}
.rnc-svg{ display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.15)); }
.rnc-svg-wrap{ display:flex;align-items:center;justify-content:center; }
.rnc-badge{
  position:absolute;top:-6px;right:-10px;
  min-width:18px;height:18px;padding:0 4px;
  border-radius:9px;
  font-size:9px;font-weight:600;color:white;
  display:flex;align-items:center;justify-content:center;
  letter-spacing:0;
}
.rnc-label-sm{
  font-size:clamp(7px,1.1vw,10px);letter-spacing:0.12em;
  text-transform:uppercase;color:var(--black);font-weight:300;
  text-align:center;line-height:1.3;
}

/* ── Live Room Item ── */
.live-room-item{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  border:1px solid var(--gray-light);border-radius:10px;
  background:var(--white);cursor:pointer;
  transition:filter 0.2s;
}
.live-room-item:active{filter:brightness(0.9);}
.lri-left{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  min-width:32px;
}
.live-dot-lg{
  width:9px;height:9px;background:#E53935;border-radius:50%;
  animation:blink 1s ease infinite;
}
.lri-rank{
  font-size:11px;letter-spacing:0.1em;
  color:var(--gray-mid);font-weight:600;
}
.lri-icon{font-size:26px;flex-shrink:0;}
.lri-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
.lri-name{
  font-size:clamp(12px,1.9vw,15px);font-weight:300;
  letter-spacing:0.08em;color:var(--black);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.lri-meta{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--gray-mid);}
.lri-right{
  display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;
}
.lri-fav{font-size:22px;opacity:0.3;cursor:pointer;transition:opacity 0.2s;color:var(--black);line-height:1;}
.lri-fav.on{opacity:1;}

/* ── Top User Item ── */
.top-user-item{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  border:1px solid var(--gray-light);border-radius:10px;
  background:var(--white);
}
.tui-rank{
  font-size:clamp(14px,2.2vw,20px);font-weight:600;
  min-width:36px;text-align:center;flex-shrink:0;
}
.tui-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--gray-light);border:2px solid var(--gray-light);
  display:flex;align-items:center;justify-content:center;font-size:18px;
  flex-shrink:0;
}
.tui-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;}
.tui-name{
  font-size:clamp(12px,1.9vw,15px);font-weight:300;
  letter-spacing:0.08em;color:var(--black);
}
.tui-stats{
  display:flex;gap:8px;flex-wrap:wrap;
  font-size:9px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gray-mid);
}
.tui-follow{
  padding:7px 12px;border:1.5px solid var(--black);background:none;
  font-family:'Georgia',serif;font-size:9px;letter-spacing:0.12em;
  text-transform:uppercase;cursor:pointer;border-radius:16px;
  transition:all 0.2s;flex-shrink:0;
}
.tui-follow:active{background:var(--black);color:var(--white);}
.tui-follow.following{background:var(--black);color:var(--white);border-color:var(--black);}

/* ════════════════════════════════════════════════════════════
   PROFIL — QR Code, Stats, Settings
   ════════════════════════════════════════════════════════════ */

.profile-stats-row{
  display:flex;gap:32px;
}
.pstat{
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.pstat-n{
  font-size:clamp(18px,3vw,24px);font-weight:300;letter-spacing:0.05em;
}
.pstat-l{
  font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-mid);
}

.qr-preview-btn{
  display:flex;align-items:center;gap:10px;
  padding:10px 20px;
  border:1.5px solid var(--black);border-radius:10px;
  background:none;cursor:pointer;font-family:'Georgia',serif;
  transition:all 0.2s;
}
.qr-preview-btn:active{background:var(--black);color:var(--white);}
.qr-icon{font-size:20px;letter-spacing:0;}

/* ── QR MODAL ── */
#qrModal{
  position:fixed;inset:0;z-index:900;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
}
.qr-backdrop{
  position:absolute;inset:0;
  background:rgba(10,10,10,0.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.qr-panel{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  background:var(--white);
  border-radius:24px;
  padding:22px 22px 26px;
  width:min(300px,100%);
  box-shadow:0 24px 64px rgba(0,0,0,0.22);
  animation:popIn 0.35s cubic-bezier(0.34,1.56,0.64,1);
}

/* Card eau + QR */
.qr-card{
  position:relative;
  width:256px;height:290px;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 4px 24px rgba(40,130,210,0.2), 0 1px 4px rgba(0,0,0,0.08);
}
.qr-card > canvas{
  position:absolute;inset:0;width:100%;height:100%;
}

/* QR centré dans la carte */
.qr-code-frame,
.qr-code-wrap-outer{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-52%);
  display:flex;align-items:center;justify-content:center;
  z-index:10;
}
#qrCodeWrap{
  background:rgba(255,255,255,0.97);
  border-radius:14px;
  padding:10px;
  box-shadow:0 3px 16px rgba(0,0,0,0.12);
  position:relative;z-index:2;
}
#qrCodeWrap img,
#qrCodeWrap canvas{ display:block;border-radius:6px; }

/* Logo eau CENTRÉ exactement sur le QR */
.qr-logo-overlay{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:3;
  pointer-events:none;
}
#qrLogoCanvas{ display:block; }

/* Nom + ID */
.qr-user-row{
  position:absolute;bottom:0;left:0;right:0;
  padding:8px 14px 14px;
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.qr-name-label{
  font-size:12px;letter-spacing:0.22em;text-transform:uppercase;
  font-weight:300;color:rgba(10,40,100,0.85);white-space:nowrap;
}
.qr-id-text{
  font-size:8px;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(40,130,210,0.6);
}
.qr-actions{ display:flex;gap:10px;width:100%; }

/* ════════════════════════════════════════════════════════════
   HOME HUB — Écran principal simple et clair
   ════════════════════════════════════════════════════════════ */

.home-hub{
  display:flex;flex-direction:column;
  align-items:center;
  gap:20px;
  padding:8px 0 20px;
  width:100%;
}

/* Greeting */
.home-greeting{
  display:flex;align-items:center;gap:14px;
  width:100%;max-width:480px;
  padding:0 4px;
}
.home-avatar{
  width:52px;height:52px;flex-shrink:0;cursor:pointer;
  border-radius:50%;
  border:2px solid var(--gray-light);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  transition:transform 0.2s;
}
.home-avatar:active{ transform:scale(0.9); }
.home-greeting-text{ display:flex;flex-direction:column;gap:3px; }
.home-hello{
  font-size:clamp(14px,2.2vw,18px);
  font-weight:300;letter-spacing:0.05em;
  color:var(--black);
}
.home-sub{
  font-size:10px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--gray-mid);
}

/* 3 Tuiles */
.home-tiles{
  display:grid;
  grid-template-columns:repeat(2, minmax(var(--tile-min,130px), 1fr));
  gap:clamp(10px,2vw,16px);
  width:100%;max-width:min(480px,100%);
}
/* 3-tile layout: Radio + Rooms on top, Relax full width */
.home-tiles-3{
  grid-template-columns:1fr 1fr;
}
.home-tiles-3 .tile-relax{
  grid-column:1 / -1;
  min-height:clamp(100px,18vw,150px);
  flex-direction:row;
  justify-content:flex-start;
  gap:20px;
  padding:16px 24px;
}
.home-tiles-3 .tile-relax .ht-icon{
  width:clamp(56px,10vw,80px);
  height:clamp(56px,10vw,80px);
  flex-shrink:0;
}
.home-tiles-3 .tile-relax .ht-label-group{
  display:flex;flex-direction:column;gap:4px;text-align:left;
}
.home-tile{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:8px;
  padding:18px 10px 14px;
  border-radius:18px;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:filter 0.18s, transform 0.15s;
  text-align:center;
  min-height:128px;
}
.home-tile:active{
  filter:brightness(0.88);
  transform:scale(0.94);
}
.tile-radio  { background:linear-gradient(145deg,rgba(0,188,212,0.16),rgba(0,150,180,0.06)); border-color:rgba(0,188,212,0.4); }
.tile-rooms  { background:linear-gradient(145deg,rgba(255,152,0,0.18),rgba(230,120,0,0.06)); border-color:rgba(255,152,0,0.45); }
.tile-relax  { background:linear-gradient(145deg,rgba(38,166,154,0.18),rgba(0,105,92,0.08)); border-color:rgba(38,166,154,0.4); }
.tile-profile{ background:linear-gradient(145deg,rgba(120,144,156,0.14),rgba(84,110,122,0.05)); border-color:rgba(120,144,156,0.3); }

.ht-icon{
  font-size:clamp(26px,4.5vw,36px);
  line-height:1;
  width:80px;height:76px;
  display:flex;align-items:center;justify-content:center;
}
.ht-label{
  font-size:clamp(12px,1.8vw,15px);
  letter-spacing:0.15em;
  text-transform:uppercase;
  font-weight:300;
  color:var(--black);
}
.ht-sub{
  font-size:9px;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--gray-mid);
}

/* Now playing bar */
.home-now-playing{
  display:flex;align-items:center;gap:10px;
  width:100%;max-width:480px;
  padding:10px 14px;
  border:1.5px solid var(--gray-light);
  border-radius:10px;
  cursor:pointer;
  background:var(--white);
  transition:background 0.2s;
  font-size:11px;letter-spacing:0.12em;text-transform:uppercase;
}
.home-now-playing:active{ background:var(--gray-light); }

/* ════════════════════════════════════════════════════════════
   DISCOVER — 3 onglets: Pays · Nom · Genre
   ════════════════════════════════════════════════════════════ */

.discover-tabs{
  display:flex;gap:6px;
  width:100%;max-width:480px;
  padding:2px;
  background:var(--gray-light);
  border-radius:12px;
}
.dtab{
  flex:1;padding:8px 6px;
  border:none;background:transparent;
  font-family:'Georgia',serif;
  font-size:clamp(9px,1.4vw,12px);
  letter-spacing:0.1em;text-transform:uppercase;
  cursor:pointer;border-radius:10px;
  transition:all 0.2s;color:var(--gray-mid);
}
.dtab:active{opacity:0.7;}
.dtab.active{
  background:var(--white);
  color:var(--black);
  box-shadow:0 1px 6px rgba(10,10,10,0.1);
}

/* Champ recherche nom */
.radio-search-input{
  width:100%;max-width:480px;
  padding:11px 16px;
  border:1.5px solid var(--black);
  border-radius:10px;
  background:var(--white);
  font-family:'Georgia',serif;
  font-size:14px;
  letter-spacing:0.05em;
  outline:none;
  transition:border-color 0.2s;
}
.radio-search-input:focus{ border-color:#29B6F6; }

/* Genre grid */
.genre-grid{
  display:flex;flex-wrap:wrap;gap:8px;
  justify-content:center;
  width:100%;max-width:480px;
}
.genre-pill{
  padding:8px 14px;
  border:1.5px solid var(--gray-light);
  border-radius:20px;
  background:var(--white);
  font-family:'Georgia',serif;
  font-size:clamp(10px,1.5vw,12px);
  letter-spacing:0.08em;
  cursor:pointer;
  transition:all 0.2s;
  white-space:nowrap;
}
.genre-pill:active{ transform:scale(0.95); }
.genre-pill.sel{
  background:var(--black);
  color:var(--white);
  border-color:var(--black);
}

/* ── LIVE LISTENERS ── */
.rcs-listeners{
  font-size:9px;
  letter-spacing:0.12em;
  color:#e53935;
  animation:listenerPulse 2s ease-in-out infinite;
}
@keyframes listenerPulse{
  0%,100%{opacity:1;}
  50%{opacity:0.55;}
}
.live-dot{
  width:7px;height:7px;
  background:#e53935;border-radius:50%;
  display:inline-block;flex-shrink:0;
  animation:listenerPulse 1.4s ease-in-out infinite;
}

/* ════════════════════════════════════════════════════════════
   RELAX LOUNGE
   ════════════════════════════════════════════════════════════ */
.relax-room{
  display:flex;flex-direction:column;gap:12px;
  width:100%;max-width:560px;
}

/* Image principale */
.relax-img-wrap{
  position:relative;
  width:100%;aspect-ratio:16/9;
  max-height:50vh;
  border-radius:16px;overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,0.2);
}
.relax-img{
  width:100%;height:100%;
  object-fit:cover;
  transition:opacity 0.6s ease;
}
.relax-img-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:12px 14px;
  background:linear-gradient(transparent,rgba(0,0,0,0.72));
}
.relax-location{
  font-size:12px;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(255,255,255,0.9);font-weight:300;
}
.relax-credit{
  font-size:9px;letter-spacing:0.12em;
  color:rgba(255,255,255,0.5);margin-top:2px;
}

/* Navigation prev/next */
.relax-nav-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,0.25);
  backdrop-filter:blur(8px);
  border:none;color:white;font-size:22px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s,transform 0.15s;
  line-height:1;
}
.relax-nav-btn:active{background:rgba(255,255,255,0.5);transform:translateY(-50%) scale(0.9);}
.relax-prev{left:10px;}
.relax-next{right:10px;}

/* Badge catégorie */
.relax-cat-badge{
  position:absolute;top:10px;right:10px;
  padding:4px 10px;border-radius:20px;
  background:rgba(0,0,0,0.45);backdrop-filter:blur(6px);
  font-size:10px;letter-spacing:0.12em;color:white;
}

/* Description IA */
.relax-desc-card{
  background:var(--white);
  border:1.5px solid var(--gray-light);
  border-radius:14px;padding:14px 16px;
  display:flex;flex-direction:column;gap:8px;
}
.relax-desc-header{
  display:flex;align-items:center;gap:8px;
}
.relax-desc-icon{color:#26A69A;font-size:14px;}
.relax-desc-title{
  font-size:10px;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--gray-mid);flex:1;
}
.relax-desc-lang{
  font-size:9px;letter-spacing:0.15em;
  background:#26A69A;color:white;
  padding:2px 8px;border-radius:10px;
}
.relax-desc-text{
  font-size:clamp(15px,2.4vw,18px);
  line-height:1.85;
  color:var(--gray-dark);
  font-style:italic;
  letter-spacing:0.01em;
}
.relax-desc-loading{
  display:flex;align-items:center;gap:8px;
  font-size:11px;letter-spacing:0.1em;color:var(--gray-mid);
}
.relax-spinner{
  width:14px;height:14px;
  border:2px solid var(--gray-light);
  border-top-color:#26A69A;
  border-radius:50%;
  animation:spin 0.8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* Footer */
.relax-footer{
  display:flex;align-items:center;justify-content:space-between;
  font-size:9px;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--gray-mid);padding:0 2px;
}
.relax-listeners{display:flex;align-items:center;gap:6px;}
.relax-timer{color:#26A69A;}

/* ════════════════════════════════════════════════════════════
   EMOJI PICKER — Photo de profil
   ════════════════════════════════════════════════════════════ */

/* Bouton photo */
.ep-photo-btn{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:12px 16px;
  border:1.5px dashed var(--gray-mid);border-radius:12px;
  background:var(--gray-light);
  font-family:'Georgia',serif;font-size:13px;
  letter-spacing:0.08em;cursor:pointer;
  color:var(--black);
  transition:all 0.2s;
}
.ep-photo-btn:active{background:var(--gray-mid);border-style:solid;}

/* Aperçu photo existante */
.ep-photo-preview{
  display:flex;align-items:center;gap:12px;
  padding:8px 12px;
  background:rgba(41,182,246,0.08);
  border:1px solid rgba(41,182,246,0.3);
  border-radius:10px;
  position:relative;
}
.ep-photo-img{
  width:48px;height:48px;
  border-radius:50%;object-fit:cover;
  border:2px solid rgba(41,182,246,0.5);
}
.ep-photo-label{
  font-size:10px;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--gray-mid);
}
.ep-photo-remove{
  position:absolute;top:6px;right:8px;
  width:20px;height:20px;border-radius:50%;
  background:rgba(220,50,50,0.15);border:1px solid rgba(220,50,50,0.3);
  color:#E53935;font-size:11px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
}
.ep-photo-remove:active{background:#E53935;color:white;}

/* Séparateur */
.ep-divider{
  font-size:9px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gray-mid);text-align:center;
  border-top:1px solid var(--gray-light);
  padding-top:10px;margin-top:2px;
}

/* Avatar photo dans le profil / home */
.avatar-photo{
  width:100%;height:100%;
  object-fit:cover;border-radius:50%;
  display:block;
}

/* ════════════════════════════════════════════════════════════
   COUNTRY INLINE SEARCH
   ════════════════════════════════════════════════════════════ */
.country-search-bar{
  width:100%;max-width:480px;
  position:relative;
}
.country-inline-search{
  width:100%;padding:11px 16px;
  border:1.5px solid var(--gray-light);
  border-radius:12px;
  background:var(--white);
  font-family:'Georgia',serif;font-size:14px;
  letter-spacing:0.04em;outline:none;
  transition:border-color 0.2s,box-shadow 0.2s;
  box-sizing:border-box;
}
.country-inline-search:focus{
  border-color:#29B6F6;
  box-shadow:0 0 0 3px rgba(41,182,246,0.12);
}

/* Dropdown résultats */
.country-inline-results{
  width:100%;max-width:480px;
  max-height:260px;overflow-y:auto;
  background:var(--white);
  border:1.5px solid rgba(41,182,246,0.3);
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,0.1);
  margin-top:4px;
}
.cis-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;cursor:pointer;
  border-bottom:1px solid var(--gray-light);
  transition:background 0.15s;
}
.cis-item:last-child{ border-bottom:none; }
.cis-item:active,.cis-item:hover{ background:rgba(41,182,246,0.06); }
.cis-item.pinned{ background:rgba(41,182,246,0.05); }
.cis-flag{ font-size:20px;flex-shrink:0; }
.cis-name{
  flex:1;font-size:13px;letter-spacing:0.04em;color:var(--black);
}
.cis-count{
  font-size:9px;letter-spacing:0.12em;color:#29B6F6;
  background:rgba(41,182,246,0.1);padding:2px 8px;border-radius:10px;
}
.cis-pinned-badge{
  font-size:10px;color:#27ae60;font-weight:bold;
}

/* Station row liste verticale */
.country-station-row{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;
  background:var(--white);
  border-radius:10px;
  border:1.5px solid var(--gray-light);
  border-left:3px solid #0a0a0a;
  cursor:pointer;
  transition:all 0.18s;
}
.country-station-row:active{ background:var(--gray-light);transform:scale(0.98); }
.csr-flag{ font-size:22px;flex-shrink:0; }
.csr-info{ flex:1;min-width:0;display:flex;flex-direction:column;gap:2px; }
.csr-name{
  font-size:12px;letter-spacing:0.08em;color:var(--black);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.csr-freq{ font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray-mid); }
.csr-likes{ font-size:10px;color:#cc2222;flex-shrink:0; }

/* ── RESUME BUTTON ── */
@keyframes slideUp{
  from{transform:translateX(-50%) translateY(20px);opacity:0;}
  to{transform:translateX(-50%) translateY(0);opacity:1;}
}
#resumeBtn{ transition:opacity 0.5s ease; }

/* ── H-SCROLL AVEC FLÈCHES ── */
.h-scroll-wrap{
  position:relative;width:100%;
}
.hsa-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,0.92);
  border:1.5px solid rgba(0,0,0,0.1);
  box-shadow:0 2px 8px rgba(0,0,0,0.12);
  cursor:pointer;z-index:5;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--gray-dark);
  transition:opacity 0.2s,transform 0.15s;
  backdrop-filter:blur(4px);
}
.hsa-btn:active{transform:translateY(-50%) scale(0.88);}
.hsa-btn.hsa-left{ left:-8px; }
.hsa-btn.hsa-right{ right:-8px; }
.hsa-btn.hsa-hidden{ opacity:0;pointer-events:none; }

/* ── BACKGROUND RADIO CREATOR UI ── */
.rbr-toggle input{opacity:0;width:0;height:0;}
.rbr-slider::before{
  content:'';position:absolute;
  width:16px;height:16px;bottom:3px;left:3px;
  background:white;border-radius:50%;transition:0.3s;
}
.rbr-toggle input:checked + .rbr-slider{background:#26A69A;}
.rbr-toggle input:checked + .rbr-slider::before{transform:translateX(16px);}

/* Background radio picker modal */
#bgRadioModal .bgr-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.4);}
.bgr-search:focus{border-color:#26A69A;}
.bgr-station:active,.bgr-station:hover{background:rgba(38,166,154,0.08);}
