:root{
  --bg:#07090d;
  --bg2:#0b1016;
  --panel:#10151d;
  --panel2:#151a23;
  --text:#fff7ef;
  --muted:#b8b0a8;
  --brand:#f43c37;
  --brand2:#ff6b52;
  --line:rgba(255,255,255,.11);
  --soft:rgba(255,255,255,.055);
  --shadow:0 24px 80px rgba(0,0,0,.38);
  --content:min(1720px,calc(100vw - 88px));
  --mobilePad:16px;
}
body[data-theme="light"]{
  --bg:#f7f0e8;
  --bg2:#fffaf5;
  --panel:#fff7ef;
  --panel2:#fffdf9;
  --text:#171412;
  --muted:#685f58;
  --line:rgba(0,0,0,.12);
  --soft:rgba(0,0,0,.055);
  --shadow:0 20px 60px rgba(70,35,15,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;min-height:100vh;color:var(--text);background:radial-gradient(circle at 74% 4%,rgba(244,60,55,.16),transparent 35vw),linear-gradient(180deg,var(--bg),var(--bg2));font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none}img{display:block;max-width:100%}button,input,textarea{font:inherit}button{cursor:pointer}.muted{color:var(--muted)}
.site-header{position:sticky;top:0;z-index:80;background:rgba(7,9,13,.88);border-bottom:1px solid var(--line);backdrop-filter:blur(18px)}
.header-inner{width:var(--content);margin:0 auto;min-height:78px;display:grid;grid-template-columns:minmax(250px,340px) minmax(480px,1fr) auto;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{width:48px;height:48px;border-radius:999px;display:grid;place-items:center;background:var(--brand);color:#fff;font-weight:950;letter-spacing:-.06em;flex:0 0 auto}.brand-copy{min-width:0;display:grid;gap:2px;line-height:1}.brand-copy strong{font-size:18px;font-weight:950;letter-spacing:-.04em;white-space:nowrap}.brand-copy small{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:290px}.nav{display:flex;align-items:center;justify-content:center;gap:clamp(18px,1.7vw,30px);min-width:0}.nav a,.nav button{border:0;background:transparent;color:var(--muted);font-weight:900;padding:29px 0 24px;white-space:nowrap;position:relative}.nav a:hover,.nav button:hover{color:var(--text)}.nav a:first-child:after{content:"";position:absolute;left:0;right:0;bottom:14px;height:2px;background:var(--brand);border-radius:9px}.nav-drop{position:relative}.nav-drop>div{display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);min-width:220px;padding:10px;border:1px solid var(--line);border-radius:18px;background:rgba(13,17,24,.98);box-shadow:var(--shadow)}.nav-drop:hover>div{display:grid}.nav-drop>div a{padding:12px 14px;border-radius:12px}.nav-drop>div a:hover{background:var(--soft)}
.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;min-width:0}.theme-toggle,.mobile-menu-toggle,.play-btn,.clean-form button{border:1px solid var(--line);border-radius:999px;background:var(--soft);color:var(--text);font-weight:950;line-height:1}.theme-toggle,.mobile-menu-toggle{padding:12px 17px}.theme-toggle:hover,.mobile-menu-toggle:hover,.play-btn:hover,.clean-form button:hover{border-color:rgba(244,60,55,.45);background:rgba(244,60,55,.16)}.mobile-menu-toggle{display:none}
.header-player{width:clamp(360px,29vw,520px);height:58px;display:grid;grid-template-columns:46px minmax(0,1fr) 48px 42px;align-items:center;gap:12px;padding:7px 10px;border:1px solid rgba(255,255,255,.13);border-radius:18px;background:linear-gradient(135deg,rgba(18,22,31,.96),rgba(50,25,36,.96));box-shadow:0 10px 36px rgba(0,0,0,.26)}.player-cover{width:44px;height:44px;border-radius:13px;object-fit:cover;background:var(--panel2)}.player-meta{min-width:0;line-height:1.06;display:grid;gap:2px}.player-meta small{font-size:10px;color:var(--brand2);text-transform:uppercase;letter-spacing:.12em;font-weight:950}.player-title,.player-artist{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-title{font-size:14px;font-weight:950}.player-artist{font-size:12px;color:var(--muted)}.play-btn{width:46px;height:46px;padding:0;display:grid;place-items:center;font-size:0}.play-btn:before{content:"▶";font-size:17px;margin-left:2px}.play-btn.is-playing:before{content:"❚❚";font-size:15px;margin-left:0}.volume-wrap{position:relative;width:38px;height:42px;display:grid;place-items:center;color:#fff}.volume-icon{width:38px;height:38px;border-radius:999px;border:1px solid var(--line);display:grid!important;place-items:center;background:rgba(255,255,255,.06);flex:0 0 auto}.volume{position:absolute;right:0;top:50%;transform:translateY(-50%);width:0;opacity:0;pointer-events:none;accent-color:var(--brand);transition:width .2s ease,opacity .2s ease}.volume-wrap:hover,.volume-wrap:focus-within,.volume-wrap.is-volume-open{width:170px;justify-content:start}.volume-wrap:hover .volume,.volume-wrap:focus-within .volume,.volume-wrap.is-volume-open .volume{right:0;width:118px;opacity:1;pointer-events:auto}.volume-wrap:hover .volume-icon,.volume-wrap:focus-within .volume-icon,.volume-wrap.is-volume-open .volume-icon{justify-self:start}
.page-shell{width:var(--content);margin:0 auto}.trr-home{padding-bottom:60px}.trr-hero{position:relative;min-height:610px;display:grid;grid-template-columns:minmax(0,.8fr) minmax(460px,.72fr);align-items:center;gap:50px;overflow:hidden;border-bottom:1px solid var(--line)}.trr-hero-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(90deg,rgba(7,9,13,.98) 0%,rgba(7,9,13,.70) 41%,rgba(7,9,13,.20) 67%,rgba(7,9,13,.82) 100%),linear-gradient(180deg,rgba(7,9,13,.18),rgba(7,9,13,.96)),url('../img/hero-onair.jpg');background-size:cover;background-position:center;opacity:.95}.trr-hero-bg:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0 42px,rgba(255,255,255,.018) 42px 43px)}.trr-hero-copy{position:relative;z-index:2;max-width:730px}.trr-kicker{margin:0 0 18px;color:var(--brand)!important;text-transform:uppercase;font-size:14px!important;font-weight:950;letter-spacing:.24em}.trr-hero h1{margin:0 0 24px;font-size:clamp(58px,5.6vw,106px);line-height:.93;letter-spacing:-.075em;color:var(--text)}.trr-hero-copy p:not(.trr-kicker){max-width:690px;margin:0;color:rgba(255,247,239,.79);font-size:clamp(21px,1.45vw,28px);line-height:1.36}.trr-hero-actions{display:flex;align-items:center;gap:16px;margin-top:34px}.trr-hero-actions a,.trr-hero-actions button{border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:15px 26px;background:rgba(255,255,255,.07);color:#fff;font-weight:950}.trr-listen{background:linear-gradient(135deg,var(--brand),#ff554d)!important;border-color:transparent!important}.trr-listen span{margin-right:8px}.trr-onair-sign{position:relative;z-index:2;justify-self:end;width:min(620px,42vw);aspect-ratio:1.9;display:grid;place-items:center;border-radius:32px;background:linear-gradient(135deg,rgba(244,60,55,.18),rgba(0,0,0,.18));box-shadow:inset 0 0 0 1px rgba(255,255,255,.10),0 38px 150px rgba(244,60,55,.22)}.trr-onair-sign span{font-size:clamp(58px,5vw,112px);font-weight:400;letter-spacing:.09em;color:#ff4945;text-shadow:0 0 10px #ff241f,0 0 30px rgba(255,36,31,.9),0 0 70px rgba(255,36,31,.45);border:5px solid #ff413a;border-radius:15px;padding:.13em .34em;transform:rotate(-2deg)}.trr-onair-sign small{position:absolute;bottom:17%;font-size:clamp(20px,1.75vw,34px);letter-spacing:.08em;color:#fff;text-transform:uppercase}.trr-live-signal{position:relative;z-index:5;margin:-58px 0 24px;display:grid;grid-template-columns:190px minmax(220px,.8fr) minmax(320px,1.1fr) minmax(150px,auto);gap:30px;align-items:center;padding:24px 34px;border:1px solid rgba(255,255,255,.11);border-radius:24px;background:rgba(12,16,23,.88);box-shadow:0 24px 80px rgba(0,0,0,.35);backdrop-filter:blur(20px)}.signal-status{display:flex;align-items:center;gap:10px;color:var(--brand);font-weight:950;text-transform:uppercase;letter-spacing:.14em}.signal-status span{width:10px;height:10px;border-radius:50%;background:var(--brand);box-shadow:0 0 20px var(--brand)}.signal-bars{height:54px;display:flex;align-items:center;gap:5px}.signal-bars i{width:4px;height:16px;border-radius:99px;background:linear-gradient(var(--brand2),var(--brand));animation:bars 1.15s ease-in-out infinite}.signal-bars i:nth-child(3n){height:34px}.signal-bars i:nth-child(4n){height:46px}.signal-bars i:nth-child(5n){height:24px}@keyframes bars{50%{transform:scaleY(.42);opacity:.68}}.signal-now{display:grid;grid-template-columns:88px minmax(0,1fr);align-items:center;gap:18px}.signal-now .player-cover{width:88px;height:88px;border-radius:22px}.signal-now small{color:var(--brand2);font-weight:950;text-transform:uppercase;letter-spacing:.12em}.signal-now strong{display:block;font-size:clamp(28px,2.2vw,44px);line-height:1.04}.signal-now span{color:rgba(255,247,239,.72)}.signal-listeners small{display:block;color:rgba(255,247,239,.62)}.signal-listeners strong{font-size:30px}.trr-grid-main{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(430px,.85fr);gap:24px}.trr-panel{border:1px solid rgba(255,255,255,.10);border-radius:24px;background:linear-gradient(180deg,rgba(14,18,26,.9),rgba(10,14,20,.82));box-shadow:0 22px 60px rgba(0,0,0,.24);padding:24px}.trr-section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.trr-section-head h2{margin:0;font-size:20px;text-transform:uppercase;letter-spacing:.04em}.trr-section-head h2:before{content:"◷";color:var(--brand);margin-right:10px}.trr-section-head a{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.06);font-weight:900;color:#fff}.recent-cards{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.recent-card{min-width:0;border:1px solid rgba(255,255,255,.08);border-radius:13px;background:rgba(255,255,255,.026);padding:10px}.recent-card img{width:100%;aspect-ratio:1;border-radius:9px;object-fit:cover;margin-bottom:10px}.recent-card strong,.recent-card span,.recent-card small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-card span,.recent-card small{color:rgba(255,247,239,.65);font-size:12px}.schedule-list{display:grid;gap:12px}.schedule-item{display:grid;grid-template-columns:92px minmax(0,1fr) 42px;gap:18px;align-items:center;padding:16px;border-radius:16px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.04)}.schedule-item span{padding:8px 12px;border-radius:8px;background:rgba(255,255,255,.06);font-size:12px;font-weight:950;text-transform:uppercase;color:rgba(255,247,239,.68)}.schedule-item.active span{background:linear-gradient(135deg,var(--brand),#ff594f);color:#fff}.schedule-item strong{display:block;font-size:18px}.schedule-item small{color:rgba(255,247,239,.62)}.schedule-item b{color:var(--brand);letter-spacing:3px}.trr-feature-tiles{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;margin-top:24px}.tile{min-height:210px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;gap:10px;border:1px solid rgba(255,255,255,.10);border-radius:20px;background:linear-gradient(135deg,rgba(15,19,26,.82),rgba(15,19,26,.70)),radial-gradient(circle at 80% 20%,rgba(244,60,55,.20),transparent 42%);padding:24px}.tile span{font-size:34px;color:var(--brand)}.tile strong{font-size:22px}.tile small{color:rgba(255,247,239,.70);line-height:1.45}.tile em{font-style:normal;color:var(--brand2);font-weight:950;margin-top:6px}.content-band{margin:54px 0 0;padding-top:30px;border-top:1px solid var(--line)}.section-head{display:flex;justify-content:space-between;align-items:center;gap:16px}.section-head h2,.content-band h2{font-size:clamp(32px,4vw,60px);letter-spacing:-.055em;margin:0 0 22px}.section-head a,.text-link{color:var(--brand2);font-weight:950}.clean-list a,.song-list div{display:grid;grid-template-columns:100px minmax(0,1fr) auto;gap:18px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line)}.clean-list time,.song-list time{color:var(--brand2);font-weight:900}.clean-list span,.song-list span{color:var(--muted)}.article-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px}.article-row a{border-top:1px solid var(--line);padding:18px 0;display:grid;gap:10px}.article-row img{height:180px;width:100%;object-fit:cover;border-radius:22px}.article-row span{color:var(--brand2);font-weight:900;text-transform:uppercase;font-size:12px;letter-spacing:.08em}.article-row strong{font-size:21px;line-height:1.1}.show-row,.event-row{display:grid;grid-template-columns:190px minmax(0,1fr);gap:26px;border-top:1px solid var(--line);padding:24px 0}.show-row img,.event-row img{border-radius:24px;aspect-ratio:1.25;object-fit:cover;background:var(--panel)}.show-row h3,.event-row h2{margin:.2rem 0;font-size:clamp(28px,3vw,48px);letter-spacing:-.045em}.show-row p,.event-row p{color:var(--muted)}.event-row time{color:var(--brand2);font-weight:900}.page-title h1{font-size:clamp(48px,6vw,96px);letter-spacing:-.065em;line-height:.9;margin:40px 0 22px}.page-title p{color:var(--muted);font-size:20px}.clean-form{display:grid;gap:16px;max-width:900px}.clean-form label{display:grid;gap:8px;color:var(--muted);font-weight:800}.clean-form input,.clean-form textarea,.clean-form select{width:100%;border:1px solid var(--line);border-radius:18px;background:var(--panel);color:var(--text);padding:14px 16px}.clean-form textarea{min-height:160px}.clean-form .form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.clean-form button{justify-self:start;padding:14px 24px;background:var(--brand);border-color:var(--brand);color:#fff}.notice{padding:14px 16px;border:1px solid var(--line);border-radius:16px;background:var(--soft)}.site-footer{width:var(--content);margin:70px auto 0;padding:34px 0 120px;color:rgba(255,247,239,.55);text-align:center;border-top:1px solid var(--line)}.mobile-player{display:none}
@media(max-width:1180px){:root{--content:calc(100vw - 42px)}.header-inner{grid-template-columns:minmax(220px,1fr) auto auto}.header-player{display:none}.mobile-menu-toggle{display:inline-flex}.nav{position:fixed;top:82px;right:20px;left:20px;z-index:90;display:none;justify-content:stretch;align-items:stretch;gap:6px;padding:16px;border:1px solid var(--line);border-radius:24px;background:rgba(8,11,16,.97);box-shadow:0 26px 80px rgba(0,0,0,.55)}.nav-open .nav{display:grid}.nav a,.nav button{padding:15px;text-align:left}.nav a:first-child:after{display:none}.nav-drop>div{position:static;display:grid;transform:none;border:0;background:transparent;box-shadow:none;padding:0}.trr-hero{grid-template-columns:1fr;min-height:680px;padding:80px 0 145px}.trr-onair-sign{position:absolute;right:0;top:115px;width:min(470px,46vw)}.trr-live-signal{grid-template-columns:1fr;gap:18px;margin-top:-120px}.signal-bars{order:-1}.trr-grid-main,.trr-feature-tiles{grid-template-columns:1fr 1fr}.recent-cards{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:760px){:root{--content:calc(100vw - 28px)}body{padding-bottom:112px;background:#07090d}.site-header{background:rgba(7,9,13,.92)}.header-inner{min-height:72px;width:100%;padding:0 var(--mobilePad);display:flex;justify-content:space-between}.brand-mark{width:42px;height:42px}.brand-copy strong{font-size:15px}.brand-copy small{max-width:190px;font-size:11px}.theme-toggle{width:42px;height:42px;padding:0;font-size:0}.theme-toggle:before{content:"☾";font-size:18px}.mobile-menu-toggle{height:42px;padding:0 14px}.nav{top:78px;left:14px;right:14px}.page-shell{width:100%;overflow:hidden}.trr-home{padding-bottom:22px}.trr-hero{margin:0;min-height:520px;padding:116px var(--mobilePad) 30px;display:block;border-bottom:0}.trr-hero-bg{background:linear-gradient(180deg,rgba(7,9,13,.18),rgba(7,9,13,.40) 35%,rgba(7,9,13,.98) 86%),url('../img/hero-onair.jpg'),radial-gradient(circle at 75% 25%,rgba(244,60,55,.44),transparent 32%);background-size:cover;background-position:center top}.trr-kicker{font-size:12px!important;margin-bottom:16px}.trr-hero h1{font-size:clamp(46px,14vw,66px);line-height:.95;letter-spacing:-.07em;max-width:430px}.trr-hero-copy p:not(.trr-kicker){font-size:17px;line-height:1.45;max-width:410px}.trr-hero-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px}.trr-hero-actions a,.trr-hero-actions button{padding:14px 12px;text-align:center}.trr-onair-sign{position:absolute;right:18px;top:118px;width:150px;border-radius:18px;background:rgba(0,0,0,.18);box-shadow:none}.trr-onair-sign span{font-size:27px;border-width:2px;border-radius:8px;padding:.14em .28em}.trr-onair-sign small{display:none}.trr-live-signal{width:var(--content);margin:18px auto 16px;padding:18px;border-radius:20px;display:grid;grid-template-columns:1fr;gap:14px}.signal-status{font-size:12px}.signal-bars{height:38px;gap:4px;order:0}.signal-bars i{width:3px}.signal-now{grid-template-columns:72px minmax(0,1fr);gap:14px}.signal-now .player-cover{width:72px;height:72px;border-radius:18px}.signal-now strong{font-size:25px}.signal-listeners{display:none}.trr-grid-main{width:var(--content);margin:0 auto;grid-template-columns:1fr;gap:16px}.trr-panel{padding:16px;border-radius:20px}.trr-section-head h2{font-size:16px}.recent-cards{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:4px}.recent-card{min-width:126px;scroll-snap-align:start}.schedule-item{grid-template-columns:76px minmax(0,1fr);gap:12px}.schedule-item b{display:none}.schedule-item strong{font-size:16px}.trr-feature-tiles{width:var(--content);margin:16px auto 0;grid-template-columns:1fr 1fr;gap:12px}.tile{min-height:142px;border-radius:18px;padding:16px}.tile span{font-size:28px}.tile strong{font-size:17px}.tile small{font-size:13px}.content-band{width:var(--content);margin:26px auto 0}.clean-list a,.song-list div{grid-template-columns:1fr;gap:5px}.article-row{grid-template-columns:1fr}.clean-form .form-grid,.show-row,.event-row{grid-template-columns:1fr}.mobile-player{position:fixed;left:12px;right:12px;bottom:12px;z-index:100;display:grid!important;grid-template-columns:58px minmax(0,1fr) 48px 40px;align-items:center;gap:12px;padding:12px;border:1px solid rgba(255,255,255,.12);border-radius:24px;background:linear-gradient(135deg,rgba(14,17,24,.96),rgba(24,14,19,.96));box-shadow:0 -18px 60px rgba(0,0,0,.55);backdrop-filter:blur(22px)}.mobile-player .player-cover{width:58px;height:58px;border-radius:16px}.mobile-player .player-meta small{font-size:9px}.mobile-player .player-title{font-size:15px}.mobile-player .player-artist{font-size:12px}.mobile-player .play-btn{width:48px;height:48px}.mobile-player .volume-wrap{width:40px!important;height:48px}.mobile-player .volume-icon{width:40px;height:40px}.mobile-player .volume-wrap.is-volume-open,.mobile-player .volume-wrap:hover,.mobile-player .volume-wrap:focus-within{position:absolute;right:12px;bottom:78px;width:205px!important;padding:8px 10px;border:1px solid rgba(255,255,255,.13);border-radius:999px;background:rgba(17,21,29,.97);display:flex;gap:10px}.mobile-player .volume-wrap.is-volume-open .volume,.mobile-player .volume-wrap:hover .volume,.mobile-player .volume-wrap:focus-within .volume{position:static;transform:none;width:136px;opacity:1;pointer-events:auto}.site-footer{width:var(--content);padding-bottom:132px}}


/* === v12.3 image + player + mobile polish overrides === */
.trr-hero-bg{
  background:
    linear-gradient(90deg,rgba(7,9,13,.94) 0%,rgba(7,9,13,.66) 38%,rgba(7,9,13,.14) 66%,rgba(7,9,13,.72) 100%),
    linear-gradient(180deg,rgba(7,9,13,.08),rgba(7,9,13,.94)),
    url('../img/hero-onair.jpg') !important;
  background-size:cover!important;
  background-position:center center!important;
}
.trr-onair-sign{display:none!important;}
.trr-hero{grid-template-columns:minmax(0,.72fr) minmax(420px,.85fr);}
.trr-hero:after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:38%;
  pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(7,9,13,.96));
  z-index:1;
}
.trr-hero-copy{padding-top:clamp(20px,4vw,64px);}

.tile{position:relative;overflow:hidden;background:#10141d!important;}
.tile:before{content:"";position:absolute;inset:0;background-size:cover;background-position:center;opacity:.28;transition:transform .35s ease,opacity .35s ease;}
.tile:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(7,9,13,.92),rgba(7,9,13,.46));}
.tile>*{position:relative;z-index:1;}
.tile:hover:before{transform:scale(1.06);opacity:.42;}
.tile-events:before{background-image:url('../img/event-1.jpg');}
.tile-shows:before{background-image:url('../img/host-1.jpg');background-position:center right;}
.tile-legends:before{background-image:url('../img/article-1.jpg');}
.tile-community:before{background-image:url('../img/hero-onair.jpg');background-position:center;}

.header-player{grid-template-columns:46px minmax(0,1fr) 48px 42px!important;overflow:visible;}
.header-player .volume-wrap{width:42px!important;min-width:42px!important;justify-content:center!important;overflow:visible;}
.header-player .volume-wrap .volume-icon{position:relative;z-index:3;}
.header-player .volume-wrap .volume{right:48px!important;left:auto!important;width:0!important;max-width:112px;}
.header-player .volume-wrap:hover,
.header-player .volume-wrap:focus-within,
.header-player .volume-wrap.is-volume-open{width:42px!important;}
.header-player .volume-wrap:hover .volume,
.header-player .volume-wrap:focus-within .volume,
.header-player .volume-wrap.is-volume-open .volume{width:106px!important;opacity:1!important;pointer-events:auto!important;}
.header-player .play-btn{position:relative;z-index:4;}

@media(max-width:1180px){
  .trr-hero{grid-template-columns:1fr;}
}

@media(max-width:760px){
  .trr-hero{min-height:620px!important;padding:108px var(--mobilePad) 34px!important;}
  .trr-hero-bg{
    background:
      linear-gradient(180deg,rgba(7,9,13,.08),rgba(7,9,13,.30) 42%,rgba(7,9,13,.98) 88%),
      url('../img/hero-onair.jpg') !important;
    background-size:cover!important;
    background-position:center top!important;
  }
  .trr-hero-copy{max-width:100%;padding-top:0;}
  .trr-hero h1{font-size:clamp(42px,13vw,62px)!important;max-width:96vw;}
  .trr-hero-copy p:not(.trr-kicker){max-width:92vw;}
  .trr-hero-actions{grid-template-columns:1fr 1fr!important;width:100%;}
  .trr-hero-actions a,.trr-hero-actions button{min-width:0;white-space:nowrap;}
  .trr-live-signal{margin-top:-8px!important;}
  .mobile-player{grid-template-columns:56px minmax(0,1fr) 48px 42px!important;}
  .mobile-player .volume-wrap{width:42px!important;min-width:42px!important;position:relative!important;}
  .mobile-player .volume-wrap .volume{display:none;}
  .mobile-player .volume-wrap.is-volume-open .volume,
  .mobile-player .volume-wrap:hover .volume,
  .mobile-player .volume-wrap:focus-within .volume{
    display:block;
    position:absolute!important;
    right:0!important;
    bottom:62px!important;
    width:164px!important;
    opacity:1!important;
    pointer-events:auto!important;
    transform:none!important;
  }
}


/* === UI polish patch: player controls, dropdown, active nav, icon theme toggle === */
.nav a:after,
.nav-drop > button:after{
  content:none!important;
}
.nav a.is-active:after,
.nav-drop.is-active > button:after{
  content:""!important;
  position:absolute;
  left:0;
  right:0;
  bottom:14px;
  height:2px;
  background:var(--brand);
  border-radius:9px;
}
.nav-drop > button{
  position:relative;
}
.nav-drop > div{
  top:100%!important;
  padding-top:14px!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.nav-drop > div:before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:14px;
}
.nav-drop > div a{
  display:block;
  background:rgba(13,17,24,.98);
  border:1px solid var(--line);
  border-bottom:0;
}
.nav-drop > div a:first-child{border-radius:18px 18px 0 0}
.nav-drop > div a:last-child{border-bottom:1px solid var(--line);border-radius:0 0 18px 18px}
.theme-toggle{
  width:48px;
  height:48px;
  padding:0!important;
  display:grid;
  place-items:center;
  font-size:0;
  flex:0 0 auto;
}
.theme-toggle::before{
  content:"☾";
  font-size:20px;
  line-height:1;
}
body[data-theme="light"] .theme-toggle::before{content:"☀"}
.header-player{
  grid-template-columns:46px minmax(0,1fr) 46px 40px!important;
  overflow:visible!important;
}
.play-btn{
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  min-height:44px!important;
  padding:0!important;
  border-radius:50%!important;
  display:grid!important;
  place-items:center!important;
  line-height:1!important;
  flex:0 0 auto!important;
  position:relative;
}
.play-btn::before{
  display:block!important;
  margin:0!important;
  transform:translateX(1px);
  line-height:1!important;
}
.play-btn.is-playing::before{transform:none!important}
.volume-wrap{
  width:40px!important;
  min-width:40px!important;
  max-width:40px!important;
  height:44px!important;
  display:grid!important;
  place-items:center!important;
  position:relative!important;
  overflow:visible!important;
  flex:0 0 40px!important;
}
.volume-icon{
  width:40px!important;
  height:40px!important;
  border-radius:999px!important;
  display:grid!important;
  place-items:center!important;
  margin:0!important;
  z-index:2;
}
.volume-wrap:hover,
.volume-wrap:focus-within,
.volume-wrap.is-volume-open{
  width:40px!important;
  min-width:40px!important;
  max-width:40px!important;
  justify-content:center!important;
}
.volume{
  position:absolute!important;
  right:0!important;
  top:calc(100% + 10px)!important;
  transform:none!important;
  width:150px!important;
  max-width:150px!important;
  height:38px;
  opacity:0;
  pointer-events:none;
  padding:0 14px;
  border-radius:999px;
  background:rgba(12,16,23,.98);
  border:1px solid var(--line);
  box-shadow:0 18px 44px rgba(0,0,0,.38);
  transition:opacity .18s ease, transform .18s ease;
}
.volume-wrap:hover .volume,
.volume-wrap:focus-within .volume,
.volume-wrap.is-volume-open .volume{
  opacity:1!important;
  pointer-events:auto!important;
  transform:translateY(2px)!important;
}
.mobile-player .volume{
  top:auto!important;
  bottom:calc(100% + 12px)!important;
  right:0!important;
  width:min(210px,calc(100vw - 42px))!important;
  max-width:min(210px,calc(100vw - 42px))!important;
}
@media (max-width:900px){
  .theme-toggle{width:44px;height:44px}
  .mobile-menu-toggle{font-size:0;width:64px;height:44px;padding:0!important;display:grid;place-items:center}
  .mobile-menu-toggle::before{content:"☰";font-size:22px;line-height:1}
  body.nav-open .mobile-menu-toggle::before{content:"×";font-size:28px}
  .mobile-player .play-btn{width:48px!important;height:48px!important;min-width:48px!important;min-height:48px!important}
  .mobile-player .volume-wrap{width:44px!important;min-width:44px!important;max-width:44px!important;height:48px!important;flex-basis:44px!important}
  .mobile-player .volume-icon{width:44px!important;height:44px!important}
}


/* === v12.5 dark-only player/header cleanup === */
body{
  color:var(--text)!important;
  background:radial-gradient(circle at 74% 4%,rgba(244,60,55,.16),transparent 35vw),linear-gradient(180deg,var(--bg),var(--bg2))!important;
}
body[data-theme="light"]{all:unset;}
.header-actions{gap:14px!important;}
.theme-toggle{display:none!important;}

/* Desktop player: clean compact bar with inline expanding volume */
.header-player{
  width:clamp(430px,30vw,560px)!important;
  height:64px!important;
  grid-template-columns:50px minmax(0,1fr) 46px 42px!important;
  gap:12px!important;
  padding:8px 12px!important;
  border-radius:20px!important;
  overflow:visible!important;
  transition:width .22s ease, grid-template-columns .22s ease!important;
}
.header-player:has(.volume-wrap:hover),
.header-player:has(.volume-wrap:focus-within),
.header-player:has(.volume-wrap.is-volume-open){
  width:clamp(540px,38vw,690px)!important;
  grid-template-columns:50px minmax(0,1fr) 46px 176px!important;
}
.player-ui .player-cover{
  width:48px!important;
  height:48px!important;
  border-radius:13px!important;
}
.player-ui .play-btn{
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  min-height:44px!important;
  max-width:44px!important;
  max-height:44px!important;
  aspect-ratio:1/1!important;
  border-radius:999px!important;
  padding:0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  line-height:1!important;
  font-size:0!important;
  text-indent:0!important;
  overflow:hidden!important;
  background:rgba(255,255,255,.09)!important;
  border:1px solid rgba(255,255,255,.14)!important;
  color:#fff!important;
  flex:0 0 44px!important;
}
.player-ui .play-btn::before{
  content:"▶"!important;
  display:block!important;
  font-size:17px!important;
  line-height:1!important;
  width:auto!important;
  height:auto!important;
  margin:0 0 0 2px!important;
  transform:none!important;
  position:static!important;
}
.player-ui .play-btn.is-playing::before{
  content:"❚❚"!important;
  font-size:15px!important;
  margin:0!important;
  transform:none!important;
}

.header-player .volume-wrap{
  position:relative!important;
  width:42px!important;
  min-width:42px!important;
  max-width:none!important;
  height:44px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:10px!important;
  overflow:hidden!important;
  flex:0 0 auto!important;
  transition:width .22s ease!important;
}
.header-player .volume-wrap:hover,
.header-player .volume-wrap:focus-within,
.header-player .volume-wrap.is-volume-open{
  width:176px!important;
  min-width:176px!important;
  max-width:176px!important;
}
.header-player .volume-icon{
  width:40px!important;
  height:40px!important;
  min-width:40px!important;
  flex:0 0 40px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  position:relative!important;
  z-index:2!important;
}
.header-player .volume{
  position:static!important;
  transform:none!important;
  right:auto!important;
  top:auto!important;
  bottom:auto!important;
  width:0!important;
  min-width:0!important;
  height:auto!important;
  opacity:0!important;
  pointer-events:none!important;
  padding:0!important;
  border:0!important;
  box-shadow:none!important;
  background:transparent!important;
  accent-color:var(--brand)!important;
  transition:width .22s ease, opacity .18s ease!important;
}
.header-player .volume-wrap:hover .volume,
.header-player .volume-wrap:focus-within .volume,
.header-player .volume-wrap.is-volume-open .volume{
  width:118px!important;
  min-width:118px!important;
  opacity:1!important;
  pointer-events:auto!important;
}

/* Mobile: keep spotify-style bottom player, but no theme button */
@media(max-width:900px){
  .header-actions{gap:10px!important;}
  .mobile-menu-toggle{display:grid!important;}
  .mobile-player{
    grid-template-columns:56px minmax(0,1fr) 48px 42px!important;
    padding:12px!important;
    gap:12px!important;
  }
  .mobile-player .play-btn{
    width:48px!important;
    height:48px!important;
    min-width:48px!important;
    min-height:48px!important;
    max-width:48px!important;
    max-height:48px!important;
  }
  .mobile-player .volume-wrap{
    width:42px!important;
    min-width:42px!important;
    height:48px!important;
    overflow:visible!important;
  }
  .mobile-player .volume{
    position:absolute!important;
    right:0!important;
    bottom:calc(100% + 12px)!important;
    top:auto!important;
    width:min(210px,calc(100vw - 42px))!important;
    max-width:min(210px,calc(100vw - 42px))!important;
    padding:0 14px!important;
    border-radius:999px!important;
    background:rgba(12,16,23,.98)!important;
    border:1px solid var(--line)!important;
    opacity:0!important;
    pointer-events:none!important;
  }
  .mobile-player .volume-wrap:hover .volume,
  .mobile-player .volume-wrap:focus-within .volume,
  .mobile-player .volume-wrap.is-volume-open .volume{
    opacity:1!important;
    pointer-events:auto!important;
  }
}

/* === v12.6 custom PNG icon patch === */
.player-ui .play-btn,
.player-ui .volume-icon{
  font-size:0!important;
  line-height:0!important;
}

.player-ui .play-btn::before,
.player-ui .play-btn.is-playing::before,
.trr-listen.play-btn::before{
  content:none!important;
  display:none!important;
}

.player-ui .play-btn img.play-icon,
.player-ui .volume-icon img{
  display:block;
  width:21px;
  height:21px;
  object-fit:contain;
  pointer-events:none;
  filter:drop-shadow(0 1px 4px rgba(0,0,0,.24));
}

.player-ui .volume-icon img{
  width:20px;
  height:20px;
}

.player-ui .play-btn.is-playing img.play-icon{
  width:18px;
  height:18px;
}

.trr-listen.play-btn{
  width:auto!important;
  height:auto!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:10px!important;
  font-size:15px!important;
  line-height:1!important;
}

.trr-listen .inline-play-icon{
  width:15px;
  height:15px;
  object-fit:contain;
  display:block;
}

.tile .tile-icon{
  width:44px;
  height:44px;
  object-fit:contain;
  display:block;
  margin:0 0 18px;
  filter:drop-shadow(0 10px 22px rgba(255,60,55,.20));
}

.tile span{
  display:none!important;
}

@media(max-width:760px){
  .tile .tile-icon{
    width:36px;
    height:36px;
    margin-bottom:12px;
  }
}


/* PATCH: keep custom icons from blowing up hero/player buttons */
.trr-hero-actions .trr-listen,
.trr-hero-actions .js-listen-live{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:10px!important;
  width:auto!important;
  height:auto!important;
  min-width:0!important;
  padding:15px 26px!important;
  border-radius:999px!important;
  font-size:15px!important;
  line-height:1!important;
}
.trr-hero-actions .inline-play-icon,
.trr-hero-actions .trr-listen img,
.trr-hero-actions .js-listen-live img{
  width:14px!important;
  height:14px!important;
  max-width:14px!important;
  max-height:14px!important;
  object-fit:contain!important;
  flex:0 0 14px!important;
}
.player-ui .play-btn img,
.player-ui .volume-icon img{
  width:18px!important;
  height:18px!important;
  max-width:18px!important;
  max-height:18px!important;
  object-fit:contain!important;
  display:block!important;
  pointer-events:none!important;
}
.player-ui .play-btn{
  width:46px!important;
  height:46px!important;
  min-width:46px!important;
  min-height:46px!important;
  padding:0!important;
  display:grid!important;
  place-items:center!important;
  border-radius:999px!important;
  overflow:hidden!important;
  flex:0 0 46px!important;
}
.player-ui .play-btn:before{
  content:none!important;
}
.player-ui .volume-icon{
  width:38px!important;
  height:38px!important;
  min-width:38px!important;
  min-height:38px!important;
  display:grid!important;
  place-items:center!important;
  overflow:hidden!important;
}
@media (max-width:900px){
  .trr-hero-actions{display:flex!important;gap:12px!important;flex-wrap:nowrap!important;overflow:hidden!important;}
  .trr-hero-actions .trr-listen{flex:1 1 auto!important;}
  .trr-hero-actions .trr-outline{flex:0 0 auto!important;}
}

/* =========================================================
   TRR PATCH: dropdown polish + sane player controls
   Date: 2026-05-28
   ========================================================= */

/* Remove old theme toggle space if any stale markup/css remains */
.theme-toggle{display:none!important}

/* Active nav underline must follow actual page, not hardcoded Home */
.nav a:first-child:after{display:none!important}
.nav a.is-active:after,
.nav-drop.is-active > button:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:14px;
  height:2px;
  background:var(--brand);
  border-radius:999px;
}

/* Concerts dropdown: give it a bridge so it does not vanish when moving cursor */
.nav-drop{position:relative;padding-bottom:10px;margin-bottom:-10px}
.nav-drop > button{display:flex!important;align-items:center;gap:8px}
.nav-drop > button:after{
  content:"";
  width:7px;
  height:7px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(45deg) translateY(-2px);
  opacity:.65;
}
.nav-drop > div{
  top:calc(100% - 2px)!important;
  left:50%;
  transform:translateX(-50%);
  display:grid!important;
  gap:4px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  min-width:245px;
  padding:10px!important;
  border:1px solid rgba(255,255,255,.14)!important;
  border-radius:20px!important;
  background:rgba(8,11,16,.98)!important;
  box-shadow:0 24px 70px rgba(0,0,0,.48)!important;
  transition:opacity .16s ease, transform .16s ease, visibility .16s ease;
}
.nav-drop:hover > div,
.nav-drop:focus-within > div,
.nav-drop.is-open > div{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateX(-50%) translateY(4px);
}
.nav-drop > div:before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:-16px;
  height:18px;
}
.nav-drop > div a{
  display:flex!important;
  align-items:center;
  padding:13px 14px!important;
  border-radius:14px!important;
  color:rgba(255,247,239,.78)!important;
}
.nav-drop > div a:hover,
.nav-drop > div a.is-active{
  color:#fff!important;
  background:rgba(244,60,55,.16)!important;
}

