/* ============================================================
   RADIO HIDAYAH — Stylesheet v2
   Light Mode (default) + Dark Mode toggle
   ============================================================ */

/* ---- Light Mode Variables (DEFAULT) ---- */
:root {
  --green:       #3DB800;
  --green-dark:  #2A8000;
  --green-glow:  rgba(61,184,0,0.28);
  --green-bg:    rgba(61,184,0,0.08);
  --green-bg2:   rgba(61,184,0,0.14);

  --bg:          #F4F7F4;
  --bg2:         #E8EEE8;
  --card:        #FFFFFF;
  --card2:       #F0F5F0;
  --border:      rgba(0,0,0,0.09);
  --border-g:    rgba(61,184,0,0.22);

  --text:        #1A1A1A;
  --text2:       #4A4A4A;
  --text3:       #999999;
  --white:       #FFFFFF;

  --player-grad:  linear-gradient(145deg,#cde8b0 0%,#e4f5d0 50%,#f5fbee 100%);
  --player-glow:  radial-gradient(ellipse at 30% 10%,rgba(61,184,0,.14) 0%,transparent 65%);
  --header-bg:    rgba(255,255,255,0.95);
  --nav-bg:       rgba(255,255,255,0.97);
  --nav-border:   rgba(61,184,0,0.18);
  --shadow-sm:    0 2px 12px rgba(0,0,0,.07);
  --shadow-card:  0 4px 20px rgba(0,0,0,.08);
  --shadow-play:  0 4px 22px rgba(61,184,0,.4);
  --logo-bg:      #FFFFFF;

  --nav-h:    64px;
  --hdr-h:    56px;
  --radius:   16px;
  --radius-sm:10px;
}

/* ---- Dark Mode Variables ---- */
[data-theme="dark"] {
  --bg:          #0D0D0D;
  --bg2:         #141414;
  --card:        #1C1C1C;
  --card2:       #242424;
  --border:      rgba(255,255,255,.07);
  --border-g:    rgba(61,184,0,.18);

  --text:        #F0F0F0;
  --text2:       #A0A0A0;
  --text3:       #6A6A6A;

  --player-grad:  linear-gradient(145deg,#1a2a0a 0%,#0f1f05 40%,#0D0D0D 100%);
  --player-glow:  radial-gradient(ellipse at 30% 0%,rgba(61,184,0,.12) 0%,transparent 65%);
  --header-bg:    rgba(13,13,13,.93);
  --nav-bg:       rgba(20,20,20,.96);
  --nav-border:   rgba(61,184,0,.15);
  --shadow-sm:    0 2px 12px rgba(0,0,0,.4);
  --shadow-card:  0 8px 40px rgba(0,0,0,.55);
  --shadow-play:  0 0 28px rgba(61,184,0,.35);
  --logo-bg:      #FFFFFF;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Poppins','Tajawal',sans-serif;
  background:var(--bg);color:var(--text);
  min-height:100vh;overflow-x:hidden;
  padding-bottom:var(--nav-h);
  transition:background .25s,color .25s;
}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;border:none;background:none;}
img{max-width:100%;display:block;}

/* ============================================================ HEADER */
.app-header{
  position:sticky;top:0;z-index:100;
  background:var(--header-bg);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border-g);
  height:var(--hdr-h);box-shadow:var(--shadow-sm);
  transition:background .25s;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:100%;}
.header-logo{
  height:34px;width:auto;object-fit:contain;
  background:var(--logo-bg);border-radius:8px;padding:4px 8px;
}
.header-right{display:flex;align-items:center;gap:10px;}

.theme-toggle{
  width:36px;height:36px;border-radius:50%;
  background:var(--card2);border:1px solid var(--border-g);
  font-size:17px;display:flex;align-items:center;justify-content:center;
  transition:all .2s;-webkit-tap-highlight-color:transparent;
}
.theme-toggle:active{transform:scale(.9);}

.on-air-badge{
  display:flex;align-items:center;gap:6px;
  background:var(--green-bg);border:1px solid var(--green);
  color:var(--green);font-size:11px;font-weight:700;letter-spacing:1.5px;
  padding:0;border-width:0;border-radius:20px;
  max-width:0;overflow:hidden;opacity:0;
  transition:opacity .4s, max-width .4s, padding .4s, border-width .4s;
  white-space:nowrap;
}
.on-air-badge.visible{
  opacity:1;max-width:120px;padding:4px 10px;border-width:1px;
}
.on-air-badge .dot{
  width:7px;height:7px;background:var(--green);border-radius:50%;
  animation:pulse 1.2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(1.4);}}

/* ============================================================ SECTIONS */
.section{padding:20px 16px 28px;border-bottom:1px solid var(--border);}
.section-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.section-icon{font-size:28px;}
.section-title{font-size:18px;font-weight:700;color:var(--text);line-height:1.2;}
.section-sub{font-size:12px;color:var(--text2);margin-top:2px;}

/* ============================================================ PLAYER */
.section-player{padding:16px;background:var(--bg);}

.player-card{
  position:relative;background:var(--player-grad);
  border:1px solid var(--border-g);border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow-card);transition:background .25s;
}
.player-bg-blur{position:absolute;inset:0;background:var(--player-glow);pointer-events:none;}
.player-content{
  position:relative;padding:24px 20px 20px;
  display:flex;flex-direction:column;align-items:center;gap:20px;
}
.player-radio-info{display:flex;align-items:center;gap:16px;width:100%;}
.radio-logo-wrap{position:relative;width:72px;height:72px;flex-shrink:0;}
.radio-logo-img{
  width:72px;height:72px;object-fit:contain;border-radius:14px;
  background:#FFFFFF;padding:6px;position:relative;z-index:2;border:1px solid rgba(0,0,0,0.08);
}
.radio-ring{
  position:absolute;border-radius:50%;border:1.5px solid var(--green);
  top:50%;left:50%;transform:translate(-50%,-50%) scale(1);opacity:0;
}
.radio-ring.ring1{width:90px;height:90px;}
.radio-ring.ring2{width:110px;height:110px;}
.radio-ring.ring3{width:130px;height:130px;}
body.playing .radio-ring.ring1{animation:ringPulse 2s ease-out infinite 0s;}
body.playing .radio-ring.ring2{animation:ringPulse 2s ease-out infinite .5s;}
body.playing .radio-ring.ring3{animation:ringPulse 2s ease-out infinite 1s;}
@keyframes ringPulse{0%{opacity:.5;transform:translate(-50%,-50%) scale(.8);}100%{opacity:0;transform:translate(-50%,-50%) scale(1.4);}}

