
:root{
  --blue:#004985;
  --blue2:#007fc1;
  --deep:#06345f;
  --navy:#053761;
  --orange:#f7941d;
  --sky:#eaf7fd;
  --line:#d8eaf5;
  --text:#12324e;
  --muted:#62778b;
  --white:#fff;
  --shadow:0 14px 38px rgba(0,47,87,.12);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Arial,Helvetica,sans-serif;background:var(--sky);color:var(--text);line-height:1.45}
a{color:inherit}
.wrap{width:min(1280px,calc(100% - 64px));margin:0 auto}

/* HEADER */
.site-header{background:#007fc1;position:relative;z-index:5}
.header-top{height:170px;background:#007fc1}
.header-top-inner{height:150px;display:flex;justify-content:flex-end;align-items:center;position:relative}
.logo{
position:absolute;
left:6px !important;
top:0px !important;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}
.logo img{
display:block;
width:100%;
height:auto;
filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))
}
.status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}
.status-item{display:grid;grid-template-columns:52px auto;gap:13px;align-items:center;padding-left:26px;border-left:1px solid var(--line);min-width:0}
.status-item:first-child{border-left:0;padding-left:0}
.status-icon{width:52px;height:52px;border-radius:999px;background:#f4f8fb;border:1px solid #dfebf3;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--deep);font-weight:900;overflow:hidden}
.status-icon img{width:100%;height:100%;object-fit:cover}
.status-icon.record{border-radius:6px;background:var(--deep);color:var(--orange)}
.status-label{display:block;text-transform:uppercase;color:var(--orange);font-size:.78rem;font-weight:900;letter-spacing:.055em;margin-bottom:3px}
.status-title{display:block;color:var(--blue);font-weight:900;font-size:1.12rem;line-height:1.15}
.status-sub{display:block;color:var(--muted);font-size:.92rem;margin-top:4px}
.listen-live{display:inline-flex;align-items:center;justify-content:center;background:var(--orange);color:#fff;text-decoration:none;font-weight:900;text-transform:uppercase;border-radius:4px;padding:17px 31px;box-shadow:0 5px 0 rgba(0,0,0,.17);white-space:nowrap}
.listen-live:hover,.button:hover{filter:brightness(1.04)}

/* NAV - logo drops slightly over left of bar, menu starts after it */
.main-nav{min-height:58px;background:linear-gradient(90deg,var(--deep),#073d6f);box-shadow:0 7px 20px rgba(0,45,90,.18);position:relative;z-index:10}
.nav-inner{padding-left:0;padding-top:0}
.main-nav ul{margin:0;padding:0;display:flex;flex-wrap:wrap;list-style:none}
.main-nav a{min-height:58px;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;font-weight:900;font-size:1.02rem;padding:0 21px;border-left:1px solid rgba(255,255,255,.12)}
.main-nav a:hover,.main-nav a.active{background:var(--orange)}

/* HERO */
.hero{background:linear-gradient(135deg,#1499d4 0%,#0875b6 40%,#004b88 100%);color:#fff;padding:58px 0 62px}
.hero h1{font-size:clamp(3.1rem,6vw,4.75rem);line-height:.95;letter-spacing:-.055em;margin:0 0 18px;font-weight:900}
.hero p{font-size:1.27rem;margin:0;color:rgba(255,255,255,.96)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}

/* LAYOUT */
.main{padding:42px 0 64px}
.two-col{display:grid;grid-template-columns:minmax(0,2fr) 360px;gap:28px;align-items:start}
.three-col{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr) 360px;gap:24px;align-items:start}
.card{background:#fff;border:1px solid var(--line);border-radius:7px;box-shadow:var(--shadow);padding:28px;margin-bottom:24px}
.card h2,.card h3{color:var(--blue);margin-top:0;line-height:1.1}
.card h2{font-size:1.55rem}
.card h2:after{content:"";display:block;width:38px;height:3px;background:var(--orange);margin-top:10px}
.button{display:inline-flex;align-items:center;justify-content:center;background:var(--orange);color:#fff;text-decoration:none;text-transform:uppercase;font-weight:900;padding:14px 24px;border-radius:4px;box-shadow:0 5px 0 rgba(0,0,0,.16);border:0;cursor:pointer}

/* HOME */
.feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:22px}
.feature{background:#f8fcff;border-left:5px solid var(--orange);border-radius:5px;padding:20px}
.feature strong{display:block;color:var(--blue);font-size:1.15rem;margin-bottom:6px}

/* CONTACT */
.contact-boxes{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin:24px 0}
.contact-box{background:#f8fcff;border-left:6px solid var(--orange);border-radius:5px;padding:22px}
.contact-box h3{margin-bottom:10px}
.form{display:grid;gap:15px}
.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:15px}
.form label{display:grid;gap:8px;color:var(--blue);font-weight:900}
.form input,.form textarea{width:100%;border:1px solid #cfdce8;border-radius:4px;background:#fbfdff;padding:13px 14px;font:inherit;color:var(--text)}
.form textarea{min-height:170px;resize:vertical}
.map{border:1px solid #cfdce8;border-radius:6px;overflow:hidden;background:#f5f9fc}
.map iframe{display:block;width:100%;height:335px;border:0}

/* NETWORK */
.network-row{display:grid;grid-template-columns:128px 1fr;gap:16px;align-items:center;padding:16px 0;border-bottom:1px solid var(--line)}
.network-row:last-child{border-bottom:0}
.network-row img{width:128px;height:76px;object-fit:contain;display:block}
.network-row strong{display:block;color:var(--blue);text-transform:uppercase;font-weight:900}
.network-row span,.network-row small{display:block;color:var(--blue);margin-top:5px}

/* SCHEDULE / CREW */
.schedule-day{font-size:1.35rem;color:var(--blue);font-weight:900;text-transform:capitalize;margin:24px 0 10px}
.schedule-item,.crew-card,.played-item{display:grid;grid-template-columns:120px 1fr;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:7px;padding:16px;margin-bottom:12px;box-shadow:0 6px 20px rgba(0,45,90,.06)}
.schedule-time{color:var(--orange);font-weight:900}
.crew-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.crew-card{display:block}
.crew-photo{width:100%;height:170px;border-radius:5px;background:linear-gradient(135deg,#d8edf9,#fff);margin-bottom:14px}

/* FOOTER */
.footer{background:linear-gradient(135deg,var(--deep),var(--navy));color:#fff;margin-top:0}
.footer-main{display:grid;grid-template-columns:1.25fr .9fr 1fr .8fr;gap:32px;padding:34px 0}
.footer h3{margin:0 0 14px;color:#fff;text-transform:uppercase}
.footer a,.footer p{color:rgba(255,255,255,.9);text-decoration:none}
.footer-links{display:grid;grid-template-columns:1fr 1fr;gap:7px 18px}
.footer-bottom{background:rgba(0,0,0,.18);padding:16px 0}
.footer-bottom .wrap{display:flex;justify-content:space-between;gap:20px;color:rgba(255,255,255,.88)}

@media(max-width:1180px){
  .header-top{height:auto}
  .header-top-inner{height:auto;display:grid;gap:20px;justify-content:center;padding:20px 0}
  .logo{
position:absolute;
left:22px;
top:10px;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}
  .status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}
  .nav-inner{padding-left:20px;padding-top:10px}
  .main-nav ul{justify-content:center}
  .two-col,.three-col,.footer-main{grid-template-columns:1fr}
  .crew-grid,.feature-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:700px){
  .wrap{width:min(100% - 32px,1280px)}
  .status-strip,.status-item{display:grid;width:100%}
  .status-item{grid-template-columns:52px 1fr;border-left:0;padding-left:0}
  .form-row,.contact-boxes,.crew-grid,.feature-grid{grid-template-columns:1fr}
  .network-row,.schedule-item{grid-template-columns:1fr;text-align:center}
  .network-row img{margin:0 auto}
  .footer-bottom .wrap{flex-direction:column}
}


/* FIX: logo over left menu bar without covering buttons */
.header-top {
  height: 152px !important;
}

.header-top-inner {
  height: 152px !important;
}

.logo{
position:absolute;
left:22px;
top:10px;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}

.logo img{
display:block;
width:100%;
height:auto;
filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))
}

.status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}

/* Start menu after the logo so nothing sits underneath it */
.nav-inner {
  padding-left: 360px !important;
}

.main-nav ul {
  flex-wrap: nowrap !important;
}

.main-nav a {
  padding-left: 17px !important;
  padding-right: 17px !important;
  font-size: .96rem !important;
  white-space: nowrap !important;
}

@media(max-width:1180px){
  .header-top,
  .header-top-inner {
    height: auto !important;
  }

  .logo{
position:absolute;
left:22px;
top:10px;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}

  .logo img{
display:block;
width:100%;
height:auto;
filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))
}

  .status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}

  .nav-inner {
    padding-left: 0 !important;
  }

  .main-nav ul {
    flex-wrap: wrap !important;
    justify-content: center !important;
  }
}


/* Right side panels - network stations + Facebook feed */
.right-stack {
  display: grid;
  gap: 24px;
}

.facebook-feed {
  min-height: 0;
  padding-bottom: 18px;
}

.facebook-feed-frame {
  border: 0;
  width: 100%;
  height: 500px;
  overflow: hidden;
  border-radius: 6px;
  background: #f7fcff;
}

.facebook-fallback {
  padding: 0;
  background: transparent;
  border-radius: 0;
  border: 0;
  margin-top: 10px;
}

@media (max-width: 1150px) {
  .right-stack {
    display: grid;
    gap: 24px;
  }
}


/* Contact page Northern Ireland weather panel */
.weather-panel {
  overflow: hidden;
}

.weather-current {
  display: grid;
  grid-template-columns: 76px 1fr;
  gap: 16px;
  align-items: center;
  margin-bottom: 18px;
}

.weather-icon {
  width: 76px;
  height: 76px;
  border-radius: 999px;
  background: #f7fcff;
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.4rem;
}

.weather-temp {
  color: var(--blue);
  font-weight: 900;
  font-size: 2rem;
  line-height: 1;
}

.weather-desc {
  color: var(--muted);
  margin-top: 6px;
}

.weather-grid {
  display: grid;
  gap: 10px;
}

.weather-place {
  display: grid;
  grid-template-columns: 38px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #f7fcff;
}

.weather-place .wi {
  font-size: 1.35rem;
}

.weather-place strong {
  display: block;
  color: var(--blue);
}

.weather-place small {
  display: block;
  color: var(--muted);
}

.weather-place .degrees {
  color: var(--orange);
  font-weight: 900;
  white-space: nowrap;
}

.weather-updated {
  margin: 14px 0 0;
  color: var(--muted);
  font-size: .88rem;
}


/* Northern Ireland weather panel */
.weather-panel {
  overflow: hidden;
}

.weather-current {
  display: grid;
  grid-template-columns: 76px 1fr;
  gap: 16px;
  align-items: center;
  margin-bottom: 18px;
}

.weather-icon {
  width: 76px;
  height: 76px;
  border-radius: 999px;
  background: #f7fcff;
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.4rem;
}

.weather-temp {
  color: var(--blue);
  font-weight: 900;
  font-size: 2rem;
  line-height: 1;
}

.weather-desc {
  color: var(--muted);
  margin-top: 6px;
}

.weather-grid {
  display: grid;
  gap: 10px;
}

.weather-place {
  display: grid;
  grid-template-columns: 38px 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #f7fcff;
}

.weather-place .wi {
  font-size: 1.35rem;
}

.weather-place strong {
  display: block;
  color: var(--blue);
}

.weather-place small {
  display: block;
  color: var(--muted);
}

.weather-place .degrees {
  color: var(--orange);
  font-weight: 900;
  white-space: nowrap;
}


.weather-updated {
  display: none !important;
}

/* Modern sunny Northern Ireland refresh */
:root{
  --blue:#0755a3;
  --blue2:#05a7df;
  --deep:#063b72;
  --navy:#072f61;
  --orange:#ff9f18;
  --orange2:#ffc247;
  --aqua:#48d6ff;
  --sky:#e9f9ff;
  --line:rgba(6,74,132,.12);
  --text:#113553;
  --muted:#60788d;
  --shadow:0 22px 55px rgba(1,62,112,.14);
}

html{scroll-behavior:smooth}
body{
  font-family:Arial,Helvetica,sans-serif;
  background:
    radial-gradient(circle at 14% 6%, rgba(255,194,71,.38) 0 130px, transparent 131px),
    radial-gradient(circle at 86% 16%, rgba(72,214,255,.26) 0 180px, transparent 181px),
    linear-gradient(180deg,#f7fdff 0%,#e9f9ff 44%,#fff7e6 100%);
}

.wrap{width:min(1240px,calc(100% - 48px))}
.site-header{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,255,255,.88));
  backdrop-filter:blur(12px);
  box-shadow:0 10px 40px rgba(3,56,104,.08);
}
.header-top,.header-top-inner{height:180px !important}
.logo{
position:absolute;
left:22px;
top:10px;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}
.logo img{
display:block;
width:100%;
height:auto;
filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))
}
.status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}
.status-item{
  border-left:0 !important;
  padding-left:0 !important;
  background:#fff;
  border-radius:22px;
  padding:12px 16px !important;
  box-shadow:0 10px 24px rgba(0,80,145,.08);
}
.status-icon{
  background:linear-gradient(135deg,#fff7dd,#e8f9ff);
  border:0;
  box-shadow:inset 0 -4px 12px rgba(0,121,190,.08);
}
.status-icon.record{
  border-radius:999px;
  background:linear-gradient(135deg,var(--orange),#ff6f18);
  color:#fff;
}
.listen-live,.button{
  border-radius:999px;
  background:linear-gradient(135deg,var(--orange),#ff7f18);
  box-shadow:0 12px 24px rgba(255,127,24,.28), inset 0 1px 0 rgba(255,255,255,.45);
  letter-spacing:.035em;
}
.main-nav{
  background:linear-gradient(90deg,#074984,#077bbb 55%,#05a7df);
  box-shadow:0 14px 30px rgba(0,72,130,.18);
}
.nav-inner{padding-left:20px;padding-top:10px}
.main-nav a{
  min-height:62px;
  border-left:0;
  border-radius:999px;
  margin:7px 2px;
  padding-left:16px !important;
  padding-right:16px !important;
}
.main-nav a:hover,.main-nav a.active{background:linear-gradient(135deg,var(--orange),#ff7f18)}

.hero{
  position:relative;
  overflow:hidden;
  padding:82px 0 90px;
  background:
    radial-gradient(circle at 8% 16%, rgba(255,194,71,.95) 0 85px, transparent 86px),
    radial-gradient(circle at 90% 12%, rgba(255,255,255,.34) 0 160px, transparent 161px),
    linear-gradient(135deg,#10b5e7 0%,#0879c8 42%,#0755a3 100%);
}
.hero:before{
  content:"";
  position:absolute;
  inset:auto -10% -70px -10%;
  height:170px;
  background:radial-gradient(ellipse at center, rgba(255,255,255,.92), rgba(255,255,255,0) 70%);
  opacity:.55;
}
.hero:after{
  content:"";
  position:absolute;
  right:-70px;
  bottom:-80px;
  width:420px;
  height:420px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,194,71,.46), rgba(255,194,71,0) 68%);
}
.hero .wrap{position:relative;z-index:1;max-width:1240px}
.hero h1{
  max-width:850px;
  font-size:clamp(3.3rem,7vw,6.2rem);
  text-shadow:0 8px 24px rgba(0,50,98,.18);
}
.hero p{max-width:700px;font-size:clamp(1.15rem,2vw,1.45rem)}
.hero-actions{margin-top:30px}
.card{
  border:1px solid rgba(7,85,163,.1);
  border-radius:28px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card h2{font-size:1.75rem;letter-spacing:-.02em}
.card h2:after{width:56px;height:5px;border-radius:999px;background:linear-gradient(90deg,var(--orange),var(--aqua))}
.feature{
  border-left:0;
  border-radius:24px;
  background:linear-gradient(180deg,#fff,#f0fbff);
  box-shadow:inset 0 0 0 1px rgba(7,85,163,.08);
}
.schedule-item,.crew-card,.played-item,.weather-place{
  border-radius:20px;
  border-color:rgba(7,85,163,.1);
  box-shadow:0 10px 28px rgba(0,74,135,.08);
}
.weather-icon{background:linear-gradient(135deg,#fff3cf,#e7fbff);border:0}
.weather-place{background:linear-gradient(135deg,#fff,#f0fbff)}
.network-row{grid-template-columns:150px 1fr}
.network-row img{width:150px;height:92px}
.footer{background:linear-gradient(135deg,#063b72,#0755a3 55%,#007fc1)}

@media(max-width:1180px){
  .header-top,.header-top-inner{height:auto !important}
  .logo{
position:absolute;
left:22px;
top:10px;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}
  .logo img{
display:block;
width:100%;
height:auto;
filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))
}
  .status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}
  .nav-inner{padding-left:20px;padding-top:10px}
}
@media(max-width:760px){
  .wrap{width:min(100% - 28px,1240px)}
  .hero{padding:54px 0 60px}
  .hero h1{font-size:clamp(2.55rem,13vw,4rem)}
  .status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}
  .main-nav a{min-height:48px;margin:4px 2px}
  .card{border-radius:22px;padding:22px}
}


/* V9: real Northern Ireland beach photo header; menu remains separate */
.header-top{
  background:
    linear-gradient(90deg, rgba(0,39,82,.56), rgba(0,119,176,.18)),
    url('assets/canary-islands-beach-header.jpg') center center / cover no-repeat !important;
  height:170px !important;
  min-height:170px !important;
  overflow:visible !important;
}

.header-top-inner{
  height:170px !important;
  min-height:170px !important;
  position:relative;
}

.logo{
position:absolute;
left:22px;
top:10px;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}

.logo img{
display:block;
width:100%;
height:auto;
filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))
}

.status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}

.main-nav{
  min-height:58px !important;
  background:linear-gradient(90deg,var(--deep),#073d6f) !important;
  position:relative !important;
  z-index:10 !important;
  box-shadow:0 7px 20px rgba(0,45,90,.18) !important;
}

.nav-inner{
  padding-left:0 !important;
  padding-top:0 !important;
}

@media(max-width:1180px){
  .header-top,.header-top-inner{height:150px !important;min-height:150px !important}
  .logo{
position:absolute;
left:22px;
top:10px;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}
  .status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}
}

@media(max-width:760px){
  .header-top,.header-top-inner{height:auto !important;min-height:0 !important}
  .logo{
position:absolute;
left:22px;
top:10px;
width:285px;
z-index:30;
transform:rotate(-3deg);
transform-origin:left center;
transition:transform .25s ease
}
  .status-strip{
margin-left:335px;
display:flex;
align-items:center;
justify-content:flex-end;
gap:24px;
min-width:0
}
  .nav-inner{padding-left:0 !important}
}






/* Reverted clean white header */
.site-header{
  background:#ffffff !important;
}

.header-top{
  background:#ffffff !important;
  height:125px !important;
  min-height:125px !important;
  overflow:visible !important;
  position:relative !important;
  border-bottom:1px solid rgba(0,95,160,.12) !important;
}

.header-top-inner{
  height:125px !important;
  min-height:125px !important;
  position:relative !important;
}

.logo{
  position:absolute !important;
  left:24px !important;
  top:12px !important;
  width:300px !important;
  transform:rotate(-3deg) !important;
  transform-origin:left center !important;
  z-index:40 !important;
}

.logo img{
  display:block !important;
  width:100% !important;
  height:auto !important;
  filter:none !important;
}

.status-strip{
  margin-left:360px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:24px !important;
  min-width:0 !important;
}

.main-nav{
  position:relative !important;
  z-index:20 !important;
  background:rgba(0,127,193,.92) !important;
  border-top:0 !important;
  border-bottom:3px solid #ff9f1a !important;
}

.nav-inner{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  padding-left:320px !important;
  gap:10px !important;
  padding-left:0 !important;
  padding-top:0 !important;
}

@media(max-width:1180px){
  .logo{width:245px !important;}
  .status-strip{margin-left:300px !important;gap:14px !important;}
}

@media(max-width:760px){
  .header-top,
  .header-top-inner{
    height:auto !important;
    min-height:0 !important;
  }
  .logo{
    width:200px !important;
    position:relative !important;
    left:auto !important;
    top:8px !important;
    transform:none !important;
    margin:14px auto 8px !important;
  }
  .status-strip{
    margin-left:0 !important;
    justify-content:center !important;
    flex-wrap:wrap !important;
  }
  .nav-inner{
    flex-wrap:wrap !important;
  }
}


/* Facebook page box */
.facebook-embed{
  width:100%;
  max-width:500px;
  height:300px;
  max-height:300px;
  overflow:hidden;
  border-radius:18px;
  background:#fff;
}

.facebook-embed iframe{
  display:block;
  width:100% !important;
  max-width:500px;
  height:300px !important;
  min-height:300px;
  max-height:300px;
}


/* Homepage hero slider */
.hero-slider{
  position:relative;
  min-height:520px;
  padding:0;
  overflow:hidden;
  background:#007fc1;
}

.hero-slider .slides{
  position:relative;
  min-height:520px;
}

.hero-slider .slide{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
  background-size:cover;
  background-position:center;
  transition:opacity .6s ease;
}

.hero-slider .slide.active{
  opacity:1;
  pointer-events:auto;
}

.slide-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,74,140,.82) 0%, rgba(0,129,190,.54) 44%, rgba(0,42,88,.32) 100%),
    radial-gradient(circle at 9% 18%, rgba(255,190,42,.55), transparent 9%),
    radial-gradient(circle at 88% 32%, rgba(255,255,255,.32), transparent 14%);
}

.slide-content{
  position:relative;
  z-index:2;
  min-height:520px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  color:#fff;
}

.slide-content h1{
  max-width:760px;
  margin:0 0 18px;
  font-size:clamp(3.2rem,7vw,6.8rem);
  line-height:.92;
  letter-spacing:-.065em;
  color:#fff;
  text-shadow:0 4px 24px rgba(0,46,98,.28);
}

.slide-content p{
  max-width:700px;
  font-size:1.35rem;
  line-height:1.45;
  margin:0 0 28px;
  color:#fff;
  text-shadow:0 2px 10px rgba(0,46,98,.25);
}

.slider-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:48px;
  height:48px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  color:#005da8;
  font-size:2.5rem;
  line-height:1;
  cursor:pointer;
  box-shadow:0 10px 25px rgba(0,0,0,.18);
}

.slider-arrow.prev{left:22px}
.slider-arrow.next{right:22px}

.slider-dots{
  position:absolute;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
  z-index:5;
  display:flex;
  gap:10px;
}

.slider-dots button{
  width:12px;
  height:12px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.62);
  cursor:pointer;
}

.slider-dots button.active{
  width:34px;
  background:#ff8a18;
}

@media(max-width:760px){
  .hero-slider,
  .hero-slider .slides,
  .slide-content{
    min-height:500px;
  }

  .slide-content h1{
    font-size:clamp(2.8rem,14vw,4.5rem);
  }

  .slide-content p{
    font-size:1.08rem;
  }

  .slider-arrow{
    display:none;
  }
}

/* CLEAN REBUILT HEADER - single source of truth */
.site-header{
  background:#fff !important;
  border:0 !important;
  box-shadow:none !important;
  position:relative !important;
  z-index:20 !important;
}

.header-top{
  background:#fff !important;
  height:124px !important;
  min-height:124px !important;
  border:0 !important;
  box-shadow:none !important;
  overflow:visible !important;
}

.header-top-inner{
  height:124px !important;
  min-height:124px !important;
  display:grid !important;
  grid-template-columns:340px 1fr !important;
  align-items:center !important;
  column-gap:28px !important;
  position:relative !important;
}

.logo{
  position:relative !important;
  left:auto !important;
  right:auto !important;
  top:auto !important;
  width:315px !important;
  max-width:315px !important;
  margin:0 !important;
  transform:none !important;
  z-index:40 !important;
  grid-column:1 !important;
  justify-self:start !important;
}

.logo img{
  display:block !important;
  width:100% !important;
  height:auto !important;
}

.status-strip{
  position:relative !important;
  grid-column:2 !important;
  display:flex !important;
  justify-content:flex-end !important;
  align-items:center !important;
  gap:16px !important;
  margin:0 !important;
  padding:0 !important;
  width:100% !important;
  max-width:none !important;
  z-index:30 !important;
}

.status-item{
  margin:0 !important;
  min-height:70px !important;
  box-sizing:border-box !important;
}

.listen-live{
  margin:0 !important;
  min-height:58px !important;
  white-space:nowrap !important;
  box-sizing:border-box !important;
}

.main-nav{
  background:#fff !important;
  background-image:none !important;
  border:0 !important;
  box-shadow:none !important;
  margin:0 !important;
  padding:0 !important;
  min-height:54px !important;
  position:relative !important;
  z-index:10 !important;
  overflow:visible !important;
}

.main-nav::before,
.main-nav::after,
.header-top::before,
.header-top::after,
.site-header::before,
.site-header::after{
  display:none !important;
  content:none !important;
}

.main-nav .wrap{
  width:min(100% - 36px,1240px) !important;
  margin:0 auto !important;
  padding:0 !important;
}

.nav-inner{
  width:100% !important;
  min-height:54px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  padding-left:320px !important;
  flex-wrap:nowrap !important;
  gap:10px !important;
  margin:0 !important;
  padding:0 !important;
  transform:none !important;
}

.main-nav a{
  flex:0 0 auto !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:42px !important;
  margin:0 !important;
  padding:10px 16px !important;
  border-radius:999px !important;
  color:#00539f !important;
  background:transparent !important;
  text-decoration:none !important;
  white-space:nowrap !important;
}

.main-nav a:hover,
.main-nav a.active,
.main-nav .active{
  color:#fff !important;
  background:#ff8a18 !important;
}

.hero-slider,
.hero{
  border-top:1px solid rgba(0,95,160,.12) !important;
}

@media(max-width:1180px){
  .header-top,
  .header-top-inner{
    height:auto !important;
    min-height:0 !important;
  }

  .header-top{
    padding:12px 0 !important;
  }

  .header-top-inner{
    grid-template-columns:260px 1fr !important;
    column-gap:18px !important;
  }

  .logo{
    width:250px !important;
    max-width:250px !important;
  }

  .status-strip{
    gap:10px !important;
  }
}

@media(max-width:760px){
  html,body{
    overflow-x:hidden !important;
  }

  .wrap{
    width:calc(100% - 24px) !important;
    max-width:calc(100% - 24px) !important;
  }

  .header-top{
    height:auto !important;
    min-height:0 !important;
    padding:10px 0 12px !important;
  }

  .header-top-inner{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    height:auto !important;
    min-height:0 !important;
    gap:10px !important;
  }

  .logo{
    width:230px !important;
    max-width:82vw !important;
    margin:0 auto !important;
  }

  .status-strip{
    display:grid !important;
    grid-template-columns:1fr !important;
    width:100% !important;
    gap:8px !important;
  }

  .status-item,
  .listen-live{
    width:100% !important;
    min-height:0 !important;
  }

  .main-nav{
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
  }

  .main-nav .wrap{
    width:100% !important;
    max-width:100% !important;
  }

  .nav-inner{
    width:max-content !important;
    min-width:100% !important;
    justify-content:flex-start !important;
    gap:6px !important;
    padding:0 8px !important;
  }

  .main-nav a{
    padding:10px 13px !important;
    font-size:.9rem !important;
  }
}

/* HEADER SPACING FIX - prevents logo/status/menu overlap */
.header-top{
  height:170px !important;
  min-height:170px !important;
  padding:0 !important;
  overflow:visible !important;
}

.header-top-inner{
  height:170px !important;
  min-height:170px !important;
  display:grid !important;
  grid-template-columns:360px 1fr !important;
  align-items:center !important;
  column-gap:32px !important;
}

.logo{
  width:355px !important;
  max-width:355px !important;
  align-self:center !important;
  z-index:40 !important;
}

.status-strip{
  align-self:center !important;
  display:flex !important;
  justify-content:flex-end !important;
  align-items:center !important;
  gap:18px !important;
  margin:0 !important;
  padding:0 !important;
}

.status-item{
  min-height:76px !important;
}

.listen-live{
  min-height:60px !important;
}

/* Nav sits below the header, not through it */
.main-nav{
  position:relative !important;
  z-index:5 !important;
  clear:both !important;
  background:linear-gradient(90deg,#007fc1,#05afd3) !important;
  background-image:linear-gradient(90deg,#007fc1,#05afd3) !important;
  min-height:56px !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  box-shadow:none !important;
}

.nav-inner{
  min-height:56px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  padding-left:320px !important;
  gap:10px !important;
  margin:0 !important;
  padding:0 !important;
}

.main-nav a{
  color:#ffffff !important;
  background:transparent !important;
  padding:10px 16px !important;
}

.main-nav a:hover,
.main-nav a.active,
.main-nav .active{
  color:#ffffff !important;
  background:#ff8a18 !important;
}

.hero-slider,
.hero{
  border-top:0 !important;
}

/* Medium width: stack status neatly if needed */
@media(max-width:1180px){
  .header-top{
    height:auto !important;
    min-height:0 !important;
    padding:14px 0 !important;
  }

  .header-top-inner{
    height:auto !important;
    min-height:0 !important;
    grid-template-columns:280px 1fr !important;
  }

  .logo{
    width:260px !important;
    max-width:260px !important;
  }

  .status-strip{
    flex-wrap:wrap !important;
    gap:10px !important;
  }
}

/* Mobile */
@media(max-width:760px){
  .header-top{
    height:auto !important;
    min-height:0 !important;
    padding:12px 0 !important;
  }

  .header-top-inner{
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    height:auto !important;
    min-height:0 !important;
    gap:10px !important;
  }

  .logo{
    width:230px !important;
    max-width:82vw !important;
  }

  .status-strip{
    width:100% !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:8px !important;
  }

  .main-nav{
    overflow-x:auto !important;
  }

  .nav-inner{
    width:max-content !important;
    min-width:100% !important;
    justify-content:flex-start !important;
    gap:6px !important;
    padding:0 8px !important;
  }

  .main-nav a{
    padding:10px 13px !important;
    font-size:.9rem !important;
  }
}

/* ACTUAL MENU RIGHNorthern Ireland SHIFT */
@media (min-width: 761px) {
  .main-nav .wrap {
    width: min(100% - 36px, 1240px) !important;
    margin: 0 auto !important;
    overflow: visible !important;
  }

  .nav-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: translateX(190px) !important;
  }

  .main-nav a {
    margin: 0 !important;
  }
}

@media (max-width: 760px) {
  .nav-inner {
    transform: none !important;
  }
}

/* Network station logo updates */
.network-logo-img{
  display:block;
  width:100%;
  max-width:260px;
  height:auto;
  object-fit:contain;
  margin:0 0 14px;
}

.network-card .network-logo-img,
.station-card .network-logo-img,
.card .network-logo-img{
  border-radius:14px;
}

@media(max-width:760px){
  .network-logo-img{
    max-width:220px;
    margin-left:auto;
    margin-right:auto;
  }
}

.network-row{text-decoration:none;color:inherit}
.network-row:hover strong{text-decoration:underline}
.station-logo{max-width:260px;width:100%;height:auto;object-fit:contain;margin:0 0 18px}
.station-options{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px}
.station-options .feature{background:#f7fbff;border:1px solid var(--line);border-radius:12px;padding:16px}
@media(max-width:700px){.station-options{grid-template-columns:1fr}}


/* Dropdown navigation update */
.main-nav ul{
  align-items:center !important;
  gap:6px !important;
}
.main-nav li{
  position:relative !important;
}
.main-nav .nav-dropdown{
  display:flex !important;
  align-items:center !important;
}
.main-nav .nav-dropbtn{
  flex:0 0 auto !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:42px !important;
  margin:0 !important;
  padding:10px 16px !important;
  border:0 !important;
  border-radius:999px !important;
  color:#ffffff !important;
  background:transparent !important;
  font:inherit !important;
  font-weight:900 !important;
  text-decoration:none !important;
  white-space:nowrap !important;
  cursor:pointer !important;
}
.main-nav .nav-dropbtn::after{
  content:"▾";
  margin-left:8px;
  font-size:.8em;
}
.main-nav .nav-dropbtn:hover,
.main-nav .nav-dropbtn.active,
.main-nav .nav-dropdown:focus-within > .nav-dropbtn,
.main-nav .nav-dropdown:hover > .nav-dropbtn{
  color:#ffffff !important;
  background:#ff8a18 !important;
}
.main-nav .nav-dropdown-menu{
  display:none !important;
  position:absolute !important;
  top:calc(100% + 6px) !important;
  left:0 !important;
  min-width:190px !important;
  margin:0 !important;
  padding:8px !important;
  list-style:none !important;
  background:#ffffff !important;
  border-radius:16px !important;
  box-shadow:0 16px 34px rgba(0,45,90,.22) !important;
  z-index:999 !important;
}
.main-nav .nav-dropdown:hover > .nav-dropdown-menu,
.main-nav .nav-dropdown:focus-within > .nav-dropdown-menu{
  display:block !important;
}
.main-nav .nav-dropdown-menu li{
  display:block !important;
}
.main-nav .nav-dropdown-menu a{
  display:flex !important;
  justify-content:flex-start !important;
  width:100% !important;
  min-height:38px !important;
  padding:9px 13px !important;
  border-radius:12px !important;
  color:#00539f !important;
  background:transparent !important;
  box-sizing:border-box !important;
}
.main-nav .nav-dropdown-menu a:hover,
.main-nav .nav-dropdown-menu a.active{
  color:#ffffff !important;
  background:#ff8a18 !important;
}
@media (max-width:760px){
  .main-nav .nav-dropdown-menu{
    position:static !important;
    min-width:0 !important;
    margin-left:4px !important;
    padding:6px !important;
    box-shadow:none !important;
    border-radius:14px !important;
  }
  .main-nav .nav-dropdown:hover > .nav-dropdown-menu,
  .main-nav .nav-dropdown:focus-within > .nav-dropdown-menu{
    display:block !important;
  }
}

/* CANARY ISLANDS FUN VIBE REFRESH */
:root{
  --sun:#ffd166;
  --coral:#ff6b6b;
  --teal:#20c6b7;
  --pink:#ff4fb3;
  --sand:#fff0c7;
  --ocean:#00a8e8;
  --deep:#034f84;
  --blue:#005da8;
  --orange:#ff8a18;
}

body{
  background:
    radial-gradient(circle at 8% 5%, rgba(255,209,102,.55) 0 115px, transparent 116px),
    radial-gradient(circle at 93% 12%, rgba(32,198,183,.30) 0 170px, transparent 171px),
    radial-gradient(circle at 12% 85%, rgba(255,107,107,.16) 0 230px, transparent 231px),
    linear-gradient(180deg,#effcff 0%,#f8fdff 34%,#fff6dc 100%) !important;
  position:relative;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.22) 0 2px, transparent 2px 18px),
    radial-gradient(ellipse at 70% 95%, rgba(0,168,232,.18), transparent 44%);
}

.main{
  position:relative;
  overflow:hidden;
}

.main::before,
.main::after{
  content:"";
  position:absolute;
  pointer-events:none;
  z-index:0;
  border-radius:999px;
  filter:blur(.2px);
}

.main::before{
  width:420px;
  height:420px;
  right:-190px;
  top:60px;
  background:radial-gradient(circle, rgba(255,138,24,.20), rgba(255,138,24,0) 70%);
}

.main::after{
  width:520px;
  height:520px;
  left:-260px;
  bottom:80px;
  background:radial-gradient(circle, rgba(32,198,183,.20), rgba(32,198,183,0) 72%);
}

.main > .wrap,
.two-col,
.three-col{
  position:relative;
  z-index:1;
}

.hero-slider .slide-overlay,
.slide-overlay{
  background:
    linear-gradient(90deg, rgba(0,70,130,.78) 0%, rgba(0,151,196,.48) 45%, rgba(255,138,24,.18) 100%),
    radial-gradient(circle at 10% 18%, rgba(255,209,102,.70), transparent 10%),
    radial-gradient(circle at 88% 28%, rgba(32,198,183,.36), transparent 16%) !important;
}

.slide-content h1,
.hero h1{
  text-shadow:0 8px 24px rgba(0,45,90,.28), 0 2px 0 rgba(255,209,102,.24) !important;
}

.card,
.feature,
.contact-box,
.schedule-item,
.crew-card,
.played-item,
.weather-place,
.station-options .feature{
  position:relative;
  isolation:isolate;
  border-radius:26px !important;
  border:1px solid rgba(0,130,190,.14) !important;
  background:
    linear-gradient(#ffffff,#ffffff) padding-box,
    linear-gradient(135deg, rgba(255,209,102,.72), rgba(32,198,183,.54), rgba(0,168,232,.44)) border-box !important;
  box-shadow:0 20px 48px rgba(0,85,150,.12) !important;
}

.card::before,
.feature::before,
.contact-box::before,
.schedule-item::before,
.crew-card::before,
.played-item::before,
.weather-place::before,
.station-options .feature::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  border-radius:inherit;
  background:
    radial-gradient(circle at 92% 12%, rgba(255,209,102,.32) 0 58px, transparent 59px),
    radial-gradient(circle at 6% 94%, rgba(32,198,183,.14) 0 76px, transparent 77px),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(242,252,255,.94));
}

.card::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:7px;
  background:linear-gradient(90deg,var(--sun),var(--coral),var(--teal),var(--ocean));
  opacity:.85;
}

.card h2,
.card h3,
.feature strong,
.network-row strong,
.weather-place strong{
  color:#005da8 !important;
}

.card h2::after{
  width:74px !important;
  height:6px !important;
  border-radius:99px !important;
  background:linear-gradient(90deg,var(--orange),var(--sun),var(--teal)) !important;
}

.button,
.listen-live,
.slider-dots button.active,
.main-nav a:hover,
.main-nav a.active,
.main-nav .active,
.main-nav .nav-dropbtn:hover,
.main-nav .nav-dropdown:hover > .nav-dropbtn,
.main-nav .nav-dropdown-menu a:hover,
.main-nav .nav-dropdown-menu a.active{
  background:linear-gradient(135deg,#ff8a18,#ffb703,#20c6b7) !important;
  color:#fff !important;
  box-shadow:0 12px 26px rgba(255,138,24,.24) !important;
}

.main-nav{
  background:linear-gradient(90deg,#007fc1,#00a8e8,#20c6b7) !important;
  border-bottom:4px solid #ffd166 !important;
}

.main-nav .nav-dropdown-menu{
  border:1px solid rgba(0,130,190,.14) !important;
  background:linear-gradient(180deg,#ffffff,#f1fcff) !important;
}

.status-item{
  background:
    radial-gradient(circle at 96% 8%, rgba(255,209,102,.35) 0 42px, transparent 43px),
    linear-gradient(180deg,#fff,#f2fcff) !important;
}

.status-icon{
  background:linear-gradient(135deg,#fff0c7,#dcfbff) !important;
}

.network-row,
.weather-place{
  transition:transform .18s ease, box-shadow .18s ease;
}

.network-row:hover,
.weather-place:hover,
.feature:hover,
.contact-box:hover,
.station-options .feature:hover{
  transform:translateY(-3px);
  box-shadow:0 24px 52px rgba(0,85,150,.18) !important;
}

.footer{
  background:
    radial-gradient(circle at 8% 12%, rgba(255,209,102,.25), transparent 18%),
    linear-gradient(135deg,#034f84,#007fc1 56%,#20c6b7) !important;
}

/* Add a subtle wave/sun feel behind sidebar and content boxes */
.right-stack .card,
.two-col > .card,
.three-col > .card{
  overflow:hidden;
}

.right-stack .card::before{
  background:
    radial-gradient(circle at 86% 8%, rgba(255,209,102,.42) 0 52px, transparent 53px),
    repeating-radial-gradient(ellipse at 16% 110%, rgba(0,168,232,.14) 0 10px, transparent 11px 24px),
    linear-gradient(180deg,#fff,#f0fbff) !important;
}

@media(max-width:760px){
  .card,
  .feature,
  .contact-box,
  .schedule-item,
  .crew-card,
  .played-item{
    border-radius:22px !important;
  }
}


/* Listening icons across all pages */
.listen-icons-strip{
  margin-top:-28px;
  position:relative;
  z-index:3;
  padding:0 0 12px;
}
.listen-icons-inner{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.listen-icon-card{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:82px;
  padding:14px 18px;
  text-decoration:none;
  color:var(--blue);
  font-weight:900;
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(255,247,220,.92));
  border:1px solid rgba(255,255,255,.75);
  border-radius:24px;
  box-shadow:0 18px 36px rgba(4,78,132,.15);
  transition:transform .2s ease, box-shadow .2s ease;
}
.listen-icon-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px rgba(4,78,132,.2)}
.listen-icon-card img{width:54px;height:54px;display:block;flex:0 0 auto;filter:drop-shadow(0 8px 12px rgba(0,80,145,.18))}
.listen-icon-card span{font-size:1.05rem;line-height:1.1}
.listen-method-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:22px}
.listen-method{
  padding:22px;
  border-radius:26px;
  background:linear-gradient(135deg,#ffffff 0%,#fff4d5 48%,#e7fbff 100%);
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 14px 34px rgba(4,78,132,.1);
}
.listen-method img{width:76px;height:76px;margin-bottom:12px;filter:drop-shadow(0 10px 14px rgba(0,80,145,.18))}
.listen-method h3{margin:0 0 8px;color:var(--blue)}
.listen-method p{margin:0;color:var(--muted)}
@media(max-width:850px){.listen-icons-inner,.listen-method-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.listen-icons-strip{margin-top:18px}}
@media(max-width:520px){.listen-icons-inner,.listen-method-grid{grid-template-columns:1fr}.listen-icon-card{min-height:72px}}


/* Photo-based How To Listen cards for station pages */
.listen-photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 18px;
  margin-top: 18px;
}

.listen-photo-card {
  overflow: hidden;
  border-radius: 18px;
  background: rgba(255,255,255,0.94);
  box-shadow: 0 14px 35px rgba(10, 30, 50, 0.18);
  border: 1px solid rgba(255,255,255,0.75);
}

.listen-photo-card img {
  width: 100%;
  height: 150px;
  object-fit: cover;
  display: block;
}

.listen-photo-content {
  padding: 16px;
}

.listen-photo-content strong {
  display: block;
  font-size: 1.05rem;
  margin-bottom: 7px;
  color: #06213d;
}

.listen-photo-content span {
  display: block;
  line-height: 1.45;
  color: #34495e;
}


/* Professional device photos on Tuning In page */
.device-listen-section {
  padding: 36px 0 52px;
}

.device-listen-section h2 {
  margin-bottom: 8px;
}

.device-listen-intro {
  max-width: 760px;
  margin-bottom: 24px;
  color: #345;
  font-size: 1.05rem;
}

.device-photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 22px;
}

.device-photo-card {
  overflow: hidden;
  border-radius: 22px;
  background: rgba(255,255,255,0.96);
  box-shadow: 0 18px 45px rgba(10, 34, 58, 0.18);
  border: 1px solid rgba(255,255,255,0.8);
  transition: transform .2s ease, box-shadow .2s ease;
}

.device-photo-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 24px 55px rgba(10, 34, 58, 0.25);
}

.device-photo-card img {
  display: block;
  width: 100%;
  height: 185px;
  object-fit: cover;
}

.device-photo-card div {
  padding: 18px 18px 20px;
}

.device-photo-card h3 {
  margin: 0 0 8px;
  color: #06213d;
}

.device-photo-card p {
  margin: 0;
  color: #34495e;
  line-height: 1.5;
}


/* Visible professional device photos on Tuning In page */
.tuning-device-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 22px;
  margin-top: 22px;
}

.tuning-device-item {
  overflow: hidden;
  border-radius: 22px;
  background: #ffffff;
  box-shadow: 0 18px 42px rgba(10, 34, 58, 0.18);
  border: 1px solid rgba(255,255,255,0.85);
  transition: transform .2s ease, box-shadow .2s ease;
}

.tuning-device-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 24px 56px rgba(10, 34, 58, 0.26);
}

.tuning-device-item img {
  display: block;
  width: 100%;
  height: 165px;
  object-fit: cover;
}

.tuning-device-copy {
  padding: 17px 18px 20px;
  background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(236,249,255,.98));
}

.tuning-device-copy h3 {
  margin: 0 0 8px;
  color: #005baa;
}

.tuning-device-copy p {
  margin: 0;
  color: #42627a;
  line-height: 1.5;
}


/* FM radio image section */
.fm-radio-layout {
  display: grid;
  grid-template-columns: minmax(220px, 360px) 1fr;
  gap: 24px;
  align-items: center;
  margin-top: 14px;
}

.fm-radio-layout img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  border-radius: 20px;
  box-shadow: 0 16px 36px rgba(10, 34, 58, 0.2);
}

.fm-radio-layout p {
  margin: 0;
  line-height: 1.75;
  font-size: 1.03rem;
}

@media (max-width: 720px) {
  .fm-radio-layout {
    grid-template-columns: 1fr;
  }
}












/* Sky News equal card grid homepage section */
.sky-news-section {
  margin: 28px 0 34px;
  padding: 0;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.news-section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 20px;
}

.news-section-header h2 {
  margin: 0 0 8px;
  color: #06213d;
  font-size: 1.75rem;
}

.news-section-header h2::after {
  content: "";
  display: block;
  width: 70px;
  height: 4px;
  margin-top: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, #ff9f1c, #16c7c9);
}

.news-section-header p {
  margin: 0;
  color: #34495e;
  font-size: 1.02rem;
}

.news-actions {
  display: flex;
  align-items: center;
  gap: 18px;
  white-space: nowrap;
}

.news-actions a {
  color: #005baa;
  font-weight: 800;
  text-decoration: none;
}

.sky-badge {
  display: inline-flex;
  align-items: center;
  overflow: hidden;
  border-radius: 10px;
  box-shadow: 0 8px 18px rgba(0,91,170,.18);
  font-weight: 800;
}

.sky-badge span {
  background: #0072ce;
  color: #fff;
  padding: 9px 10px;
}

.sky-badge strong {
  background: #e30613;
  color: #fff;
  padding: 9px 10px;
}

.sky-card-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 18px !important;
  width: 100% !important;
  align-items: stretch;
}