/* Desktop header player: stable circular buttons, no weird oval, inline volume expansion */
.header-player.player-ui{
  width:clamp(430px,31vw,560px)!important;
  min-width:430px!important;
  height:62px!important;
  display:grid!important;
  grid-template-columns:48px minmax(130px,1fr) 46px auto!important;
  align-items:center!important;
  gap:12px!important;
  overflow:visible!important;
  transition:width .22s ease, min-width .22s ease;
}
.header-player.player-ui:has(.volume-wrap:hover),
.header-player.player-ui:has(.volume-wrap:focus-within),
.header-player.player-ui:has(.volume-wrap.is-volume-open){
  width:clamp(540px,38vw,660px)!important;
  min-width:540px!important;
}
.player-ui .play-btn,
.player-ui .volume-icon{
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  min-height:44px!important;
  max-width:44px!important;
  max-height:44px!important;
  padding:0!important;
  border-radius:999px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:rgba(255,255,255,.07)!important;
  border:1px solid rgba(255,255,255,.12)!important;
  overflow:hidden!important;
  line-height:0!important;
  flex:0 0 44px!important;
  aspect-ratio:1/1!important;
}
.player-ui .play-btn:before,
.player-ui .play-btn:after,
.player-ui .volume-icon:before,
.player-ui .volume-icon:after{content:none!important;display:none!important}
.player-ui .play-btn img.play-icon{
  width:18px!important;
  height:18px!important;
  object-fit:contain!important;
  display:block!important;
  margin:0!important;
  transform:none!important;
}
.player-ui .volume-icon img{
  width:19px!important;
  height:19px!important;
  object-fit:contain!important;
  display:block!important;
  margin:0!important;
}
.header-player .volume-wrap{
  position:relative!important;
  width:44px!important;
  min-width:44px!important;
  height:44px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:10px!important;
  overflow:hidden!important;
  transition:width .22s ease!important;
}
.header-player .volume-wrap:hover,
.header-player .volume-wrap:focus-within,
.header-player .volume-wrap.is-volume-open{
  width:172px!important;
  min-width:172px!important;
}
.header-player .volume{
  position:static!important;
  transform:none!important;
  width:0!important;
  max-width:118px!important;
  opacity:0!important;
  pointer-events:none!important;
  accent-color:var(--brand)!important;
  transition:width .22s ease, opacity .16s ease!important;
}
.header-player .volume-wrap:hover .volume,
.header-player .volume-wrap:focus-within .volume,
.header-player .volume-wrap.is-volume-open .volume{
  width:118px!important;
  opacity:1!important;
  pointer-events:auto!important;
}

