/* radio.css — adapted to match news.css / lajme.css look */

:root{
  --font-ui:"Segoe UI", SegoeUI, "Helvetica Neue", Arial, sans-serif;

  --bg:#ffffff;
  --surface:#ffffff;
  --surface-2:#f5f7fb;
  --card:#ffffff;
  --text:#111111;
  --muted:#5f6368;

  --border:#e3e7ee;
  --border-soft:#edf1f5;
  --border-strong:#d4dae3;

  --accent:#377eff;
  --accent-2:#4c9cff;

  --radius:12px;
  --radius-sm:8px;
  --radius-pill:999px;

  --shadow:none;
  --shadow-soft:none;

  --ease:cubic-bezier(.2,.8,.2,1);
  --t-fast:.18s;
  --t-med:.28s;
}

/* scoped only */
.radio-wrap .radio-app{
  font-family:var(--font-ui);
  color:var(--text);
}

.radio-wrap .radio-app *{
  box-sizing:border-box;
}

.radio-wrap{
  margin-top:16px;
}

.radio-wrap .radio-app{
  position:relative;
}

/* =========================
   Header
========================= */
.radio-wrap .r-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}

.radio-wrap .r-h{
  margin:0;
  font-size:21px;
  line-height:1.2;
  letter-spacing:0;
  color:var(--text);
  font-family:var(--font-ui);
}

.radio-wrap .r-b1,
.radio-wrap .r-b2{
  font-weight:600;
}

.radio-wrap .r-small{
  font-size:12px;
  line-height:1.35;
  color:var(--muted);
  margin-top:6px;
}

.radio-wrap .r-toolbar{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.radio-wrap .r-search{
  position:relative;
  display:flex;
  align-items:center;
}

.radio-wrap .r-search input{
  width:280px;
  border:1px solid var(--border);
  border-radius:8px;
  padding:8px 12px 8px 34px;
  background:var(--surface);
  outline:none;
  font:600 14px/1 var(--font-ui);
  color:var(--text);
  transition:
    background-color var(--t-fast) var(--ease),
    border-color var(--t-fast) var(--ease),
    color var(--t-fast) var(--ease);
}

.radio-wrap .r-search input::placeholder{
  color:var(--muted);
  opacity:1;
}

.radio-wrap .r-search input:focus{
  border-color:var(--border-strong);
  background:var(--surface-2);
}

.radio-wrap .r-sicon{
  position:absolute;
  left:10px;
  opacity:.65;
  font-size:14px;
  color:var(--muted);
}

/* =========================
   Layout
========================= */
.radio-wrap .r-grid{
  display:grid;
  grid-template-columns:1fr 358.4px;
  gap:12px;
  align-items:start;
}

@media (max-width:980px){
  .radio-wrap .r-grid{
    grid-template-columns:1fr;
  }

  .radio-wrap .r-search input{
    width:min(360px, 80vw);
  }
}

/* =========================
   Cards
========================= */
.radio-wrap .r-card{
  position:relative;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  box-shadow:none;
  transition:
    border-color var(--t-med) var(--ease),
    background-color var(--t-med) var(--ease);
}

.radio-wrap .r-card:hover{
  border-color:#cfd6e0;
}

/* =========================
   Left list
========================= */
.radio-wrap .r-list-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  background:#fff;
}

.radio-wrap .r-list-title{
  font-weight:600;
  font-size:14px;
  line-height:1.2;
  color:var(--text);
}

.radio-wrap .r-list-meta{
  font-size:12px;
  color:var(--muted);
  line-height:1.2;
  font-weight:500;
}

.radio-wrap .r-radio-list{
  padding:10px 10px 12px;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px 12px;
  font-family:var(--font-ui);
}