.sky-story-card {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  background: #fff;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 8px 22px rgba(10,34,58,.08);
  border: 1px solid rgba(10,34,58,.07);
  transition: transform .18s ease, box-shadow .18s ease;
}

.sky-story-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(10,34,58,.16);
}

.sky-story-card img {
  display: block !important;
  width: 100% !important;
  height: 125px !important;
  max-height: 125px !important;
  object-fit: cover !important;
  background: #e8f3fb;
  flex: 0 0 125px !important;
}

.sky-story-copy {
  padding: 15px 14px 17px;
  flex: 1;
}

.sky-story-copy h3 {
  margin: 0;
  color: #06213d;
  font-size: 1.02rem;
  line-height: 1.25;
  font-weight: 900;
}

.sky-story-copy p {
  margin: 18px 0 0;
  color: #56697c;
  font-size: .9rem;
}

.sky-story-copy span {
  margin: 0 5px;
}

.sky-news-loading,
.sky-news-error {
  grid-column: 1 / -1;
  padding: 18px;
  border-radius: 16px;
  background: rgba(255,255,255,.92);
  color: #42627a;
}

.sky-news-error strong {
  display: block;
  color: #005baa;
  margin-bottom: 6px;
}

.sky-news-error a {
  color: #005baa;
  font-weight: 800;
}