/* Mobile player: tap volume icon, show a tidy popup box above the bar, no hover-only behaviour */
@media(max-width:760px){
  .mobile-player.player-ui{
    grid-template-columns:58px minmax(0,1fr) 48px 44px!important;
    gap:12px!important;
    overflow:visible!important;
  }
  .mobile-player .play-btn,
  .mobile-player .volume-icon{
    width:44px!important;
    height:44px!important;
    min-width:44px!important;
    min-height:44px!important;
    flex:0 0 44px!important;
  }
  .mobile-player .volume-wrap{
    position:static!important;
    width:44px!important;
    min-width:44px!important;
    height:44px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    overflow:visible!important;
  }
  .mobile-player .volume{
    position:absolute!important;
    right:10px!important;
    bottom:76px!important;
    width:190px!important;
    max-width:calc(100vw - 42px)!important;
    height:44px!important;
    padding:0 16px!important;
    opacity:0!important;
    pointer-events:none!important;
    transform:translateY(10px)!important;
    border:1px solid rgba(255,255,255,.14)!important;
    border-radius:18px!important;
    background:rgba(11,14,20,.97)!important;
    box-shadow:0 18px 60px rgba(0,0,0,.55)!important;
    accent-color:var(--brand)!important;
    transition:opacity .18s ease, transform .18s ease!important;
    z-index:10002!important;
  }
  .mobile-player .volume-wrap:hover .volume,
  .mobile-player .volume-wrap:focus-within .volume{
    opacity:0!important;
    pointer-events:none!important;
  }
  .mobile-player .volume-wrap.is-volume-open .volume{
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateY(0)!important;
  }
  .nav a.is-active:after,
  .nav-drop.is-active > button:after{display:none!important}
  .nav-drop{padding-bottom:0;margin-bottom:0}
  .nav-drop > div{
    position:static!important;
    transform:none!important;
    opacity:1!important;
    visibility:visible!important;
    pointer-events:auto!important;
    min-width:0!important;
    border:0!important;
    box-shadow:none!important;
    background:transparent!important;
    padding:0 0 0 10px!important;
  }
  .nav-drop > div:before{display:none!important}
}