.radio-text{flex:1;min-width:0;}
.radio-name{font-size:20px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.radio-freq{font-size:11px;color:var(--green);letter-spacing:.5px;margin-top:2px;}
.radio-now{font-size:12px;color:var(--text2);margin-top:4px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;max-width:220px;white-space:normal;}

/* Waveform */
.waveform{display:flex;align-items:center;justify-content:center;gap:3px;height:40px;width:100%;}
.waveform .bar{width:3px;border-radius:2px;background:var(--green);height:4px;}
body.playing .waveform .bar:nth-child(1) {animation:wave 1.0s ease-in-out infinite .00s;}
body.playing .waveform .bar:nth-child(2) {animation:wave 1.1s ease-in-out infinite .10s;}
body.playing .waveform .bar:nth-child(3) {animation:wave 0.9s ease-in-out infinite .20s;}
body.playing .waveform .bar:nth-child(4) {animation:wave 1.2s ease-in-out infinite .30s;}
body.playing .waveform .bar:nth-child(5) {animation:wave 1.0s ease-in-out infinite .40s;}
body.playing .waveform .bar:nth-child(6) {animation:wave 0.8s ease-in-out infinite .10s;}
body.playing .waveform .bar:nth-child(7) {animation:wave 1.3s ease-in-out infinite .20s;}
body.playing .waveform .bar:nth-child(8) {animation:wave 1.0s ease-in-out infinite .30s;}
body.playing .waveform .bar:nth-child(9) {animation:wave 0.9s ease-in-out infinite .00s;}
body.playing .waveform .bar:nth-child(10){animation:wave 1.1s ease-in-out infinite .40s;}
body.playing .waveform .bar:nth-child(11){animation:wave 1.0s ease-in-out infinite .15s;}
body.playing .waveform .bar:nth-child(12){animation:wave .85s ease-in-out infinite .25s;}
body.playing .waveform .bar:nth-child(13){animation:wave 1.2s ease-in-out infinite .35s;}
body.playing .waveform .bar:nth-child(14){animation:wave 1.0s ease-in-out infinite .05s;}
body.playing .waveform .bar:nth-child(15){animation:wave .95s ease-in-out infinite .45s;}
body.playing .waveform .bar:nth-child(16){animation:wave 1.1s ease-in-out infinite .10s;}
body.playing .waveform .bar:nth-child(17){animation:wave 0.9s ease-in-out infinite .20s;}
body.playing .waveform .bar:nth-child(18){animation:wave 1.15s ease-in-out infinite .30s;}
body.playing .waveform .bar:nth-child(19){animation:wave 1.0s ease-in-out infinite .40s;}
body.playing .waveform .bar:nth-child(20){animation:wave 0.8s ease-in-out infinite .05s;}
@keyframes wave{0%,100%{height:4px;opacity:.4;}50%{height:32px;opacity:1;}}

/* Controls */
.player-controls{display:flex;align-items:center;justify-content:center;gap:28px;}
.ctrl-btn{
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--card);border:1px solid var(--border-g);
  box-shadow:var(--shadow-sm);transition:all .2s;-webkit-tap-highlight-color:transparent;
}
.ctrl-btn svg{width:22px;height:22px;fill:var(--text2);}
.ctrl-btn:active{transform:scale(.92);}
.play-btn{
  width:72px;height:72px;background:var(--green);border:none;
  box-shadow:var(--shadow-play);position:relative;overflow:hidden;transition:all .2s;
}
.play-btn svg{width:34px;height:34px;fill:#fff;}
.play-btn:active{transform:scale(.94);}
.play-btn.loading{animation:spinGlow 1s linear infinite;}
@keyframes spinGlow{0%,100%{box-shadow:0 4px 22px rgba(61,184,0,.4);}50%{box-shadow:0 4px 42px rgba(61,184,0,.7);}}
.play-ripple{position:absolute;inset:0;border-radius:50%;background:rgba(255,255,255,.2);transform:scale(0);opacity:0;}
.play-btn:active .play-ripple{animation:ripple .4s ease-out;}
@keyframes ripple{from{transform:scale(0);opacity:1;}to{transform:scale(2);opacity:0;}}

/* Volume */
.volume-wrap{display:flex;align-items:center;gap:10px;width:100%;}
.vol-icon{width:18px;height:18px;fill:var(--text3);flex-shrink:0;}
.vol-slider{
  flex:1;-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;outline:none;
  background:linear-gradient(to right,var(--green) 80%,var(--bg2) 80%);
}
.vol-slider::-webkit-slider-thumb{
  -webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--green);box-shadow:0 0 8px rgba(61,184,0,.4);cursor:pointer;
}
.status-bar{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text3);flex-shrink:0;}
.status-dot.connecting{background:#f0a500;animation:pulse 1s infinite;}
.status-dot.playing{background:var(--green);animation:pulse 1.5s infinite;}
.status-dot.error{background:#e74c3c;}

/* ============================================================ SKELETONS */
@keyframes shimmer{from{background-position:-200% 0;}to{background-position:200% 0;}}
.skeleton-card,.skeleton-kajian,.skeleton-nasehat{
  background:var(--card2);border-radius:var(--radius);
  background-image:linear-gradient(90deg,var(--card2) 0%,var(--bg2) 50%,var(--card2) 100%);
  background-size:200% 100%;animation:shimmer 1.5s infinite linear;
}
.skeleton-card{height:100px;margin-bottom:10px;}
.skeleton-kajian{height:280px;width:220px;flex-shrink:0;}
.skeleton-nasehat{height:340px;width:100%;margin-bottom:16px;}

/* ============================================================ JADWAL SIARAN */
.section-jadwal{background:var(--bg2);}
.jadwal-list{display:flex;flex-direction:column;gap:10px;}
.jadwal-card{
  background:var(--card);border:1px solid var(--border-g);
  border-radius:var(--radius);padding:14px 16px;
  position:relative;overflow:hidden;box-shadow:var(--shadow-sm);
}
.jadwal-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--green);border-radius:4px 0 0 4px;}
.jadwal-time{font-size:13px;font-weight:600;color:var(--green);margin-bottom:6px;}
.jadwal-program{font-size:15px;font-weight:600;color:var(--text);margin-bottom:4px;}
.jadwal-pemateri{font-size:12px;color:var(--text2);margin-bottom:3px;}
.jadwal-tema{font-size:12px;color:var(--text3);font-style:italic;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px;}
.card-actions-stack{margin-top:10px;margin-bottom:10px;}
.alarm-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:9px 12px;border-radius:10px;
  background:var(--green-bg);border:1px solid var(--border-g);
  color:var(--green-dark);font-size:12px;font-weight:700;
  font-family:'Poppins',sans-serif;
}
[data-theme="dark"] .alarm-btn{color:#9be85d;}
.alarm-btn:active,.alarm-btn:hover{background:var(--green-bg2);}
.share-btn,
.nasehat-link-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:9px 12px;border-radius:10px;border:1px solid var(--border-g);
  font-size:12px;font-weight:700;font-family:'Poppins',sans-serif;text-decoration:none;
}
.share-btn{background:var(--card);color:var(--text);}
.share-btn:active,.share-btn:hover{background:var(--bg2);}

