
/* ── Speaking pulse animation for room avatars ── */
@keyframes speak-pulse{
  0%  { box-shadow: 0 0 0 2px rgba(76,175,80,0.5); transform: scale(1); }
  100%{ box-shadow: 0 0 0 7px rgba(76,175,80,0);   transform: scale(1.04); }
}
/* ============================================================
   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(600px,100%);
  padding:4px clamp(8px,3vw,20px) clamp(16px,4vh,32px);
  margin:0 auto;
  position:relative;z-index:2;
  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
   ════════════════════════════════════════════════════════════ */



/* 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:active{ cursor:grabbing; }

/* Header: drag + title + buttons */



.rdc-color,
.rdc-color:hover,.rdc-collapse:hover{ background:rgba(0,0,0,0.2); }

/* Text body */

.rdc-body.text-white{ color:#ffffff; }

/* Collapsed state */
.relax-desc-card-float.collapsed 
.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;
  left:0;right:0;
  z-index:25;
  padding:0 8px 6px;
  pointer-events:auto;
}
.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 !important;
  inset:0 !important;
  z-index:15;
  overflow:hidden;
  min-height:100vh;
  width:100%;
}

/* 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
   ════════════════════════════════════════════════════════════ */



/* 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);}

/* ── Room wave bars — variable heights when someone speaks ── */
@keyframes room-wave-pulse{
  0%,100%{ height:15%; }
  50%    { height:95%; }
}
.l-wave .l-bar{
  animation: room-wave-pulse 0.6s ease-in-out infinite;
  background:#4CAF50;
}
.l-wave .l-bar:nth-child(1){ animation-delay: 0s;    animation-duration:0.5s; }
.l-wave .l-bar:nth-child(2){ animation-delay: 0.1s;  animation-duration:0.7s; }
.l-wave .l-bar:nth-child(3){ animation-delay: 0.15s; animation-duration:0.45s; }
.l-wave .l-bar:nth-child(4){ animation-delay: 0.05s; animation-duration:0.8s; }
.l-wave .l-bar:nth-child(5){ animation-delay: 0.2s;  animation-duration:0.55s; }
.l-wave .l-bar:nth-child(6){ animation-delay: 0.1s;  animation-duration:0.65s; }
.l-wave .l-bar:nth-child(7){ animation-delay: 0.0s;  animation-duration:0.5s; }

/* ════════════════════════════════════════════════════════════
   RELAX HOME — Premium Zen Lounge (v30)
═════════════════════════════════════════════════════════════ */



.relax-home-bg{
  position:absolute;inset:0;z-index:0;
  transition:opacity 1s;
}
.relax-home-overlay{
  position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse at center,
    rgba(139,94,47,0.15) 0%,
    rgba(44,28,14,0.55) 100%);
  pointer-events:none;
}

/* ── TOP BAR ── */
.relax-top-bar{
  position:relative;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 28px 12px;
}
.relax-brand{
  display:flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:0.35em;
  color:rgba(245,234,214,0.75);
  text-transform:uppercase;
}
.relax-brand-drop{
  display:inline-block;width:14px;height:14px;
  background:radial-gradient(circle at 40% 30%, #FFFBEF, #D9B986);
  border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  box-shadow:0 0 10px rgba(230,200,138,0.4);
}
.relax-top-title{
  display:flex;align-items:center;gap:10px;
  font-size:12px;letter-spacing:0.5em;
  color:#F5EAD6;
  text-transform:uppercase;
}
.relax-region-pill{
  background:rgba(20,14,8,0.4);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(245,234,214,0.15);
  padding:7px 16px;border-radius:100px;
  font-size:11px;letter-spacing:0.15em;color:#F5EAD6;
}

/* ── MAIN LAYOUT ── */
.relax-home-main{
  position:relative;z-index:5;
  flex:1;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:24px;
  padding:10px 28px 20px;
}

/* ── LEFT ACTION CARDS ── */
.relax-side-actions{
  display:flex;flex-direction:column;gap:16px;
  max-width:340px;justify-self:start;align-self:center;
}
.relax-action-card{
  display:flex;align-items:center;gap:16px;
  background:rgba(245,234,214,0.14);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(245,234,214,0.22);
  border-radius:20px;
  padding:18px 22px;
  cursor:pointer;
  transition:transform 0.3s, box-shadow 0.3s, background 0.3s;
  box-shadow:0 8px 32px rgba(0,0,0,0.15);
  color:#F5EAD6;
  text-align:left;
  font-family:inherit;
}
.relax-action-card:hover{
  transform:translateY(-4px);
  background:rgba(245,234,214,0.20);
  box-shadow:0 16px 48px rgba(139,94,47,0.25);
}
.relax-action-radio{
  background:linear-gradient(135deg, rgba(217,241,238,0.20), rgba(127,192,185,0.10));
}
.relax-action-rooms{
  background:linear-gradient(135deg, rgba(245,234,214,0.20), rgba(212,184,150,0.15));
}
.rac-orb{
  flex-shrink:0;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,0.2));
}
.rac-texts{flex:1;}
.rac-title{
  font-size:22px;letter-spacing:0.25em;font-weight:500;
  color:#FBF6ED;margin-bottom:4px;
}
.rac-sub{
  font-size:10px;letter-spacing:0.3em;
  color:rgba(245,234,214,0.65);
  text-transform:uppercase;
}