/* =========================================================
   V12.8 REAL FIX: Concert dropdown + mobile tap volume popup
   This block intentionally sits last to override earlier player/nav rules.
   ========================================================= */

/* Desktop nav dropdown: clean panel with no hover gap */
@media (min-width: 761px){
  .nav-drop{
    position:relative!important;
    padding-bottom:18px!important;
    margin-bottom:-18px!important;
  }

  .nav-drop > button{
    cursor:pointer!important;
  }

  .nav-drop > div{
    display:grid!important;
    position:absolute!important;
    top:calc(100% - 4px)!important;
    left:50%!important;
    transform:translateX(-50%) translateY(8px)!important;
    min-width:245px!important;
    padding:10px!important;
    border:1px solid rgba(255,255,255,.12)!important;
    border-radius:20px!important;
    background:linear-gradient(180deg,rgba(14,18,25,.98),rgba(8,10,15,.98))!important;
    box-shadow:0 24px 70px rgba(0,0,0,.50)!important;
    opacity:0!important;
    visibility:hidden!important;
    pointer-events:none!important;
    z-index:5000!important;
    overflow:hidden!important;
  }

  .nav-drop > div::before{
    content:""!important;
    position:absolute!important;
    left:0!important;
    right:0!important;
    top:-22px!important;
    height:24px!important;
    display:block!important;
  }

  .nav-drop:hover > div,
  .nav-drop:focus-within > div,
  .nav-drop.is-open > div{
    opacity:1!important;
    visibility:visible!important;
    pointer-events:auto!important;
    transform:translateX(-50%) translateY(0)!important;
  }

  .nav-drop > div a{
    display:flex!important;
    align-items:center!important;
    min-height:44px!important;
    padding:12px 14px!important;
    border-radius:14px!important;
    color:rgba(255,247,239,.78)!important;
    font-weight:900!important;
  }

  .nav-drop > div a:hover,
  .nav-drop > div a.is-active{
    color:#fff!important;
    background:rgba(255,73,67,.14)!important;
  }
}