/* ============================================================ KAJIAN */
.kajian-tabs{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;padding-bottom:2px;}
.kajian-tabs::-webkit-scrollbar{display:none;}
.ktab{
  flex-shrink:0;padding:8px 18px;border-radius:20px;
  border:1px solid var(--border-g);color:var(--text2);
  font-size:13px;font-weight:500;font-family:'Poppins',sans-serif;
  background:var(--card);transition:all .2s;-webkit-tap-highlight-color:transparent;
}
.ktab.active{background:var(--green);border-color:var(--green);color:#fff;font-weight:600;}
.kajian-panel{display:none;}
.kajian-panel.active{display:block;}
.panel-title{
  font-size:14px;font-weight:600;color:var(--green);margin-bottom:14px;
  padding:10px 14px;background:var(--green-bg);border-radius:var(--radius-sm);border-left:3px solid var(--green);
}
.kajian-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch;}
.kajian-scroll::-webkit-scrollbar{height:3px;}
.kajian-scroll::-webkit-scrollbar-thumb{background:var(--green);border-radius:2px;}
.kajian-card{flex-shrink:0;width:220px;background:var(--card);border:1px solid var(--border-g);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.kajian-poster{width:100%;aspect-ratio:4/5;max-height:260px;object-fit:cover;background:var(--card2);display:block;}
.kajian-poster-placeholder{
  width:100%;aspect-ratio:4/5;max-height:260px;
  background:linear-gradient(135deg,var(--card2),var(--bg));
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text3);font-size:12px;
}
.kajian-poster-placeholder span{font-size:40px;}
.kajian-body{padding:12px;}
.kajian-jenis{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--green);font-weight:700;margin-bottom:6px;background:var(--green-bg);display:inline-block;padding:2px 8px;border-radius:20px;}
.kajian-waktu{font-size:12px;color:var(--text2);margin-bottom:5px;display:flex;align-items:flex-start;gap:5px;}
.kajian-waktu::before{content:'🕐';font-size:11px;}
.kajian-pemateri{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;display:flex;align-items:flex-start;gap:5px;}
.kajian-pemateri::before{content:'🎤';font-size:11px;}
.kajian-penerjemah{font-size:12px;color:var(--text2);margin-bottom:4px;display:flex;align-items:flex-start;gap:5px;}
.kajian-penerjemah::before{content:'🗣️';font-size:11px;}
.kajian-tema{font-size:12px;color:var(--text2);margin-bottom:6px;font-style:italic;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.kajian-masjid{font-size:12px;color:var(--text);font-weight:700;margin-bottom:5px;display:flex;align-items:flex-start;gap:4px;white-space:normal;word-break:break-word;}
.kajian-masjid::before{content:'🕌';font-size:10px;}
.kajian-lokasi{font-size:11px;color:var(--text3);display:flex;align-items:flex-start;gap:4px;margin-bottom:8px;white-space:normal;word-break:break-word;}
.kajian-lokasi::before{content:'📍';font-size:10px;}
.kajian-maps{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--green);color:#fff;font-size:12px;font-weight:600;padding:8px;border-radius:8px;text-decoration:none;-webkit-tap-highlight-color:transparent;}
.kajian-maps:active{opacity:.85;}

/* ============================================================ NASEHAT */
.nasehat-container{width:100%;}
.nasehat-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch;}
.nasehat-scroll::-webkit-scrollbar{height:3px;}
.nasehat-scroll::-webkit-scrollbar-thumb{background:var(--green);border-radius:2px;}
.nasehat-card{flex-shrink:0;width:220px;background:var(--card);border:1px solid var(--border-g);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.nasehat-img-wrap{width:100%;aspect-ratio:4/5;overflow:hidden;background:var(--card2);}
.nasehat-img{width:100%;height:100%;object-fit:cover;display:block;}
.nasehat-img-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text3);}
.nasehat-img-placeholder span{font-size:60px;}
.nasehat-body{padding:16px;}
.nasehat-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:8px;}
.nasehat-text{font-size:14px;color:var(--text2);line-height:1.7;white-space:pre-line;margin-bottom:0;}
.nasehat-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-top:14px;}
.nasehat-link-btn{background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);padding:10px 16px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;}
.nasehat-link-btn:active,.nasehat-link-btn:hover{background:var(--green-dark);}
.nasehat-dots{display:none;}
.ndot{display:none;}

/* ============================================================ CARI KAJIAN BTN */
.cari-kajian-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:14px;padding:11px 20px;background:var(--card);border:1.5px solid var(--green);border-radius:var(--radius-sm);color:var(--green);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .2s;text-decoration:none;box-sizing:border-box;}
.cari-kajian-btn:active,.cari-kajian-btn:hover{background:var(--green);color:#fff;}

/* ============================================================ IN-APP BROWSER */
.inapp-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:10000;display:flex;flex-direction:column;justify-content:flex-end;animation:fadeIn .2s ease;}
.inapp-sheet{display:flex;flex-direction:column;background:var(--bg);border-radius:20px 20px 0 0;height:90vh;overflow:hidden;animation:slideUp .3s ease;}
.inapp-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--card);border-bottom:1px solid var(--border-g);min-height:52px;}
.inapp-close{width:36px;height:36px;border-radius:50%;background:var(--bg2);border:none;color:var(--text);font-size:18px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;}
.inapp-title{flex:1;font-size:13px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.inapp-external{width:36px;height:36px;border-radius:50%;background:var(--bg2);display:flex;align-items:center;justify-content:center;color:var(--green);font-size:18px;flex-shrink:0;text-decoration:none;}
.inapp-frame{flex:1;width:100%;border:none;background:#fff;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ============================================================ INFO RADIO */
.section-info{padding:20px 16px 36px;}
.info-card{background:var(--card);border:1px solid var(--border-g);border-radius:24px;padding:28px 20px;text-align:center;box-shadow:var(--shadow-card);}
.info-logo{width:120px;margin:0 auto 16px;border-radius:12px;background:#FFFFFF;padding:8px;border:1px solid rgba(0,0,0,0.08);}
.info-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:8px;}
.info-desc{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:20px;}
.info-divider{height:1px;background:var(--border-g);margin:20px 0;}
.info-sub{font-size:14px;font-weight:600;color:var(--green);margin-bottom:14px;}
.info-links{display:flex;flex-direction:column;gap:10px;text-align:left;}
.info-btn{display:flex;align-items:center;gap:12px;background:var(--bg2);border:1px solid var(--border-g);border-radius:var(--radius-sm);padding:12px 16px;font-size:14px;color:var(--text);transition:all .2s;-webkit-tap-highlight-color:transparent;}
.info-btn:active,.info-btn:hover{background:var(--green-bg2);border-color:var(--green);}
.info-btn-icon{font-size:20px;}
.info-btn-arr{margin-left:auto;color:var(--text3);font-size:18px;}
.info-footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-g);font-size:11px;color:var(--text3);}
.info-footer code{display:block;margin-top:6px;background:var(--bg2);padding:8px 12px;border-radius:8px;font-size:11px;color:var(--green);word-break:break-all;}