@media (min-width: 1180px) { .sky-card-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; } }

@media (max-width: 720px) {
  .news-section-header {
    display: block;
  }

  .news-actions {
    margin-top: 16px;
  }

  .sky-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 470px) {
  .sky-card-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Hide homepage listening buttons below slider */
body.home-page .listen-icons-strip { display: none !important; }


/* Homepage day-specific Coast schedule */
.coast-on-air{
  overflow:hidden;
  padding:0 !important;
  background:#ffffff !important;
}
.coast-on-air-head{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  padding:24px 26px 18px;
  background:linear-gradient(135deg,#052c55 0%,#007fc1 72%,#22c6d5 100%);
  color:#ffffff;
}
.coast-on-air .eyebrow{
  margin:0 0 5px;
  color:#ffbd26;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.78rem;
}
.coast-on-air h2{
  margin:0;
  color:#ffffff !important;
  font-size:1.85rem;
  letter-spacing:-.03em;
}
.coast-on-air h2:after{display:none !important}
.schedule-link{
  color:#07345f !important;
  background:#ffbd26;
  font-weight:900;
  text-decoration:none;
  white-space:nowrap;
  padding:10px 15px;
  border-radius:999px;
  box-shadow:0 8px 18px rgba(0,0,0,.15);
}
.coast-day-block{
  background:#ffffff;
  border:0;
  border-radius:0;
  padding:22px 24px 26px;
  margin:0;
  box-shadow:none;
}
.coast-day-block.featured{border-top:0}
.coast-day-block h3{
  display:flex;
  align-items:center;
  gap:10px;
  color:#004985;
  font-size:1.18rem;
  margin:0 0 16px;
  font-weight:900;
}
.coast-day-block h3:before{
  content:"";
  width:10px;
  height:10px;
  border-radius:999px;
  background:#ff9d00;
  box-shadow:0 0 0 6px rgba(255,157,0,.16);
}
.coast-show-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.coast-show-card{
  display:grid;
  grid-template-columns:82px minmax(0,1fr);
  gap:15px;
  align-items:center;
  background:linear-gradient(180deg,#ffffff,#f6fbff);
  border:1px solid #d8eaf5;
  border-radius:18px;
  padding:13px;
  min-height:112px;
  box-shadow:0 10px 24px rgba(0,47,87,.08);
}
.coast-show-card img,
.show-icon{
  width:82px;
  height:82px;
  border-radius:16px;
  object-fit:cover;
  display:block;
  background:#eaf7fd;
  border:3px solid #ffffff;
  box-shadow:0 0 0 2px rgba(0,127,193,.24),0 10px 18px rgba(0,47,87,.14);
}
.show-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#ffffff;
  background:linear-gradient(135deg,#007fc1,#052c55);
  font-weight:900;
  font-size:1.05rem;
}
.coast-show-card h4{
  margin:0;
  color:#004985;
  font-size:1.02rem;
  line-height:1.15;
  font-weight:900;
}
.coast-show-card h4 span{
  display:block;
  color:#12324e;
  font-size:.9rem;
  margin-top:3px;
  font-weight:700;
}
.coast-show-card p{
  display:inline-flex;
  margin:9px 0 0;
  color:#07345f;
  background:#fff2d5;
  border:1px solid rgba(255,157,0,.24);
  border-radius:999px;
  padding:5px 9px;
  font-weight:900;
  font-size:.85rem;
}
@media(max-width:980px){
  .coast-show-list{grid-template-columns:1fr}
  .coast-on-air-head{display:block}
  .schedule-link{display:inline-flex;margin-top:12px}
}
@media(max-width:520px){
  .coast-show-card{grid-template-columns:70px minmax(0,1fr);min-height:96px;padding:11px}
  .coast-show-card img,.show-icon{width:70px;height:70px;border-radius:14px}
  .coast-day-block{padding:18px 16px 22px}
  .coast-on-air-head{padding:22px 18px 16px}
}

/* Footer logo */
.footer-brand-logo{display:block;width:150px;max-width:100%;height:auto;margin:0 0 12px 0;}
.footer a{color:inherit;text-decoration:none;font-weight:800;}
.footer a:hover{text-decoration:underline;}


/* Redesigned simple Coast FM footer */
.site-footer,
footer {
  background: linear-gradient(135deg, #061b33 0%, #0b3d66 48%, #00a6d6 100%);
  color: #ffffff;
  padding: 34px 22px 24px;
}

.coast-footer-inner {
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 26px;
  flex-wrap: wrap;
}

.coast-footer-brand {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 240px;
}

.coast-footer-logo {
  width: 92px;
  max-width: 92px;
  height: auto;
  display: block;
  background: #ffffff;
  border-radius: 14px;
  padding: 9px;
  box-shadow: 0 10px 24px rgba(0,0,0,.16);
}

.coast-footer-wordmark {
  font-family: inherit;
  line-height: 1.1;
}

.coast-footer-title {
  margin: 0;
  font-size: 1.45rem;
  font-weight: 800;
  letter-spacing: .02em;
  color: #ffffff;
}

.coast-footer-tagline {
  margin: 5px 0 0;
  color: rgba(255,255,255,.82);
  font-size: .95rem;
}

.coast-footer-links {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.coast-footer-links a,
.coast-footer-button {
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.42);
  border-radius: 999px;
  padding: 9px 15px;
  text-decoration: none !important;
  font-weight: 700;
  font-size: .92rem;
  background: rgba(255,255,255,.10);
}

.coast-footer-links a:hover,
.coast-footer-button:hover {
  background: rgba(255,255,255,.20);
}

.coast-footer-bottom {
  max-width: 1180px;
  margin: 24px auto 0;
  padding-top: 15px;
  border-top: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.76);
  font-size: .86rem;
  text-align: left;
}

.footer-coast-logo {
  display: none !important;
}

@media (max-width: 700px) {
  .coast-footer-inner {
    align-items: flex-start;
    flex-direction: column;
  }
  .coast-footer-logo {
    width: 78px;
    max-width: 78px;
  }
  .coast-footer-bottom {
    text-align: left;
  }
}


/* Coast FM text-only footer branding */
.coast-footer-brand {
  gap: 0 !important;
}

.coast-footer-logo,
.coast-footer-brand img {
  display: none !important;
}

.coast-footer-title {
  font-size: 2rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase;
  background: linear-gradient(90deg,#7fe7ff 0%, #00c2ff 45%, #ffffff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline-block;
}

.coast-footer-tagline {
  margin-top: 6px !important;
  color: rgba(255,255,255,0.82) !important;
}


/* Clean no-tree Coast FM footer logo */
.coast-footer-brand{display:flex;align-items:center;gap:18px!important;}
.coast-footer-clean-logo{display:block!important;width:230px;max-width:42vw;height:auto;background:transparent!important;border:0!important;border-radius:0!important;padding:0!important;box-shadow:none!important;}
.coast-footer-logo,.coast-footer-brand>img:not(.coast-footer-clean-logo){display:none!important;}
.coast-footer-wordmark{display:none!important;}
@media (max-width:700px){.coast-footer-clean-logo{width:190px;max-width:80vw;}}


.coast-footer-logo{
  display:block !important;
  width:220px !important;
  max-width:90%;
  height:auto !important;
  background:none !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
}

.coast-footer-wordmark-wrap{
  margin-bottom:16px;
}
.coast-footer-wordmark-logo{
  width:220px !important;
  max-width:90%;
  height:auto !important;
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
}


/* Correct centred Coast footer logo */
.coast-footer-logo-area{
  width:100%;
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  margin:0 auto 18px auto !important;
  text-align:center !important;
}

.coast-footer-clean-logo{
  display:block !important;
  width:210px !important;
  max-width:80% !important;
  height:auto !important;
  margin:0 auto !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  opacity:1 !important;
  visibility:visible !important;
}

.coast-footer-wordmark-wrap,
.coast-footer-wordmark-logo,
.coast-footer-brand img:not(.coast-footer-clean-logo){
  display:none !important;
}


.coast-custom-footer{
  background:linear-gradient(180deg,#07223f 0%,#0a3f67 100%);
  padding:48px 24px 26px;
  color:#fff;
  margin-top:60px;
}

.coast-footer-grid{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:40px;
  align-items:center;
}

.footer-col{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.footer-col h4{
  margin:0 0 8px 0;
  font-size:1.1rem;
  color:#7fe7ff;
}

.footer-col a{
  color:#ffffff;
  text-decoration:none;
  opacity:.9;
}

.footer-col a:hover{
  opacity:1;
}

.footer-center{
  align-items:center;
  text-align:center;
}

.footer-logo-transparent{
  width:230px;
  max-width:100%;
  display:block;
}

.footer-tagline{
  margin-top:12px;
  color:rgba(255,255,255,.8);
}

.footer-bottom{
  text-align:center;
  margin-top:36px;
  padding-top:20px;
  border-top:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.7);
  font-size:.9rem;
}

@media(max-width:800px){
  .coast-footer-grid{
    grid-template-columns:1fr;
    text-align:center;
  }

  .footer-col{
    align-items:center;
  }
}


.coast-footer-final{
 background:linear-gradient(90deg,#06213f 0%, #0a4f79 55%, #0ca8cf 100%);
 padding:48px 28px 22px;
 color:#fff;
 margin-top:60px;
}

.coast-footer-wrap{
 max-width:1200px;
 margin:0 auto;
 display:grid;
 grid-template-columns:1fr auto 1fr;
 align-items:center;
 gap:50px;
}

.coast-footer-col{
 display:flex;
 flex-direction:column;
 gap:12px;
}

.coast-footer-col.right{
 align-items:flex-start;
}

.coast-footer-col h4{
 margin:0 0 10px;
 color:#a7e8ff;
 font-size:1.1rem;
}

.coast-footer-col a{
 color:#fff;
 text-decoration:none;
 font-weight:600;
}

.coast-footer-col a:hover{
 text-decoration:underline;
}

.coast-footer-centre{
 display:flex;
 justify-content:center;
 align-items:center;
}

.coast-footer-logo-final{
 width:320px;
 max-width:100%;
 height:auto;
 display:block;
 background:none!important;
}

.coast-footer-copy{
 text-align:center;
 margin-top:30px;
 padding-top:18px;
 border-top:1px solid rgba(255,255,255,.18);
 color:rgba(255,255,255,.8);
}

@media(max-width:900px){
 .coast-footer-wrap{
   grid-template-columns:1fr;
   text-align:center;
 }
 .coast-footer-col,
 .coast-footer-col.right{
   align-items:center;
 }
 .coast-footer-logo-final{
   width:260px;
 }
}

.footer-approved-logo{
 width:360px !important;
 max-width:100% !important;
 height:auto !important;
 display:block !important;
 margin:0 auto !important;
 background:transparent !important;
 border:none !important;
 box-shadow:none !important;
 padding:0 !important;
}


/* Clean alternative Coast FM footer */
.coast-alt-footer{
  margin-top:60px !important;
  padding:38px 24px 20px !important;
  background:
    radial-gradient(circle at 12% 0%, rgba(255,174,0,.22) 0 90px, transparent 92px),
    linear-gradient(135deg,#061f3b 0%,#073f67 52%,#09a5c8 100%) !important;
  color:#fff !important;
}

.coast-alt-footer-inner{
  max-width:1180px !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:1.4fr 1fr 1fr !important;
  gap:34px !important;
  align-items:center !important;
}

.coast-alt-brand{
  display:flex !important;
  align-items:center !important;
  gap:16px !important;
}

.coast-alt-mark{
  position:relative !important;
  width:74px !important;
  height:56px !important;
  flex:0 0 74px !important;
}

.coast-alt-mark:before{
  content:"" !important;
  position:absolute !important;
  left:2px !important;
  bottom:3px !important;
  width:56px !important;
  height:56px !important;
  border:10px solid #ffad00 !important;
  border-right-color:transparent !important;
  border-bottom-color:transparent !important;
  border-radius:50% !important;
  transform:rotate(-8deg) !important;
}

.coast-alt-mark span{
  position:absolute !important;
  display:block !important;
  height:8px !important;
  border-radius:99px !important;
  background:#5bd8ff !important;
  left:24px !important;
}

.coast-alt-mark span:nth-child(1){ bottom:8px; width:46px; }
.coast-alt-mark span:nth-child(2){ bottom:20px; width:38px; }
.coast-alt-mark span:nth-child(3){ bottom:32px; width:30px; }

.coast-alt-title{
  font-family:Arial Black, Arial, Helvetica, sans-serif !important;
  font-size:2.25rem !important;
  line-height:1 !important;
  letter-spacing:-.04em !important;
}

.coast-alt-title span{
  color:#62d6ff !important;
  
  text-shadow:none;
}

.coast-alt-title strong{
  color:#ffad00 !important;
  
  text-shadow:none;
}

.coast-alt-subtitle{
  margin-top:6px !important;
  color:rgba(255,255,255,.82) !important;
  font-size:.95rem !important;
  font-weight:600 !important;
}

.coast-alt-links,
.coast-alt-social{
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
}

.coast-alt-links a,
.coast-alt-social a{
  color:#fff !important;
  text-decoration:none !important;
  font-weight:750 !important;
  opacity:.92 !important;
}

.coast-alt-links a:hover,
.coast-alt-social a:hover{
  opacity:1 !important;
  text-decoration:underline !important;
}

.coast-alt-bottom{
  max-width:1180px !important;
  margin:28px auto 0 !important;
  padding-top:18px !important;
  border-top:1px solid rgba(255,255,255,.18) !important;
  text-align:center !important;
  color:rgba(255,255,255,.78) !important;
  font-size:.92rem !important;
}

@media(max-width:850px){
  .coast-alt-footer-inner{
    grid-template-columns:1fr !important;
    text-align:center !important;
  }
  .coast-alt-brand{
    justify-content:center !important;
  }
  .coast-alt-links,
  .coast-alt-social{
    align-items:center !important;
  }
}


/* Professional Advertise page */
.advertise-hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 82% 14%, rgba(255,184,0,.35) 0 90px, transparent 92px),
    radial-gradient(circle at 8% 92%, rgba(255,140,0,.18) 0 150px, transparent 152px),
    linear-gradient(135deg,#052c55 0%,#006fae 50%,#22c6d5 100%);
  color:#fff;
  padding:76px 0 82px;
}
.advertise-hero:after{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 1px, transparent 1px 16px);
  pointer-events:none;
}
.advertise-hero-inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) 330px;
  gap:38px;
  align-items:center;
}
.eyebrow{
  display:inline-flex;
  color:#ffb126;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:.08em;
  font-size:.82rem;
  margin-bottom:12px;
}
.advertise-hero h1{
  margin:0;
  max-width:880px;
  font-size:clamp(2.65rem,5.2vw,5rem);
  line-height:.94;
  letter-spacing:-.065em;
  font-weight:900;
}
.advertise-hero p{
  max-width:760px;
  margin:22px 0 0;
  font-size:1.22rem;
  color:rgba(255,255,255,.94);
}
.advertise-hero-actions,.adv-cta-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:28px;
}
.adv-primary{
  background:linear-gradient(135deg,#ff9d00,#ffbd26)!important;
  color:#07345f!important;
}
.adv-secondary{
  background:rgba(255,255,255,.14)!important;
  border:1px solid rgba(255,255,255,.38)!important;
  box-shadow:none!important;
}
.advertise-stat-card{
  background:rgba(255,255,255,.96);
  color:#06345f;
  border-radius:24px;
  padding:30px;
  box-shadow:0 28px 70px rgba(0,35,72,.26);
  border:1px solid rgba(255,255,255,.6);
}
.advertise-stat-card strong{
  display:block;
  font-size:5rem;
  line-height:.9;
  color:#ff9800;
  letter-spacing:-.08em;
}
.advertise-stat-card span{
  display:block;
  margin-top:12px;
  font-size:1.25rem;
  font-weight:900;
  color:#004985;
}
.advertise-stat-card small{
  display:block;
  margin-top:16px;
  color:#62778b;
}
.advertise-page{
  background:linear-gradient(180deg,#eaf7fd 0%,#f7fcff 100%);
}
.adv-intro-grid{
  display:grid;
  grid-template-columns:1.35fr 1fr 1fr;
  gap:20px;
  margin-bottom:32px;
}
.adv-card{
  background:#fff;
  border:1px solid #d8eaf5;
  border-radius:18px;
  padding:28px;
  box-shadow:0 16px 42px rgba(0,47,87,.10);
}
.adv-card h2,.adv-card h3{
  margin-top:0;
  color:#004985;
}
.adv-card h2:after{
  content:"";
  display:block;
  width:46px;
  height:4px;
  background:#ff9800;
  border-radius:99px;
  margin-top:12px;
}
.adv-card-blue{
  color:#fff;
  background:linear-gradient(135deg,#004985,#087ec0);
}
.adv-card-blue h2,.adv-card-blue h3{color:#fff}
.adv-card-blue p{color:rgba(255,255,255,.92)}
.adv-section{
  margin:44px 0;
}
.adv-section-heading{
  max-width:780px;
  margin-bottom:22px;
}
.adv-section-heading h2,.adv-cta h2{
  margin:0;
  color:#004985;
  font-size:clamp(2rem,3.8vw,3.1rem);
  line-height:1;
  letter-spacing:-.045em;
}
.adv-section-heading p{
  font-size:1.1rem;
  color:#62778b;
}
.package-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}
.package-card{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  padding:28px;
  color:#fff;
  min-height:250px;
  box-shadow:0 18px 46px rgba(0,47,87,.16);
}
.package-card:after{
  content:"";
  position:absolute;
  right:-40px;
  bottom:-50px;
  width:160px;
  height:160px;
  border-radius:50%;
  background:rgba(255,255,255,.13);
}
.package-card.bronze{background:linear-gradient(135deg,#9b5a22,#f39121)}
.package-card.silver{background:linear-gradient(135deg,#4a6a86,#9fc8e8)}
.package-card.gold{background:linear-gradient(135deg,#005096,#ff9d00)}
.package-label{
  display:inline-flex;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.package-card h3{
  margin:24px 0 8px;
  font-size:1.65rem;
}
.package-price{
  margin-top:20px;
  font-size:2.35rem;
  font-weight:900;
  letter-spacing:-.05em;
}
.package-price span{
  display:block;
  font-size:.95rem;
  font-weight:800;
  letter-spacing:0;
}
.package-card small{
  display:block;
  margin-top:8px;
  color:rgba(255,255,255,.88);
  font-weight:700;
}
.adv-note{
  margin-top:14px;
  color:#62778b;
  font-weight:700;
}
.adv-split{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:24px;
  margin:44px 0;
}
.adv-check-list{
  list-style:none;
  padding:0;
  margin:22px 0 0;
  display:grid;
  gap:12px;
}
.adv-check-list li{
  position:relative;
  padding-left:32px;
  font-weight:800;
}
.adv-check-list li:before{
  content:"✓";
  position:absolute;
  left:0;
  top:-2px;
  width:22px;
  height:22px;
  border-radius:50%;
  background:#ff9800;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.85rem;
}
.adv-purple{
  color:#fff;
  background:linear-gradient(135deg,#6222ad,#9b29d9 55%,#ff9d00);
}
.adv-purple h2{color:#fff}
.adv-purple p{color:rgba(255,255,255,.92)}
.sponsor-price{
  margin:24px 0 8px;
  color:#fff;
  font-weight:900;
  font-size:2.1rem;
}
.audience-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:14px;
}
.audience-card{
  background:#fff;
  border-radius:18px;
  padding:22px 16px;
  text-align:center;
  border:1px solid #d8eaf5;
  box-shadow:0 10px 28px rgba(0,47,87,.08);
}
.audience-card strong{
  display:block;
  font-size:2.3rem;
  line-height:1;
  color:#ff9800;
  font-weight:900;
}
.audience-card span{
  display:block;
  margin-top:8px;
  font-size:.9rem;
  color:#004985;
  font-weight:800;
}
.adv-cta{
  display:grid;
  grid-template-columns:1fr auto;
  gap:28px;
  align-items:center;
  background:
    radial-gradient(circle at 88% 18%, rgba(255,184,0,.28) 0 90px, transparent 92px),
    linear-gradient(135deg,#06345f,#007fc1);
  color:#fff;
  border-radius:26px;
  padding:34px;
  box-shadow:0 22px 60px rgba(0,47,87,.18);
}
.adv-cta h2{color:#fff}
.adv-cta p{color:rgba(255,255,255,.9);font-size:1.08rem}
@media(max-width:1050px){
  .advertise-hero-inner,.adv-intro-grid,.adv-split,.adv-cta{grid-template-columns:1fr}
  .audience-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:760px){
  .package-grid,.audience-grid{grid-template-columns:1fr}
  .advertise-hero{padding:54px 0}
  .advertise-stat-card strong{font-size:4rem}
}

}
.small{opacity:.9}

@media(max-width:1100px){
  .advertise-hero-inner,
  .adv-intro-grid,
  .adv-split,
  .adv-cta{
    grid-template-columns:1fr;
  }
  .audience-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

@media(max-width:700px){
  .package-grid,
  .audience-grid{
    grid-template-columns:1fr;
  }

  .advertise-hero{
    padding:56px 0 62px;
  }

  .advertise-stat-card strong{
    font-size:4rem;
  }

  .advertise-hero h1{
    font-size:2.8rem;
  }
}


/* Site-wide refresh using the Advertise page style */
body{
  background:linear-gradient(180deg,#eaf7fd 0%,#f7fcff 100%) !important;
}

.hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 84% 12%, rgba(255,184,0,.34) 0 85px, transparent 87px),
    radial-gradient(circle at 8% 90%, rgba(255,140,0,.16) 0 150px, transparent 152px),
    linear-gradient(135deg,#052c55 0%,#006fae 50%,#22c6d5 100%) !important;
  padding:70px 0 74px !important;
}

.hero:after{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 1px, transparent 1px 16px);
  pointer-events:none;
}

.hero .wrap{
  position:relative;
  z-index:1;
}

.hero h1{
  max-width:920px;
  font-size:clamp(2.75rem,5.4vw,5rem) !important;
  line-height:.94 !important;
  letter-spacing:-.065em !important;
}

.hero p{
  max-width:760px;
  font-size:1.22rem !important;
}

.card,
.weather-panel,
.network-card,
.song-card,
.photo-card{
  border-radius:18px !important;
  border:1px solid #d8eaf5 !important;
  box-shadow:0 16px 42px rgba(0,47,87,.10) !important;
}

.card h2,
.card h3{
  color:#004985 !important;
}

.card h2:after,
.card h3:after{
  content:"";
  display:block;
  width:46px;
  height:4px;
  background:#ff9800;
  border-radius:99px;
  margin-top:12px;
}

.button,
.listen-live,
button,
input[type="submit"]{
  background:linear-gradient(135deg,#ff9d00,#ffbd26) !important;
  color:#07345f !important;
  border-radius:999px !important;
  box-shadow:0 8px 18px rgba(255,157,0,.26) !important;
}

.main-nav{
  background:linear-gradient(90deg,#052c55,#007fc1) !important;
}

.main-nav a:hover,
.main-nav a.active{
  background:linear-gradient(135deg,#ff9d00,#ffbd26) !important;
  color:#07345f !important;
}

.listen-icons-strip{
  background:#fff !important;
  box-shadow:0 10px 30px rgba(0,47,87,.08);
}

.listen-icon-card{
  border-radius:18px !important;
  background:linear-gradient(180deg,#ffffff,#f4fbff) !important;
  border:1px solid #d8eaf5 !important;
  box-shadow:0 10px 28px rgba(0,47,87,.08) !important;
}

.feature,
.contact-box{
  border-left:0 !important;
  border-radius:18px !important;
  background:#fff !important;
  box-shadow:0 10px 28px rgba(0,47,87,.08);
  position:relative;
  overflow:hidden;
}

.feature:before,
.contact-box:before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:5px;
  background:linear-gradient(90deg,#ff9d00,#22c6d5);
}

.schedule-item,
.crew-card,
.played-item{
  border-radius:18px !important;
  box-shadow:0 10px 28px rgba(0,47,87,.08) !important;
}

.form input,
.form textarea{
  border-radius:14px !important;
  border:1px solid #d8eaf5 !important;
  background:#fff !important;
  box-shadow:inset 0 1px 0 rgba(0,0,0,.02);
}

.form input:focus,
.form textarea:focus{
  outline:3px solid rgba(34,198,213,.18);
  border-color:#22c6d5 !important;
}

.contact-success{
  border-left:6px solid #19b86a !important;
  margin-top:24px;
}

.contact-error{
  border-left:6px solid #d93232 !important;
  margin-top:24px;
}

/* Colourful page section helpers */
.two-col > section > .card:first-child,
.three-col > section > .card:first-child{
  position:relative;
  overflow:hidden;
}

.two-col > section > .card:first-child:before,
.three-col > section > .card:first-child:before{
  content:"";
  position:absolute;
  right:-42px;
  top:-42px;
  width:130px;
  height:130px;
  border-radius:50%;
  background:rgba(255,157,0,.12);
}

@media(max-width:700px){
  .hero{
    padding:54px 0 58px !important;
  }
}


.contact-success{border-left:6px solid #19b86a!important;margin:24px auto!important}
.contact-error{border-left:6px solid #d93232!important;margin:24px auto!important}
.contact-working-form button{margin-top:6px}

/* Professional Contact page */
.contact-page .contact-hero{
  padding:86px 0 92px !important;
  background:
    linear-gradient(105deg,rgba(5,44,85,.94),rgba(0,111,174,.86)),
    radial-gradient(circle at 84% 16%,rgba(255,189,38,.42) 0 100px,transparent 102px),
    radial-gradient(circle at 12% 84%,rgba(34,198,213,.28) 0 180px,transparent 182px) !important;
}
.contact-hero-inner{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:40px;align-items:center}
.page-kicker,.section-kicker{display:inline-flex;align-items:center;gap:8px;color:#ffbd26;font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px}
.contact-page .section-kicker{color:#007fc1}
.contact-hero h1{margin-bottom:18px !important}
.contact-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.contact-ghost-button{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:13px 22px;border:1px solid rgba(255,255,255,.42);border-radius:999px;color:#fff;text-decoration:none;font-weight:900;background:rgba(255,255,255,.09);backdrop-filter:blur(8px)}
.contact-hero-card{border:1px solid rgba(255,255,255,.32);border-radius:24px;padding:28px;background:rgba(255,255,255,.13);box-shadow:0 24px 70px rgba(0,0,0,.18);backdrop-filter:blur(12px);color:#fff}
.contact-hero-card span{display:block;text-transform:uppercase;letter-spacing:.12em;font-size:.76rem;font-weight:900;color:#ffbd26;margin-bottom:12px}
.contact-hero-card strong{display:block;font-size:2rem;line-height:1.05;margin-bottom:12px}
.contact-hero-card small{display:block;font-size:1rem;line-height:1.55;color:rgba(255,255,255,.86)}
.contact-main{padding-top:54px}
.contact-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:30px;align-items:start}
.contact-content{display:grid;gap:26px}
.contact-intro-card,.contact-form-card,.contact-location-card,.contact-quick-card{overflow:hidden}
.contact-intro-card p,.form-intro,.contact-location-copy p{font-size:1.05rem;line-height:1.7;color:#4b6274}
.contact-method-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:26px}
.contact-method-card{display:grid;gap:8px;min-height:150px;padding:22px;border-radius:18px;text-decoration:none;color:#07345f;background:linear-gradient(180deg,#f7fcff,#fff);border:1px solid #d8eaf5;box-shadow:0 12px 26px rgba(0,47,87,.08);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.contact-method-card:hover{transform:translateY(-4px);border-color:#22c6d5;box-shadow:0 18px 36px rgba(0,47,87,.13)}
.contact-method-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#ff9d00,#ffbd26);color:#07345f;font-weight:900;font-size:1.2rem}
.contact-method-card small{font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#007fc1}
.contact-method-card strong{font-size:1.02rem;overflow-wrap:anywhere}
.contact-form-card .form{margin-top:22px}
.contact-form-card .form label{color:#07345f}
.contact-form-card .form input,.contact-form-card .form textarea{padding:15px 16px !important;font-size:1rem}
.contact-form-card .form textarea{min-height:190px}
.contact-form-footer{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:4px}
.contact-form-footer small{color:#5c7180;line-height:1.5}
.contact-form-footer a{color:#005da8;font-weight:900}
.contact-location-card{display:grid;gap:22px}
.contact-location-card .map{border-radius:18px;border:1px solid #d8eaf5;box-shadow:0 14px 34px rgba(0,47,87,.10)}
.contact-location-card .map iframe{height:390px}
.contact-sidebar{position:sticky;top:18px}
.contact-list{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:12px}
.contact-list li{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px 0;border-bottom:1px solid #e4f0f7}
.contact-list li:last-child{border-bottom:0}
.contact-list span{color:#5c7180;font-weight:800}
.contact-list a{color:#004985;font-weight:900;text-decoration:none;overflow-wrap:anywhere;text-align:right}
.contact-status-message .card{margin-bottom:20px}
@media(max-width:980px){
  .contact-hero-inner,.contact-layout{grid-template-columns:1fr}
  .contact-sidebar{position:static}
  .contact-method-grid{grid-template-columns:1fr}
}
@media(max-width:620px){
  .contact-page .contact-hero{padding:58px 0 66px !important}
  .contact-hero-actions{align-items:stretch;flex-direction:column}
  .contact-ghost-button,.contact-hero-actions .button{width:100%}
  .contact-hero-card strong{font-size:1.55rem}
  .contact-list li{display:grid;text-align:left}
  .contact-list a{text-align:left}
}

/* Popup web player */
.live-player-card{background:linear-gradient(180deg,#ffffff,#f6fbff);border:1px solid #d7eaf6;box-shadow:0 18px 44px rgba(0,47,87,.10)}
.player-station-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:24px 0}
.player-station-grid button{border:1px solid #d8eaf5;border-radius:14px;background:#fff;color:#07345f;font-weight:900;padding:13px 10px;cursor:pointer;box-shadow:0 8px 18px rgba(0,47,87,.06)}
.player-station-grid button:hover{border-color:#22c6d5;transform:translateY(-2px)}
.player-small-note{margin-top:18px;color:#5c7180;font-size:.95rem}
.popup-player-body{margin:0;min-height:100vh;background:linear-gradient(150deg,#042d57,#006fae 58%,#ff9d00);font-family:Arial,Helvetica,sans-serif;color:#07345f}
.popup-player-shell{min-height:100vh;display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr) auto;gap:16px;padding:18px;box-sizing:border-box}
.popup-player-hero{display:flex;justify-content:space-between;gap:14px;align-items:center;color:#fff}
.popup-player-brand{display:flex;align-items:center;gap:12px}.popup-player-brand img{width:74px;height:auto;filter:drop-shadow(0 10px 22px rgba(0,0,0,.25))}.popup-player-brand span{display:block;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:900;color:#ffdc73}.popup-player-brand h1{margin:2px 0 0;font-size:1.25rem;line-height:1.1}.popup-close{width:42px;height:42px;border:1px solid rgba(255,255,255,.35);border-radius:999px;background:rgba(255,255,255,.14);color:#fff;font-size:1.8rem;line-height:1;cursor:pointer}.popup-now-card{display:flex;gap:16px;align-items:center;padding:18px;border-radius:24px;background:rgba(255,255,255,.94);box-shadow:0 20px 55px rgba(0,0,0,.22)}.popup-now-logo{display:grid;place-items:center;flex:0 0 78px;width:78px;height:78px;border-radius:20px;background:#f2f8fc;border:1px solid #d8eaf5}.popup-now-logo img{max-width:64px;max-height:54px}.popup-now-copy span{display:block;color:#007fc1;text-transform:uppercase;letter-spacing:.10em;font-size:.72rem;font-weight:900}.popup-now-copy h2{margin:4px 0 5px;font-size:1.45rem;color:#07345f}.popup-now-copy p{margin:0;color:#4f6574;line-height:1.4}.popup-audio{width:100%;height:46px}.popup-player-actions{display:flex;gap:10px}.popup-play-button,.popup-external-link{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:10px 14px;border-radius:999px;border:0;text-decoration:none;font-weight:900;cursor:pointer}.popup-play-button{flex:1;background:#ffbd26;color:#07345f}.popup-external-link{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.32);color:#fff}.popup-player-frame-wrap{height:245px;border-radius:22px;overflow:hidden;background:#fff;box-shadow:0 16px 42px rgba(0,0,0,.18)}.popup-player-frame-wrap iframe{width:100%;height:100%;border:0}.popup-station-list{display:grid;grid-template-columns:1fr;gap:10px;overflow:auto;padding-right:3px}.popup-station-button{display:flex;align-items:center;gap:12px;width:100%;padding:12px;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:rgba(255,255,255,.92);color:#07345f;text-align:left;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.10)}.popup-station-button.active{outline:3px solid rgba(255,189,38,.85);background:#fff}.popup-station-button img{width:48px;height:38px;object-fit:contain}.popup-station-button strong{display:block;font-size:1rem}.popup-station-button small{display:block;color:#5c7180;font-weight:800;margin-top:2px}.popup-player-note{margin:0;color:rgba(255,255,255,.9);font-size:.84rem;line-height:1.45}.popup-player-note strong{color:#fff}@media(max-width:700px){.player-station-grid{grid-template-columns:1fr}.popup-player-shell{padding:14px}.popup-player-frame-wrap{height:220px}.popup-player-actions{display:grid}.popup-external-link{width:auto}}

/* Refined popup web player */
.popup-player-body{margin:0;min-height:100vh;background:radial-gradient(circle at 12% 0%,rgba(255,198,45,.32),transparent 30%),linear-gradient(145deg,#05284d 0%,#075f9b 52%,#13b5c8 100%);font-family:Arial,Helvetica,sans-serif;color:#07345f}.popup-player-shell{min-height:100vh;box-sizing:border-box;display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:14px;padding:18px;max-width:520px;margin:0 auto}.popup-player-panel,.popup-stations-panel{background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.6);border-radius:28px;box-shadow:0 24px 70px rgba(0,31,68,.28);overflow:hidden}.popup-player-panel{padding:16px}.popup-player-hero{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px;color:#07345f}.popup-player-brand{display:flex;align-items:center;gap:12px}.popup-player-brand img{width:72px;max-height:48px;object-fit:contain;filter:none}.popup-player-brand span{display:block;text-transform:uppercase;letter-spacing:.13em;font-size:.7rem;font-weight:900;color:#007fc1}.popup-player-brand h1{margin:2px 0 0;font-size:1.16rem;line-height:1.1;color:#07345f}.popup-close{width:40px;height:40px;border:1px solid #d5e9f4;border-radius:999px;background:#f4f9fc;color:#07345f;font-size:1.55rem;line-height:1;cursor:pointer}.popup-close:hover{background:#e9f6fb}.popup-now-card{display:flex;gap:14px;align-items:center;padding:18px;border-radius:24px;background:linear-gradient(135deg,#07345f 0%,#007fc1 66%,#18b9ca 100%);box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 16px 34px rgba(0,68,120,.18);color:#fff}.popup-station-mark{display:grid;place-items:center;flex:0 0 76px;width:76px;height:76px;border-radius:22px;background:#ffbd26;color:#07345f;font-size:1.05rem;font-weight:1000;letter-spacing:.04em;box-shadow:0 12px 30px rgba(0,0,0,.18)}.popup-station-mark[data-brand="coast-gold"]{background:#f2c94c}.popup-station-mark[data-brand="coast-rock"]{background:#111;color:#fff}.popup-station-mark[data-brand="energy-fm"]{background:#e71970;color:#fff}.popup-now-copy span{display:block;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:900;color:#ffe48b}.popup-now-copy h2{margin:5px 0 6px;font-size:1.55rem;color:#fff;line-height:1.08}.popup-now-copy p{margin:0;color:rgba(255,255,255,.88);line-height:1.4}.popup-audio{width:100%;height:42px;margin-top:14px}.popup-player-actions{display:flex;gap:10px;margin-top:14px}.popup-play-button,.popup-secondary-link{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:10px 15px;border-radius:999px;text-decoration:none;font-weight:900;cursor:pointer}.popup-play-button{flex:1;border:0;background:#ffbd26;color:#07345f;box-shadow:0 12px 24px rgba(255,189,38,.22)}.popup-play-button:hover{filter:brightness(1.03)}.popup-secondary-link{border:1px solid #d7eaf5;background:#fff;color:#0071ad}.popup-stream-status{margin-top:14px;padding:13px 14px;border:1px solid #f6d99b;background:#fff8e7;border-radius:16px;color:#735000}.popup-stream-status strong,.popup-stream-status span{display:block}.popup-stream-status span{margin-top:3px;font-size:.9rem;line-height:1.4}.popup-stations-panel{min-height:0;padding:14px}.popup-section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin:0 0 11px}.popup-section-head span{font-weight:1000;color:#07345f}.popup-section-head small{color:#5d7180;text-align:right;line-height:1.2}.popup-station-list{display:grid;gap:9px;max-height:360px;overflow:auto;padding-right:2px}.popup-station-button{display:grid;grid-template-columns:46px 1fr auto;align-items:center;gap:12px;width:100%;padding:11px;border:1px solid #dcecf5;border-radius:18px;background:#fff;color:#07345f;text-align:left;cursor:pointer;box-shadow:0 7px 18px rgba(0,47,87,.06)}.popup-station-button:hover{border-color:#78cde2;transform:translateY(-1px)}.popup-station-button.active{border-color:#ffbd26;box-shadow:0 0 0 3px rgba(255,189,38,.28),0 10px 24px rgba(0,47,87,.10)}.popup-station-initials{display:grid;place-items:center;width:46px;height:46px;border-radius:15px;background:#eef8fc;color:#007fc1;font-size:.78rem;font-weight:1000;letter-spacing:.04em}.popup-station-text strong{display:block;font-size:.98rem}.popup-station-text small{display:block;color:#647887;font-weight:800;margin-top:2px}.popup-station-state{justify-self:end;padding:5px 8px;border-radius:999px;background:#edf8fb;color:#08779f;font-size:.68rem;font-weight:1000;text-transform:uppercase;letter-spacing:.05em}.popup-station-button:not(.active) .popup-station-state{background:#f3f7fa;color:#718390}.popup-player-note{margin:0;color:rgba(255,255,255,.92);font-size:.84rem;line-height:1.45;text-align:center}.popup-player-note strong{color:#fff}@media(max-width:540px){.popup-player-shell{padding:12px}.popup-player-panel,.popup-stations-panel{border-radius:22px}.popup-now-card{padding:15px}.popup-station-mark{width:64px;height:64px;flex-basis:64px;border-radius:18px}.popup-player-actions{display:grid}.popup-section-head{display:block}.popup-section-head small{text-align:left;display:block;margin-top:3px}.popup-station-list{max-height:none}.popup-station-button{grid-template-columns:42px 1fr}.popup-station-state{grid-column:2;justify-self:start}}

/* Professional logo-led popup player refinement */
.popup-player-shell{max-width:560px;gap:16px}
.popup-player-panel,.popup-stations-panel{border-radius:30px;border:1px solid rgba(255,255,255,.72);box-shadow:0 28px 80px rgba(0,31,68,.28)}
.popup-player-brand img{width:86px;max-height:56px}
.popup-now-card{gap:16px;padding:20px;background:linear-gradient(135deg,#052b52 0%,#007fc1 62%,#18b9ca 100%)}
.popup-station-logo-wrap{display:grid;place-items:center;flex:0 0 96px;width:96px;height:96px;border-radius:26px;background:#fff;border:1px solid rgba(255,255,255,.7);box-shadow:0 16px 34px rgba(0,0,0,.18);padding:12px;box-sizing:border-box}
.popup-station-logo-wrap img{display:block;max-width:100%;max-height:72px;object-fit:contain}
.popup-now-copy h2{font-size:1.65rem}.popup-now-copy p{font-size:.98rem}
.popup-player-actions{margin-top:16px}.popup-play-button{min-height:48px;font-size:1rem}
.popup-secondary-link{display:none!important}
.popup-section-head{display:block;margin:0 0 13px}.popup-section-head span{font-size:1rem;letter-spacing:.01em}.popup-section-head small{display:none!important}
.popup-station-list{gap:10px;max-height:390px;padding:2px 4px 4px 2px}
.popup-station-button{grid-template-columns:70px 1fr auto;gap:14px;padding:12px 13px;border-radius:20px;background:linear-gradient(180deg,#fff,#f8fcff);border:1px solid #d8eaf5;box-shadow:0 10px 24px rgba(0,47,87,.065)}
.popup-station-button:hover{background:#fff;box-shadow:0 14px 30px rgba(0,47,87,.1)}
.popup-station-button.active{background:#fff;border-color:#ffbd26;box-shadow:0 0 0 3px rgba(255,189,38,.28),0 16px 32px rgba(0,47,87,.12)}
.popup-station-logo{display:grid;place-items:center;width:70px;height:50px;border-radius:16px;background:#fff;border:1px solid #e0eef6;box-shadow:inset 0 1px 0 rgba(255,255,255,.8);padding:7px;box-sizing:border-box}
.popup-station-logo img{display:block;max-width:100%;max-height:36px;object-fit:contain}
.popup-station-text strong{font-size:1rem;line-height:1.1}.popup-station-text small{font-size:.82rem;color:#607788;font-weight:800}
.popup-station-state{background:#eaf8f4;color:#027b62;font-size:.66rem;padding:5px 9px}
.popup-station-button:not(.active) .popup-station-state{background:#f1f7fb;color:#637b8e}
.popup-player-note{font-size:.86rem}
@media(max-width:540px){.popup-player-shell{max-width:none;padding:12px}.popup-player-brand img{width:76px}.popup-station-logo-wrap{width:76px;height:76px;flex-basis:76px;border-radius:22px}.popup-station-logo-wrap img{max-height:56px}.popup-now-copy h2{font-size:1.35rem}.popup-station-button{grid-template-columns:62px 1fr;gap:12px}.popup-station-logo{width:62px;height:48px}.popup-station-state{grid-column:2;justify-self:start}}


/* Compact professional station buttons */
.station-grid,
.stations-grid,
.player-stations,
.station-list {
    display:grid !important;
    grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
    gap:10px !important;
}

.station-btn,
.station-card,
button[data-stream],
.stream-button,
.station-button {
    min-height:48px !important;
    padding:10px 14px !important;
    border-radius:12px !important;
    font-size:14px !important;
    font-weight:600 !important;
    letter-spacing:.2px;
    background:rgba(255,255,255,.08) !important;
    border:1px solid rgba(255,255,255,.12) !important;
    backdrop-filter:blur(10px);
    transition:all .2s ease;
    box-shadow:none !important;
}

.station-btn:hover,
.station-card:hover,
button[data-stream]:hover,
.stream-button:hover,
.station-button:hover {
    transform:translateY(-1px);
    background:rgba(255,255,255,.14) !important;
}

.station-btn img,
.station-card img,
.stream-button img,
.station-button img {
    display:none !important;
}


/* ===== Modern Coast FM Player Redesign ===== */

.player-popup,
.radio-player,
.popup-player,
#player,
.player-container{
    max-width:420px !important;
    margin:auto;
    background:linear-gradient(180deg,#08111f 0%,#0f1c2d 100%) !important;
    border-radius:24px !important;
    padding:24px !important;
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 20px 50px rgba(0,0,0,.45);
}

.station-grid,
.stations-grid,
.player-stations,
.station-list{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:8px !important;
    margin-top:18px !important;
}

.station-btn,
.station-button,
.stream-button,
button[data-stream],
.station-card{
    height:42px !important;
    min-height:42px !important;
    border-radius:10px !important;
    border:1px solid rgba(255,255,255,.08) !important;
    background:rgba(255,255,255,.04) !important;
    color:#fff !important;
    font-size:12px !important;
    font-weight:600 !important;
    letter-spacing:.3px !important;
    padding:0 12px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    transition:all .18s ease !important;
    backdrop-filter:blur(8px);
    text-transform:none !important;
    box-shadow:none !important;
}

.station-btn:hover,
.station-button:hover,
.stream-button:hover,
button[data-stream]:hover,
.station-card:hover{
    background:#00a8ff !important;
    border-color:#00a8ff !important;
    transform:translateY(-1px);
}

.station-btn.active,
.station-button.active,
.stream-button.active,
button[data-stream].active,
.station-card.active{
    background:linear-gradient(135deg,#00a8ff,#0066ff) !important;
    border-color:transparent !important;
}

.station-btn img,
.station-button img,
.stream-button img,
.station-card img{
    display:none !important;
}

.player-header,
.player-top{
    text-align:center;
    margin-bottom:20px;
}

.player-header h1,
.player-top h1,
.player-header h2{
    font-size:24px !important;
    font-weight:700 !important;
    margin-bottom:6px !important;
    color:white !important;
}

.player-subtitle,
.player-description{
    display:none !important;
}

audio{
    width:100%;
    margin-top:20px;
    border-radius:12px;
}

.open-station-page,
.station-link,
.player-footer{
    display:none !important;
}





/* FINAL HEADER LOGO RESTORE */
.header-top .logo{display:block !important;background:none !important;text-indent:0 !important;overflow:visible !important;}
.header-top .logo img{display:block !important;width:100% !important;max-width:355px !important;height:auto !important;opacity:1 !important;visibility:visible !important;}
@media (max-width: 760px){.header-top .logo img{max-width:230px !important;}}

/* Location split additions */
.location-switch{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:8px 12px!important;}
.site-header .logo img{display:block!important;max-width:210px!important;height:auto!important;}


/* Northern Ireland homepage fix */
.ni-hero-slider,
.hero-slider.ni-hero-slider {
    position: relative;
    min-height: 560px;
    overflow: hidden;
    background: #07111f;
}

.ni-hero-slider .slide {
    min-height: 560px;
    background-size: cover;
    background-position: center;
    display: none;
    align-items: center;
    padding: 80px 24px;
}

.ni-hero-slider .slide.active,
.ni-hero-slider .slide:first-child {
    display: flex;
}

.ni-hero-slider .slide-content {
    max-width: 1120px;
    width: 100%;
    margin: 0 auto;
    color: #fff;
}

.ni-hero-slider h1 {
    font-size: clamp(2.5rem, 5vw, 4.8rem);
    line-height: 1;
    margin: 0 0 18px;
}

.ni-hero-slider p {
    font-size: clamp(1.05rem, 2vw, 1.45rem);
    max-width: 640px;
    margin: 0;
}

.ni-news-weather {
    padding: 64px 20px;
    background: #f6f8fb;
}

.ni-news-weather .container {
    max-width: 1120px;
    margin: 0 auto;
}

.ni-news-weather .section-heading h2 {
    margin: 0 0 10px;
    color: #08111f;
    font-size: clamp(2rem, 4vw, 3rem);
}

.ni-news-weather .section-heading p {
    color: #536173;
    margin: 0 0 28px;
}

.ni-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 18px;
}

.ni-info-card {
    display: block;
    padding: 26px;
    border-radius: 20px;
    background: #fff;
    color: #08111f;
    text-decoration: none;
    box-shadow: 0 14px 36px rgba(8,17,31,.08);
    border: 1px solid rgba(8,17,31,.06);
}

.ni-info-card:hover {
    transform: translateY(-2px);
}

.ni-info-card .card-kicker {
    display: inline-block;
    margin-bottom: 12px;
    color: #0077c8;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: .78rem;
}

.ni-info-card strong {
    display: block;
    font-size: 1.35rem;
    margin-bottom: 8px;
}

.ni-info-card p {
    color: #536173;
    margin: 0;
}


/* Coast FM logo size fix */
header .logo img,
.site-header .logo img,
.navbar .logo img,
.logo img,
.brand img,
.header-logo img,
img[alt="Coast FM"] {
    width: clamp(220px, 24vw, 340px) !important;
    max-width: 340px !important;
    height: auto !important;
    display: block !important;
    object-fit: contain !important;
}

@media (max-width: 700px) {
    header .logo img,
    .site-header .logo img,
    .navbar .logo img,
    .logo img,
    .brand img,
    .header-logo img,
    img[alt="Coast FM"] {
        width: 230px !important;
        max-width: 230px !important;
    }
}

/* Reliable Northern Ireland image slider */
.ni-clean-slider {
    position: relative !important;
    width: 100% !important;
    height: min(62vw, 620px) !important;
    min-height: 430px !important;
    overflow: hidden !important;
    background: #07111f !important;
    isolation: isolate !important;
}

.ni-clean-slide {
    position: absolute !important;
    inset: 0 !important;
    opacity: 0 !important;
    transition: opacity .7s ease !important;
    z-index: 0 !important;
}

.ni-clean-slide.is-active {
    opacity: 1 !important;
    z-index: 1 !important;
}

.ni-clean-slide img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.ni-clean-slide::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(90deg, rgba(3,7,18,.72), rgba(3,7,18,.20), rgba(3,7,18,.35)) !important;
    z-index: 2 !important;
}

.ni-clean-caption {
    position: absolute !important;
    left: max(28px, 7vw) !important;
    bottom: max(48px, 12vw) !important;
    max-width: 760px !important;
    color: #fff !important;
    z-index: 3 !important;
}

.ni-clean-caption h1 {
    margin: 0 0 16px !important;
    font-size: clamp(2.6rem, 5.4vw, 5.2rem) !important;
    line-height: .95 !important;
    font-weight: 800 !important;
    color: #fff !important;
}

.ni-clean-caption p {
    margin: 0 !important;
    font-size: clamp(1.05rem, 2vw, 1.45rem) !important;
    line-height: 1.45 !important;
    color: #e8f2ff !important;
}

@media (max-width: 700px) {
    .ni-clean-slider {
        min-height: 500px !important;
        height: 500px !important;
    }
    .ni-clean-caption {
        left: 22px !important;
        right: 22px !important;
        bottom: 44px !important;
    }
}

/* Final NI static hero replacement */
.ni-clean-slider,
.ni-hero-slider,
.hero-slider.ni-hero-slider {
    display: none !important;
}

.ni-final-hero {
    position: relative !important;
    min-height: 560px !important;
    overflow: hidden !important;
    background: #071a2d !important;
}

.ni-final-hero-img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    z-index: 1 !important;
}

.ni-final-hero::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(90deg, rgba(3,7,18,.72), rgba(3,7,18,.20), rgba(3,7,18,.38)) !important;
    z-index: 2 !important;
}

.ni-final-hero-copy {
    position: relative !important;
    z-index: 3 !important;
    max-width: 1120px !important;
    margin: 0 auto !important;
    padding: 170px 28px 120px !important;
    color: #fff !important;
}

.ni-final-hero-copy h1 {
    margin: 0 0 18px !important;
    font-size: clamp(2.7rem, 5.2vw, 5rem) !important;
    line-height: .95 !important;
    font-weight: 800 !important;
    color: #fff !important;
}

.ni-final-hero-copy p {
    margin: 0 !important;
    max-width: 660px !important;
    font-size: clamp(1.1rem, 2vw, 1.45rem) !important;
    line-height: 1.45 !important;
    color: #e8f2ff !important;
}

@media (max-width: 700px) {
    .ni-final-hero { min-height: 500px !important; }
    .ni-final-hero-copy { padding: 145px 22px 90px !important; }
}

/* FINAL: NI homepage uses a static hero, not a slider */
.ni-clean-slider,
.ni-hero-slider,
.hero-slider,
.hero-carousel,
.slider,
.carousel,
.slide:not(.coast-keep-slide),
.ni-final-hero,
.ni-static-hero {
  display: none !important;
}

.coast-ni-hero {
  position: relative !important;
  min-height: 560px !important;
  overflow: hidden !important;
  background: #071827 !important;
  display: block !important;
}

.coast-ni-hero img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  z-index: 1 !important;
}

.coast-ni-hero::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(90deg, rgba(3,7,18,.72), rgba(3,7,18,.18), rgba(3,7,18,.36)) !important;
  z-index: 2 !important;
}

.coast-ni-hero-text {
  position: relative !important;
  z-index: 3 !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
  padding: 170px 28px 120px !important;
  color: #fff !important;
}

.coast-ni-hero-text h1 {
  margin: 0 0 18px !important;
  font-size: clamp(2.7rem, 5.2vw, 5rem) !important;
  line-height: .95 !important;
  font-weight: 800 !important;
  color: #fff !important;
}

.coast-ni-hero-text p {
  margin: 0 !important;
  max-width: 660px !important;
  font-size: clamp(1.1rem, 2vw, 1.45rem) !important;
  line-height: 1.45 !important;
  color: #e8f2ff !important;
}

@media (max-width: 700px) {
  .coast-ni-hero { min-height: 500px !important; }
  .coast-ni-hero-text { padding: 145px 22px 90px !important; }
}

/* Working NI homepage slider - final */
.coast-ni-slider {
  position: relative !important;
  min-height: 560px !important;
  overflow: hidden !important;
  background: #071a2d !important;
  display: block !important;
}

.coast-ni-panel {
  position: absolute !important;
  inset: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .75s ease !important;
  display: block !important;
  z-index: 1 !important;
}

.coast-ni-panel.is-visible {
  opacity: 1 !important;
  pointer-events: auto !important;
  z-index: 2 !important;
}

.coast-ni-panel img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  z-index: 1 !important;
}

.coast-ni-panel::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(90deg, rgba(3,7,18,.72), rgba(3,7,18,.18), rgba(3,7,18,.36)) !important;
  z-index: 2 !important;
}

.coast-ni-panel-copy {
  position: relative !important;
  z-index: 3 !important;
  max-width: 1120px !important;
  margin: 0 auto !important;
  padding: 170px 28px 120px !important;
  color: #fff !important;
}

.coast-ni-panel-copy h1 {
  margin: 0 0 18px !important;
  font-size: clamp(2.7rem, 5.2vw, 5rem) !important;
  line-height: .95 !important;
  font-weight: 800 !important;
  color: #fff !important;
}

.coast-ni-panel-copy p {
  margin: 0 !important;
  max-width: 660px !important;
  font-size: clamp(1.1rem, 2vw, 1.45rem) !important;
  line-height: 1.45 !important;
  color: #e8f2ff !important;
}

.coast-ni-dots {
  position: absolute !important;
  left: 50% !important;
  bottom: 26px !important;
  transform: translateX(-50%) !important;
  display: flex !important;
  gap: 10px !important;
  z-index: 5 !important;
}

.coast-ni-dots button {
  width: 12px !important;
  height: 12px !important;
  border-radius: 999px !important;
  border: 0 !important;
  padding: 0 !important;
  background: rgba(255,255,255,.45) !important;
  cursor: pointer !important;
}

.coast-ni-dots button.is-visible {
  width: 32px !important;
  background: #ffbd26 !important;
}

@media (max-width: 700px) {
  .coast-ni-slider { min-height: 500px !important; }
  .coast-ni-panel-copy { padding: 145px 22px 90px !important; }
}

/* Ensure old slider attempts stay hidden if any cached markup remains */
.ni-clean-slider,
.ni-hero-slider,
.hero-slider.ni-hero-slider,
.ni-final-hero,
.ni-static-hero,
.coast-ni-hero {
  display: none !important;
}


/* Final NI hero cleanup */
.hero-content,
.slide-content,
.hero-text,
.slider-caption,
.coast-ni-panel-copy h2 {
    display:none !important;
}

.ni-simple-hero {
    position: relative;
    height: 560px;
    overflow: hidden;
    background:#071827;
}

.ni-simple-hero img {
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.ni-simple-overlay {
    position:absolute;
    inset:0;
    background:linear-gradient(90deg, rgba(0,0,0,.68), rgba(0,0,0,.22));
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:80px;
    color:#fff;
}

.ni-simple-overlay h1 {
    font-size:72px;
    line-height:1;
    margin:0 0 20px;
    font-weight:800;
    max-width:700px;
}

.ni-simple-overlay p {
    font-size:24px;
    max-width:700px;
    margin:0;
}

@media(max-width:768px){
    .ni-simple-overlay{
        padding:40px 24px;
    }
    .ni-simple-overlay h1{
        font-size:44px;
    }
    .ni-simple-overlay p{
        font-size:18px;
    }
}

/* Remove ghost slider text */
.coast-ni-panel-copy,
.hero-copy,
.hero-caption,
.slide-copy,
.slide-title,
.slide-subtitle,
.slider-content,
.slider-text,
.hero-heading,
.hero-subheading {
    display:none !important;
}

.ni-simple-overlay,
.coast-ni-hero-text {
    display:flex !important;
    flex-direction:column;
    justify-content:center;
}


/* NI showcase slider replacement */
.ni-showcase{
    background:#071827;
    padding:0;
    overflow:hidden;
}

.ni-grid{
    display:grid;
    grid-template-columns:repeat(6,1fr);
    gap:0;
}

.ni-tile{
    position:relative;
    height:420px;
    overflow:hidden;
}

.ni-tile img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
    transition:transform .4s ease;
}

.ni-tile::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(to top, rgba(0,0,0,.75), rgba(0,0,0,.15));
}

.ni-tile:hover img{
    transform:scale(1.04);
}

.ni-tile span{
    position:absolute;
    left:24px;
    bottom:28px;
    z-index:2;
    color:#fff;
    font-size:42px;
    font-weight:800;
    letter-spacing:.02em;
}

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

@media(max-width:768px){
    .ni-grid{
        grid-template-columns:1fr;
    }
    .ni-tile{
        height:260px;
    }
    .ni-tile span{
        font-size:32px;
    }
}

/* Mockup-style Northern Ireland location showcase */
.ni-location-showcase{
  position:relative;
  background:#071827;
  border-top:3px solid #ffbd26;
  overflow:hidden;
}
.ni-location-strip{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  min-height:430px;
}
.ni-location-card{
  position:relative;
  min-height:430px;
  overflow:hidden;
  border-right:4px solid rgba(255,255,255,.72);
  transform:skewX(-4deg);
  margin-left:-18px;
  background:#071827;
}
.ni-location-card:first-child{margin-left:0;}
.ni-location-card img{
  width:115%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:skewX(4deg) scale(1.08);
  margin-left:-7%;
  filter:saturate(1.1) contrast(1.04);
}
.ni-location-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.78),rgba(0,0,0,.05) 62%);
  z-index:1;
}
.ni-location-card div{
  position:absolute;
  left:34px;
  right:18px;
  bottom:26px;
  z-index:2;
  color:white;
  transform:skewX(4deg);
}
.ni-location-card h2{
  margin:0 0 4px;
  color:#fff;
  font-size:clamp(1.45rem,2.2vw,2.2rem);
  line-height:1;
  font-weight:900;
  letter-spacing:.02em;
  text-shadow:0 3px 12px rgba(0,0,0,.55);
}
.ni-location-card p{
  margin:0;
  color:#fff;
  font-size:1.02rem;
  text-shadow:0 2px 8px rgba(0,0,0,.55);
}
.ni-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:54px;
  height:54px;
  border:0;
  border-radius:999px;
  background:rgba(0,0,0,.55);
  color:#fff;
  font-size:48px;
  line-height:48px;
  cursor:pointer;
}
.ni-arrow-left{left:18px;}
.ni-arrow-right{right:18px;}
@media(max-width:1200px){
  .ni-location-strip{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:760px){
  .ni-location-strip{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;}
  .ni-location-card{min-width:78%;scroll-snap-align:start;}
}

/* Real 5-slide Northern Ireland location carousel */
.ni-photo-carousel {
    position:relative !important;
    height:520px !important;
    min-height:520px !important;
    overflow:hidden !important;
    background:#071827 !important;
    border-top:3px solid #ffbd26 !important;
}

.ni-photo-slides,
.ni-photo-slide {
    position:absolute !important;
    inset:0 !important;
}

.ni-photo-slide {
    opacity:0 !important;
    pointer-events:none !important;
    transition:opacity .65s ease !important;
    z-index:1 !important;
}

.ni-photo-slide.is-active {
    opacity:1 !important;
    pointer-events:auto !important;
    z-index:2 !important;
}

.ni-photo-slide img {
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    display:block !important;
    filter:saturate(1.05) contrast(1.04) !important;
}

.ni-photo-slide::after {
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    background:linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,.08) 58%, rgba(0,0,0,.18)) !important;
    z-index:2 !important;
}

.ni-photo-caption {
    position:absolute !important;
    left:70px !important;
    bottom:70px !important;
    z-index:3 !important;
    color:#fff !important;
}

.ni-photo-caption h1 {
    margin:0 0 8px !important;
    font-size:clamp(3rem, 6vw, 5.6rem) !important;
    line-height:.9 !important;
    color:#fff !important;
    font-weight:900 !important;
    letter-spacing:.02em !important;
    text-shadow:0 6px 20px rgba(0,0,0,.65) !important;
}

.ni-photo-caption p {
    margin:0 !important;
    font-size:clamp(1.2rem, 2vw, 1.8rem) !important;
    color:#fff !important;
    text-shadow:0 4px 14px rgba(0,0,0,.65) !important;
}

.ni-photo-arrow {
    position:absolute !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    z-index:5 !important;
    width:56px !important;
    height:56px !important;
    border:0 !important;
    border-radius:999px !important;
    background:rgba(0,0,0,.58) !important;
    color:#fff !important;
    font-size:54px !important;
    line-height:48px !important;
    cursor:pointer !important;
}

.ni-photo-prev { left:22px !important; }
.ni-photo-next { right:22px !important; }

.ni-photo-dots {
    position:absolute !important;
    left:50% !important;
    bottom:24px !important;
    transform:translateX(-50%) !important;
    z-index:6 !important;
    display:flex !important;
    gap:9px !important;
}

.ni-photo-dots button {
    width:10px !important;
    height:10px !important;
    border-radius:999px !important;
    border:0 !important;
    padding:0 !important;
    background:rgba(255,255,255,.6) !important;
    cursor:pointer !important;
}

.ni-photo-dots button.is-active {
    width:32px !important;
    background:#ffbd26 !important;
}

@media(max-width:768px){
    .ni-photo-carousel {
        height:460px !important;
        min-height:460px !important;
    }
    .ni-photo-caption {
        left:28px !important;
        right:28px !important;
        bottom:72px !important;
    }
}

/* Hide failed previous NI slider/showcase attempts */
.ni-photo-carousel,
.ni-location-showcase,
.ni-showcase,
.coast-ni-slider,
.ni-clean-slider,
.ni-hero-slider,
.hero-slider.ni-hero-slider,
.ni-final-hero,
.ni-static-hero,
.coast-ni-hero,
.ni-simple-hero {
    display:none !important;
}


/* Web player polish */
.player-logo,
.player-brand,
.player-header,
.radio-player-header,
.web-player-header {
    background:#ffffff !important;
    text-align:center !important;
    justify-content:center !important;
    align-items:center !important;
}

.player-logo img,
.player-brand img,
.player-header img,
.radio-player-header img,
.web-player-header img,
.player-card img[alt*="Coast"],
.player-card img[alt*="logo"] {
    display:block !important;
    margin:0 auto !important;
    max-width:240px !important;
    height:auto !important;
}

.player-title,
.web-player-title,
.radio-player-title {
    text-align:center !important;
}

.selected-stream-status {
    margin:14px auto 16px !important;
    padding:12px 16px !important;
    max-width:360px !important;
    border-radius:14px !important;
    background:rgba(255,255,255,.10) !important;
    border:1px solid rgba(255,255,255,.16) !important;
    color:#ffffff !important;
    text-align:center !important;
    font-size:13px !important;
}

.selected-stream-status span {
    display:block !important;
    opacity:.78 !important;
    margin-bottom:4px !important;
}

.selected-stream-status strong {
    display:block !important;
    font-size:17px !important;
    color:#ffbd26 !important;
}


/* FINAL popup player repair: white logo panel + visible full station list */
.popup-player-card,
.player-card,
.radio-player,
.web-player,
.player-shell {
    overflow: visible !important;
}

.popup-player-card,
.player-card {
    background: #ffffff !important;
}

.popup-player-header,
.player-header,
.player-top,
.player-brand,
.player-logo,
.player-hero,
.popup-player-hero {
    background: #ffffff !important;
    background-color: #ffffff !important;
    background-image: none !important;
    text-align: center !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    padding: 20px 18px 10px !important;
}

.popup-player-header img,
.player-header img,
.player-top img,
.player-brand img,
.player-logo img,
.player-hero img,
.popup-player-hero img {
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 210px !important;
    width: auto !important;
    height: auto !important;
}

.player-title-wrap,
.popup-player-body,
.player-body {
    background: #086da3 !important;
}

.station-grid,
.stations-grid,
.station-list,
.player-stations {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
    padding-bottom: 14px !important;
}

.station-button,
.station-btn,
.stream-button,
button[data-stream] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 34px !important;
    height: 34px !important;
    padding: 6px 10px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

.station-button.is-active,
.station-btn.is-active,
.stream-button.is-active,
button[data-stream].is-active {
    box-shadow: inset 0 0 0 2px rgba(255,255,255,.8) !important;
}

#current-station-name {
    color: #ffb21a !important;
    font-weight: 900 !important;
}

.now-selected {
    margin: 10px 0 12px !important;
    padding: 0 !important;
    text-align: center !important;
    background: transparent !important;
    border: 0 !important;
}


/* HQ NI slider image fix */
.ni-real-slide img,
.ni-slide img,
.ni-hero-slide img,
.ni-carousel img{
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    object-position:center center !important;
    image-rendering:auto !important;
    transform:none !important;
    filter:saturate(1.04) contrast(1.02);
}

.ni-real-carousel,
.ni-carousel,
.ni-slider{
    background:#071b2b !important;
}


/* Real uploaded NI slider images */
.ni-slide img,
.ni-slider img,
.ni-hero-slide img,
.ni-carousel img{
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    object-position:center center !important;
    transform:none !important;
}

/* NI uploaded-image 6 slide carousel */
.ni-upload-carousel {
    position: relative !important;
    height: 540px !important;
    min-height: 540px !important;
    overflow: hidden !important;
    background: #071827 !important;
    border-top: 3px solid #ffbd26 !important;
}

.ni-upload-slides,
.ni-upload-slide {
    position: absolute !important;
    inset: 0 !important;
}

.ni-upload-slide {
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity .65s ease !important;
    z-index: 1 !important;
}

.ni-upload-slide.is-active {
    opacity: 1 !important;
    pointer-events: auto !important;
    z-index: 2 !important;
}

.ni-upload-slide img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
    display: block !important;
    transform: none !important;
    filter: saturate(1.03) contrast(1.02) !important;
}

.ni-upload-slide::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background:
      linear-gradient(90deg, rgba(0, 28, 54, .72), rgba(0, 50, 80, .25) 48%, rgba(0, 0, 0, .10)),
      linear-gradient(to top, rgba(0,0,0,.55), transparent 58%) !important;
    z-index: 2 !important;
}

.ni-upload-caption {
    position: absolute !important;
    left: max(32px, 8vw) !important;
    bottom: 76px !important;
    z-index: 3 !important;
    color: #fff !important;
    max-width: 720px !important;
}

.ni-upload-caption h1 {
    margin: 0 0 8px !important;
    color: #fff !important;
    font-size: clamp(3rem, 6vw, 5.6rem) !important;
    line-height: .9 !important;
    font-weight: 900 !important;
    letter-spacing: -.03em !important;
    text-shadow: 0 8px 24px rgba(0,0,0,.55) !important;
}

.ni-upload-caption p {
    margin: 0 !important;
    color: #fff !important;
    font-size: clamp(1.2rem, 2vw, 1.8rem) !important;
    text-shadow: 0 4px 14px rgba(0,0,0,.65) !important;
}

.ni-upload-arrow {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 5 !important;
    width: 58px !important;
    height: 58px !important;
    border: 0 !important;
    border-radius: 999px !important;
    background: rgba(255,173,24,.95) !important;
    color: #07345a !important;
    font-size: 54px !important;
    line-height: 48px !important;
    cursor: pointer !important;
    box-shadow: 0 12px 28px rgba(0,0,0,.22) !important;
}

.ni-upload-prev { left: 22px !important; }
.ni-upload-next { right: 22px !important; }

.ni-upload-dots {
    position: absolute !important;
    left: 50% !important;
    bottom: 24px !important;
    transform: translateX(-50%) !important;
    z-index: 6 !important;
    display: flex !important;
    gap: 9px !important;
}

.ni-upload-dots button {
    width: 10px !important;
    height: 10px !important;
    border-radius: 999px !important;
    border: 0 !important;
    padding: 0 !important;
    background: rgba(255,255,255,.62) !important;
    cursor: pointer !important;
}

.ni-upload-dots button.is-active {
    width: 34px !important;
    background: #ffbd26 !important;
}

@media(max-width:768px) {
    .ni-upload-carousel {
        height: 460px !important;
        min-height: 460px !important;
    }

    .ni-upload-caption {
        left: 28px !important;
        right: 28px !important;
        bottom: 72px !important;
    }

    .ni-upload-arrow {
        width: 46px !important;
        height: 46px !important;
        font-size: 44px !important;
    }
}

/* Hide previous failed NI slider blocks if any remain cached in markup */
.ni-real-carousel,
.ni-photo-carousel,
.ni-location-showcase,
.ni-showcase,
.coast-ni-slider,
.ni-clean-slider,
.ni-hero-slider,
.hero-slider.ni-hero-slider,
.ni-final-hero,
.ni-static-hero,
.coast-ni-hero,
.ni-simple-hero {
    display: none !important;
}


/* Professional listen strip replacement */
.listen-icons-strip-pro,
.listen-icons-strip {
  background: linear-gradient(135deg,#062f56,#0787bf) !important;
  padding: 18px 20px !important;
  border-top: 1px solid rgba(255,255,255,.12) !important;
  border-bottom: 1px solid rgba(0,0,0,.08) !important;
}

.listen-icons-strip-pro .listen-icons-inner,
.listen-icons-strip .listen-icons-inner {
  max-width: 1120px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(4,minmax(0,1fr)) !important;
  gap: 14px !important;
}

.listen-icons-strip-pro .listen-icon-card,
.listen-icons-strip .listen-icon-card {
  min-height: 74px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 14px 16px !important;
  border-radius: 18px !important;
  text-decoration: none !important;
  background: linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.08)) !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  box-shadow: 0 14px 34px rgba(0,35,70,.20), inset 0 1px 0 rgba(255,255,255,.18) !important;
  color: #fff !important;
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease !important;
}

.listen-icons-strip-pro .listen-icon-card:hover,
.listen-icons-strip .listen-icon-card:hover {
  transform: translateY(-2px) !important;
  background: linear-gradient(145deg,rgba(255,255,255,.25),rgba(255,255,255,.12)) !important;
  box-shadow: 0 18px 40px rgba(0,35,70,.26), inset 0 1px 0 rgba(255,255,255,.22) !important;
}

.listen-icons-strip-pro .listen-icon-badge,
.listen-icons-strip .listen-icon-badge,
.listen-icons-strip .listen-icon-card > span:first-child {
  width: 42px !important;
  height: 42px !important;
  flex: 0 0 42px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 14px !important;
  background: #ffbd26 !important;
  color: #06345c !important;
  font-size: 14px !important;
  font-weight: 950 !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.20) !important;
}

.listen-icons-strip-pro .listen-icon-card strong,
.listen-icons-strip .listen-icon-card strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 16px !important;
  line-height: 1.05 !important;
  font-weight: 950 !important;
}

.listen-icons-strip-pro .listen-icon-card small,
.listen-icons-strip .listen-icon-card small {
  display: block !important;
  margin-top: 4px !important;
  color: rgba(255,255,255,.78) !important;
  font-size: 11px !important;
  line-height: 1.15 !important;
  font-weight: 700 !important;
}

/* Also force the schedule hero buttons to the same professional look */
.rebuilt-schedule-hero .listen-badges,
.schedule-hero .listen-badges {
  display: grid !important;
  grid-template-columns: repeat(4,minmax(145px,1fr)) !important;
  gap: 14px !important;
  margin-top: 24px !important;
  max-width: 760px !important;
}

.rebuilt-schedule-hero .listen-badge,
.schedule-hero .listen-badge {
  min-height: 74px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 14px 16px !important;
  border-radius: 18px !important;
  background: linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.08)) !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  box-shadow: 0 14px 34px rgba(0,35,70,.20), inset 0 1px 0 rgba(255,255,255,.18) !important;
  color: #fff !important;
}

.rebuilt-schedule-hero .listen-badge span,
.schedule-hero .listen-badge span {
  width: 42px !important;
  height: 42px !important;
  flex: 0 0 42px !important;
  border-radius: 14px !important;
  background: #ffbd26 !important;
  color: #06345c !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  font-weight: 950 !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.20) !important;
}

.rebuilt-schedule-hero .listen-badge strong,
.schedule-hero .listen-badge strong {
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 950 !important;
  line-height: 1.05 !important;
}

.rebuilt-schedule-hero .listen-badge em,
.schedule-hero .listen-badge em {
  display: block !important;
  margin-top: 4px !important;
  color: rgba(255,255,255,.78) !important;
  font-size: 11px !important;
  line-height: 1.15 !important;
  font-style: normal !important;
  font-weight: 700 !important;
}

@media(max-width:900px) {
  .listen-icons-strip-pro .listen-icons-inner,
  .listen-icons-strip .listen-icons-inner,
  .rebuilt-schedule-hero .listen-badges,
  .schedule-hero .listen-badges {
    grid-template-columns: repeat(2,minmax(0,1fr)) !important;
  }
}

@media(max-width:520px) {
  .listen-icons-strip-pro .listen-icons-inner,
  .listen-icons-strip .listen-icons-inner,
  .rebuilt-schedule-hero .listen-badges,
  .schedule-hero .listen-badges {
    grid-template-columns: 1fr !important;
  }
}


/* HARD REMOVE OLD WHITE BUTTON STRIP */
.listen-icons-strip,
.listen-icons-inner {
    display:none !important;
    height:0 !important;
    overflow:hidden !important;
    margin:0 !important;
    padding:0 !important;
    border:0 !important;
}

/* REAL BUTTONS */
.listen-badges{
    display:flex !important;
    flex-wrap:wrap !important;
    gap:14px !important;
    margin-top:24px !important;
}

.listen-badge{
    display:flex !important;
    align-items:center !important;
    gap:12px !important;
    padding:14px 18px !important;
    min-width:170px !important;
    border-radius:16px !important;
    background:linear-gradient(135deg,#0b4e82,#1ba3d7) !important;
    border:1px solid rgba(255,255,255,.18) !important;
    box-shadow:0 10px 24px rgba(0,0,0,.25) !important;
    color:#fff !important;
}

.listen-badge span{
    width:42px !important;
    height:42px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    border-radius:12px !important;
    background:#ffbf1f !important;
    color:#08385e !important;
    font-weight:900 !important;
}

.listen-badge strong{
    color:#fff !important;
    font-size:16px !important;
    line-height:1.1 !important;
}

.listen-badge em{
    display:block !important;
    font-style:normal !important;
    color:rgba(255,255,255,.8) !important;
    font-size:11px !important;
    margin-top:3px !important;
}


/* Header live on-air block - automatically filled from the schedule */
.status-strip .header-onair{
  min-width:190px;
  background:#ffffff;
  box-shadow:0 10px 28px rgba(10,48,82,.10);
  border-radius:18px;
  padding:12px 16px;
}
.status-strip .header-onair .live-dot-icon{
  color:#e94141;
  background:#ffecee;
  font-size:1.65rem;
  line-height:1;
}
.status-strip .header-onair .status-title{
  font-size:1.12rem;
  line-height:1.08;
}
.status-strip .header-onair .status-sub{
  margin-top:3px;
  font-size:.86rem;
  color:#31536f;
}
@media(max-width:760px){
  .status-strip .header-onair{min-width:0;width:100%;}
}

/* Final professional header On Air Now styling - applies site wide */
.status-strip .header-onair{
  position:relative !important;
  overflow:hidden !important;
  min-width:220px !important;
  padding:13px 18px !important;
  border-radius:22px !important;
  border:1px solid rgba(0,115,180,.16) !important;
  background:
    radial-gradient(circle at 18% 50%, rgba(255,191,31,.20) 0 0, transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(232,247,255,.96) 52%, rgba(214,243,255,.96)) !important;
  box-shadow:0 14px 34px rgba(4,58,101,.13) !important;
}
.status-strip .header-onair:before{
  content:"" !important;
  position:absolute !important;
  inset:0 auto 0 0 !important;
  width:5px !important;
  background:linear-gradient(180deg,#ffbf1f,#ff8a1f) !important;
}
.status-strip .header-onair .live-dot-icon{
  width:42px !important;
  height:42px !important;
  flex:0 0 42px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  color:#fff !important;
  background:linear-gradient(135deg,#e94141,#ff7a59) !important;
  border-radius:50% !important;
  box-shadow:0 0 0 7px rgba(233,65,65,.10) !important;
  font-size:1.15rem !important;
}
.status-strip .header-onair .status-label{
  color:#ff8a1f !important;
  letter-spacing:.08em !important;
  font-weight:900 !important;
}
.status-strip .header-onair .status-title{
  color:#004b86 !important;
  font-size:1.08rem !important;
  line-height:1.12 !important;
  font-weight:900 !important;
}
.status-strip .header-onair .status-sub{
  color:#31536f !important;
  font-size:.84rem !important;
  font-weight:600 !important;
}



/* Polished header Now Playing block - matches the redesigned On-Air Now panel */
.status-strip .header-nowplaying{
  min-width:230px;
  background:linear-gradient(135deg,#ffffff 0%,#f4fbff 100%);
  border:1px solid rgba(216,234,245,.95) !important;
  box-shadow:0 12px 30px rgba(10,48,82,.11);
  border-radius:18px;
  padding:12px 16px !important;
  overflow:hidden;
}
.status-strip .header-nowplaying .status-icon.record{
  border-radius:14px;
  background:linear-gradient(135deg,#004985 0%,#007fc1 100%);
  color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25),0 8px 20px rgba(0,73,133,.18);
  font-size:1.35rem;
}
.status-strip .header-nowplaying .status-title{
  max-width:240px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color:#053761;
}
@media(max-width:760px){
  .status-strip .header-nowplaying{min-width:0;width:100%;}
  .status-strip .header-nowplaying .status-title{max-width:100%;}
}

/* Minimal live fix: make Now Playing match the On Air Now header box */
.status-strip .header-nowplaying{
  display:grid !important;
  grid-template-columns:42px minmax(0,1fr) !important;
  gap:13px !important;
  align-items:center !important;
  position:relative !important;
  overflow:hidden !important;
  min-width:220px !important;
  min-height:76px !important;
  padding:13px 18px !important;
  border-radius:22px !important;
  border:1px solid rgba(0,115,180,.16) !important;
  background:
    radial-gradient(circle at 18% 50%, rgba(255,191,31,.20) 0 0, transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(232,247,255,.96) 52%, rgba(214,243,255,.96)) !important;
  box-shadow:0 14px 34px rgba(4,58,101,.13) !important;
}
.status-strip .header-nowplaying:before{
  content:"" !important;
  position:absolute !important;
  inset:0 auto 0 0 !important;
  width:5px !important;
  background:linear-gradient(180deg,#ffbf1f,#ff8a1f) !important;
}
.status-strip .header-nowplaying .status-icon.record{
  width:42px !important;
  height:42px !important;
  flex:0 0 42px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  color:#fff !important;
  background:linear-gradient(135deg,#004985,#007fc1) !important;
  border-radius:50% !important;
  box-shadow:0 0 0 7px rgba(0,127,193,.10) !important;
  font-size:1.15rem !important;
}
.status-strip .header-nowplaying .status-label{
  color:#ff8a1f !important;
  letter-spacing:.08em !important;
  font-weight:900 !important;
}
.status-strip .header-nowplaying .status-title{
  color:#004b86 !important;
  font-size:1.08rem !important;
  line-height:1.12 !important;
  font-weight:900 !important;
  max-width:240px !important;
  white-space:nowrap !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
}
@media(max-width:760px){
  .status-strip .header-nowplaying{min-width:0 !important;width:100% !important;}
  .status-strip .header-nowplaying .status-title{max-width:100% !important;}
}


/* Core homepage On Air Today cleanup - no layered layout changes */
.coast-on-air {
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 24px !important;
}
.coast-on-air-head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 18px !important;
  padding: 24px 26px 18px !important;
  margin: 0 !important;
  background: linear-gradient(135deg, #043f74, #007fc1) !important;
  color: #fff !important;
}
.coast-on-air-head .eyebrow,
.coast-on-air-head h2,
.coast-on-air-head .schedule-link {
  color: #fff !important;
}
.coast-on-air-head h2 {
  margin: 0 !important;
  font-size: 1.8rem !important;
  line-height: 1 !important;
}
.coast-on-air-head h2:after { display: none !important; }
.coast-on-air-head .eyebrow {
  margin: 0 0 5px !important;
  color: #ffbd26 !important;
  letter-spacing: .08em !important;
}
.coast-on-air-head .schedule-link {
  flex: 0 0 auto !important;
  text-decoration: none !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.14) !important;
  border: 1px solid rgba(255,255,255,.24) !important;
  font-weight: 900 !important;
}
.coast-on-air .coast-day-block.featured {
  margin: 0 !important;
  border: 0 !important;
  border-top: 0 !important;
  border-radius: 0 !important;
  padding: 22px 24px 26px !important;
  background: linear-gradient(180deg, #ffffff, #f4fbff) !important;
  box-shadow: none !important;
}
.coast-on-air .coast-day-block.featured h3 {
  margin: 0 0 18px !important;
  font-size: 1.25rem !important;
  color: #004985 !important;
}
.coast-on-air .coast-day-block.featured h3:after { display: none !important; }
.coast-on-air .coast-show-list {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
}
.coast-on-air .coast-show-card {
  display: grid !important;
  grid-template-columns: 82px minmax(0, 1fr) !important;
  gap: 15px !important;
  align-items: center !important;
  min-height: 112px !important;
  padding: 14px !important;
  margin: 0 !important;
  background: #fff !important;
  border: 1px solid #d8eaf5 !important;
  border-radius: 18px !important;
  box-shadow: 0 10px 26px rgba(0,47,87,.08) !important;
  overflow: hidden !important;
}
.coast-on-air .coast-show-card img,
.coast-on-air .show-icon {
  width: 82px !important;
  height: 82px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  display: block !important;
  background: #eaf7fd !important;
  border: 3px solid #fff !important;
  box-shadow: 0 0 0 2px #007fc1, 0 8px 18px rgba(0,47,87,.12) !important;
}
.coast-on-air .coast-show-card h4 {
  margin: 0 !important;
  color: #004985 !important;
  font-size: 1.03rem !important;
  line-height: 1.16 !important;
  font-weight: 900 !important;
}
.coast-on-air .coast-show-card h4 span {
  display: block !important;
  margin-top: 4px !important;
  color: #4d6578 !important;
  font-size: .88rem !important;
  font-weight: 700 !important;
}
.coast-on-air .coast-show-card p {
  margin: 8px 0 0 !important;
  color: #ff8a18 !important;
  font-size: .94rem !important;
  font-weight: 900 !important;
}
@media (max-width: 980px) {
  .coast-on-air .coast-show-list { grid-template-columns: 1fr !important; }
}
@media (max-width: 520px) {
  .coast-on-air-head { display: block !important; }
  .coast-on-air-head .schedule-link { display: inline-flex !important; margin-top: 14px !important; }
  .coast-on-air .coast-show-card { grid-template-columns: 70px minmax(0,1fr) !important; min-height: 96px !important; }
  .coast-on-air .coast-show-card img,
  .coast-on-air .show-icon { width: 70px !important; height: 70px !important; }
}