/* ── CENTER ORB ── */
.relax-center-wrap{
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.relax-center-orb{
  position:relative;
  width:360px;height:360px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
}
.relax-center-orb:hover .relax-orb-core{
  transform:scale(1.02);
}

.rh-ring{
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(245,234,214,0.25);
  pointer-events:none;
}
.rh-ring-1{width:340px;height:340px;
  animation:orb-pulse 6s ease-in-out infinite;}
.rh-ring-2{width:300px;height:300px;
  border-color:rgba(230,200,138,0.35);
  animation:orb-pulse 6s ease-in-out infinite 1.5s;}
.rh-ring-3{width:260px;height:260px;
  border-color:rgba(245,234,214,0.4);
  animation:orb-pulse 6s ease-in-out infinite 3s;}

@keyframes orb-pulse{
  0%,100%{transform:scale(1);opacity:0.5;}
  50%{transform:scale(1.05);opacity:0.8;}
}

/* ── RADIAL WAVEFORM ── */
.relax-orb-waveform{
  position:absolute;
  width:100%;height:100%;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  animation:waveform-rotate 60s linear infinite;
}
.rh-wave-bar{
  position:absolute;
  width:2px;
  top:50%;left:50%;
  transform-origin:center top;
  background:linear-gradient(to bottom,
    rgba(230,200,138,0.9),
    rgba(230,200,138,0.1));
  border-radius:2px;
  animation:waveform-bar 2.5s ease-in-out infinite;
}
@keyframes waveform-rotate{
  from{transform:translate(-50%,-50%) rotate(0deg);}
  to{transform:translate(-50%,-50%) rotate(360deg);}
}
@keyframes waveform-bar{
  0%,100%{opacity:0.4;height:10px;}
  50%{opacity:0.85;height:22px;}
}

/* ── ORB CORE ── */
.relax-orb-core{
  position:relative;z-index:2;
  width:220px;height:220px;
  border-radius:50%;
  background:radial-gradient(circle at 40% 35%,
    rgba(255,251,239,0.95),
    rgba(230,200,138,0.9) 40%,
    rgba(184,136,64,0.75) 90%);
  box-shadow:
    0 0 60px rgba(230,200,138,0.4),
    0 0 100px rgba(184,136,64,0.2),
    inset 0 2px 12px rgba(255,255,255,0.4);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  transition:transform 0.4s;
  color:#5D3F16;
}
.relax-orb-icon{margin-bottom:-14px;}
.relax-orb-title{
  font-size:20px;letter-spacing:0.45em;
  font-weight:400;margin-top:4px;
  color:#5D3F16;
}
.relax-orb-sub{
  font-size:9px;letter-spacing:0.35em;
  color:rgba(93,63,22,0.7);
  text-transform:uppercase;
  margin-top:2px;
}
.relax-orb-dots{
  display:flex;align-items:center;gap:6px;
  margin-top:8px;
  color:rgba(93,63,22,0.6);
  font-size:11px;
}
.rod-dot{
  width:5px;height:5px;border-radius:50%;
  background:rgba(93,63,22,0.6);
}
.rod-prev,.rod-next{cursor:pointer;padding:0 4px;}
.rod-prev:hover,.rod-next:hover{color:#5D3F16;}

/* ── RIGHT FLOATING NAV ── */
.relax-floating-nav{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  justify-self:end;
  background:rgba(245,234,214,0.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.5);
  border-radius:40px;
  padding:12px 8px;
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
  width:70px;
}
.rfn-avatar{
  width:50px;height:50px;border-radius:50%;
  border:none;background:#E0EFFF;
  padding:0;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  margin-bottom:4px;
}
.rfn-avatar-inner{
  width:42px;height:42px;border-radius:50%;overflow:hidden;
}
.rfn-btn{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:10px 4px;border:none;background:none;
  cursor:pointer;border-radius:12px;
  transition:background 0.2s;
  width:54px;
  font-family:inherit;
}
.rfn-btn:hover{background:rgba(139,94,47,0.08);}
.rfn-active{
  background:rgba(217,241,238,0.6);
}
.rfn-icon{
  font-size:18px;color:#3D2E18;
}
.rfn-lbl{
  font-size:8px;letter-spacing:0.2em;
  color:#5D3F16;text-transform:uppercase;
  font-weight:500;
}

/* ── BOTTOM BAR ── */
.relax-bottom-bar{
  position:relative;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 28px 20px;
  gap:20px;
}

/* Mini player */
.relax-mini-player{
  display:flex;align-items:center;gap:12px;
  background:rgba(20,14,8,0.45);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(245,234,214,0.2);
  border-radius:100px;
  padding:8px 18px 8px 12px;
  min-width:280px;max-width:340px;
  color:#F5EAD6;
  cursor:pointer;
  transition:background 0.2s;
}
.relax-mini-player:hover{background:rgba(20,14,8,0.6);}
.rmp-icon{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,#E6C88A,#B88840);
  display:flex;align-items:center;justify-content:center;
  color:#5D3F16;font-size:14px;flex-shrink:0;
}
.rmp-info{flex:1;min-width:0;}
.rmp-name{
  font-size:12px;font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.rmp-country{
  font-size:9px;letter-spacing:0.15em;
  color:rgba(245,234,214,0.6);text-transform:uppercase;
}
.rmp-eq{display:flex;align-items:flex-end;gap:2px;height:18px;}
.rmp-eq span{
  width:2.5px;background:#E6C88A;border-radius:1px;
  animation:mp-eq 1.1s ease-in-out infinite;
}
.rmp-eq span:nth-child(1){height:50%;animation-delay:0s;}
.rmp-eq span:nth-child(2){height:100%;animation-delay:0.15s;}
.rmp-eq span:nth-child(3){height:70%;animation-delay:0.3s;}
.rmp-eq span:nth-child(4){height:40%;animation-delay:0.45s;}
@keyframes mp-eq{
  0%,100%{transform:scaleY(0.4);}
  50%{transform:scaleY(1);}
}
.rmp-play{
  width:28px;height:28px;border-radius:50%;
  background:rgba(245,234,214,0.2);
  border:1px solid rgba(245,234,214,0.3);
  color:#F5EAD6;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;padding:0;
}

/* Quote */
.relax-bottom-quote{
  flex:1;text-align:center;
  font-size:11px;letter-spacing:0.4em;
  color:rgba(245,234,214,0.7);
  text-transform:uppercase;font-family:'Georgia',serif;
}

/* Weather/Time */
.relax-weather{
  display:flex;flex-direction:column;align-items:flex-end;
  font-family:'Georgia',serif;color:#F5EAD6;
}
.rw-time{
  font-size:18px;font-weight:500;letter-spacing:0.1em;
}
.rw-location{
  font-size:10px;letter-spacing:0.25em;
  color:rgba(245,234,214,0.65);text-transform:uppercase;
}

/* ────────── RESPONSIVE (Mobile) ────────── */
@media (max-width: 900px){
  .relax-home-main{
    grid-template-columns:1fr;
    grid-template-rows:auto auto auto;
    padding:10px 14px;gap:16px;
  }
  .relax-side-actions{
    flex-direction:row;gap:10px;
    max-width:100%;width:100%;
    justify-self:stretch;order:2;
  }
  .relax-action-card{
    flex:1;padding:14px;gap:10px;
  }
  .rac-orb svg{width:44px;height:44px;}
  .rac-title{font-size:15px;letter-spacing:0.2em;}
  .rac-sub{font-size:8px;}
  .relax-center-wrap{order:1;}
  .relax-center-orb{width:280px;height:280px;}
  .relax-orb-core{width:180px;height:180px;}
  .relax-orb-icon{width:60px;height:84px;}
  .relax-orb-title{font-size:16px;}
  .rh-ring-1{width:260px;height:260px;}
  .rh-ring-2{width:230px;height:230px;}
  .rh-ring-3{width:200px;height:200px;}
  .rh-wave-bar{height:8px;}

  .relax-floating-nav{
    order:3;flex-direction:row;
    width:auto;border-radius:100px;
    padding:8px 12px;gap:6px;
    justify-self:center;
  }
  .rfn-avatar{width:40px;height:40px;margin:0;}
  .rfn-avatar-inner{width:34px;height:34px;}
  .rfn-btn{width:auto;padding:8px;}

  .relax-top-bar{padding:14px 14px 8px;}
  .relax-top-title{display:none;}
  .relax-brand-text{font-size:10px;letter-spacing:0.25em;}

  .relax-bottom-bar{
    flex-direction:column;gap:10px;padding:8px 14px 16px;
  }
  .relax-bottom-quote{font-size:9px;letter-spacing:0.3em;}
  .relax-mini-player{min-width:auto;width:100%;}
  .relax-weather{align-items:center;}
}

/* Hide external navbar when Home relax-shell is active (it has its own floating nav) */
body.home-immersive #contentLayer{
  padding:0 !important;margin:0 !important;
  max-width:100% !important;
}
body.home-immersive #homeScreen{
  padding:0 !important;
  background:#0E0903;
}

/* ════════════════════════════════════════════════════════════
   RELAX HOME — Radio Frequency Orb (v31)
═════════════════════════════════════════════════════════════ */

/* Gradient overlay bottom for readability */
.relax-gradient-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,0.05) 0%,
    rgba(0,0,0,0) 30%,
    rgba(0,0,0,0) 55%,
    rgba(20,12,0,0.55) 85%,
    rgba(20,12,0,0.75) 100%
  );
  pointer-events:none;
}