@media (max-width:1200px){
  .radio-wrap .r-radio-list{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

@media (max-width:860px){
  .radio-wrap .r-radio-list{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width:520px){
  .radio-wrap .r-radio-list{
    grid-template-columns:1fr;
  }
}

.radio-wrap .r-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border-radius:10px;
  cursor:pointer;
  user-select:none;
  text-decoration:none;
  color:inherit;
  border:1px solid transparent;
  background:transparent;
  transition:
    background-color var(--t-fast) var(--ease),
    border-color var(--t-fast) var(--ease),
    color var(--t-fast) var(--ease);
}

.radio-wrap .r-item:hover{
  background:#f7f9fc;
}

.radio-wrap .r-item.r-active{
  background:#111827;
  border-color:#111827;
  color:#fff;
}

.radio-wrap .r-logo{
  width:56px;
  height:56px;
  border-radius:10px;
  background:#f5f7fb;
  border:1px solid var(--border);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 56px;
}

.radio-wrap .r-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:6px;
  display:block;
}

.radio-wrap .r-item.r-active .r-logo{
  border-color:rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
}

.radio-wrap .r-txt{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:4px;
}

.radio-wrap .r-name{
  font:600 15px/1.15 var(--font-ui);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color:inherit;
}

.radio-wrap .r-sub{
  font:600 12px/1.2 var(--font-ui);
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.radio-wrap .r-item.r-active .r-sub{
  color:rgba(255,255,255,.72);
}

.radio-wrap .r-bullet{
  display:none !important;
}

/* =========================
   Show more
========================= */
.radio-wrap .r-list-more{
  border-top:1px solid var(--border);
  padding:8px 10px;
  display:flex;
  align-items:center;
  gap:8px;
  background:#fff;
}

.radio-wrap .r-is-hidden{
  display:none !important;
}

.radio-wrap .r-more-link{
  font:600 13px/1 var(--font-ui);
  color:var(--text);
  text-decoration:none;
  border:1px solid var(--border);
  background:#fff;
  padding:8px 12px;
  border-radius:999px;
  transition:
    background-color var(--t-fast) var(--ease),
    border-color var(--t-fast) var(--ease),
    color var(--t-fast) var(--ease);
}

.radio-wrap .r-more-link:hover{
  background:#f7f9fc;
  border-color:var(--border-strong);
}

.radio-wrap .r-more-note{
  font:500 12px/1.2 var(--font-ui);
  color:var(--muted);
}

/* =========================
   Right column
========================= */
.radio-wrap .r-right{
  display:flex;
  flex-direction:column;
  gap:12px;
  width:358.4px;
}

.radio-wrap .r-side-card{
  padding-top:0;
}

@media (max-width:980px){
  .radio-wrap .r-right{
    width:100%;
  }
}

/* =========================
   Ad
========================= */
.radio-wrap .r-ad-slot{
  padding:12px;
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:250px;
  width:358.4px;
}

.radio-wrap .r-ad-link{
  display:block;
  width:300px;
  height:250px;
}

.radio-wrap .r-ad-link img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  border:0;
  border-radius:8px;
}

@media (max-width:980px){
  .radio-wrap .r-ad-slot,
  .radio-wrap .r-ad-link{
    width:100%;
  }

  .radio-wrap .r-ad-link{
    max-width:358.4px;
    height:auto;
  }

  .radio-wrap .r-ad-link img{
    aspect-ratio:6/5;
  }
}

/* =========================
   Station info
========================= */
.radio-wrap .r-info-slot{
  padding:12px;
}

.radio-wrap .r-station-hero{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
}

.radio-wrap .r-station-logo{
  width:211px;
  height:118px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#f5f7fb;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:none;
}

.radio-wrap .r-station-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:8px;
  display:block;
}

.radio-wrap .r-station-name{
  font:600 18px/1.15 var(--font-ui);
  letter-spacing:0;
  color:var(--text);
}

.radio-wrap .r-station-site{
  display:inline-block;
  font:600 12px/1.2 var(--font-ui);
  color:var(--accent);
  text-decoration:none;
  max-width:340px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.radio-wrap .r-station-site:hover{
  text-decoration:underline;
}

.radio-wrap .r-station-note{
  margin-top:6px;
  font:500 12px/1.35 var(--font-ui);
  color:var(--muted);
}

/* =========================
   Player
========================= */
.radio-wrap .r-player-card{
  width:358.4px;
}

.radio-wrap .r-player-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  background:#fff;
}

.radio-wrap .r-player-title{
  font-weight:600;
  font-size:14px;
  color:var(--text);
}

.radio-wrap .r-player-status{
  font:600 12px/1 var(--font-ui);
  color:var(--muted);
}

.radio-wrap .r-player-body{
  padding:12px;
}

.radio-wrap .r-now-k{
  font:600 11px/1.2 var(--font-ui);
  color:var(--muted);
}

.radio-wrap .r-now-v{
  font:600 15px/1.3 var(--font-ui);
  margin-top:6px;
  color:var(--text);
}

.radio-wrap .r-controls{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:12px;
}

.radio-wrap .r-btn{
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid #111827;
  background:#111827;
  color:#fff;
  font:700 16px/1 var(--font-ui);
  cursor:pointer;
  transition:
    background-color var(--t-fast) var(--ease),
    border-color var(--t-fast) var(--ease),
    color var(--t-fast) var(--ease);
}