/* Desktop header player volume: expand inline to the right and never drop below */
@media (min-width: 761px){
  .header-player.player-ui{
    grid-template-columns:48px minmax(120px,1fr) 44px 44px!important;
    width:clamp(420px,30vw,560px)!important;
    min-width:420px!important;
    max-width:660px!important;
    overflow:visible!important;
  }

  .header-player.player-ui:has(.volume-wrap:hover),
  .header-player.player-ui:has(.volume-wrap:focus-within),
  .header-player.player-ui:has(.volume-wrap.is-volume-open){
    grid-template-columns:48px minmax(110px,1fr) 44px 174px!important;
    width:clamp(540px,38vw,680px)!important;
    min-width:540px!important;
  }

  .header-player .play-btn,
  .header-player .volume-icon{
    width:44px!important;
    height:44px!important;
    min-width:44px!important;
    min-height:44px!important;
    border-radius:999px!important;
    display:grid!important;
    place-items:center!important;
    padding:0!important;
    line-height:0!important;
  }

  .header-player .volume-wrap{
    position:relative!important;
    width:44px!important;
    min-width:44px!important;
    max-width:none!important;
    height:44px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
    gap:10px!important;
    overflow:hidden!important;
    transition:width .22s ease!important;
  }

  .header-player .volume-wrap:hover,
  .header-player .volume-wrap:focus-within,
  .header-player .volume-wrap.is-volume-open{
    width:174px!important;
    min-width:174px!important;
  }

  .header-player .volume{
    position:static!important;
    width:0!important;
    min-width:0!important;
    height:auto!important;
    padding:0!important;
    opacity:0!important;
    pointer-events:none!important;
    transform:none!important;
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    accent-color:var(--brand)!important;
    transition:width .22s ease, opacity .16s ease!important;
  }

  .header-player .volume-wrap:hover .volume,
  .header-player .volume-wrap:focus-within .volume,
  .header-player .volume-wrap.is-volume-open .volume{
    width:118px!important;
    opacity:1!important;
    pointer-events:auto!important;
  }
}