/* ── Central Radio Orb ── */
.rlx-radio-orb{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-58%);
  width:220px;height:220px;
  display:flex;align-items:center;justify-content:center;
  z-index:5;
  /* Hidden when no radio */
  opacity:0.35;
  transition:opacity 0.6s ease;
  pointer-events:none;
}
.rlx-radio-orb--active{
  opacity:1;
  pointer-events:auto;
  cursor:pointer;
}

/* Outer animated rings */
.rlx-orb-ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(230,200,138,0.4);
  pointer-events:none;
}
.rlx-orb-ring-1{
  width:200px;height:200px;
  animation:rlx-ring-pulse 4s ease-in-out infinite;
}
.rlx-orb-ring-2{
  width:240px;height:240px;
  border-color:rgba(230,200,138,0.2);
  animation:rlx-ring-pulse 4s ease-in-out infinite 1.3s;
}
@keyframes rlx-ring-pulse{
  0%,100%{transform:scale(1);opacity:0.4;}
  50%{transform:scale(1.06);opacity:0.7;}
}

/* Radial waveform bars rotating around orb */
.rlx-orb-waveform{
  position:absolute;width:100%;height:100%;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  animation:rlx-wf-rotate 45s linear infinite;
}
.rlx-wb{
  position:absolute;
  width:2px;
  top:50%;left:50%;
  transform-origin:center top;
  background:linear-gradient(to bottom,
    rgba(245,234,214,0.95),
    rgba(230,200,138,0.1));
  border-radius:2px;
  animation:rlx-wb-anim 2.2s ease-in-out infinite;
}
@keyframes rlx-wf-rotate{
  from{transform:translate(-50%,-50%) rotate(0deg);}
  to{  transform:translate(-50%,-50%) rotate(360deg);}
}
@keyframes rlx-wb-anim{
  0%,100%{opacity:0.3;transform:rotate(var(--r,0deg)) translateY(-82px) scaleY(0.5);}
  50%{opacity:0.9;transform:rotate(var(--r,0deg)) translateY(-82px) scaleY(1);}
}

/* Orb core — golden disc */
.rlx-orb-core{
  position:relative;z-index:3;
  width:150px;height:150px;
  border-radius:50%;
  background:radial-gradient(circle at 40% 35%,
    rgba(255,251,236,0.98),
    rgba(230,195,120,0.95) 45%,
    rgba(184,136,64,0.88) 100%);
  box-shadow:
    0 0 40px rgba(230,200,138,0.5),
    0 0 80px rgba(184,136,64,0.25),
    inset 0 2px 10px rgba(255,255,255,0.5);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:4px;
  transition:transform 0.3s;
}
.rlx-radio-orb--active .rlx-orb-core:hover{
  transform:scale(1.04);
}