/* ============================================================ BOTTOM NAV */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);
  background:var(--nav-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid var(--nav-border);display:flex;z-index:100;
  box-shadow:0 -2px 12px rgba(0,0,0,.06);
}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text3);font-size:10px;font-weight:500;transition:color .2s;-webkit-tap-highlight-color:transparent;}
.nav-item svg{width:22px;height:22px;fill:currentColor;}
.nav-item.active{color:var(--green);}
.nav-item span{font-family:'Poppins',sans-serif;}

/* ============================================================ MISC */
.empty-state,.empty-kajian{text-align:center;color:var(--text3);padding:28px 16px;font-size:13px;}
.install-prompt{position:fixed;bottom:calc(var(--nav-h)+12px);left:16px;right:16px;background:var(--card);border:1px solid var(--green);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-card);z-index:99;animation:slideUp .4s ease;}
@keyframes slideUp{from{transform:translateY(100%);opacity:0;}to{transform:translateY(0);opacity:1;}}
.install-prompt p{flex:1;font-size:13px;color:var(--text);}
.install-prompt p strong{color:var(--green);}
.install-btn{background:var(--green);color:#fff;font-size:13px;font-weight:600;padding:8px 14px;border-radius:8px;font-family:'Poppins',sans-serif;}
.install-close{color:var(--text3);font-size:20px;padding:4px;}

.reminder-sheet-overlay{
  position:fixed;inset:0;z-index:150;
  background:rgba(0,0,0,.56);
  display:flex;align-items:flex-end;justify-content:center;
  padding:16px;
}
.reminder-sheet{
  width:min(100%, 440px);
  background:var(--card);
  border:1px solid var(--border-g);
  border-radius:24px;
  padding:18px 16px 16px;
  box-shadow:var(--shadow-card);
  animation:slideUp .24s ease;
}
.reminder-sheet-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px;}
.reminder-sheet-kicker{font-size:11px;font-weight:700;letter-spacing:.8px;color:var(--green);text-transform:uppercase;margin-bottom:4px;}
.reminder-sheet h3{font-size:18px;line-height:1.3;color:var(--text);}
.reminder-sheet-meta{font-size:12px;color:var(--text2);margin-top:4px;}
.reminder-close-btn{width:36px;height:36px;border-radius:50%;background:var(--bg2);color:var(--text2);font-size:22px;line-height:1;}
.reminder-sheet-info{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:14px;}
.reminder-choice-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
.reminder-choice{
  padding:12px 10px;border-radius:12px;background:var(--bg2);
  border:1px solid var(--border-g);color:var(--text);
  font-size:13px;font-weight:600;font-family:'Poppins',sans-serif;
}
.reminder-custom-block{background:var(--bg2);border:1px solid var(--border-g);border-radius:14px;padding:12px;}
.reminder-custom-block label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px;}
.reminder-input-row{display:flex;gap:10px;align-items:center;}
.reminder-input-row input{
  flex:1;min-width:0;padding:11px 12px;border-radius:10px;
  border:1px solid var(--border-g);background:var(--card);color:var(--text);
  font-family:'Poppins',sans-serif;font-size:14px;
}
.reminder-save-btn{
  flex-shrink:0;padding:11px 14px;border-radius:10px;
  background:var(--green);color:#fff;font-size:13px;font-weight:700;
  font-family:'Poppins',sans-serif;
}
.reminder-sheet-note{font-size:11px;color:var(--text3);line-height:1.6;margin-top:12px;}
.app-toast{
  position:fixed;left:50%;bottom:calc(var(--nav-h) + 18px);z-index:160;
  transform:translate(-50%, 120%);
  background:var(--card);color:var(--text);
  border:1px solid var(--border-g);border-radius:12px;
  padding:10px 14px;box-shadow:var(--shadow-card);
  font-size:12px;font-weight:600;opacity:0;transition:all .24s ease;
  width:min(calc(100% - 32px), 420px);text-align:center;
}
.app-toast.show{transform:translate(-50%, 0);opacity:1;}
.app-toast.success{color:var(--green-dark);}
.app-toast.error{color:#d84d43;border-color:rgba(216,77,67,.3);}
.app-toast.info{color:var(--text);}

@media(min-width:480px){
  .player-card{max-width:480px;margin:0 auto;}
  .kajian-card{width:260px;}
  .kajian-poster{max-height:340px;}
  .nasehat-card{width:260px;}
}

@media(max-width:420px){
  .reminder-choice-row{grid-template-columns:1fr;}
  .reminder-input-row{flex-direction:column;align-items:stretch;}
}

/* ============================================================
   KONTEN PAGE — Full-page overlay
   ============================================================ */
.konten-page{position:fixed;inset:0;background:var(--bg);z-index:5000;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow:hidden;}
.konten-page.open{transform:translateX(0);}
.konten-page-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--card);border-bottom:1px solid var(--border-g);min-height:56px;flex-shrink:0;}
.konten-back-btn{width:38px;height:38px;border-radius:50%;background:var(--bg2);border:none;color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;}
.konten-page-title{font-size:17px;font-weight:700;color:var(--text);margin:0;}

/* Search bar */
.konten-search-wrap{display:flex;gap:10px;padding:12px 16px;flex-shrink:0;}
.konten-search-bar{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg2);border:1px solid var(--border-g);border-radius:var(--radius-sm);padding:0 12px;height:42px;}
.konten-search-icon{color:var(--text3);flex-shrink:0;}
.konten-search-input{flex:1;border:none;background:transparent;font-size:14px;color:var(--text);outline:none;font-family:inherit;}
.konten-search-input::placeholder{color:var(--text3);}
.konten-filter-btn{display:flex;align-items:center;gap:6px;padding:0 14px;height:42px;background:var(--bg2);border:1px solid var(--border-g);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;font-family:inherit;}
.konten-filter-btn.active{background:var(--green);color:#fff;border-color:var(--green);}

/* Filter panel */
.konten-filter-panel{padding:0 16px 12px;flex-shrink:0;border-bottom:1px solid var(--border-g);}
.filter-group{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;}
.filter-label{font-size:12px;color:var(--text3);font-weight:600;white-space:nowrap;}
.filter-chip{padding:5px 12px;border-radius:20px;background:var(--bg2);border:1px solid var(--border-g);font-size:12px;color:var(--text2);cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;}
.filter-chip.active{background:var(--green);color:#fff;border-color:var(--green);}
.filter-tags{display:flex;flex-wrap:wrap;gap:6px;}

/* Scroll area */
.konten-scroll-area{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch;}
.konten-scroll-area::-webkit-scrollbar{width:3px;}
.konten-scroll-area::-webkit-scrollbar-thumb{background:var(--green);border-radius:2px;}
.konten-section-title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 10px;}

/* Netflix row */
.konten-row-wrap{margin-bottom:24px;}
.konten-row-label{font-size:14px;font-weight:700;color:var(--text);margin-bottom:10px;}
.konten-row-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;}
.konten-row-scroll::-webkit-scrollbar{height:3px;}
.konten-row-scroll::-webkit-scrollbar-thumb{background:var(--green);border-radius:2px;}