.radio-wrap .r-btn:hover{
  filter:none;
  background:#1f2937;
}

.radio-wrap .r-ghost{
  background:#fff;
  color:#111827;
  border-color:var(--border);
}

.radio-wrap .r-ghost:hover{
  background:#f7f9fc;
  border-color:var(--border-strong);
}

.radio-wrap .r-vol{
  flex:1;
  min-width:0;
}

.radio-wrap .r-vol-k{
  font:600 11px/1.2 var(--font-ui);
  color:var(--muted);
  margin-bottom:6px;
}

.radio-wrap .r-vol input{
  width:100%;
}

/* compact player */
.radio-wrap .r-player-compact .r-player-body{
  padding:10px 12px;
}

.radio-wrap .r-now-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.radio-wrap .r-now-status{
  font:600 11px/1 var(--font-ui);
  color:var(--muted);
  border:1px solid var(--border);
  background:#f9fafb;
  padding:5px 8px;
  border-radius:999px;
  white-space:nowrap;
}

.radio-wrap .r-now-k{
  margin:0;
}

.radio-wrap .r-now-v{
  font:600 14px/1.25 var(--font-ui);
  margin-top:6px;
}

.radio-wrap .r-player-compact .r-controls{
  margin-top:10px;
  gap:8px;
}

.radio-wrap .r-player-compact .r-btn{
  width:42px;
  height:42px;
  border-radius:12px;
}

.radio-wrap .r-player-compact .r-vol-k{
  margin-bottom:4px;
}

@media (max-width:980px){
  .radio-wrap .r-player-card{
    width:100%;
  }
}

/* =========================
   Mobile carousel
========================= */
@media (max-width:720px){
  .radio-wrap .r-h{
    font-size:20px;
    line-height:1.2;
  }

  .radio-wrap .r-header{
    flex-direction:column;
    align-items:stretch;
  }

  .radio-wrap .r-toolbar{
    width:100%;
    justify-content:flex-start;
  }

  .radio-wrap .r-search{
    width:100%;
  }

  .radio-wrap .r-search input{
    width:100%;
  }

  .radio-wrap .r-radio-list{
    display:flex;
    flex-wrap:nowrap;
    gap:12px;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    scroll-padding:10px;
    padding:10px 10px 14px;
    max-height:none;
    scrollbar-width:none;
  }

  .radio-wrap .r-radio-list::-webkit-scrollbar{
    display:none;
  }

  .radio-wrap .r-item{
    flex:0 0 100%;
    scroll-snap-align:start;
    background:var(--card);
    border:1px solid var(--border);
    border-radius:12px;
    padding:16px;
    gap:16px;
  }

  .radio-wrap .r-item:hover{
    background:#fff;
    border-color:#cfd6e0;
  }

  .radio-wrap .r-logo{
    width:112px;
    height:112px;
    border-radius:16px;
    background:#f5f7fb;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center;
    flex:0 0 112px;
    border:1px solid var(--border);
  }

  .radio-wrap .r-logo img{
    width:100%;
    height:100%;
    object-fit:contain;
    padding:8px;
    display:block;
  }

  .radio-wrap .r-name{
    font:600 18px/1.1 var(--font-ui);
  }

  .radio-wrap .r-sub{
    font:600 13px/1.25 var(--font-ui);
  }

  .radio-wrap .r-item.r-active{
    background:#111827;
    color:#fff;
    border-color:#111827;
  }

  .radio-wrap #rMoreWrap{
    display:none !important;
  }
}

/* =========================
   Loading overlay
========================= */
.radio-wrap .r-loading{
  position:absolute;
  inset:0;
  z-index:50;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.92);
  pointer-events:all;
}

.radio-wrap .r-loading.is-on{
  display:flex;
}

.radio-wrap .r-loading-card{
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 24px;
  border:1px solid var(--border);
  background:var(--card);
  box-shadow:none;
  border-radius:12px;
}

.radio-wrap .r-loading-text{
  font:600 13px/1.2 var(--font-ui);
  color:var(--text);
}

.radio-wrap .r-spinner{
  width:18px;
  height:18px;
  border-radius:999px;
  border:2px solid rgba(60,64,67,.20);
  border-top-color:var(--accent);
  animation:rSpin .8s linear infinite;
}

@keyframes rSpin{
  to{ transform:rotate(360deg); }
}