/* Waveform bars inside orb (when radio plays) */
.rlx-orb-wave{
  display:flex;align-items:center;gap:3px;
  height:32px;
}
.rlx-bar{
  width:3px;
  background:rgba(93,63,22,0.8);
  border-radius:3px;
  animation:rlx-bar-eq 1.1s ease-in-out infinite;
}
.rlx-bar:nth-child(1){height:40%;animation-delay:0s;}
.rlx-bar:nth-child(2){height:80%;animation-delay:0.08s;}
.rlx-bar:nth-child(3){height:100%;animation-delay:0.16s;}
.rlx-bar:nth-child(4){height:65%;animation-delay:0.24s;}
.rlx-bar:nth-child(5){height:90%;animation-delay:0.32s;}
.rlx-bar:nth-child(6){height:45%;animation-delay:0.40s;}
.rlx-bar:nth-child(7){height:100%;animation-delay:0.48s;}
.rlx-bar:nth-child(8){height:60%;animation-delay:0.56s;}
.rlx-bar:nth-child(9){height:85%;animation-delay:0.64s;}
.rlx-bar:nth-child(10){height:40%;animation-delay:0.72s;}
.rlx-bar:nth-child(11){height:70%;animation-delay:0.80s;}
.rlx-bar:nth-child(12){height:50%;animation-delay:0.88s;}
@keyframes rlx-bar-eq{
  0%,100%{transform:scaleY(0.35);}
  50%{transform:scaleY(1);}
}

.rlx-orb-name{
  font-size:11px;font-weight:600;
  color:#5D3F16;letter-spacing:0.1em;
  text-align:center;max-width:120px;
  overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;padding:0 6px;
}
.rlx-orb-country{
  font-size:9px;letter-spacing:0.2em;
  color:rgba(93,63,22,0.65);
  text-transform:uppercase;
}
.rlx-orb-idle{
  display:flex;align-items:center;justify-content:center;
  opacity:0.8;
}

/* ═══════════════════════════════════════════════════════════
   RELAX HOME v32 — Full immersive overlay layout
═══════════════════════════════════════════════════════════ */

/* ── Shell ── */

.rlx-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(
    135deg,
    rgba(20,10,0,0.12) 0%,
    rgba(0,0,0,0) 40%,
    rgba(0,0,0,0) 60%,
    rgba(20,10,0,0.35) 100%
  );
}

/* ── Top bar ── */
.rlx-topbar{
  position:relative;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 24px 8px;
}
.rlx-brand{
  display:flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:0.35em;color:rgba(245,234,214,0.8);
}
.rlx-brand-drop{
  display:inline-block;width:12px;height:12px;
  background:radial-gradient(circle at 40% 30%,#FFFBEF,#D9B986);
  border-radius:50% 50% 50% 0;transform:rotate(-45deg);
  box-shadow:0 0 8px rgba(230,200,138,0.5);
}
.rlx-brand-label{font-size:11px;letter-spacing:0.35em;}
.rlx-img-info{display:flex;align-items:center;gap:12px;}
.rlx-cat-badge{
  background:rgba(20,10,0,0.35);backdrop-filter:blur(8px);
  border:1px solid rgba(245,234,214,0.2);
  padding:5px 14px;border-radius:100px;
  font-size:10px;letter-spacing:0.15em;
}
.rlx-counter{font-size:10px;letter-spacing:0.15em;color:rgba(245,234,214,0.65);}

/* ── Main layout (3 cols) ── */
.rlx-main-layout{
  position:relative;z-index:5;
  flex:1;
  display:grid;
  grid-template-columns:280px 1fr 90px;
  align-items:center;
  gap:0;
  padding:8px 16px 8px 20px;
}

/* ── LEFT CARDS ── */
.rlx-left-cards{
  display:flex;flex-direction:column;gap:14px;
  padding-right:8px;
}
.rlx-card{
  display:flex;align-items:center;gap:16px;
  background:rgba(245,234,214,0.14);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(245,234,214,0.28);
  border-radius:20px;padding:16px 20px;
  cursor:pointer;transition:transform 0.3s,box-shadow 0.3s,background 0.3s;
  box-shadow:0 6px 28px rgba(0,0,0,0.15);
  color:#F5EAD6;text-align:left;font-family:inherit;
  min-width:200px;
}
.rlx-card:hover{
  transform:translateY(-4px);
  background:rgba(245,234,214,0.22);
  box-shadow:0 14px 40px rgba(0,0,0,0.25);
}
.rlx-card-radio{
  background:linear-gradient(135deg,rgba(210,240,237,0.22),rgba(100,180,170,0.12));
}
.rlx-card-rooms{
  background:linear-gradient(135deg,rgba(245,234,214,0.22),rgba(200,170,120,0.12));
}
.rlx-card-orb{
  flex-shrink:0;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,0.15));
}
.rlx-card-title{
  font-size:20px;letter-spacing:0.25em;font-weight:500;
  margin-bottom:3px;color:#FBF6ED;
}
.rlx-card-sub{
  font-size:9px;letter-spacing:0.3em;
  color:rgba(245,234,214,0.6);text-transform:uppercase;
}

/* ── CENTRE ORB ── */
.rlx-center{
  display:flex;align-items:center;justify-content:center;
}
.rlx-orb-wrap{
  position:relative;
  width:300px;height:300px;
  display:flex;align-items:center;justify-content:center;
  cursor:default;
}
.rlx-orb-playing{ cursor:pointer; }
.rlx-orb-playing:hover .rlx-orb-inner{ transform:scale(1.04); }