/* Konten card */
.konten-card{flex-shrink:0;width:140px;cursor:pointer;-webkit-tap-highlight-color:transparent;}
.konten-card-thumb{width:140px;height:105px;border-radius:10px;overflow:hidden;background:var(--card2);position:relative;margin-bottom:7px;}
.konten-card-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.konten-card-type{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.65);color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;}
.konten-card-duration{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.7);color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;}
.konten-card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px;background:var(--bg2);}
.konten-card-title{font-size:12px;font-weight:600;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.konten-card-tags{font-size:11px;color:var(--text3);margin-top:3px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}

/* Grid (search results) */
.konten-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.konten-grid .konten-card{width:100%;}
.konten-grid .konten-card-thumb{width:100%;height:auto;aspect-ratio:4/3;}

/* Load more */
.konten-load-more{text-align:center;margin-top:16px;}
.konten-load-more button{padding:10px 24px;background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;}

/* Skeleton */
.skeleton-konten{flex-shrink:0;width:140px;height:160px;border-radius:10px;background:var(--card2);animation:shimmer 1.5s infinite linear;background:linear-gradient(90deg,var(--card2) 25%,var(--bg2) 50%,var(--card2) 75%);background-size:200% 100%;}

/* ============================================================
   DETAIL KONTEN — Bottom Sheet
   ============================================================ */
.konten-detail-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:6000;display:flex;align-items:flex-end;}
.konten-detail-sheet{background:var(--bg);border-radius:20px 20px 0 0;width:100%;max-height:92vh;overflow-y:auto;animation:slideUp .3s ease;-webkit-overflow-scrolling:touch;}
.konten-detail-drag{width:40px;height:4px;background:var(--border-g);border-radius:2px;margin:12px auto 0;}
.konten-detail-media{width:100%;background:#000;position:relative;}
.konten-detail-media img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;}
.konten-detail-media-placeholder{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:60px;background:var(--card2);}
.konten-detail-body{padding:16px;}
.konten-detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;}
.konten-detail-tag{font-size:11px;padding:3px 9px;background:var(--bg2);border:1px solid var(--border-g);border-radius:20px;color:var(--text2);}
.konten-detail-title{font-size:17px;font-weight:700;color:var(--text);margin:0 0 6px;}
.konten-detail-meta{font-size:12px;color:var(--text3);margin:0 0 10px;}
.konten-detail-desc{font-size:13px;color:var(--text2);line-height:1.7;margin:0 0 16px;white-space:pre-line;}

