:root{
  /* Grey theme + red accent */
  --bg:#0e1113; --panel:#121417; --panel-2:#171a1e; --line:#23272d;
  --text:#e6e8ea; --muted:#9aa0a6; --accent:#d91022; /* POWER 98.7 official red */
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial}

.app-header{text-align:center;padding:22px 16px;position:relative}
.app-header h1{margin:0;font-size:28px;font-weight:800;letter-spacing:.2px}
.app-header p{margin:6px 0 0;color:var(--muted)}

/* Header branding with MAB+ logo */
.header-branding{display:flex;align-items:center;justify-content:center;gap:15px;flex-wrap:wrap}
.header-logo{height:135px;width:auto;filter:brightness(1.4);margin-bottom:0px}
.header-text{display:flex;flex-direction:column;align-items:flex-start}
@media (max-width: 480px){
  .header-branding{flex-direction:column;gap:8px}
  .header-text{align-items:center}
  .header-logo{height:105px;margin-bottom:0px}
}

/* Splash Screen */
.splash-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0b0f17,#111315);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity 0.5s ease}
.splash-screen.fade-out{opacity:0;pointer-events:none}
.splash-content{text-align:center;color:white;animation:splashFadeIn 1s ease-out}
.splash-logo{height:150px;width:auto;filter:brightness(1.5);margin-bottom:20px;animation:logoGlow 2s ease-in-out infinite alternate}
.splash-text h1{font-size:48px;font-weight:800;margin:0 0 10px;letter-spacing:2px;color:#ffffff}
.splash-text p{font-size:20px;color:var(--muted);margin:0 0 15px;font-weight:600}
.splash-stations{font-size:16px;color:var(--accent);font-weight:700;margin-bottom:30px}
.splash-loading{width:200px;height:4px;background:rgba(255,255,255,0.2);border-radius:2px;overflow:hidden;margin:0 auto}
.loading-bar{height:100%;background:linear-gradient(90deg,#d91022,var(--accent));border-radius:2px;animation:loadingProgress 2.5s ease-in-out}
@keyframes splashFadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes logoGlow{from{filter:brightness(1.5) drop-shadow(0 0 10px rgba(225,29,72,0.3))}to{filter:brightness(1.8) drop-shadow(0 0 20px rgba(225,29,72,0.6))}}
@keyframes loadingProgress{from{width:0%}to{width:100%}}

/* Install banner */
.install-banner{background:linear-gradient(135deg,var(--accent),#d91022);color:white;border-radius:16px;padding:12px 16px;margin:16px 0 0;max-width:400px;margin-left:auto;margin-right:auto}
.install-content{display:flex;align-items:center;gap:12px}
.install-icon{font-size:24px}
.install-text{flex:1;text-align:left}
.install-text p{margin:0;font-weight:600;font-size:14px}
.install-text small{color:rgba(255,255,255,0.9);font-size:12px}
.install-btn-small{background:rgba(255,255,255,0.2);color:white;border:1px solid rgba(255,255,255,0.3);border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
.install-btn-small:hover{background:rgba(255,255,255,0.3);transform:scale(1.05)}
.dismiss-btn{background:none;border:none;color:white;font-size:18px;cursor:pointer;padding:4px;line-height:1}

/* POPIA Consent Modal */
.popia-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}
.popia-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.8);backdrop-filter:blur(4px)}
.popia-content{position:relative;background:var(--panel);border:2px solid var(--line);border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px rgba(0,0,0,0.5)}
.popia-header{background:linear-gradient(135deg,var(--accent),#d91022);color:white;padding:20px;border-radius:14px 14px 0 0}
.popia-header h3{margin:0 0 4px;font-size:20px;font-weight:700}
.popia-header p{margin:0;opacity:0.9;font-size:14px}
.popia-body{padding:24px;color:var(--text);line-height:1.6}
.popia-body h4{color:var(--accent);margin:16px 0 8px;font-size:16px}
.popia-body ul{margin:8px 0 16px 20px;color:var(--muted)}
.popia-body li{margin:4px 0}
.popia-actions{padding:20px 24px;border-top:1px solid var(--line);display:flex;gap:12px;flex-wrap:wrap}
.popia-btn{padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:14px}
.popia-btn.primary{background:var(--accent);color:white;flex:1;min-width:140px}
.popia-btn.primary:hover{background:#d91022;transform:translateY(-1px)}
.popia-btn.secondary{background:var(--panel-2);color:var(--muted);border:1px solid var(--line)}
.popia-btn.secondary:hover{background:var(--line);color:var(--text)}
.popia-note{font-size:12px;color:var(--muted);margin:12px 24px 0;padding-top:12px;border-top:1px solid var(--line)}

@media (max-width:600px){
.popia-actions{flex-direction:column}
.popia-btn{width:100%}
}

/* Contact links styling */
a[href^="tel:"]{color:var(--accent);text-decoration:none;font-weight:600;transition:all .2s}
a[href^="tel:"]:hover{color:#d91022;text-decoration:underline}
a[href^="mailto:"]{color:var(--accent);text-decoration:none;font-weight:600;transition:all .2s}
a[href^="mailto:"]:hover{color:#d91022;text-decoration:underline}
a[href^="https://wa.me/"]{color:#25d366;text-decoration:none;font-weight:600;transition:all .2s}
a[href^="https://wa.me/"]:hover{color:#128c7e;text-decoration:underline}
.container{max-width:1100px;margin:0 auto;padding:10px 20px 20px;min-height:100vh;display:flex;flex-direction:column}

/* Tabs */
.tabs{display:flex;gap:6px;justify-content:center;padding:0 16px 0px;margin-bottom:0px;flex-wrap:wrap}
.tab{padding:8px 12px;border:1px solid var(--line);border-radius:12px;background:var(--panel-2);color:var(--text);text-decoration:none;text-align:center;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;min-width:70px}
.tab.active{outline:2px solid #d91022; outline-offset:2px}

/* Pages */
.page{display:none;flex:1}
.page.active{display:flex;flex-direction:column}

/* Player - Enhanced layout for better space utilization */
.player{background:var(--panel-2);border:1px solid var(--line);border-radius:20px;padding:24px;margin-bottom:24px}
.nowline{display:flex;flex-direction:column;gap:24px;position:relative}
.now-left{display:flex;align-items:center;justify-content:center;gap:20px;position:relative;padding:20px 0}
.nowmeta{text-align:center}
.nowmeta #now-station{font-weight:800;font-size:24px;letter-spacing:.2px}
.nowmeta #now-status{color:#10b981;font-size:16px;margin-top:4px;font-weight:600}

/* Station toggle - Enhanced for better visibility */
.station-toggle{display:flex;align-items:center;gap:16px;background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:12px;padding:16px 20px;cursor:pointer;transition:border-color .15s,background .15s;font-weight:600;font-size:16px;min-width:280px;justify-content:space-between}
.station-toggle:hover{border-color:#d91022;background:var(--panel-2)}
.station-toggle .dot{width:14px;height:14px;border-radius:999px;display:inline-block;background:#d91022;transition:background .15s}
.station-toggle .dot.playing{background:#10b981}
.station-toggle .switch-text{color:#ffffff;font-size:10px;padding:8px 12px;background:#d91022;border-radius:8px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;line-height:1.2;text-align:center;min-width:50px}

/* Player Controls - Modern app-like design */
.player-controls{display:flex;flex-direction:column;align-items:center;gap:24px;margin-top:16px}

/* Main play/pause button */
.main-control{display:flex;justify-content:center}
.play-pause-btn{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#d91022);border:none;color:white;font-size:28px;cursor:pointer;transition:all .2s;box-shadow:0 8px 24px rgba(225,29,72,.3);display:flex;align-items:center;justify-content:center;position:relative}
.play-pause-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 12px 32px rgba(225,29,72,.4)}
.play-pause-btn:active{transform:scale(0.98)}
.play-pause-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.play-pause-btn .play-icon,.play-pause-btn .pause-icon{position:absolute;display:flex;align-items:center;justify-content:center;color:white;font-size:28px}

/* Secondary controls - Colorful and exciting */
.secondary-controls{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;padding:0 16px}
.control-btn{display:flex;flex-direction:column;align-items:center;gap:6px;border:none;border-radius:16px;padding:16px 20px;color:white;cursor:pointer;transition:all .2s;min-width:80px;box-shadow:0 6px 16px rgba(0,0,0,.2);font-weight:600}
.control-btn:hover:not(:disabled){transform:translateY(-4px) scale(1.05);box-shadow:0 12px 28px rgba(0,0,0,.3)}
.control-btn:active{transform:translateY(-2px) scale(1.02)}
.control-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}
.control-btn .btn-icon{font-size:22px;line-height:1;margin-bottom:2px}
.control-btn .btn-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}

/* Share button styling */

#shareBtn{background:linear-gradient(135deg,#d91022,#b01120);box-shadow:0 6px 16px rgba(225,29,72,.3)}
#shareBtn:hover{box-shadow:0 12px 28px rgba(225,29,72,.4)}

/* ===== Main controls row ===== */
.main-controls{
  display: flex; 
  align-items: center; 
  justify-content: center; 
  gap: 20px; 
  padding: 32px 0 16px;
  flex-wrap: wrap;
}
.play-big{
  width:140px; height:140px; border-radius:999px; display:grid; place-items:center; position:relative;
  background: #d91022;
  border:3px solid rgba(255,255,255,.08); cursor:pointer;
  box-shadow: 0 18px 60px rgba(225,29,72,.35), inset 0 0 0 5px rgba(0,0,0,.25);
  transition: transform .12s ease, box-shadow .12s ease;
  color:#fff; font-size:42px; font-weight:800; letter-spacing:.3px;
}
.play-big:hover{ transform: translateY(-2px); box-shadow: 0 24px 80px rgba(225,29,72,.45), inset 0 0 0 5px rgba(0,0,0,.25); }
.play-big.is-playing{
  background: #10b981;
  box-shadow: 0 18px 60px rgba(16,185,129,.35), inset 0 0 0 5px rgba(0,0,0,.25);
  animation: pulse 1.5s ease-in-out infinite;
}
.play-big.is-playing{
  color: transparent; /* Hide the regular text content */
}
.play-big.is-playing::before{
  content: "⏸️";
  position: absolute;
  font-size: 42px;
  font-weight: 800;
  color: #fff;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
  animation: none; /* Keep pause icon stationary */
}
@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
@keyframes spin-reverse {
  from { transform: rotate(0deg); }
  to { transform: rotate(-360deg); }
}
@keyframes pulse {
  0%, 100% { 
    transform: scale(1);
    box-shadow: 0 18px 60px rgba(16,185,129,.35), inset 0 0 0 5px rgba(0,0,0,.25), 0 0 0 0 rgba(16,185,129,0.4);
  }
  50% { 
    transform: scale(1.05);
    box-shadow: 0 24px 80px rgba(16,185,129,.5), inset 0 0 0 5px rgba(0,0,0,.25), 0 0 0 15px rgba(16,185,129,0.2);
  }
}




/* Share strip - centered */
.share-strip{
  margin-top:16px; display:flex; align-items:center; justify-content:center;
  gap:12px; padding:12px;
}
.btn-share, .btn-install{
  font:inherit; background:var(--panel-2); color:var(--text);
  border:1px solid var(--line); border-radius:10px; padding:8px 16px; cursor:pointer;
  transition: all 0.3s ease;
}
.btn-share:hover, .btn-install:hover{ border-color:var(--accent); }

/* Station-specific share button styling */
.btn-share.station-power{
  background: linear-gradient(135deg, #d91022, #b01120) !important;
  color: #fff !important;
  border-color: #d91022 !important;
  box-shadow: 0 4px 12px rgba(225,29,72,.3);
}
.btn-share.station-power:hover{
  background: linear-gradient(135deg, #b01120, #991b1b) !important;
  border-color: #b01120 !important;
  box-shadow: 0 6px 16px rgba(225,29,72,.4) !important;
}

.btn-share.station-capricorn{
  background: linear-gradient(135deg, #d91022, #b01120) !important;
  color: #fff !important;
  border-color: #d91022 !important;
  box-shadow: 0 4px 12px rgba(225,29,72,.3);
}
.btn-share.station-capricorn:hover{
  background: linear-gradient(135deg, #b01120, #991b1b) !important;
  border-color: #b01120 !important;
  box-shadow: 0 6px 16px rgba(225,29,72,.4) !important;
}
.tip{color:var(--muted);margin:16px 0 0;font-size:12px;text-align:center}

/* Station cards (optional quick access) */
.station-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:32px;padding:0 8px}
.station-card{position:relative;border:3px solid var(--line);background:var(--panel);border-radius:16px;padding:16px;text-align:left;cursor:default;transition:all .3s;min-height:160px;display:flex;flex-direction:column;justify-content:center}

.station-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 100%;
}

.current-show {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.show-details {
  flex: 1;
}

.show-title {
  font-size: 14px;
  font-weight: 600;
  margin: 0;
  color: rgba(255, 255, 255, 0.9);
}

.show-host {
  font-size: 12px;
  margin: 2px 0 0 0;
  color: rgba(255, 255, 255, 0.7);
  font-weight: 400;
}

.presenter-photo {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.1);
  border: 2px solid rgba(255, 255, 255, 0.3);
  flex-shrink: 0;
}

.presenter-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.4);
}

/* Enhanced centering and cropping for better face focus */
.presenter-img[src*="power987.co.za"], 
.presenter-img[src*="capricornfm.co.za"], 
.presenter-img[src*="github"], 
.presenter-img[src*="wikipedia"], 
.presenter-img[src*="tvsa"] {
  object-position: center top;
  transform: scale(1.3);
}
.station-card .badge{position:absolute;left:12px;top:12px;background:#10b981;color:#052017;border-radius:999px;padding:6px 12px;font-weight:800;font-size:12px;box-shadow:0 2px 8px rgba(16,185,129,0.3)}
.station-card.power{transition:all .3s}
.station-card.capricorn{transition:all .3s}
.station-card.power.selected{border-color:#d91022;opacity:0.8}
.station-card.capricorn.selected{border-color:#d91022;opacity:0.8}
.station-card.power.active{border-color:#d91022;box-shadow:0 0 16px rgba(225,29,72,.2)}
.station-card.capricorn.active{border-color:#d91022;box-shadow:0 0 16px rgba(225,29,72,.2)}

/* White text styling for station cards */
.white-text{color:#ffffff !important}

/* Station logo styling */
.station-logo {
  height: 36px;
  width: auto;
  max-width: 150px;
  margin-bottom: 2px;
}

/* Capricorn logo needs white background for visibility on dark theme */
.station-card.capricorn .station-logo {
  background: white;
  padding: 4px 8px;
  border-radius: 4px;
}

/* Toggle station logo styling */
.toggle-logo-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.toggle-station-logo {
  height: 32px;
  width: auto;
  max-width: 120px;
}

/* Capricorn toggle logo needs background for visibility */
.toggle-station-logo[src*="capricorn"] {
  background: white;
  padding: 4px 8px;
  border-radius: 4px;
}

#toggle-text {
  display: none;
}



/* Explore */
.competitions,.quick-links{margin-top:24px}
.comp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.comp-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;position:relative}
.comp-card h4{margin:0 0 6px}
.comp-card p{margin:0 0 10px;color:var(--muted)}
.comp-tag{position:absolute;top:10px;right:10px;background:#10b981;color:#052017;font-size:11px;font-weight:800;border-radius:999px;padding:2px 8px}
.comp-tag.teal{background:#3b82f6;color:#ffffff}
.btn{background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:10px;padding:8px 12px;display:inline-block;text-decoration:none}
.comp-card .btn{border:1px solid #3b82f6;color:#ffffff}
.comp-card .btn:hover{border-color:#2563eb;background:var(--panel)}
.link{color:#ffd1d8;font-size:12px;margin-left:8px}

.quick-links .ql-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.ql{display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 12px;text-decoration:none;color:var(--text);transition:all 0.2s ease}
.ql:hover{border-color:#d91022;transform:translateY(-2px);box-shadow:0 4px 12px rgba(225,29,72,0.2)}
.ql-icon{font-size:24px;filter:brightness(1.2)}
.ql-text{font-weight:600;font-size:14px}



/* News */
.news{margin-top:24px}
.news-header{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.news-header h3{margin:0;font-size:20px;font-weight:700}
.news-filters{display:flex;gap:10px;flex-wrap:wrap}
.news-filters select{padding:8px 12px;border:1px solid #d91022;border-radius:999px;background:var(--panel);color:#ffffff;cursor:pointer;font-size:16px;outline:none;min-width:140px}
.news-filters select:focus{outline:2px solid #d91022}
.news-filters select option{background:var(--panel);color:#ffffff;border:none}
.news-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.news-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:8px;position:relative;transition:all 0.2s ease}
.news-card:hover{border-color:#d91022;transform:translateY(-2px);box-shadow:0 4px 12px rgba(225,29,72,0.15)}

.card-header{display:flex;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.source-badge{background:#d91022;color:white;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}
.subject-badge{background:var(--panel-2);color:var(--text);padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:capitalize;border:1px solid var(--line)}

.subject-world{background:#3b82f6;color:white}
.subject-business{background:#10b981;color:white}
.subject-politics{background:#8b5cf6;color:white}
.subject-sport{background:#f59e0b;color:white}
.subject-technology{background:#06b6d4;color:white}
.subject-health{background:#ef4444;color:white}
.subject-entertainment{background:#ec4899;color:white}
.subject-local{background:#84cc16;color:white}

.news-card h4{margin:0;font-size:16px;line-height:1.3;font-weight:700}
.news-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.4}
.news-card a[data-article]{color:#d91022;text-decoration:none;font-weight:600;font-size:13px;margin-top:auto}
.news-card a[data-article]:hover{color:#d91022;text-decoration:underline}

.no-results{grid-column:1/-1;text-align:center;padding:40px 20px}
.no-results-content h4{margin:0 0 8px;color:var(--text)}
.no-results-content p{margin:0;color:var(--muted)}

/* Lineup */
.schedule{margin-top:24px}
.sched-controls{display:flex;flex-direction:column;gap:10px;margin-bottom:10px}
.station-switch{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:var(--panel);color:var(--text);cursor:pointer}
.chip.active{outline:2px solid #d91022}
.day-switch{display:flex;gap:8px;overflow:auto;padding-bottom:6px}
.day-btn{min-width:88px;text-align:center;padding:8px 10px;border:1px solid #64748b;border-radius:10px;background:var(--panel);cursor:pointer;color:#ffffff}
.day-btn.active{outline:2px solid #d91022}
.schedule-list{display:flex;flex-direction:column;gap:8px;max-height:60vh;overflow:auto;border:1px solid var(--line);border-radius:12px;padding:10px;background:var(--panel)}
.slot{display:flex;gap:16px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:16px;background:var(--panel-2)}
.slot-time{width:86px;flex:0 0 86px;color:#cbd5e1;font-weight:600}
.slot-body{flex:1}
.slot-title{margin:0 0 4px;font-weight:800}
.slot-host{margin:0;color:var(--muted);font-size:13px}
.slot.live{border-color:#10b981}
.slot-presenter-photo{width:100px;height:100px;border-radius:50%;overflow:hidden;background:rgba(255,255,255,0.1);border:2px solid rgba(255,255,255,0.15);flex-shrink:0}
.slot-presenter-img{width:100%;height:100%;object-fit:cover;object-position:center center;transform:scale(1.4)}
.slot-presenter-img[src*="power987.co.za"], 
.slot-presenter-img[src*="capricornfm.co.za"], 
.slot-presenter-img[src*="github"], 
.slot-presenter-img[src*="wikipedia"], 
.slot-presenter-img[src*="tvsa"]{object-position:center top;transform:scale(1.3)}

/* Modal */
.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:1000}
.modal.hidden{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(2px)}
.modal-card{position:relative;width:min(840px,92vw);max-height:85vh;overflow:hidden;background:var(--panel-2);border:1px solid var(--line);border-radius:14px;padding:0;box-shadow:0 10px 40px rgba(0,0,0,.45);display:flex;flex-direction:column}
.modal-header{padding:16px 16px 12px;border-bottom:1px solid var(--line);flex-shrink:0}
.modal-title{margin:0;font-size:18px;font-weight:700;color:var(--text);padding-right:40px}
.modal-close{position:absolute;top:12px;right:12px;background:#d91022;color:white;border:1px solid #d91022;border-radius:8px;padding:8px 12px;cursor:pointer;font-size:14px;font-weight:600;transition:all 0.2s ease}
.modal-close:hover{background:#d91022;border-color:#d91022;transform:scale(1.05)}
.modal-body{padding:16px;overflow-y:auto;flex:1;line-height:1.6}
.modal-body img{max-width:100%;height:auto;border-radius:8px;margin:10px 0}
.modal-body a{color:#d91022;text-decoration:none}
.modal-body a:hover{color:#d91022;text-decoration:underline}

/* News Article Styling */
.news-article{max-width:100%}

/* Community Tab Styling */
.community{margin-top:24px}
.community-section{margin-bottom:32px;padding:20px;background:var(--panel);border:1px solid var(--line);border-radius:16px}
.section-title{font-size:20px;font-weight:700;margin:0 0 20px;color:var(--text);display:flex;align-items:center;gap:8px}

/* Text Us Section */
.text-us-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}
.text-card{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:16px;transition:all 0.2s ease}
.text-card:hover{border-color:#d91022;transform:translateY(-2px);box-shadow:0 4px 12px rgba(225,29,72,0.15)}
.text-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.station-mini-logo{height:32px;width:auto;border-radius:4px}
.text-header h4{margin:0;font-size:16px;font-weight:700}
.text-options{display:flex;flex-direction:column;gap:10px}
.text-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--text);text-decoration:none;cursor:pointer;transition:all 0.2s ease;font:inherit}
.text-btn:hover{border-color:#d91022;background:var(--panel-2);transform:translateY(-1px)}
.text-btn.whatsapp{border-color:#25d366;color:#25d366}
.text-btn.whatsapp:hover{background:#25d366;color:white}
.text-icon{font-size:16px}

/* Live Chat & Shout-Outs */
.chat-section{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width: 768px){.chat-section{grid-template-columns:1fr}}
.shoutout-form{background:var(--panel-2);padding:16px;border-radius:12px;border:1px solid var(--line)}
.shoutout-form h4{margin:0 0 16px;color:var(--text)}
.shoutout-form input,.shoutout-form textarea,.shoutout-form select{width:100%;padding:10px;margin-bottom:12px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--text);font:inherit}
.shoutout-form input:focus,.shoutout-form textarea:focus,.shoutout-form select:focus{outline:2px solid #d91022;border-color:#d91022}
.submit-shout{width:100%;padding:12px;background:#d91022;color:white;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all 0.2s ease}
.submit-shout:hover{background:#b01120;transform:translateY(-1px)}
.special-occasions{background:var(--panel-2);padding:16px;border-radius:12px;border:1px solid var(--line)}
.special-occasions h4{margin:0 0 16px;color:var(--text)}
.occasion-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.occasion-btn{padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--text);cursor:pointer;transition:all 0.2s ease;font:inherit}
.occasion-btn:hover{border-color:#d91022;background:var(--panel-2)}

/* Competitions Hub */
.competitions-hub{display:grid;grid-template-columns:2fr 1fr;gap:20px}
@media (max-width: 768px){.competitions-hub{grid-template-columns:1fr}}
.active-competitions h4,.winners-gallery h4{margin:0 0 16px;color:var(--text)}
.winners-grid{display:flex;flex-direction:column;gap:10px}
.winner-card{background:var(--panel-2);padding:12px;border-radius:8px;border:1px solid var(--line)}
.winner-info strong{color:#d91022;font-weight:700}
.winner-info .prize{display:block;color:var(--text);font-weight:600;margin:4px 0}
.winner-info small{color:var(--muted)}

/* Events & Concerts */
.events-section{display:grid;grid-template-columns:2fr 1fr;gap:20px}
@media (max-width: 768px){.events-section{grid-template-columns:1fr}}
.events-grid{display:flex;flex-direction:column;gap:16px}
.event-card{display:flex;gap:16px;background:var(--panel-2);padding:16px;border-radius:12px;border:1px solid var(--line);transition:all 0.2s ease}
.event-card:hover{border-color:#d91022;transform:translateY(-2px);box-shadow:0 4px 12px rgba(225,29,72,0.15)}
.event-date{display:flex;flex-direction:column;align-items:center;background:#d91022;color:white;padding:8px 12px;border-radius:8px;min-width:60px}
.event-date .day{font-size:20px;font-weight:800;line-height:1}
.event-date .month{font-size:12px;font-weight:600;text-transform:uppercase}
.event-info{flex:1}
.event-info h5{margin:0 0 8px;font-size:16px;font-weight:700;color:var(--text)}
.event-info p{margin:0 0 12px;color:var(--muted)}
.event-actions{display:flex;gap:8px}
.event-btn{padding:8px 16px;border:1px solid #d91022;border-radius:6px;background:#d91022;color:white;cursor:pointer;font:inherit;font-weight:600;transition:all 0.2s ease}
.event-btn:hover{background:#b01120;transform:translateY(-1px)}
.event-btn.secondary{background:transparent;color:#d91022}
.event-btn.secondary:hover{background:#d91022;color:white}

.live-broadcasts h4{margin:0 0 16px;color:var(--text)}
.broadcast-schedule{display:flex;flex-direction:column;gap:8px}
.broadcast-item{display:flex;align-items:center;gap:12px;padding:10px;background:var(--panel-2);border-radius:8px;border:1px solid var(--line)}
.broadcast-datetime{display:flex;flex-direction:column;align-items:center;min-width:60px}
.broadcast-date{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase}
.broadcast-time{font-weight:700;color:#d91022;font-size:14px}
.broadcast-event{flex:1;color:var(--text);margin-left:8px}
.broadcast-station{font-size:12px;color:var(--muted);font-weight:600}

/* Social Media Section */
.station-social-selector{display:flex;gap:8px;margin-bottom:12px;justify-content:center}
.station-social-btn{padding:10px 20px;border:2px solid var(--line);border-radius:8px;background:var(--panel);color:var(--text);cursor:pointer;transition:all 0.2s ease;font:inherit;font-weight:600}
.station-social-btn.active{border-color:#d91022;background:#d91022;color:white}
.station-social-btn:hover:not(.active){border-color:#d91022}

.social-tabs{display:flex;gap:12px;margin-bottom:16px;justify-content:center;flex-wrap:wrap}
.social-tab{padding:12px;border:2px solid var(--line);border-radius:12px;background:var(--panel);color:var(--muted);cursor:pointer;transition:all 0.2s ease;display:flex;align-items:center;justify-content:center;width:48px;height:48px}
.social-tab.active{border-color:#d91022;background:#d91022;color:white}
.social-tab:hover:not(.active){border-color:#d91022;color:var(--text)}
.social-icon{width:24px;height:24px;transition:transform 0.2s ease}
.social-tab:hover .social-icon{transform:scale(1.1)}

/* Platform-specific colors */
.social-tab[data-social="instagram"].active{background:linear-gradient(45deg, #f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);border-color:#e1306c}
.social-tab[data-social="facebook"].active{background:#1877F2;border-color:#1877F2}
.social-tab[data-social="twitter"].active{background:#000000;border-color:#000000}
.social-tab[data-social="tiktok"].active{background:#000000;border-color:#ff0050}
.social-feed{display:none}
.social-feed.active{display:block}

/* Social Feed Placeholders */
.social-placeholder{background:var(--panel);border-radius:12px;padding:20px;border:1px solid var(--line)}
.social-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.platform-icon-large{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:white}
.platform-icon-large svg{width:28px;height:28px}
.instagram-icon{background:linear-gradient(45deg, #f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%)}
.facebook-icon{background:#1877F2}
.twitter-icon{background:#000000}
.tiktok-icon{background:#000000}
.social-info h4{margin:0;font-size:16px;font-weight:600;color:var(--text)}
.social-info p{margin:4px 0 0 0;font-size:14px;color:var(--muted)}
.feed-preview{text-align:center}
.feed-preview p{color:var(--muted);margin-bottom:16px;line-height:1.5}
.visit-btn{background:#d91022;color:white;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all 0.2s ease;width:100%}
.visit-btn:hover{background:#b8081c;transform:translateY(-1px)}

.social-grid{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}
.social-post{background:var(--panel-2);padding:16px;border-radius:12px;border:1px solid var(--line);margin-bottom:12px}
.post-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.post-account{display:flex;align-items:center;gap:6px}
.platform-icon{font-size:14px}
.post-header strong{color:#d91022}
.post-time{color:var(--muted);font-size:12px}
.post-content{color:var(--text);line-height:1.5;margin-bottom:12px}
.post-media{width:100%;max-height:200px;object-fit:cover;border-radius:6px;margin-top:8px}
.social-post p{margin:0 0 12px;color:var(--text);line-height:1.5}
.post-engagement{display:flex;gap:16px;margin-top:12px}
.post-engagement span{font-size:14px;color:var(--muted)}
.post-link{color:#d91022;text-decoration:none;font-size:12px;margin-top:8px;display:inline-block}
.post-link:hover{text-decoration:underline}

.loading-posts{text-align:center;padding:20px;color:var(--muted)}
.no-social-posts{text-align:center;padding:20px;color:var(--muted)}

.social-setup-message{text-align:center;padding:30px;background:var(--panel-2);border-radius:12px;border:1px solid var(--line)}
.setup-icon{font-size:48px;margin-bottom:16px}
.social-setup-message h4{margin:0 0 12px;color:var(--text);font-size:18px}
.social-setup-message p{margin:0 0 16px;color:var(--muted);line-height:1.5}
.setup-steps{text-align:left;background:var(--panel);padding:16px;border-radius:8px;margin:16px 0;border:1px solid var(--line)}
.setup-steps ul{margin:8px 0 0 20px;color:var(--muted)}
.setup-steps li{margin-bottom:4px}
.setup-btn{background:#d91022;color:white;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:background 0.2s}
.setup-btn:hover{background:#b01120}

.social-setup-modal ol{text-align:left;margin:16px 0;padding-left:20px}
.social-setup-modal li{margin-bottom:8px;color:var(--text)}
.modal-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}
.modal-actions .btn{padding:10px 20px;border-radius:6px;font-weight:600;cursor:pointer;border:1px solid var(--line);background:#d91022;color:white}
.modal-actions .btn.secondary{background:transparent;color:var(--text)}
.modal-actions .btn.secondary:hover{background:var(--panel-2)}
.modal-actions .btn:hover{background:#b01120}

.user-content{background:var(--panel-2);padding:16px;border-radius:12px;border:1px solid var(--line)}
.user-content h4{margin:0 0 16px;color:var(--text)}
.share-options{display:flex;gap:8px;flex-wrap:wrap}
.share-btn{padding:10px 14px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--text);cursor:pointer;transition:all 0.2s ease;font:inherit}
.share-btn:hover{border-color:#d91022;background:var(--panel-2);transform:translateY(-1px)}
.article-meta{display:flex;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.article-source{background:#d91022;color:white;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}
.article-date{color:var(--muted);font-size:12px}
.article-content{color:var(--text)}
.article-content h1,.article-content h2,.article-content h3{color:var(--text);margin:20px 0 10px}
.article-content h1{font-size:24px}
.article-content h2{font-size:20px}
.article-content h3{font-size:18px}
.article-content p{margin:12px 0;line-height:1.7}
.article-content ul,.article-content ol{margin:12px 0;padding-left:20px}
.article-content li{margin:6px 0}
.article-content blockquote{margin:16px 0;padding:12px 16px;border-left:4px solid #d91022;background:var(--panel);border-radius:0 8px 8px 0}

/* Loading and Error States */
.loading-spinner{text-align:center;padding:40px 20px;color:var(--muted);font-size:16px}
.error-message{color:var(--text);line-height:1.6}
.error-message ul{margin:12px 0;padding-left:20px}
.error-message li{margin:6px 0;color:var(--muted)}

/* Simple form styles for competitions */
.form-grid{display:grid;gap:10px}
.input,.select,.textarea{width:100%;padding:10px 12px;background:#0b1220;color:var(--text);border:1px solid #334155;border-radius:8px}
.form-actions{display:flex;gap:10px;margin-top:8px}

/* Mobile Footer Menu */
.mobile-footer-menu{
  display:flex;
  justify-content:space-around;
  align-items:center;
  background:var(--panel);
  border-top:1px solid var(--line);
  padding:12px 8px 8px;
  position:sticky;
  bottom:0;
  z-index:100;
  backdrop-filter:blur(10px);
}

.footer-menu-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  background:transparent;
  border:none;
  color:var(--muted);
  cursor:pointer;
  padding:8px 12px;
  border-radius:12px;
  transition:all 0.2s ease;
  min-width:60px;
}

.footer-menu-item:hover{
  color:var(--text);
  background:var(--panel-2);
  transform:translateY(-2px);
}

.footer-menu-item:active{
  transform:translateY(0);
  background:var(--line);
}

.footer-icon{
  font-size:18px;
  line-height:1;
  filter:grayscale(0.3);
}

.footer-menu-item:hover .footer-icon{
  filter:grayscale(0);
  transform:scale(1.1);
}

.footer-label{
  font-size:10px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.5px;
  line-height:1;
}

/* Toggle Switches */
.setting-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 0;
  border-bottom:1px solid var(--line);
}

.setting-row:last-child{
  border-bottom:none;
}

.toggle-switch{
  position:relative;
  display:inline-block;
  width:50px;
  height:24px;
}

.toggle-switch input{
  opacity:0;
  width:0;
  height:0;
}

.toggle-slider{
  position:absolute;
  cursor:pointer;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:var(--line);
  transition:0.3s;
  border-radius:24px;
}

.toggle-slider:before{
  position:absolute;
  content:"";
  height:18px;
  width:18px;
  left:3px;
  bottom:3px;
  background:white;
  transition:0.3s;
  border-radius:50%;
}

input:checked + .toggle-slider{
  background:#d91022;
}

input:checked + .toggle-slider:before{
  transform:translateX(26px);
}

.setting-buttons{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:15px 0;
}

.setting-btn{
  padding:10px 15px;
  background:var(--panel);
  color:var(--text);
  border:1px solid var(--line);
  border-radius:8px;
  cursor:pointer;
  transition:all 0.2s ease;
  font-weight:600;
}

.setting-btn:hover{
  background:var(--panel-2);
  border-color:#d91022;
}

/* Enhanced Settings Styling */
.settings-section {
  margin-bottom: 25px;
}

.settings-section h4 {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 16px;
  font-weight: 700;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
  margin-bottom: 15px;
}

.info-btn {
  background: var(--panel);
  color: var(--accent);
  border: 1px solid var(--line);
  padding: 4px 12px;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-weight: 600;
}

.info-btn:hover {
  background: var(--panel-2);
  border-color: var(--accent);
  transform: translateY(-1px);
}

/* Volume slider styling */
input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  height: 6px;
  border-radius: 3px;
  background: var(--line);
  outline: none;
}

input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  transition: all 0.2s ease;
}

input[type="range"]::-webkit-slider-thumb:hover {
  transform: scale(1.2);
  box-shadow: 0 0 10px rgba(217, 16, 34, 0.3);
}

input[type="range"]::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  border: none;
  transition: all 0.2s ease;
}

input[type="range"]::-moz-range-thumb:hover {
  transform: scale(1.2);
  box-shadow: 0 0 10px rgba(217, 16, 34, 0.3);
}

/* Dark mode support (basic) */
.dark-mode {
  --root: #0f0f23;
  --panel: #16213e;
  --panel-2: #1e2a54;
  --text: #e2e8f0;
  --muted: #94a3b8;
  --line: #334155;
}

.dark-mode .modal-card {
  background: var(--panel);
  border-color: var(--line);
}

/* Phone Links */
.phone-link{
  color:#d91022;
  text-decoration:none;
  font-weight:700;
  padding:2px 6px;
  border-radius:4px;
  background:rgba(225,29,72,0.1);
  border:1px solid rgba(225,29,72,0.3);
  transition:all 0.2s ease;
  display:inline-block;
  cursor:pointer;
}

.phone-link:hover{
  background:rgba(225,29,72,0.2);
  border-color:#d91022;
  transform:translateY(-1px);
  box-shadow:0 2px 8px rgba(225,29,72,0.3);
}

.phone-link:active{
  transform:translateY(0);
  box-shadow:0 1px 4px rgba(225,29,72,0.2);
}

/* Mobile Footer Menu */
.mobile-footer-menu {
  display: flex;
  justify-content: space-around;
  align-items: center;
  background: #d91022; /* Red background - same as accent color */
  border-top: 2px solid #b01120;
  padding: 8px 0;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  box-shadow: 0 -4px 12px rgba(217, 16, 34, 0.3);
}

.footer-menu-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: none;
  border: none;
  color: #ffffff; /* White for icons and text */
  cursor: pointer;
  padding: 8px 12px;
  border-radius: 8px;
  transition: all 0.2s ease;
  font-size: 10px;
  min-width: 60px;
}

.footer-menu-item:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #f3f4f6; /* Light grey on hover */
  transform: translateY(-2px);
}

.footer-menu-item.active {
  background: #000000; /* Black background for active state */
  color: #ffffff; /* White text for active state */
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.footer-icon {
  font-size: 18px;
  line-height: 1;
  color: inherit; /* Use same color as parent */
}

/* Ensure all icons are consistently sized and white */
.footer-menu-item[data-action="privacy"] .footer-icon,
.footer-menu-item[data-action="contact"] .footer-icon,
.footer-menu-item[data-action="about"] .footer-icon,
.footer-menu-item[data-action="settings"] .footer-icon {
  filter: brightness(0) invert(1); /* Force white color */
  font-size: 19px; /* Slightly larger for better visibility */
}

.footer-label {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  font-size: 9px;
}

/* Add padding to body to account for fixed footer */
body {
  padding-bottom: 80px;
}

/* Lineup page - Station Toggle */
.schedule-toggle-container{display:flex;gap:12px;margin-bottom:24px;justify-content:center;flex-wrap:wrap;background:var(--panel);border-radius:12px;padding:6px;border:1px solid var(--line)}
.schedule-station-toggle{position:relative;cursor:pointer}
.schedule-station-toggle input[type="radio"]{position:absolute;opacity:0;width:0;height:0}
.toggle-option{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:8px;background:transparent;color:var(--muted);font-weight:600;font-size:14px;transition:all .2s ease;white-space:nowrap}
.schedule-station-toggle input[type="radio"]:checked + .toggle-option{background:linear-gradient(135deg,var(--accent),#d91022);color:white;transform:translateY(-1px)}
.schedule-station-toggle:hover .toggle-option{background:var(--panel-2);color:var(--text)}
.schedule-station-toggle:hover input[type="radio"]:checked + .toggle-option{background:linear-gradient(135deg,var(--accent),#d91022);color:white}

/* Enhanced Player Controls */
.enhanced-controls {
  margin: 16px 0;
  text-align: center;
}

.control-row {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-bottom: 8px;
}

.control-btn.modern {
  background: rgba(255, 255, 255, 0.08);
  border: 1.5px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  padding: 6px;
  color: #ffffff;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  min-width: 36px;
  min-height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
}

.control-btn.modern::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(45deg, transparent, rgba(255,255,255,0.1), transparent);
  transform: translateX(-100%);
  transition: transform 0.6s;
}

.control-btn.modern:hover::before {
  transform: translateX(100%);
}

.control-btn.modern:hover {
  background: rgba(217, 16, 34, 0.15);
  border-color: rgba(217, 16, 34, 0.4);
  transform: translateY(-2px);
  box-shadow: 
    0 8px 25px rgba(0, 0, 0, 0.3),
    0 0 20px rgba(217, 16, 34, 0.2);
}

.control-btn.modern.active {
  background: rgba(217, 16, 34, 0.25);
  border-color: #d91022;
  box-shadow: 
    0 0 20px rgba(217, 16, 34, 0.4),
    inset 0 0 20px rgba(217, 16, 34, 0.1);
}

.control-btn.modern svg {
  filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.3));
  transition: all 0.3s ease;
}

.control-btn.modern:hover svg {
  filter: drop-shadow(0 0 12px rgba(217, 16, 34, 0.6));
  transform: scale(1.1);
}

.control-btn:hover {
  background: var(--panel);
  border-color: #d91022;
  transform: translateY(-1px);
  filter: brightness(2) contrast(1.5);
  text-shadow: 0 0 4px rgba(255,255,255,1);
}

.control-btn.active {
  background: #d91022;
  color: white;
  border-color: #d91022;
}

.timer-display {
  font-size: 12px;
  color: #ffffff;
  margin-top: 4px;
  opacity: 0.9;
}

.timer-display.hidden {
  display: none;
}

/* Stats Section */
.stats-section {
  margin-bottom: 24px;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.stat-card {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px 12px;
  text-align: center;
  transition: all 0.2s ease;
}

.stat-card:hover {
  border-color: #d91022;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(217, 16, 34, 0.2);
}

.stat-icon {
  font-size: 24px;
  margin-bottom: 8px;
}

/* Make only the music icon white for better visibility */
.stat-card:nth-child(3) .stat-icon {
  filter: brightness(0) invert(1);
}

.stat-number {
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}

.stat-label {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.5px;
}

/* Recent Songs */
.recent-songs {
  margin-bottom: 24px;
}

.songs-list {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px;
  margin-top: 16px;
  max-height: 300px;
  overflow-y: auto;
}

.song-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}

.song-item:last-child {
  border-bottom: none;
}

.song-info {
  flex: 1;
}

.song-title {
  font-weight: 600;
  color: var(--text);
  margin: 0 0 4px 0;
  font-size: 14px;
}

/* ========= SHOWS STYLES ========= */

.shows-header {
  margin-bottom: 20px;
}

.search-container {
  background: var(--panel);
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 20px;
  border: 1px solid var(--line);
}

.search-box {
  display: flex;
  align-items: center;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 15px;
  position: relative;
}

.search-icon {
  color: var(--muted);
  margin-right: 12px;
  flex-shrink: 0;
}

.search-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--text);
  font-size: 16px;
}

.search-input::placeholder {
  color: var(--muted);
}

.clear-search {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 20px;
  padding: 4px 8px;
  border-radius: 4px;
  margin-left: 8px;
}

.clear-search:hover {
  background: var(--panel-2);
  color: var(--text);
}

.clear-search.hidden {
  display: none;
}

.search-filters {
  display: flex;
  gap: 12px;
}

.filter-select {
  flex: 1;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 12px;
  color: var(--text);
  font-size: 14px;
}

.shows-tabs {
  display: flex;
  background: var(--panel);
  border-radius: 10px;
  padding: 4px;
  margin-bottom: 24px;
  border: 1px solid var(--line);
}

.shows-tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: none;
  border: none;
  color: var(--muted);
  padding: 12px 16px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 14px;
  font-weight: 500;
}

.shows-tab.active {
  background: #d91022;
  color: white;
}

.shows-tab:hover:not(.active) {
  background: var(--panel-2);
  color: var(--text);
}

.shows-content {
  display: none;
}

.shows-content.active {
  display: block;
}

.content-section {
  margin-bottom: 32px;
}

.content-title {
  color: var(--text);
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 16px;
  padding-left: 4px;
}

.shows-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.show-card {
  background: var(--panel);
  border-radius: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}

.show-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.3);
  border-color: #d91022;
}

.show-thumbnail {
  width: 100%;
  height: 120px;
  background: linear-gradient(45deg, #d91022, #b8001d);
  border-radius: 8px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.show-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.play-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(0,0,0,0.7);
  color: white;
  border: none;
  border-radius: 50%;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.2s ease;
  font-size: 18px;
}

.show-card:hover .play-overlay {
  opacity: 1;
}

.show-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.show-title {
  color: var(--text);
  font-weight: 600;
  font-size: 14px;
  margin: 0;
  line-height: 1.3;
}

.show-description {
  color: var(--muted);
  font-size: 12px;
  margin: 0;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.show-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 8px;
  font-size: 11px;
  color: var(--muted);
}

.show-station {
  display: flex;
  align-items: center;
  gap: 4px;
}

.station-icon {
  width: 16px;
  height: 16px;
  border-radius: 2px;
}

.show-duration {
  background: var(--bg);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 10px;
}

.station-section {
  margin-bottom: 32px;
}

.station-podcast-title {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--text);
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 16px;
  padding-left: 4px;
}

.podcasts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.search-results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

.results-count {
  color: var(--muted);
  font-size: 14px;
}

.song-artist {
  color: var(--muted);
  margin: 0;
  font-size: 12px;
}

.song-time {
  color: var(--muted);
  font-size: 11px;
  white-space: nowrap;
}

.song-station {
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  margin-left: 8px;
}

.song-station.power {
  background: rgba(217, 16, 34, 0.2);
  color: #d91022;
}

.song-station.capricorn {
  background: rgba(59, 130, 246, 0.2);
  color: #3b82f6;
}

.empty-state {
  text-align: center;
  color: var(--muted);
  padding: 32px 16px;
}

.empty-state p {
  margin: 0;
  font-size: 14px;
}

/* Sleep Timer Modal */
.sleep-option {
  padding: 8px 16px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 14px;
  font-weight: 600;
}

.sleep-option:hover {
  background: #d91022;
  color: white;
  border-color: #d91022;
}

.app-footer{text-align:center;padding:16px 20px 8px;color:var(--muted);font-size:11px}