/* Anneaux concentriques */
.rlx-ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(245,234,214,0.3);pointer-events:none;
}
.rlx-ring-1{width:280px;height:280px;animation:rlx-rp 5s ease-in-out infinite;}
.rlx-ring-2{width:250px;height:250px;border-color:rgba(230,200,138,0.4);animation:rlx-rp 5s ease-in-out infinite 1.2s;}
.rlx-ring-3{width:210px;height:210px;border-color:rgba(245,234,214,0.5);animation:rlx-rp 5s ease-in-out infinite 2.4s;}
@keyframes rlx-rp{
  0%,100%{transform:scale(1);opacity:0.45;}
  50%{transform:scale(1.06);opacity:0.8;}
}

/* Waveform bars container */
.rlx-wf-container{
  position:absolute;width:100%;height:100%;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  animation:rlx-wf-rot 55s linear infinite;
}
.rlx-wb{
  position:absolute;
  width:2px;top:50%;left:50%;
  transform-origin:center top;
  background:linear-gradient(to bottom,rgba(245,234,214,0.95),rgba(230,200,138,0.05));
  border-radius:2px;
  animation:rlx-wb-a 2.4s ease-in-out infinite;
}
@keyframes rlx-wf-rot{
  from{transform:translate(-50%,-50%) rotate(0deg);}
  to{  transform:translate(-50%,-50%) rotate(360deg);}
}
@keyframes rlx-wb-a{
  0%,100%{opacity:0.25;transform:rotate(0deg) translateY(-108px) scaleY(0.4);}
  50%{opacity:0.9;transform:rotate(0deg) translateY(-108px) scaleY(1);}
}

/* Cœur de l'orbe */
.rlx-orb-inner{
  position:relative;z-index:3;
  width:175px;height:175px;
  border-radius:50%;
  background:radial-gradient(circle at 42% 32%,
    rgba(255,251,236,0.98),
    rgba(232,198,115,0.94) 50%,
    rgba(180,132,58,0.85) 100%);
  box-shadow:
    0 0 50px rgba(230,200,138,0.55),
    0 0 90px rgba(184,136,64,0.22),
    inset 0 2px 12px rgba(255,255,255,0.45);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:2px;
  transition:transform 0.35s;
}
.rlx-drop-svg{margin-bottom:-8px;}