/* Mobile player volume: tap icon to open a neat popup above player */
@media (max-width: 760px){
  .mobile-player.player-ui{
    grid-template-columns:58px minmax(0,1fr) 48px 44px!important;
    gap:12px!important;
    overflow:visible!important;
    padding-bottom:16px!important;
  }

  .mobile-player .play-btn,
  .mobile-player .volume-icon{
    width:44px!important;
    height:44px!important;
    min-width:44px!important;
    min-height:44px!important;
    border-radius:999px!important;
    display:grid!important;
    place-items:center!important;
    padding:0!important;
    line-height:0!important;
  }

  .mobile-player .volume-wrap{
    position:relative!important;
    width:44px!important;
    min-width:44px!important;
    max-width:44px!important;
    height:44px!important;
    display:grid!important;
    place-items:center!important;
    overflow:visible!important;
  }

  .mobile-player .volume{
    position:absolute!important;
    right:0!important;
    bottom:58px!important;
    width:min(220px,calc(100vw - 44px))!important;
    height:48px!important;
    padding:0 16px!important;
    opacity:0!important;
    pointer-events:none!important;
    transform:translateY(10px)!important;
    border:1px solid rgba(255,255,255,.14)!important;
    border-radius:18px!important;
    background:rgba(9,12,18,.98)!important;
    box-shadow:0 18px 60px rgba(0,0,0,.58)!important;
    accent-color:var(--brand)!important;
    z-index:10005!important;
    transition:opacity .18s ease, transform .18s ease!important;
  }

  /* kill hover opening on touch screens */
  .mobile-player .volume-wrap:hover .volume,
  .mobile-player .volume-wrap:focus-within .volume{
    opacity:0!important;
    pointer-events:none!important;
    transform:translateY(10px)!important;
  }

  .mobile-player .volume-wrap.is-volume-open .volume{
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateY(0)!important;
  }
}

/* =========================================================
   TRR 12.9 FINAL PATCH: logo, correct player visibility,
   mobile tap-volume popup, and stable custom icon sizing
   ========================================================= */
.brand-mark-logo{
  width:52px!important;
  height:52px!important;
  overflow:hidden!important;
  background:transparent!important;
  display:block!important;
  border-radius:999px!important;
  box-shadow:0 0 0 1px rgba(255,255,255,.12)!important;
}
.brand-mark-logo img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
}

.play-btn,
.volume-icon{
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  min-height:44px!important;
  padding:0!important;
  border-radius:999px!important;
  display:grid!important;
  place-items:center!important;
  line-height:0!important;
  overflow:hidden!important;
  background:rgba(255,255,255,.06)!important;
  border:1px solid rgba(255,255,255,.12)!important;
}
.play-btn::before,
.play-btn::after,
.volume-icon::before,
.volume-icon::after{content:none!important;display:none!important;}
.play-btn img,
.volume-icon img,
.play-icon,
.volume-img{
  width:18px!important;
  height:18px!important;
  max-width:18px!important;
  max-height:18px!important;
  object-fit:contain!important;
  display:block!important;
  pointer-events:none!important;
}
.volume-icon img{width:20px!important;height:20px!important;max-width:20px!important;max-height:20px!important;}