/* Action buttons */
.konten-detail-actions{display:grid;grid-template-columns:2fr 1fr 1fr;gap:8px;margin-bottom:20px;}
.konten-action-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;background:var(--bg2);border:1px solid var(--border-g);border-radius:var(--radius-sm);color:var(--text);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;}
.konten-action-btn:active{background:var(--bg3,var(--border-g));}
.konten-action-play{background:var(--green);color:#fff;border-color:var(--green);}
.konten-action-play:active{background:var(--green-dark);}

/* Reaksi */
.konten-reaksi{display:flex;gap:8px;margin-bottom:20px;}
.reaksi-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 4px;background:var(--bg2);border:1px solid var(--border-g);border-radius:var(--radius-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;font-family:inherit;}
.reaksi-btn.active{background:rgba(61,184,0,.12);border-color:var(--green);}
.reaksi-emoji{font-size:22px;}
.reaksi-label{font-size:10px;color:var(--text2);font-weight:600;}
.reaksi-count{font-size:13px;font-weight:700;color:var(--text);}

/* Rating */
.konten-rating-wrap{border-top:1px solid var(--border-g);padding-top:16px;}
.rating-summary{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.rating-avg{font-size:36px;font-weight:700;color:var(--text);line-height:1;}
.rating-stars-display{display:flex;gap:2px;}
.rating-stars-display .star-d{font-size:20px;color:#F5C518;}
.rating-total{font-size:12px;color:var(--text3);}
.rating-prompt{font-size:13px;color:var(--text2);margin:0 0 8px;font-weight:600;}
.star-picker{display:flex;gap:6px;}
.star-picker .star{font-size:32px;color:var(--border-g);cursor:pointer;transition:color .15s;-webkit-tap-highlight-color:transparent;}
.star-picker .star.lit{color:#F5C518;}

/* Nama modal */
.nama-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:7000;display:flex;align-items:center;justify-content:center;padding:24px;}
.nama-modal{background:var(--card);border-radius:16px;padding:24px;width:100%;max-width:340px;}
.nama-modal h3{font-size:16px;font-weight:700;color:var(--text);margin:0 0 6px;}
.nama-modal p{font-size:13px;color:var(--text2);margin:0 0 16px;}
.nama-modal-input{width:100%;padding:11px 14px;border:1px solid var(--border-g);border-radius:var(--radius-sm);background:var(--bg2);color:var(--text);font-size:15px;font-family:inherit;box-sizing:border-box;outline:none;}
.nama-modal-input:focus{border-color:var(--green);}
.nama-modal-actions{display:flex;gap:8px;margin-top:14px;}
.nama-modal-btn{flex:1;padding:11px;background:var(--green);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;}
.nama-modal-cancel{padding:11px 16px;background:var(--bg2);border:1px solid var(--border-g);border-radius:var(--radius-sm);color:var(--text2);font-size:14px;cursor:pointer;font-family:inherit;}

/* Video modal */
.video-modal-overlay{position:fixed;inset:0;background:#000;z-index:8000;display:flex;align-items:center;justify-content:center;}
.video-modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.2);border:none;color:#fff;font-size:20px;cursor:pointer;z-index:1;}
.video-modal-player{width:100%;max-height:100vh;}

/* ============================================================
   MINI PLAYER
   ============================================================ */
.mini-player{position:fixed;bottom:calc(var(--nav-h,64px) + 6px);left:8px;right:8px;background:var(--card);border:1px solid var(--border-g);border-radius:14px;display:flex;align-items:center;gap:10px;padding:8px 12px;box-shadow:0 4px 20px rgba(0,0,0,.15);z-index:4500;animation:slideUp .3s ease;}
.mini-thumb{width:40px;height:40px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:20px;}
.mini-thumb img{width:100%;height:100%;object-fit:cover;}
.mini-info{flex:1;min-width:0;}
.mini-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mini-progress-wrap{height:3px;background:var(--border-g);border-radius:2px;margin-top:5px;}
.mini-progress{height:100%;background:var(--green);border-radius:2px;width:0%;transition:width .5s linear;}
.mini-btn{width:34px;height:34px;border-radius:50%;background:var(--bg2);border:none;color:var(--text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;}
.mini-close{font-size:14px;}

/* ============================================================
   CARI KAJIAN BUTTON (updated)
   ============================================================ */
.cari-kajian-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:14px;padding:11px 20px;background:var(--card);border:1.5px solid var(--green);border-radius:var(--radius-sm);color:var(--green);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .2s;box-sizing:border-box;}
.cari-kajian-btn:active,.cari-kajian-btn:hover{background:var(--green);color:#fff;}

@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ============================================================
   JADWAL CARD v2 — Live & Rekaman
   ============================================================ */
.jadwal-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;flex-wrap:wrap;gap:6px;}
.jadwal-live-badge{display:none;align-items:center;gap:5px;background:#dc2626;color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;letter-spacing:.3px;animation:pulseLive 1.5s infinite;}
.jadwal-live-badge .live-dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:none;}
.jadwal-tipe-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;margin-bottom:5px;}
.jadwal-tipe-badge.rekaman{background:rgba(99,102,241,.12);color:#6366f1;}
.jadwal-tipe-badge.studio{background:rgba(239,68,68,.12);color:#ef4444;}
.jadwal-tipe-badge.relay{background:rgba(16,185,129,.12);color:#10b981;}
.jadwal-tema{font-size:12px;color:var(--text3);font-style:italic;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-top:2px;}
.card-actions-jadwal{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:7px;margin-top:12px;}
.btn-download-rekaman{display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 10px;background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.3);border-radius:var(--radius-sm);color:#6366f1;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;}
.btn-download-rekaman:active{background:rgba(99,102,241,.2);}
.btn-tanya-ustadz{display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 10px;background:#25D366;border:none;border-radius:var(--radius-sm);color:#fff;font-size:12px;font-weight:700;text-decoration:none;-webkit-tap-highlight-color:transparent;}
.btn-tanya-ustadz:active{background:#128C7E;}

/* Live badge di header player */
.live-broadcast-badge{display:none;align-items:center;gap:5px;background:#dc2626;color:#fff;font-size:11px;font-weight:700;padding:5px 10px;border-radius:20px;animation:pulseLive 1.5s infinite;}
.live-broadcast-badge .live-dot,.live-dot{width:7px;height:7px;border-radius:50%;background:#fff;display:inline-block;}
@keyframes pulseLive{0%,100%{opacity:1}50%{opacity:.65}}

/* ============================================================
   TANYA USTADZ — Player Area Button
   ============================================================ */
.tanya-ustadz-player{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;margin-top:10px;padding:11px 20px;
  background:#25D366;border-radius:var(--radius-sm);
  color:#fff;font-size:14px;font-weight:700;
  text-decoration:none;box-sizing:border-box;
  -webkit-tap-highlight-color:transparent;transition:background .2s;
}
.tanya-ustadz-player:active{background:#128C7E;}

/* ============================================================
   PLAY BUTTON — Loading state visual
   ============================================================ */
#btnPlay.loading{
  position:relative;pointer-events:none;opacity:.85;
}
#btnPlay.loading::after{
  content:'';position:absolute;
  width:20px;height:20px;
  border:3px solid rgba(255,255,255,.4);
  border-top-color:#fff;
  border-radius:50%;
  animation:spinBtn .7s linear infinite;
}
@keyframes spinBtn{to{transform:rotate(360deg)}}
#btnPlay.loading svg{opacity:0;}

/* ============================================================
   NASEHAT — YouTube Card
   ============================================================ */
.nasehat-card-yt{width:280px;}
.nasehat-yt-wrap{width:100%;aspect-ratio:16/9;overflow:hidden;background:#000;border-radius:var(--radius) var(--radius) 0 0;}
.nasehat-yt-iframe{width:100%;height:100%;border:none;display:block;}
@media(min-width:480px){.nasehat-card-yt{width:300px;}}

/* ============================================================
   PLAYER BOTTOM ACTIONS
   ============================================================ */
.player-share-icon{
  position:absolute;top:12px;right:12px;
  width:34px;height:34px;border-radius:50%;
  background:var(--bg2);border:1px solid var(--border-g);
  color:var(--text2);font-size:15px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;-webkit-tap-highlight-color:transparent;
  transition:all .2s;z-index:2;font-family:inherit;
}
.player-share-icon:active{background:var(--green);color:#fff;border-color:var(--green);}

/* Live actions (Tanya + Call Ustadz) */
.live-actions-wrap{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;}
.tanya-ustadz-player,.call-ustadz-player{
  display:flex;align-items:center;justify-content:center;
  gap:7px;padding:13px 10px;
  border-radius:var(--radius-sm);
  color:#fff;font-size:13px;font-weight:700;
  text-decoration:none;text-align:center;
  -webkit-tap-highlight-color:transparent;
  transition:filter .2s;
  white-space:nowrap;
  box-sizing:border-box;
  min-height:52px;
}
.tanya-ustadz-player{background:#25D366;}
.tanya-ustadz-player:active{filter:brightness(.88);}
.call-ustadz-player{background:#128C7E;}
.call-ustadz-player:active{filter:brightness(.88);}

/* ============================================================
   JADWAL LIBUR
   ============================================================ */
.jadwal-libur{opacity:.85;}
.jadwal-libur-notice{display:flex;align-items:center;gap:6px;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:7px 10px;font-size:12px;color:#d97706;font-weight:600;margin-bottom:8px;}

/* Recurring reminder button */
.btn-recurring-reminder{display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 10px;background:var(--bg2);border:1px solid var(--border-g);border-radius:var(--radius-sm);color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;width:100%;}
.btn-recurring-reminder.active{background:rgba(61,184,0,.12);border-color:var(--green);color:var(--green);}

/* Off-air status dot */
.status-dot.offair{background:#9ca3af;}

/* ============================================================
   ============================================================
   RADIO HIDAYAH WEB — RESPONSIVE LAYER (PC / Tablet / Mobile)
   Mobile-first base di atas tetap utuh; di bawah ini penyesuaian
   untuk layar lebih besar + komponen baru (Rekaman YouTube).
   ============================================================
   ============================================================ */

/* ---- Komponen baru: defaultnya tersembunyi di mobile ---- */
.top-nav{display:none;}
.header-brand-text{display:none;}
.top-nav-cari{display:none;}
.site-footer{display:none;}
.section-header-link{display:none;}

/* Brand jadi link logo biasa di mobile */
.header-brand{display:flex;align-items:center;gap:10px;text-decoration:none;}

/* ============================================================ REKAMAN (YouTube) — base */
.rekaman-toolbar{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;}
.rekaman-search-bar{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border-g);border-radius:var(--radius-sm);padding:0 12px;height:44px;}
.rekaman-search-icon{fill:var(--text3);flex-shrink:0;}
.rekaman-search-input{flex:1;border:none;background:none;outline:none;font-family:inherit;font-size:14px;color:var(--text);height:100%;}
.rekaman-search-input::placeholder{color:var(--text3);}
.rekaman-filter-chips{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;}
.rekaman-filter-chips::-webkit-scrollbar{height:0;}
.rekaman-chip{flex-shrink:0;padding:7px 14px;border-radius:20px;background:var(--card2);border:1px solid var(--border);color:var(--text2);font-size:12.5px;font-weight:600;font-family:inherit;transition:all .2s;}
.rekaman-chip.active{background:rgba(61,184,0,.12);border-color:var(--green);color:var(--green);}

.rekaman-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.rekaman-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;cursor:pointer;display:flex;flex-direction:column;}
.rekaman-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);border-color:var(--border-g);}
.rekaman-thumb-wrap{position:relative;width:100%;aspect-ratio:16/9;background:var(--card2);overflow:hidden;}
.rekaman-thumb-wrap img{width:100%;height:100%;object-fit:cover;}
.rekaman-thumb-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.18);opacity:0;transition:opacity .2s;}
.rekaman-card:hover .rekaman-thumb-play{opacity:1;}
.rekaman-thumb-play svg{width:54px;height:54px;fill:#fff;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4));}
.rekaman-duration{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.8);color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:5px;}
.rekaman-badge{position:absolute;top:6px;left:6px;background:var(--green);color:#fff;font-size:10px;font-weight:700;letter-spacing:.5px;padding:3px 8px;border-radius:5px;}
.rekaman-body{padding:11px 12px 14px;display:flex;flex-direction:column;gap:5px;flex:1;}
.rekaman-title{font-size:13.5px;font-weight:600;color:var(--text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.rekaman-meta{font-size:11.5px;color:var(--text2);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
.rekaman-date{font-size:11px;color:var(--text3);margin-top:auto;}

.skeleton-rekaman{aspect-ratio:16/9;border-radius:var(--radius);background:linear-gradient(90deg,var(--card2) 25%,var(--bg2) 50%,var(--card2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;}

.rekaman-empty{grid-column:1/-1;text-align:center;padding:36px 16px;color:var(--text2);font-size:14px;}
.rekaman-empty small{display:block;margin-top:6px;color:var(--text3);font-size:12px;}

.rekaman-load-more{display:flex;justify-content:center;margin-top:18px;}
.rekaman-load-more button{padding:11px 24px;border-radius:22px;background:var(--card);border:1px solid var(--border-g);color:var(--green);font-weight:600;font-family:inherit;font-size:13px;transition:all .2s;}
.rekaman-load-more button:hover{background:var(--green);color:#fff;}

/* ============================================================ INFO KAJIAN — tampilan daftar (teks+peta kiri, poster kanan) */
.kajian-scroll{display:flex;flex-direction:column;gap:16px;overflow:visible;padding-bottom:0;}
.kajian-item{display:flex;gap:18px;background:var(--card);border:1px solid var(--border-g);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 18px;transition:box-shadow .2s;}
.kajian-item:hover{box-shadow:var(--shadow-card);}
.kajian-item-left{flex:1;min-width:0;display:flex;flex-direction:column;}
.kajian-item-right{width:240px;flex-shrink:0;}
.kajian-item-right .kajian-poster{width:100%;height:auto;aspect-ratio:4/5;max-height:none;border-radius:var(--radius-sm);object-fit:cover;background:var(--card2);border:1px solid var(--border);}
/* Ukuran teks lebih besar & nyaman dibaca */
.kajian-item .kajian-jenis{font-size:13.5px;padding:5px 13px;letter-spacing:.5px;margin-bottom:9px;border-radius:20px;}
.kajian-item .kajian-waktu{font-size:14.5px;margin-bottom:7px;}
.kajian-item .kajian-pemateri{font-size:17px;font-weight:700;margin-bottom:6px;}
.kajian-item .kajian-penerjemah{font-size:14px;margin-bottom:6px;}
.kajian-item .kajian-tema{-webkit-line-clamp:unset;display:block;overflow:visible;font-size:15.5px;font-style:normal;margin-bottom:10px;line-height:1.5;}
.kajian-item .kajian-masjid{font-size:14.5px;margin-bottom:5px;}
.kajian-item .kajian-lokasi{font-size:13px;}
.kajian-lokasi-wrap{margin:2px 0 4px;}
.kajian-maps-embed{margin:10px 0 8px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border-g);aspect-ratio:16/9;background:var(--card2);max-width:540px;}
.kajian-maps-embed iframe{width:100%;height:100%;border:0;display:block;}
.kajian-item .card-actions-kajian{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}
.kajian-item .kajian-maps{display:inline-flex;width:auto;align-self:flex-start;margin-top:2px;}
@media (max-width:640px){
  .kajian-item{flex-direction:column;gap:12px;padding:14px;}
  .kajian-item-right{width:100%;max-width:300px;align-self:center;order:-1;}
  .kajian-maps-embed{max-width:none;}
}
@media (min-width:1024px){
  .kajian-item-right{width:300px;}
}

/* ============================================================ JADWAL SHOLAT */
.sholat-card{background:var(--card);border:1px solid var(--border-g);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);}
.sholat-top{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:16px 18px;background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);color:#fff;}
.sholat-date-masehi{font-size:15px;font-weight:700;}
.sholat-date-hijri{font-size:12.5px;opacity:.9;margin-top:2px;}
.sholat-next{text-align:right;}
.sholat-next-label{display:block;font-size:11.5px;opacity:.92;}
.sholat-next-label b{font-weight:700;}
.sholat-countdown{display:block;font-size:24px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:1px;line-height:1.15;}

.sholat-times{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px;}
.sholat-time{display:flex;flex-direction:column;align-items:center;gap:3px;padding:11px 6px;border-radius:var(--radius-sm);background:var(--card2);border:1px solid var(--border);transition:all .2s;}
.sholat-time.active{background:var(--green-bg2);border-color:var(--green);box-shadow:0 0 0 1px var(--green) inset;}
.sholat-time-icon{font-size:18px;}
.sholat-time-name{font-size:11.5px;color:var(--text2);font-weight:600;}
.sholat-time.active .sholat-time-name{color:var(--green-dark);}
.sholat-time-val{font-size:15px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums;}
.sholat-time.active .sholat-time-val{color:var(--green-dark);}
.sholat-note{font-size:11px;color:var(--text3);padding:0 16px 14px;text-align:center;}
.sholat-error{grid-column:1/-1;text-align:center;color:var(--text2);font-size:13px;padding:18px;}
.sholat-skeleton{height:64px;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--card2) 25%,var(--bg2) 50%,var(--card2) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;}

/* ============================================================ YOUTUBE MODAL */
.yt-modal-overlay{position:fixed;inset:0;z-index:6000;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease;}
.yt-modal-box{width:100%;max-width:900px;background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5);position:relative;}
.yt-modal-close{position:absolute;top:10px;right:10px;z-index:3;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;}
.yt-modal-frame{width:100%;aspect-ratio:16/9;background:#000;}
.yt-modal-frame iframe{width:100%;height:100%;border:0;display:block;}
.yt-modal-info{padding:16px 18px 20px;}
.yt-modal-info h3{font-size:16px;font-weight:700;color:var(--text);line-height:1.35;}
.yt-modal-info p{font-size:13px;color:var(--text2);margin-top:6px;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}

/* ============================================================ FOOTER */
.site-footer{background:var(--card);border-top:1px solid var(--border-g);margin-top:8px;}
.site-footer-inner{max-width:1200px;margin:0 auto;padding:28px 24px;display:flex;flex-wrap:wrap;align-items:center;gap:18px 32px;}
.footer-brand{display:flex;align-items:center;gap:12px;}
.footer-brand img{height:42px;width:auto;background:var(--logo-bg);border-radius:8px;padding:4px 8px;}
.footer-brand strong{display:block;font-size:14px;color:var(--text);}
.footer-brand span{font-size:12px;color:var(--text2);}
.footer-links,.footer-social{display:flex;gap:18px;flex-wrap:wrap;}
.footer-links a,.footer-social a{font-size:13px;color:var(--text2);transition:color .2s;}
.footer-links a:hover,.footer-social a:hover{color:var(--green);}
.footer-copy{flex-basis:100%;font-size:11.5px;color:var(--text3);border-top:1px solid var(--border);padding-top:16px;margin-top:4px;line-height:1.5;}

/* ============================================================
   TABLET ≥ 640px
   ============================================================ */
@media (min-width:640px){
  .rekaman-grid{grid-template-columns:repeat(3,1fr);}
  .rekaman-toolbar{flex-direction:row;align-items:center;justify-content:space-between;}
  .rekaman-search-bar{flex:1;max-width:380px;}
  .konten-grid{grid-template-columns:repeat(3,1fr);}
  .sholat-times{grid-template-columns:repeat(5,1fr);}
  .sholat-countdown{font-size:28px;}
}

/* ============================================================
   DESKTOP ≥ 1024px
   ============================================================ */
@media (min-width:1024px){
  :root{--hdr-h:64px;}
  body.web{padding-bottom:0;}

  /* Header dengan top-nav */
  .header-inner{max-width:1280px;margin:0 auto;padding:0 28px;gap:20px;}
  .header-logo{height:40px;}
  .header-brand-text{display:flex;flex-direction:column;line-height:1.1;font-weight:700;font-size:16px;color:var(--text);}
  .header-brand-text small{font-size:10.5px;font-weight:500;color:var(--green);letter-spacing:.5px;}

  .top-nav{display:flex;align-items:center;gap:4px;margin-left:8px;flex:1;}
  .top-nav-item{padding:8px 14px;border-radius:10px;font-size:14px;font-weight:600;color:var(--text2);transition:all .18s;position:relative;}
  .top-nav-item:hover{color:var(--text);background:var(--card2);}
  .top-nav-item.active{color:var(--green);background:var(--green-bg);}
  .top-nav-cari{display:inline-flex;align-items:center;gap:6px;margin-left:auto;padding:9px 18px;border-radius:22px;background:var(--green);color:#fff;font-size:13.5px;font-weight:600;font-family:inherit;transition:filter .2s;}
  .top-nav-cari:hover{filter:brightness(1.06);}

  /* Sembunyikan bottom-nav & tombol cari mobile */
  .bottom-nav{display:none;}
  .cari-kajian-btn{display:none;}
  #navKonten{display:none;}

  /* Container utama */
  .site-main{max-width:1200px;margin:0 auto;width:100%;}
  .section{padding:34px 28px;border-bottom:none;}
  .section-title{font-size:24px;}
  .section-sub{font-size:13.5px;}
  .section-header{position:relative;}
  .section-header-link{display:inline-block;margin-left:auto;font-size:13px;font-weight:600;color:var(--green);align-self:center;}

  /* Hero: player (kiri) + jadwal (kanan) */
  .hero-grid{display:grid;grid-template-columns:minmax(0,420px) 1fr;gap:8px;align-items:start;padding-top:18px;}
  .section-player{position:sticky;top:calc(var(--hdr-h) + 18px);padding:16px 28px;}
  .player-content{padding:30px 26px 24px;gap:22px;}
  .radio-name{font-size:24px;}
  .radio-now{max-width:none;font-size:13px;}
  .section-jadwal{padding-top:16px;}
  .jadwal-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}

  /* Grid konten lebih lebar */
  .rekaman-grid{grid-template-columns:repeat(4,1fr);gap:18px;}
  .konten-grid{grid-template-columns:repeat(4,1fr);}

  /* Cari Kajian overlay → modal terpusat */
  .konten-page{max-width:1100px;left:50%;right:auto;top:5vh;bottom:5vh;inset:auto;transform:translate(50%,0);width:94%;border-radius:var(--radius);box-shadow:0 20px 60px rgba(0,0,0,.4);border:1px solid var(--border-g);}
  .konten-page.open{transform:translate(-50%,0);}
  .konten-row-scroll{gap:14px;}

  /* Footer tampil */
  .site-footer{display:block;}

  /* Hover affordances */
  .jadwal-card,.kajian-card,.konten-card,.nasehat-card{transition:transform .2s,box-shadow .2s;}
  .jadwal-card:hover,.kajian-card:hover,.konten-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card);}
  .info-btn:hover{border-color:var(--green);}
  .ctrl-btn:hover{border-color:var(--green);}
}

/* ============================================================
   LAYAR LEBAR ≥ 1440px
   ============================================================ */
@media (min-width:1440px){
  .site-main{max-width:1340px;}
  .hero-grid{grid-template-columns:minmax(0,460px) 1fr;}
  .rekaman-grid{grid-template-columns:repeat(4,1fr);}
}

/* Nasehat: di desktop tampil grid, bukan scroll */
@media (min-width:1024px){
  .nasehat-scroll{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;overflow:visible;}
  .nasehat-card{width:100%!important;}
  .nasehat-card-yt{grid-column:span 2;}
}