/* EQ bars intérieures (radio mode) */
.rlx-inner-eq{
  display:flex;align-items:center;gap:3px;
  height:30px;margin-bottom:2px;
}
.rlx-eq-bar{
  width:3px;border-radius:3px;
  background:rgba(93,63,22,0.82);
  animation:rlx-eq-a 1.1s ease-in-out infinite;
}
.rlx-eq-bar:nth-child(1){height:35%;}
.rlx-eq-bar:nth-child(2){height:80%;}
.rlx-eq-bar:nth-child(3){height:100%;}
.rlx-eq-bar:nth-child(4){height:55%;}
.rlx-eq-bar:nth-child(5){height:95%;}
.rlx-eq-bar:nth-child(6){height:40%;}
.rlx-eq-bar:nth-child(7){height:100%;}
.rlx-eq-bar:nth-child(8){height:65%;}
.rlx-eq-bar:nth-child(9){height:85%;}
.rlx-eq-bar:nth-child(10){height:45%;}
.rlx-eq-bar:nth-child(11){height:70%;}
.rlx-eq-bar:nth-child(12){height:50%;}
.rlx-eq-bar:nth-child(13){height:90%;}
.rlx-eq-bar:nth-child(14){height:35%;}
@keyframes rlx-eq-a{
  0%,100%{transform:scaleY(0.3);}
  50%{transform:scaleY(1);}
}
.rlx-inner-name{
  font-size:10px;font-weight:600;color:#5D3F16;
  letter-spacing:0.1em;text-align:center;
  max-width:140px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap;
  padding:0 8px;
}
.rlx-inner-country{
  font-size:8px;letter-spacing:0.2em;
  color:rgba(93,63,22,0.65);text-transform:uppercase;
}
.rlx-inner-title{
  font-size:18px;letter-spacing:0.4em;
  color:#5D3F16;font-weight:400;
  margin-top:2px;
}
.rlx-inner-sub{
  font-size:8px;letter-spacing:0.3em;
  color:rgba(93,63,22,0.65);text-transform:uppercase;
}
.rlx-orb-dots{
  display:flex;align-items:center;gap:8px;
  margin-top:6px;
}
.rlx-dot{
  width:5px;height:5px;border-radius:50%;
  background:rgba(93,63,22,0.55);
}
.rlx-dot-btn{
  background:none;border:none;cursor:pointer;
  color:rgba(93,63,22,0.65);font-size:13px;
  padding:2px 4px;transition:color 0.2s;
}
.rlx-dot-btn:hover{color:#5D3F16;}

/* ── RIGHT NAV ── */
.rlx-right-nav{
  display:flex;flex-direction:column;align-items:center;
  gap:6px;
  background:rgba(245,234,214,0.88);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,0.5);
  border-radius:36px;
  padding:10px 6px;
  box-shadow:0 10px 36px rgba(0,0,0,0.14);
  width:72px;
}
.rlx-rnav-avatar{
  width:46px;height:46px;border-radius:50%;
  border:none;background:#EAF4FE;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;cursor:pointer;margin-bottom:2px;
  padding:0;
}
.rlx-rnav-av-inner{
  width:38px;height:38px;border-radius:50%;overflow:hidden;
}
.rlx-rnav-btn{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:8px 4px;border:none;background:none;
  cursor:pointer;border-radius:12px;
  transition:background 0.2s;width:58px;font-family:inherit;
}
.rlx-rnav-btn:hover{background:rgba(139,94,47,0.08);}
.rlx-rnav-active{background:rgba(210,240,237,0.55);}
.rlx-rnav-icon{font-size:17px;color:#3D2E18;}
.rlx-rnav-lbl{
  font-size:8px;letter-spacing:0.2em;
  color:#5D3F16;text-transform:uppercase;font-weight:500;
}

/* ── BOTTOM BAR ── */
.rlx-bottom{
  position:relative;z-index:10;
  display:flex;align-items:center;gap:12px;
  padding:10px 20px 14px;
}
.rlx-location{
  font-size:11px;letter-spacing:0.25em;
  color:rgba(245,234,214,0.85);text-transform:uppercase;
  white-space:nowrap;flex-shrink:0;
}
.rlx-timer-wrap{flex-shrink:0;}

/* ── RESPONSIVE MOBILE ── */
@media(max-width:860px){
  .rlx-main-layout{
    grid-template-columns:1fr;
    grid-template-rows:auto auto auto;
    gap:12px;padding:8px 12px;
  }
  .rlx-left-cards{
    flex-direction:row;gap:10px;order:2;
  }
  .rlx-card{flex:1;padding:12px;gap:10px;min-width:0;}
  .rlx-card-title{font-size:14px;}
  .rlx-card-orb svg{width:38px;height:38px;}
  .rlx-center{order:1;}
  .rlx-orb-wrap{width:230px;height:230px;}
  .rlx-orb-inner{width:140px;height:140px;}
  .rlx-ring-1{width:218px;height:218px;}
  .rlx-ring-2{width:195px;height:195px;}
  .rlx-ring-3{width:165px;height:165px;}
  .rlx-right-nav{
    order:3;flex-direction:row;
    width:auto;border-radius:100px;
    padding:8px 12px;justify-self:center;
  }
  .rlx-bottom{flex-wrap:wrap;gap:8px;}
  .rlx-location{font-size:9px;}
}

/* ═══ RADIO PREMIUM SCREEN v36 ═══ */

body.relax-immersive #navBar,
/* radio: navBar stays visible - inline nav removed */
body.radio-immersive #breadcrumbBar{ display:none !important; }

/* Radio control buttons */
.radio-ctrl-btn{
  width:42px;height:42px;border-radius:50%;
  border:1.5px solid rgba(245,234,214,.35);
  background:rgba(245,234,214,.1);
  backdrop-filter:blur(10px);
  color:rgba(245,234,214,.85);
  cursor:pointer;font-size:16px;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.radio-ctrl-btn:hover{
  background:rgba(245,234,214,.2);
  border-color:rgba(245,234,214,.55);
  transform:scale(1.08);
}
.radio-ctrl-main{
  width:54px;height:54px;font-size:18px;
  background:radial-gradient(circle, rgba(184,136,64,.85), rgba(139,94,47,.75));
  border:none;
  box-shadow:0 4px 20px rgba(184,136,64,.35);
}
.radio-ctrl-main:hover{
  transform:scale(1.1);
  box-shadow:0 6px 28px rgba(184,136,64,.5);
}

/* Station list scrollbar hidden */
#radio-stations-list::-webkit-scrollbar{ display:none; }

/* Rooms immersive */
/* rooms: navBar stays visible - inline nav removed */
body.rooms-immersive #breadcrumbBar{ display:none !important; }

/* Carousel scrollbar hidden */
#rms-carousel::-webkit-scrollbar{ display:none; }
#rms-panel-content::-webkit-scrollbar{ display:none; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — All screens v39
═══════════════════════════════════════════════════════════ */

/* MyPlay animation */
@keyframes myplay-in{
  from{opacity:0;transform:translateY(-8px);}
  to{opacity:1;transform:translateY(0);}
}

/* ─── RELAX / RADIO / ROOMS fullscreen responsive ─── */

/* Ensure relax-fullscreen fills correctly on all devices */
/* NOTE: original .relax-fullscreen is position:fixed;inset:0 — do not override */
.relax-photo{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
}

/* ─── MOBILE PORTRAIT (≤600px) ─── */
@media(max-width:600px){

  /* Fullscreen fills entire screen */
  .relax-fullscreen{
    border-radius:0;
  }

  /* Relax main overlay: stack vertically */
  #relaxImgWrap > div[style*="display:flex;align-items:center;gap:14px"],
  #radioRoomShell > div[style*="display:flex;align-items:center;gap:14px"],
  #roomsExpShell  > div[style*="display:flex;align-items:center;gap:14px"]{
    flex-direction:column !important;
    padding:56px 10px 100px !important;
    gap:10px !important;
    align-items:stretch !important;
  }

  /* Left cards: horizontal row on mobile */
  .rlx-left-cards,
  div[style*="flex-direction:column;gap:14px;pointer-events:auto;flex-shrink:0"]{
    flex-direction:row !important;
    overflow-x:auto;
    gap:8px !important;
    padding-bottom:4px;
    width:100% !important;
    min-width:0;
    scrollbar-width:none;
  }
  .rlx-left-cards::-webkit-scrollbar{ display:none; }

  /* Cards on mobile: more compact */
  .rlx-card, button[style*="min-width:190px"]{
    min-width:140px !important;
    flex-shrink:0;
    padding:12px 14px !important;
  }
  .rlx-card-title, .rlx-card button [style*="font-size:20px"]{
    font-size:14px !important;
  }

  /* Orb smaller on mobile */
  .rlx-orb-wrap, div[style*="width:290px;height:290px"]{
    width:200px !important;
    height:200px !important;
  }
  .rlx-orb-inner, div[style*="width:172px;height:172px"]{
    width:130px !important;
    height:130px !important;
  }
  .rlx-ring-1{ width:190px !important; height:190px !important; }
  .rlx-ring-2{ width:168px !important; height:168px !important; }
  .rlx-ring-3{ width:140px !important; height:140px !important; }

  /* Right panel: full width below center */
  #radio-stations-panel,
  #rms-right-panel,
  div[id*="right-panel"]{
    width:100% !important;
    max-height:200px !important;
  }

  /* Radio categories: horizontal scroll */
  div[style*="width:230px"] .rms-cat-btn,
  div[style*="width:220px"] .rms-cat-btn{
    min-width:160px;
  }

  /* Bottom strips */
  .relax-radio-strip{ flex-wrap:nowrap; overflow-x:auto; }
  .relax-radio-list { flex-wrap:nowrap; }
  .relax-info-row { padding:6px 12px !important; }

  /* #navBar bottom on mobile */
  #navBar{
    bottom:8px !important;
    left:50% !important;
    transform:translateX(-50%) !important;
    flex-direction:row !important;
    border-radius:100px !important;
    padding:4px 8px !important;
    width:auto !important;
  }
  #navBar .nav-expanded{
    flex-direction:row !important;
    max-height:none !important;
    opacity:1 !important;
  }
  .nav-divider{ width:1px !important; height:24px !important; margin:0 2px !important; }
  .nav-btn{ padding:8px 12px !important; flex-direction:column; gap:2px; }
  .nav-btn span{ font-size:9px !important; letter-spacing:.1em; }
}