.header-player.player-ui{
  grid-template-columns:48px minmax(0,1fr) 44px 44px!important;
  align-items:center!important;
  gap:12px!important;
  overflow:visible!important;
}
.header-player .player-cover{width:46px!important;height:46px!important;}
.header-player .volume-wrap{
  position:relative!important;
  width:44px!important;
  min-width:44px!important;
  height:44px!important;
  display:flex!important;
  align-items:center!important;
  gap:10px!important;
  overflow:visible!important;
  transition:width .22s ease!important;
}
.header-player .volume{
  position:absolute!important;
  left:calc(100% + 10px)!important;
  right:auto!important;
  top:50%!important;
  bottom:auto!important;
  transform:translateY(-50%)!important;
  width:0!important;
  min-width:0!important;
  opacity:0!important;
  pointer-events:none!important;
  height:auto!important;
  padding:0!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
  accent-color:var(--brand)!important;
  transition:width .2s ease, opacity .18s ease!important;
  z-index:4!important;
}
.header-player .volume-wrap:hover .volume,
.header-player .volume-wrap:focus-within .volume,
.header-player .volume-wrap.is-volume-open .volume{
  width:116px!important;
  opacity:1!important;
  pointer-events:auto!important;
}
.header-player.player-ui:has(.volume-wrap:hover),
.header-player.player-ui:has(.volume-wrap:focus-within),
.header-player.player-ui:has(.volume-wrap.is-volume-open){
  padding-right:140px!important;
}

.mobile-player.player-ui{display:none!important;}
.mobile-menu-toggle{font-size:0!important;position:relative;}
.mobile-menu-toggle::after{content:'Menu';font-size:14px;}

@media (max-width:760px){
  .header-inner{
    width:100%!important;
    min-height:72px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:12px!important;
    padding:0 14px!important;
  }
  .brand-copy strong{font-size:16px!important;}
  .brand-copy small{max-width:190px!important;}
  .brand-mark-logo{width:44px!important;height:44px!important;}
  .header-player.player-ui{display:none!important;}
  .nav{
    position:fixed!important;
    top:72px!important;
    left:12px!important;
    right:12px!important;
    z-index:90!important;
    display:none!important;
    padding:12px!important;
    border:1px solid rgba(255,255,255,.10)!important;
    border-radius:20px!important;
    background:rgba(7,9,13,.96)!important;
    box-shadow:0 20px 70px rgba(0,0,0,.55)!important;
  }
  body.nav-open .nav{display:grid!important;gap:6px!important;}
  .nav a,.nav button{padding:14px!important;text-align:left!important;width:100%!important;}
  .nav-drop > div{position:static!important;transform:none!important;opacity:1!important;visibility:visible!important;pointer-events:auto!important;display:none!important;box-shadow:none!important;margin:4px 0 0!important;min-width:0!important;}
  .nav-drop.is-open > div{display:grid!important;}
  .mobile-menu-toggle{display:block!important;}

  .mobile-player.player-ui{
    position:fixed!important;
    left:12px!important;
    right:12px!important;
    bottom:calc(12px + env(safe-area-inset-bottom))!important;
    z-index:1000!important;
    display:grid!important;
    grid-template-columns:56px minmax(0,1fr) 44px 44px!important;
    gap:10px!important;
    align-items:center!important;
    padding:12px!important;
    border:1px solid rgba(255,255,255,.14)!important;
    border-radius:22px!important;
    background:linear-gradient(135deg,rgba(13,17,24,.96),rgba(39,20,28,.96))!important;
    backdrop-filter:blur(22px)!important;
    box-shadow:0 18px 60px rgba(0,0,0,.56)!important;
    overflow:visible!important;
  }
  .mobile-player .player-cover{width:56px!important;height:56px!important;border-radius:15px!important;object-fit:cover!important;}
  .mobile-player .player-meta small{font-size:10px!important;}
  .mobile-player .player-title{font-size:15px!important;}
  .mobile-player .player-artist{font-size:12px!important;}
  .mobile-player .play-btn,
  .mobile-player .volume-icon{width:42px!important;height:42px!important;min-width:42px!important;min-height:42px!important;}
  .mobile-player .volume-wrap{
    position:relative!important;
    width:42px!important;
    min-width:42px!important;
    max-width:42px!important;
    height:42px!important;
    display:grid!important;
    place-items:center!important;
    overflow:visible!important;
  }
  .mobile-player .volume{
    position:absolute!important;
    right:0!important;
    bottom:58px!important;
    width:220px!important;
    max-width:calc(100vw - 34px)!important;
    height:52px!important;
    padding:0 18px!important;
    opacity:0!important;
    pointer-events:none!important;
    transform:translateY(8px)!important;
    border:1px solid rgba(255,255,255,.14)!important;
    border-radius:18px!important;
    background:rgba(8,11,16,.98)!important;
    box-shadow:0 18px 60px rgba(0,0,0,.60)!important;
    accent-color:var(--brand)!important;
    z-index:1002!important;
    transition:opacity .18s ease, transform .18s ease!important;
  }
  .mobile-player .volume-wrap:hover .volume,
  .mobile-player .volume-wrap:focus-within .volume{
    opacity:0!important;
    pointer-events:none!important;
    transform:translateY(8px)!important;
  }
  .mobile-player .volume-wrap.is-volume-open .volume{
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateY(0)!important;
  }
  body{padding-bottom:106px!important;}
}

/* === v12.10 mobile volume card correction === */
.volume-icon{
  appearance:none!important;
  -webkit-appearance:none!important;
  border:none;
  cursor:pointer;
}
.volume-wrap{
  position:relative!important;
  overflow:visible!important;
}
.volume-popover{
  position:absolute;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:10020;
}
.volume-wrap.is-volume-open .volume-popover{
  opacity:1;
  pointer-events:auto;
}
.volume-popover .volume{
  position:static!important;
  width:100%!important;
  max-width:100%!important;
  opacity:1!important;
  pointer-events:auto!important;
  transform:none!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0!important;
  height:32px!important;
  accent-color:var(--brand)!important;
}

/* Desktop: slider expands inline to the right of the volume icon inside the header player. */
.header-player.player-ui{
  grid-template-columns:48px minmax(0,1fr) 44px 44px!important;
  overflow:visible!important;
}
.header-player .volume-wrap{
  width:44px!important;
  min-width:44px!important;
  height:44px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:10px!important;
  transition:width .22s ease!important;
}
.header-player .volume-popover{
  left:52px!important;
  top:50%!important;
  transform:translateY(-50%) scaleX(.96)!important;
  width:126px!important;
  height:36px!important;
  display:flex!important;
  align-items:center!important;
  padding:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
}
.header-player .volume-wrap:hover,
.header-player .volume-wrap:focus-within,
.header-player .volume-wrap.is-volume-open{
  width:178px!important;
  min-width:178px!important;
}
.header-player .volume-wrap:hover .volume-popover,
.header-player .volume-wrap:focus-within .volume-popover,
.header-player .volume-wrap.is-volume-open .volume-popover{
  opacity:1!important;
  pointer-events:auto!important;
  transform:translateY(-50%) scaleX(1)!important;
}
.header-player.player-ui:has(.volume-wrap:hover),
.header-player.player-ui:has(.volume-wrap:focus-within),
.header-player.player-ui:has(.volume-wrap.is-volume-open){
  grid-template-columns:48px minmax(0,1fr) 44px 178px!important;
  padding-right:12px!important;
}

/* Mobile: tapping the main volume icon opens one card above the player. No hover, no second icon. */
@media(max-width:760px){
  .mobile-player.player-ui{
    grid-template-columns:56px minmax(0,1fr) 44px 44px!important;
    overflow:visible!important;
  }
  .mobile-player .volume-wrap{
    width:44px!important;
    min-width:44px!important;
    max-width:44px!important;
    height:44px!important;
    position:relative!important;
    display:grid!important;
    place-items:center!important;
  }
  .mobile-player .volume-popover{
    right:0!important;
    bottom:calc(100% + 16px)!important;
    width:min(260px,calc(100vw - 32px))!important;
    height:58px!important;
    padding:13px 18px!important;
    border:1px solid rgba(255,255,255,.14)!important;
    border-radius:18px!important;
    background:linear-gradient(135deg,rgba(12,16,23,.98),rgba(38,20,30,.98))!important;
    box-shadow:0 20px 70px rgba(0,0,0,.62)!important;
    backdrop-filter:blur(18px)!important;
    transform:translateY(10px)!important;
  }
  .mobile-player .volume-wrap:hover .volume-popover,
  .mobile-player .volume-wrap:focus-within .volume-popover{
    opacity:0!important;
    pointer-events:none!important;
    transform:translateY(10px)!important;
  }
  .mobile-player .volume-wrap.is-volume-open .volume-popover{
    opacity:1!important;
    pointer-events:auto!important;
    transform:translateY(0)!important;
  }
  .mobile-player .volume-wrap.is-volume-open .volume-popover .volume,
  .mobile-player .volume-popover .volume{
    display:block!important;
    width:100%!important;
  }
}

.rock-news-panel{
    margin-top:30px;
}

.rock-news-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:18px;
}