/* ─── TABLET PORTRAIT (601–900px) ─── */
@media(min-width:601px) and (max-width:900px){
  /* relax-fullscreen is position:fixed - no min-height needed */

  /* 2-col layout: left + center */
  #relaxImgWrap > div[style*="grid-template-columns:minmax"],
  #rlx-overlay-grid{
    grid-template-columns:220px 1fr !important;
  }
  /* Hide right station panel on tablet portrait — accessible via categories */
  #radio-stations-panel{ display:none !important; }

  .rlx-orb-wrap, div[style*="width:290px;height:290px"]{
    width:240px !important; height:240px !important;
  }
  .rlx-orb-inner, div[style*="width:172px;height:172px"]{
    width:150px !important; height:150px !important;
  }
}

/* ─── RADIO mobile: stack vertically ─── */
@media(max-width:600px){
  /* Radio: orb centered, cats scrollable below */
  #radioRoomShell > div[style*="display:flex;align-items:center;gap:14px"]{
    flex-direction:column !important;
    overflow-y:auto;
  }
  #radio-orb{ width:180px !important; height:180px !important; }
  #radio-orb-core{ width:130px !important; height:130px !important; }
  #radio-orb > div:first-child{ width:172px !important; height:172px !important; }
  #radio-orb > div:nth-child(2){ width:150px !important; height:150px !important; }

  /* Rooms mobile: single col */
  #roomsExpShell .rlx-left-cards{
    flex-direction:row !important;
    overflow-x:auto;
  }
}

/* ─── IPHONE SE / very small (≤380px) ─── */
@media(max-width:380px){
  .rlx-card, button[style*="min-width:190px"]{
    min-width:120px !important;
    padding:10px !important;
    gap:8px !important;
  }
  .rlx-card-title{ font-size:12px !important; }
  .rlx-card-orb svg, .rlx-card-orb > *{ width:36px !important; height:36px !important; }
}

/* ─── LARGE DESKTOP (≥1400px) ─── */
@media(min-width:1400px){
  .rlx-left-cards{ width:300px; }
  .rlx-card{ min-width:260px; }
  .rlx-orb-wrap, div[style*="width:290px;height:290px"]{
    width:360px !important; height:360px !important;
  }
  .rlx-orb-inner, div[style*="width:172px;height:172px"]{
    width:200px !important; height:200px !important;
  }
}

/* ═══ BORDER GLOW (v42) ═══ */
@keyframes borderPulse{
  0%,100%{opacity:.7;}
  50%{opacity:1;}
}
#uje-border-glow{
  position:fixed;inset:0;z-index:9999;pointer-events:none;
}

/* ═══ PROFILE v42 ═══ */
/* relax: navBar stays visible */

/* Profile scroll */
#contentLayer > div[style*="min-height:100%"]{
  min-height:100%;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE SYSTEM v53
   Breakpoints:
   - Phone portrait  : ≤ 480px
   - Phone landscape : 481–767px
   - Tablet portrait : 768–1023px
   - Desktop/car     : ≥ 1024px
═══════════════════════════════════════════════════════════ */