.rock-news-card{
    display:flex;
    flex-direction:column;
    overflow:hidden;
    border-radius:18px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    transition:.25s ease;
}

.rock-news-card:hover{
    transform:translateY(-4px);
    border-color:rgba(255,75,75,.4);
}

.rock-news-card img{
    width:100%;
    height:200px;
    object-fit:cover;
    display:block;
}

.rock-news-content{
    padding:16px;
    display:flex;
    flex-direction:column;
    gap:10px;
    flex:1;
}

.rock-news-content span{
    color:#ff5a55;
    font-size:.75rem;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.12em;
}

.rock-news-content h3{
    font-size:1rem;
    line-height:1.35;
    margin:0;
}

.rock-news-content p{
    color:rgba(255,255,255,.7);
    font-size:.9rem;
    line-height:1.5;

    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

.rock-news-content a{
    margin-top:auto;
    color:#ff5a55;
    text-decoration:none;
    font-weight:700;
}

.rock-news-card.is-hidden{
    display:none;
}

@media (max-width:1200px){
    .rock-news-grid{
        grid-template-columns:repeat(2,1fr);
    }
}

@media (max-width:768px){
    .rock-news-grid{
        grid-template-columns:1fr;
    }
}

.orh-footer{
  border-top:1px solid rgba(255,255,255,.1);
  padding:26px 18px calc(26px + env(safe-area-inset-bottom));
  background:
    radial-gradient(circle at 50% 0,rgba(255,69,69,.12),transparent 35%),
    rgba(5,7,13,.92);
}

.orh-footer-inner{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
  text-align:left;
}

.orh-label{
  color:rgba(255,255,255,.52);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.72rem;
  font-weight:900;
}

.orh-brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  padding:11px 14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(255,255,255,.045);
  color:#fff;
  text-decoration:none;
  transition:.2s ease;
}

.orh-brand:hover{
  transform:translateY(-2px);
  border-color:rgba(255,69,69,.4);
  background:rgba(255,69,69,.08);
}

.orh-mark{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:linear-gradient(135deg,#ff4545,#7a1015);
  color:#fff;
  font-weight:950;
  letter-spacing:-.05em;
  box-shadow:0 12px 30px rgba(255,69,69,.18);
}

.orh-brand strong,
.orh-brand small{
  display:block;
}

.orh-brand strong{
  font-size:.98rem;
  line-height:1.1;
}

.orh-brand small{
  color:rgba(255,255,255,.58);
  font-size:.78rem;
  margin-top:3px;
}

@media(max-width:620px){
  .orh-footer-inner{
    flex-direction:column;
    text-align:center;
  }

  .orh-brand{
    width:100%;
    max-width:340px;
    justify-content:center;
  }
}

.trr-hero{
  width:100vw !important;
  margin-left:calc(50% - 50vw) !important;
  margin-right:calc(50% - 50vw) !important;
  min-height:560px !important;
  padding:90px max(48px, calc((100vw - 1500px) / 2 + 48px)) 150px !important;
  border-radius:0 !important;
  background-size:cover !important;
  background-position:center center !important;
}

.trr-hero-bg{
  background-size:cover !important;
  background-position:center center !important;
}

.trr-live-signal{
  margin-top:-95px !important;
  position:relative;
  z-index:5;
}

.trr-hero-actions{
  position:relative;
  z-index:10;
}

@media(max-width:760px){
  .trr-hero{
    min-height:620px !important;
    padding:80px 22px 130px !important;
    background-position:center center !important;
  }

  .trr-live-signal{
    margin-top:-70px !important;
  }
}

@media(max-width:760px){

  .mobile-menu-toggle{
    width:auto !important;
    min-width:72px !important;
    height:44px !important;
    padding:0 14px !important;
    border-radius:999px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:7px !important;
    font-size:.85rem !important;
    line-height:1 !important;
  }

  .mobile-menu-toggle::before{
    content:"☰";
    font-size:1.25rem;
    line-height:1;
  }

  .recent-cards{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:12px !important;
    overflow:visible !important;
  }

  .recent-card{
    min-width:0 !important;
    padding:10px !important;
  }

  .recent-card img{
    width:100% !important;
    aspect-ratio:1/1 !important;
    height:auto !important;
    object-fit:cover !important;
    border-radius:12px !important;
  }

  .recent-card strong{
    font-size:.95rem !important;
    white-space:nowrap !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }

  .recent-card span,
  .recent-card small{
    font-size:.78rem !important;
  }

  .schedule-list{
    gap:12px !important;
  }

  .schedule-item{
    display:grid !important;
    grid-template-columns:74px minmax(0,1fr) auto !important;
    gap:12px !important;
    padding:14px 16px !important;
    align-items:center !important;
  }

  .schedule-item > span{
    width:74px !important;
    min-width:74px !important;
    padding:9px 8px !important;
    text-align:center !important;
    font-size:.72rem !important;
    line-height:1.05 !important;
    border-radius:10px !important;
  }

  .schedule-item strong{
    font-size:1rem !important;
    line-height:1.15 !important;
  }

  .schedule-item small{
    font-size:.82rem !important;
  }

  .schedule-item b{
    display:none !important;
  }
}

@media(max-width:430px){
  .recent-cards{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .trr-panel{
    padding:16px !important;
  }

  .trr-section-head{
    gap:12px !important;
  }

  .trr-section-head h2{
    font-size:1.25rem !important;
  }

  .trr-section-head a{
    font-size:.8rem !important;
    padding:10px 12px !important;
  }
}

.signal-show img{
  width:76px;
  height:76px;
  border-radius:18px;
  object-fit:cover;
}

.trr-whats-coming .schedule-item.active > span{
  background:#ff4545;
  color:#fff;
}

@media(max-width:760px){
  .signal-show img{
    width:58px;
    height:58px;
    border-radius:14px;
  }
}
.signal-listeners,
[data-listener-count]{
  display:none !important;
}

@media(max-width:760px){
  .trr-grid-main{
    display:flex !important;
    flex-direction:column !important;
  }

  .trr-whats-on,
  .trr-whats-coming{
    order:1 !important;
  }

  .trr-recent{
    order:2 !important;
  }
}
.trr-live-signal{
  display:grid !important;
  grid-template-columns:auto minmax(220px,420px) minmax(0,1fr) !important;
  align-items:center !important;
  gap:28px !important;
  padding:28px 34px !important;
}

.signal-status{
  white-space:nowrap !important;
}

.signal-bars{
  max-width:420px !important;
  justify-content:flex-start !important;
}

.signal-now.signal-show{
  display:flex !important;
  align-items:center !important;
  gap:18px !important;
  justify-self:end !important;
  min-width:0 !important;
}

.signal-now.signal-show img{
  width:82px !important;
  height:82px !important;
  border-radius:18px !important;
  object-fit:cover !important;
}

.signal-now.signal-show small{
  color:#ff6b66 !important;
  text-transform:uppercase !important;
  letter-spacing:.16em !important;
  font-weight:950 !important;
}

.signal-now.signal-show strong{
  display:block !important;
  font-size:clamp(1.8rem,3vw,3rem) !important;
  line-height:.95 !important;
  letter-spacing:-.04em !important;
  white-space:normal !important;
}

.signal-now.signal-show span{
  display:block !important;
  margin-top:6px !important;
  color:rgba(255,255,255,.7) !important;
}

@media(max-width:900px){
  .trr-live-signal{
    grid-template-columns:1fr !important;
    gap:18px !important;
    padding:22px !important;
  }

  .signal-status{
    justify-content:flex-start !important;
  }

  .signal-bars{
    max-width:none !important;
    width:100% !important;
  }

  .signal-now.signal-show{
    justify-self:stretch !important;
    padding-top:4px !important;
  }

  .signal-now.signal-show img{
    width:64px !important;
    height:64px !important;
    border-radius:14px !important;
  }

  .signal-now.signal-show strong{
    font-size:1.55rem !important;
  }
}

@media(max-width:520px){
  .trr-live-signal{
    border-radius:22px !important;
    padding:20px !important;
  }

  .signal-bars{
    overflow:hidden !important;
  }

  .signal-bars i:nth-child(n+24){
    display:none !important;
  }

  .signal-now.signal-show{
    align-items:center !important;
  }

  .signal-now.signal-show img{
    width:58px !important;
    height:58px !important;
  }

  .signal-now.signal-show small{
    font-size:.72rem !important;
  }

  .signal-now.signal-show strong{
    font-size:1.45rem !important;
  }
}
/* RP2 page styles are included inline in recently-played.php to avoid old global image rules. */