/* ─── PHONE (portrait & landscape) ≤ 767px ─── */
@media (max-width: 767px) {

  /* NavBar — horizontal at bottom center */
  #navBar{
    bottom: env(safe-area-inset-bottom, 10px) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    top: auto !important;
    flex-direction: row !important;
    width: auto !important;
    border-radius: 100px !important;
    padding: 6px 10px !important;
    gap: 0 !important;
  }
  #navBar .nav-expanded{
    flex-direction: row !important;
    max-height: none !important;
    opacity: 1 !important;
  }
  #navBar .nav-divider{
    width: 1px !important;
    height: 28px !important;
    margin: 0 4px !important;
  }
  #navBar .nav-btn{
    padding: 6px 10px !important;
    flex-direction: column !important;
  }
  #navBar .nav-btn-inner{
    width: 36px !important;
    height: 36px !important;
  }
  #navBar .nav-btn span{ font-size: 7px !important; }
  #navBar .nav-collapse-btn{ display: none !important; }

  /* Mini radio bar — smaller on phone */
  #miniRadio{
    padding: 0 10px !important;
    min-height: 44px !important;
  }
  .mini-name{ font-size: 10px !important; }
  .mcb{ width: 30px !important; height: 30px !important; font-size: 12px !important; }

  /* Relax/Radio/Rooms fullscreen — use full height */
  #relaxImgWrap, #radioRoomShell, #roomsExpShell,
  [id$="Shell"], .relax-fullscreen{
    border-radius: 0 !important;
    inset: 0 !important;
  }

  /* ─ RELAX HOME phone layout ─ */
  /* Stack: orb center top, then cards row, then radio strip */
  #relaxImgWrap > div[style*="display:flex;align-items:center;gap:14px"],
  #rlx-overlay-grid{
    flex-direction: column !important;
    padding: 52px 12px 80px !important;
    gap: 12px !important;
    align-items: center !important;
    overflow-y: auto !important;
  }

  /* Left cards → horizontal scrolling row */
  #relaxImgWrap .rlx-left-cards,
  div[style*="flex-direction:column;gap:14px;pointer-events:auto;flex-shrink:0"],
  div[style*="flex-direction:column;gap:14px;pointer-events:auto"]{
    flex-direction: row !important;
    overflow-x: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    scrollbar-width: none !important;
    order: 2 !important;
    flex-shrink: 0 !important;
  }

  /* Individual cards — compact on phone */
  button[style*="min-width:190px"],
  .rlx-card{
    min-width: 150px !important;
    max-width: 180px !important;
    flex-shrink: 0 !important;
    padding: 12px 14px !important;
  }

  /* Orb — smaller on phone */
  .rlx-orb-wrap,
  div[style*="width:290px;height:290px"],
  div[style*="width:300px;height:300px"]{
    width: 200px !important;
    height: 200px !important;
    order: 1 !important;
  }
  .rlx-orb-inner,
  div[style*="width:172px;height:172px"],
  div[style*="width:175px;height:175px"]{
    width: 140px !important;
    height: 140px !important;
  }

  /* Radio orb on phone */
  #radio-orb{ width: 180px !important; height: 180px !important; }
  #radio-orb-core{ width: 130px !important; height: 130px !important; }

  /* Stations panel — full width below */
  #radio-stations-panel{
    width: 100% !important;
    max-height: 180px !important;
    flex-shrink: 0 !important;
  }

  /* Radio categories — compact */
  div[style*="width:230px"]{
    width: 100% !important;
    max-width: 100% !important;
  }

  /* ─ ROOMS phone layout ─ */
  #roomsExpShell > div[style*="display:flex;align-items:center;gap:14px"]{
    flex-direction: column !important;
    padding: 52px 12px 80px !important;
    overflow-y: auto !important;
    gap: 10px !important;
  }
  div[style*="width:220px"]{
    width: 100% !important;
  }
  #rms-right-panel{
    width: 100% !important;
    max-height: 200px !important;
  }

  /* Active room circle — smaller */
  div[style*="width:340px;height:340px;border-radius:50%"]{
    width: 220px !important;
    height: 220px !important;
  }

  /* Bottom carousel — hidden on small phone, shown on swipe */
  #rms-carousel{
    display: flex !important;
    gap: 8px !important;
  }
  #rms-carousel > div{ width: 130px !important; height: 82px !important; }

  /* ─ Radio strip bottom ─ */
  .relax-radio-strip{ z-index: 20 !important; }
  .relax-radio-list{ gap: 6px !important; padding: 6px 10px !important; }
  .rlx-radio-pill{ padding: 5px 10px !important; font-size: 9px !important; }

  /* Info row */
  .relax-info-row{
    padding: 4px 10px !important;
    font-size: 9px !important;
  }

  /* Breadcrumb — hide on phone (too small) */
  #breadcrumbBar{ display: none !important; }

  /* Profile — full width */
  div[style*="width:min(500px,92%)"]{
    width: 94% !important;
  }

  /* Create room modal — full screen on phone */
  #create-room-modal > div > div{
    flex-direction: column !important;
    height: 90vh !important;
    overflow-y: auto !important;
  }
  #create-room-modal > div > div > div:last-child{
    display: none !important; /* Hide preview panel on phone */
  }
  #create-room-modal > div > div > div:first-child{
    width: 100% !important;
  }
}

/* ─── PHONE PORTRAIT only ≤ 480px ─── */
@media (max-width: 480px) {
  #navBar .nav-btn span{ display: none !important; } /* Icons only on very small */
  #navBar .nav-btn{ padding: 6px 8px !important; }
  .rlx-card-title{ font-size: 13px !important; }
  .rlx-card-sub{ font-size: 8px !important; }
}

/* ─── TABLET portrait 768–1023px ─── */
@media (min-width: 768px) and (max-width: 1023px) {
  /* 2 col: left(240px) + center, no right panel by default */
  #relaxImgWrap > div[style*="display:flex;align-items:center;gap:14px"]{
    gap: 16px !important;
    padding: 60px 16px 90px !important;
  }
  #radio-stations-panel{ width: 220px !important; }

  /* Orb medium size */
  .rlx-orb-wrap,
  div[style*="width:290px;height:290px"]{
    width: 250px !important;
    height: 250px !important;
  }
  .rlx-orb-inner{ width: 160px !important; height: 160px !important; }

  /* NavBar — slightly smaller */
  #navBar{ width: 64px !important; }
  #navBar .nav-btn-inner{ width: 38px !important; height: 38px !important; }
}

/* ─── SAFE AREA (notch/home indicator on iPhone) ─── */
@supports (padding: env(safe-area-inset-bottom)) {
  #navBar{
    padding-bottom: calc(6px + env(safe-area-inset-bottom)) !important;
  }
  #miniRadio{
    padding-top: env(safe-area-inset-top) !important;
  }
  .relax-radio-strip{
    padding-bottom: calc(60px + env(safe-area-inset-bottom)) !important;
  }
}

/* ─── LANDSCAPE phone (height < 500px) ─── */
@media (max-height: 500px) and (orientation: landscape) {
  .rlx-orb-wrap{ width: 160px !important; height: 160px !important; }
  .rlx-orb-inner{ width: 120px !important; height: 120px !important; }
  #relaxImgWrap > div[style*="display:flex"]{
    padding-top: 40px !important;
    padding-bottom: 60px !important;
    flex-direction: row !important;
    align-items: center !important;
  }
  button[style*="min-width:190px"]{
    min-width: 130px !important;
    padding: 8px 12px !important;
  }
}
