/* ==========================================================
   JPF CHANNEL · MAIN STYLESHEET
   Basado en muestra.jpeg – diseño exacto
   ========================================================== */

/* ── VARIABLES ── */
:root {
  --navy:       #0a1628;
  --navy2:      #0d1e38;
  --blue:       #1e4db7;
  --blue2:      #2158d0;
  --blue3:      #2563eb;
  --red:        #e63946;
  --green:      #25d366;
  --amber:      #d97706;
  --teal:       #10b981;
  --white:      #ffffff;
  --bg:         #f5f7fa;
  --card:       #ffffff;
  --text:       #111827;
  --muted:      #6b7280;
  --border:     #e5e7eb;
  --sh-sm:      0 1px 4px rgba(0,0,0,.08);
  --sh-md:      0 4px 18px rgba(0,0,0,.11);
  --sh-lg:      0 8px 32px rgba(0,0,0,.18);
  --r:          8px;
  --r-lg:       14px;
  --ease:       all .22s ease;
  --max-w:      1260px;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins',system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:var(--ease)}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit;outline:none}

.container{max-width:var(--max-w);margin:0 auto;padding:0 22px}

/* ════════════════════════════════════
   HEADER
   ════════════════════════════════════ */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:var(--navy);
  box-shadow:0 2px 14px rgba(0,0,0,.55);
}
.header-inner{
  display:flex;align-items:center;height:62px;gap:0;
}
.site-logo{flex-shrink:0;margin-right:28px}
.site-logo .logo-img{height:46px;width:auto;object-fit:contain}

/* nav */
.main-nav{flex:1}
.nav-list{display:flex;align-items:center;gap:0;height:62px}
.nav-link{
  display:inline-flex;align-items:center;gap:5px;
  color:rgba(255,255,255,.85);font-size:.81rem;font-weight:500;
  padding:5px 12px;border-radius:6px;white-space:nowrap;
  transition:var(--ease)
}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-link.active{color:#fff;background:var(--blue2);font-weight:600}
.live-dot{
  width:7px;height:7px;background:var(--red);
  border-radius:50%;animation:blink 1.1s infinite;
  box-shadow:0 0 5px var(--red)
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

/* header actions */
.header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:14px}
.search-toggle{
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.75);border-radius:6px;transition:var(--ease)
}
.search-toggle:hover{background:rgba(255,255,255,.1);color:#fff}
.whatsapp-btn-header{
  display:inline-flex;align-items:center;gap:7px;
  background:#25d366;color:#fff;font-size:.78rem;font-weight:700;
  padding:8px 18px;border-radius:50px;transition:var(--ease)
}
.whatsapp-btn-header:hover{background:#1ebe57;color:#fff;transform:translateY(-1px)}
.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.mobile-menu-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:var(--ease)}

/* search bar */
.search-bar{
  background:#0c1e38;border-top:1px solid rgba(255,255,255,.08);
  overflow:hidden;max-height:0;transition:max-height .3s ease
}
.search-bar.open{max-height:68px}
.search-bar .container{display:flex;align-items:center;gap:12px;padding-top:12px;padding-bottom:12px}
.search-form{display:flex;flex:1;gap:8px}
.search-input{
  flex:1;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);
  color:#fff;padding:9px 16px;border-radius:8px;font-size:.86rem
}
.search-input::placeholder{color:rgba(255,255,255,.4)}
.search-input:focus{border-color:var(--blue3)}
.search-submit{background:var(--blue3);color:#fff;padding:9px 18px;border-radius:8px;display:flex;align-items:center}
.search-submit:hover{background:var(--blue)}
.search-close{color:rgba(255,255,255,.6);padding:4px 8px}
.search-close:hover{color:#fff}

/* mobile overlay */
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:999}
.mobile-overlay.open{display:block}

/* ════════════════════════════════════
   HERO SLIDER — DISEÑO PREMIUM
   ════════════════════════════════════ */

/* Keyframes globales del hero */
@keyframes floatLogo   { 0%,100%{transform:translateY(0) rotate(0deg)} 50%{transform:translateY(-12px) rotate(1deg)} }
@keyframes ringPulse   { 0%,100%{transform:scale(1);opacity:.55} 50%{transform:scale(1.12);opacity:.2} }
@keyframes ringPulse2  { 0%,100%{transform:scale(1);opacity:.35} 50%{transform:scale(1.18);opacity:.1} }
@keyframes slideIn     { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes btnPulse    { 0%,100%{box-shadow:0 0 0 0 rgba(230,57,70,.55)} 70%{box-shadow:0 0 0 14px rgba(230,57,70,0)} }
@keyframes waveFloat   { 0%,100%{transform:translateX(0) scaleY(1)} 50%{transform:translateX(-12px) scaleY(.95)} }
@keyframes dot3D       { 0%,100%{transform:scale(1)} 50%{transform:scale(1.5)} }

.hero-slider {
  position: relative;
  overflow: hidden;
  background: #050e1f;
  min-height: 500px;
}

/* decorative radial glow en fondo */
.hero-slider::before {
  content: '';
  position: absolute;
  top: -20%;
  left: 18%;
  width: 480px;
  height: 480px;
  background: radial-gradient(circle, rgba(33,88,208,.28) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
}
.hero-slider::after {
  content: '';
  position: absolute;
  bottom: -10%;
  right: 10%;
  width: 360px;
  height: 360px;
  background: radial-gradient(circle, rgba(230,57,70,.14) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
}

.hero-slide {
  display: none;
  position: relative;
  min-height: 500px;
  align-items: stretch;
}
.hero-slide.active { display: flex; }

/* foto de fondo (cuando hay imagen de CMS) */
.slide-bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center top;
}
.slide-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    108deg,
    rgba(5,14,31,.98)  0%,
    rgba(8,18,38,.92)  30%,
    rgba(10,22,48,.78) 58%,
    rgba(10,22,48,.3)  100%
  );
  z-index: 1;
}

/* contenido encima */
.slide-content {
  position: relative;
  z-index: 3;
  width: 100%;
  display: flex;
  align-items: center;
  padding: 44px 0 60px;
}
.slide-content .container {
  display: grid;
  grid-template-columns: 230px 1fr 230px;
  gap: 32px;
  align-items: center;
  width: 100%;
}

/* ── LOGO COL ── */
.slide-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

/* anillos pulsantes detrás del logo */
.slide-logo::before,
.slide-logo::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 2px solid rgba(37,99,235,.4);
  pointer-events: none;
}
.slide-logo::before {
  width: 220px; height: 220px;
  animation: ringPulse 3s ease-in-out infinite;
}
.slide-logo::after {
  width: 268px; height: 268px;
  animation: ringPulse2 3s ease-in-out infinite .6s;
}

/* tercer anillo via wrapper */
.logo-ring-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.logo-ring-wrap::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 308px; height: 308px;
  border-radius: 50%;
  border: 1px solid rgba(37,99,235,.18);
  animation: ringPulse2 3s ease-in-out infinite 1.2s;
}

.slide-logo img {
  width: 200px;
  position: relative;
  z-index: 2;
  filter:
    drop-shadow(0 0 30px rgba(37,99,235,.7))
    drop-shadow(0 8px 24px rgba(0,0,0,.6));
  animation: floatLogo 5s ease-in-out infinite;
}

/* ── TEXT COL ── */
.slide-text { animation: slideIn .7s ease both; }

.slide-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.92);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 5px 16px;
  border-radius: 50px;
  margin-bottom: 18px;
  backdrop-filter: blur(6px);
}
.slide-badge .live-dot {
  width: 8px; height: 8px;
  background: var(--red);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--red);
  animation: blink 1s infinite;
  flex-shrink: 0;
}

.slide-title {
  font-size: clamp(2.1rem, 3.6vw, 3.5rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.04;
  letter-spacing: -.02em;
  margin-bottom: 16px;
  text-shadow: 0 4px 24px rgba(0,0,0,.4);
}
/* coloreamos la última línea */
.slide-title .accent { color: var(--blue3); }

.slide-subtitle {
  color: rgba(255,255,255,.72);
  font-size: .9rem;
  line-height: 1.75;
  margin-bottom: 28px;
  max-width: 370px;
}

.slide-buttons {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.btn-live {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: var(--red);
  color: #fff;
  font-size: .84rem;
  font-weight: 800;
  padding: 14px 32px;
  border-radius: 50px;
  width: fit-content;
  transition: var(--ease);
  box-shadow: 0 6px 24px rgba(230,57,70,.5);
  text-transform: uppercase;
  letter-spacing: .06em;
  animation: btnPulse 2.4s infinite;
}
.btn-live:hover {
  background: #c9313e;
  transform: translateY(-3px) scale(1.03);
  color: #fff;
  box-shadow: 0 10px 32px rgba(230,57,70,.6);
  animation: none;
}
.btn-live .play-icon {
  width: 30px; height: 30px;
  background: rgba(255,255,255,.25);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem;
  padding-left: 2px;
  flex-shrink: 0;
}

.slide-transmision {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: rgba(255,255,255,.6);
  font-size: .78rem;
  font-weight: 500;
}
.slide-transmision svg { opacity: .7; }

/* ondas de audio decorativas bajo los botones */
.slide-waves {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  height: 22px;
  margin-top: 22px;
  opacity: .45;
}
.sw { width: 3px; background: var(--blue3); border-radius: 2px; animation: waveFloat 1.6s ease-in-out infinite; }
.sw:nth-child(1){height:7px;animation-delay:0s}
.sw:nth-child(2){height:14px;animation-delay:.12s}
.sw:nth-child(3){height:9px;animation-delay:.24s}
.sw:nth-child(4){height:18px;animation-delay:.36s}
.sw:nth-child(5){height:11px;animation-delay:.48s}
.sw:nth-child(6){height:16px;animation-delay:.6s}
.sw:nth-child(7){height:8px;animation-delay:.72s}
.sw:nth-child(8){height:20px;animation-delay:.84s}
.sw:nth-child(9){height:12px;animation-delay:.96s}
.sw:nth-child(10){height:6px;animation-delay:1.08s}
.sw:nth-child(11){height:15px;animation-delay:1.2s}
.sw:nth-child(12){height:10px;animation-delay:1.32s}

/* ── INFO CARD (columna derecha) ── */
.slide-info-card {
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  padding: 26px 22px;
  color: #fff;
  animation: slideIn .9s ease both;
}

.sic-top {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.sic-icon {
  width: 46px; height: 46px;
  background: linear-gradient(135deg, var(--blue), var(--blue3));
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(37,99,235,.4);
}
.sic-label { font-size: .78rem; font-weight: 700; line-height: 1.3; }
.sic-label span { display: block; font-size: .67rem; color: rgba(255,255,255,.5); font-weight: 400; margin-top: 2px; }

.sic-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.sic-stat {
  background: rgba(255,255,255,.07);
  border-radius: 10px;
  padding: 10px 12px;
  text-align: center;
}
.sic-stat strong {
  display: block;
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--blue3);
  line-height: 1;
  margin-bottom: 3px;
}
.sic-stat span { font-size: .65rem; color: rgba(255,255,255,.55); }

.sic-quote {
  margin-top: 12px;
  font-size: .75rem;
  color: rgba(255,255,255,.65);
  line-height: 1.65;
  font-style: italic;
  padding-left: 10px;
  border-left: 2px solid var(--blue3);
}

/* ── CONTROLES ── */
.slider-prev, .slider-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 44px; height: 44px;
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(8px);
  color: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  border: 1px solid rgba(255,255,255,.18);
  transition: var(--ease);
  line-height: 1;
}
.slider-prev { left: 18px; }
.slider-next { right: 18px; }
.slider-prev:hover, .slider-next:hover {
  background: var(--blue2);
  border-color: transparent;
  transform: translateY(-50%) scale(1.08);
}

.slider-dots {
  position: absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 7px;
  z-index: 10;
}
.slider-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.3);
  border: none;
  cursor: pointer;
  transition: var(--ease);
}
.slider-dot.active {
  background: var(--red);
  width: 28px;
  border-radius: 4px;
  box-shadow: 0 0 10px rgba(230,57,70,.7);
}

/* responsive hero */
@media(max-width:1000px){
  .slide-content .container { grid-template-columns: 180px 1fr 200px; gap: 22px; }
  .slide-logo img { width: 165px; }
  .slide-logo::before { width: 190px; height: 190px; }
  .slide-logo::after  { width: 232px; height: 232px; }
}
@media(max-width:820px){
  .slide-content .container { grid-template-columns: 1fr; }
  .slide-logo, .slide-info-card { display: none; }
  .hero-slider, .hero-slide { min-height: 380px; }
  .slide-content { padding: 36px 0 52px; text-align: center; }
  .slide-subtitle { margin-left: auto; margin-right: auto; }
  .slide-buttons { justify-content: center; }
  .slide-waves { justify-content: center; }
}

/* ════════════════════════════════════
   STATS BAR (entre hero y contenido)
   ════════════════════════════════════ */
.stats-bar {
  background: var(--blue);
  padding: 0;
}
.stats-bar-inner {
  display: grid;
  grid-template-columns: repeat(4,1fr);
}
.stat-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 24px;
  border-right: 1px solid rgba(255,255,255,.15);
  transition: var(--ease);
}
.stat-item:last-child { border-right: none; }
.stat-item:hover { background: rgba(255,255,255,.08); }
.stat-icon {
  width: 44px; height: 44px;
  background: rgba(255,255,255,.15);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}
.stat-info strong {
  display: block;
  font-size: 1.3rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  margin-bottom: 2px;
}
.stat-info span {
  font-size: .72rem;
  color: rgba(255,255,255,.7);
  font-weight: 500;
}

/* ════════════════════════════════════
   MAIN CONTENT WRAPPER
   ════════════════════════════════════ */
.main-content { background: #f8fafc; padding: 0; }

/* sección videos+noticias */
.section-vn {
  background: #fff;
  padding: 32px 0 30px;
  box-shadow: 0 1px 0 #eaecef;
}

/* sección about+player+programas */
.section-abp {
  background: #f8fafc;
  padding: 30px 0 34px;
}

/* section headers */
.sec-hdr{
  display:flex;align-items:center;
  justify-content:space-between;margin-bottom:18px
}
.sec-title{
  font-size: 1rem; font-weight: 800; color: var(--text);
  display: flex; align-items: center; gap: 10px;
}
.sec-title::before{
  content:''; width:4px; height:20px;
  background: linear-gradient(180deg, var(--blue3), var(--red));
  border-radius: 3px; flex-shrink: 0;
}
.sec-link{
  display:inline-flex;align-items:center;gap:5px;
  color:var(--blue3);font-size:.76rem;font-weight:600;
  transition:var(--ease);
  background: rgba(37,99,235,.07);
  padding: 5px 12px; border-radius: 20px;
}
.sec-link:hover { color: var(--red); background: rgba(230,57,70,.08); }
.sec-link::after { content: '→'; }

/* ── TOP GRID: videos(wide) + news(narrow) ── */
.top-grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 28px;
  align-items: start;
}

/* ── VIDEO CARDS (4 col) ── */
.vids-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 14px;
}
.video-card {
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  border: 1px solid #edf0f5;
  transition: var(--ease);
  cursor: pointer;
}
.video-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 32px rgba(30,77,183,.15);
  border-color: rgba(37,99,235,.25);
}
.video-thumb {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #0a1628;
}
.video-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.video-card:hover .video-thumb img { transform: scale(1.08); }
.v-badge {
  position: absolute; top: 7px; left: 7px;
  font-size: .6rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .06em;
  color: #fff; padding: 2px 8px;
  border-radius: 50px; z-index: 2;
}
.v-dur {
  position: absolute; bottom: 7px; right: 7px;
  background: rgba(0,0,0,.8); color: #fff;
  font-size: .62rem; font-weight: 700;
  padding: 2px 6px; border-radius: 4px; z-index: 2;
}
.v-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(30,77,183,.5), rgba(230,57,70,.3));
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: var(--ease);
}
.video-card:hover .v-overlay { opacity: 1; }
.v-play {
  width: 48px; height: 48px;
  background: #fff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--red); font-size: 1rem; padding-left: 3px;
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
  transform: scale(.85); transition: transform .2s ease;
}
.video-card:hover .v-play { transform: scale(1); }
.video-info { padding: 11px 12px 13px; }
.v-title {
  font-size: .79rem; font-weight: 700; color: var(--text);
  line-height: 1.4; margin-bottom: 7px;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.v-meta {
  display: flex; align-items: center; gap: 8px;
  color: var(--muted); font-size: .67rem;
}
.v-meta span { display: flex; align-items: center; gap: 3px; }

/* ── NEWS LIST ── */
.news-list { display: flex; flex-direction: column; }
.news-item {
  display: flex; gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid #f0f2f5;
  transition: var(--ease); color: inherit;
}
.news-item:last-child { border-bottom: none; }
.news-item:hover { padding-left: 4px; }
.news-item:hover .ni-title { color: var(--blue3); }
.ni-thumb {
  width: 84px; height: 66px;
  border-radius: 8px; overflow: hidden;
  flex-shrink: 0;
  background: linear-gradient(135deg,#0d1b2e,#1e4db7);
}
.ni-thumb img { width: 100%; height: 100%; object-fit: cover; }
.ni-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; color: rgba(255,255,255,.3);
}
.ni-body { flex: 1; min-width: 0; }
.ni-badge {
  display: inline-block;
  font-size: .6rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .06em;
  color: #fff; padding: 2px 7px;
  border-radius: 50px; margin-bottom: 5px;
}
.ni-title {
  font-size: .79rem; font-weight: 600; color: var(--text);
  line-height: 1.4; margin-bottom: 4px;
  transition: var(--ease);
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.ni-date { color: var(--muted); font-size: .67rem; }

/* ── BOTTOM GRID: about + player + programs ── */
.bot-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 22px;
  align-items: start;
}

/* about col */
.about-box {
  background: #fff;
  border-radius: 12px;
  padding: 22px 20px;
  border: 1px solid #edf0f5;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
  height: 100%;
}
.about-logo-img { width: 50px; margin-bottom: 12px; }
.about-col h3 {
  font-size: .96rem; font-weight: 800; color: var(--text);
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px;
}
.about-col h3::before {
  content: ''; width: 4px; height: 18px;
  background: linear-gradient(180deg,var(--blue3),var(--red));
  border-radius: 2px; flex-shrink: 0;
}
.about-col p {
  font-size: .8rem; color: var(--muted);
  line-height: 1.85; margin-bottom: 18px;
}
.btn-mas {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--blue); color: #fff;
  font-size: .78rem; font-weight: 700;
  padding: 11px 22px; border-radius: 8px;
  transition: var(--ease);
  box-shadow: 0 4px 14px rgba(30,77,183,.3);
}
.btn-mas:hover { background: var(--blue2); color: #fff; transform: translateY(-2px); }
.btn-mas::after { content: '→'; }

/* player col */
.player-col {
  background: var(--navy);
  border-radius: 14px;
  padding: 22px 20px;
  color: #fff;
  position: relative; overflow: hidden;
  box-shadow: 0 8px 30px rgba(10,22,40,.4);
}
.player-col::before {
  content: '';
  position: absolute; top: -40%; left: -20%;
  width: 140%; height: 140%;
  background: radial-gradient(circle, rgba(33,88,208,.25) 0%, transparent 70%);
  pointer-events: none;
}
.player-col::after {
  content: '';
  position: absolute; bottom: -30%; right: -20%;
  width: 80%; height: 80%;
  background: radial-gradient(circle, rgba(230,57,70,.12) 0%, transparent 70%);
  pointer-events: none;
}
.p-live-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--red); color: #fff;
  font-size: .62rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .12em;
  padding: 4px 12px; border-radius: 50px;
  margin-bottom: 12px;
  box-shadow: 0 3px 12px rgba(230,57,70,.4);
}
.p-live-badge::before {
  content: ''; width: 6px; height: 6px;
  background: #fff; border-radius: 50%;
  animation: blink 1s infinite;
}
.p-title { font-size: .86rem; font-weight: 700; margin-bottom: 13px; }
.p-station {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 13px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px; margin-bottom: 14px;
}
.p-station-logo {
  width: 42px; height: 42px; border-radius: 8px;
  object-fit: contain;
  background: rgba(255,255,255,.1); flex-shrink: 0;
}
.p-station-name { font-size: .84rem; font-weight: 700; }
.p-station-sub { font-size: .7rem; color: rgba(255,255,255,.5); }

/* wave */
.audio-wave {
  display: flex; align-items: flex-end; justify-content: center;
  gap: 3px; height: 32px; margin: 12px 0;
}
.wave-bar {
  width: 3px; background: var(--blue3);
  border-radius: 2px; opacity: .3;
  animation: waveAnim 1.3s ease-in-out infinite;
}
.audio-active .wave-bar { opacity: 1; }
.wave-bar:nth-child(1){height:9px;animation-delay:0s}
.wave-bar:nth-child(2){height:19px;animation-delay:.1s}
.wave-bar:nth-child(3){height:13px;animation-delay:.2s}
.wave-bar:nth-child(4){height:26px;animation-delay:.3s}
.wave-bar:nth-child(5){height:17px;animation-delay:.4s}
.wave-bar:nth-child(6){height:22px;animation-delay:.5s}
.wave-bar:nth-child(7){height:11px;animation-delay:.6s}
.wave-bar:nth-child(8){height:21px;animation-delay:.7s}
.wave-bar:nth-child(9){height:15px;animation-delay:.8s}
.wave-bar:nth-child(10){height:28px;animation-delay:.9s}
@keyframes waveAnim{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}

/* player controls */
.p-controls {
  display: flex; align-items: center;
  justify-content: center; gap: 14px; margin: 14px 0;
}
.play-pause-btn {
  width: 54px; height: 54px;
  background: var(--red); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 1.1rem; padding-left: 3px;
  transition: var(--ease);
  box-shadow: 0 6px 20px rgba(230,57,70,.5);
}
.play-pause-btn:hover { transform: scale(1.1); background: #c8303d; }
.play-pause-btn.playing { padding-left: 0; }
.vol-group {
  display: flex; align-items: center; gap: 6px;
  color: rgba(255,255,255,.6); font-size: .76rem;
}
input[type=range].vol-slider {
  width: 68px; accent-color: var(--blue3); cursor: pointer;
}
.p-wa {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: rgba(37,211,102,.12); color: #25d366;
  border: 1px solid rgba(37,211,102,.25); border-radius: 9px;
  padding: 10px; font-size: .74rem; font-weight: 600;
  margin-top: 10px; transition: var(--ease); width: 100%;
}
.p-wa:hover { background: rgba(37,211,102,.22); }

/* programs col */
.prog-box {
  background: #fff;
  border-radius: 12px;
  padding: 20px 18px;
  border: 1px solid #edf0f5;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
  height: 100%;
}
.progs-hdr {
  display: flex; align-items: center;
  justify-content: space-between; margin-bottom: 14px;
}
.progs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.prog-card {
  background: #f8fafc;
  border-radius: 10px;
  padding: 14px 12px;
  border: 1px solid #eaecef;
  transition: var(--ease);
  display: flex; flex-direction: column; gap: 7px;
  cursor: default;
}
.prog-card:hover {
  border-color: rgba(37,99,235,.3);
  background: #fff;
  box-shadow: 0 4px 16px rgba(30,77,183,.1);
  transform: translateY(-3px);
}
.prog-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.05rem;
}
.prog-name { font-size: .77rem; font-weight: 700; color: var(--text); line-height: 1.3; }
.prog-time { font-size: .68rem; color: var(--muted); }

/* ════════════════════════════════════
   TESTIMONIALS — DISEÑO PREMIUM
   ════════════════════════════════════ */
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}

.section-testimonials {
  background: #060f22;
  padding: 56px 0 48px;
  position: relative;
  overflow: hidden;
}

/* puntos decorativos de fondo */
.section-testimonials::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle, rgba(37,99,235,.12) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}
/* glow azul superior izquierda */
.section-testimonials::after {
  content: '';
  position: absolute;
  top: -120px; left: -120px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(37,99,235,.2) 0%, transparent 70%);
  border-radius: 50%; pointer-events: none;
}

/* cabecera de la sección */
.t-section-hdr {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 36px;
  position: relative; z-index: 2;
}
.t-section-hdr-left {}
.t-section-label {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(37,99,235,.2);
  border: 1px solid rgba(37,99,235,.35);
  color: #93c5fd;
  font-size: .68rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 5px 14px; border-radius: 50px;
  margin-bottom: 12px;
}
.t-section-label::before {
  content: ''; width: 6px; height: 6px;
  background: var(--blue3); border-radius: 50%;
}
.t-section-title {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  font-weight: 900; color: #fff;
  line-height: 1.15;
  margin-bottom: 6px;
}
.t-section-sub {
  font-size: .82rem; color: rgba(255,255,255,.5);
}
.t-section-hdr-right {
  display: flex; align-items: center; gap: 8px;
  flex-shrink: 0;
}
.t-nav-btn {
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.8);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; transition: var(--ease); cursor: pointer;
}
.t-nav-btn:hover {
  background: var(--blue3);
  border-color: var(--blue3);
  color: #fff;
  transform: scale(1.08);
}

/* track */
.t-wrap { overflow: hidden; position: relative; z-index: 2; }
.testimonials-track {
  display: flex; gap: 20px;
  transition: transform .55s cubic-bezier(.25,.46,.45,.94);
}

/* ── CARD TESTIMONIAL ── */
.testimonial-card {
  flex: 0 0 calc(33.333% - 14px);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 18px;
  padding: 28px 26px;
  color: #fff;
  position: relative;
  overflow: hidden;
  transition: var(--ease);
  cursor: default;
}
.testimonial-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(37,99,235,.08) 0%, rgba(230,57,70,.04) 100%);
  border-radius: 18px;
  opacity: 0; transition: var(--ease);
}
.testimonial-card:hover {
  border-color: rgba(37,99,235,.4);
  transform: translateY(-6px);
  box-shadow: 0 20px 48px rgba(0,0,0,.4);
}
.testimonial-card:hover::before { opacity: 1; }

/* comillas decorativas grandes */
.t-bigquote {
  position: absolute;
  top: 16px; right: 20px;
  font-size: 6rem;
  line-height: 1;
  color: rgba(37,99,235,.15);
  font-family: Georgia, serif;
  font-weight: 900;
  user-select: none;
}

/* estrellas */
.t-stars {
  display: flex; gap: 3px; margin-bottom: 14px;
  position: relative; z-index: 1;
}
.t-stars span {
  font-size: 1rem; color: #fbbf24;
  text-shadow: 0 0 8px rgba(251,191,36,.5);
}

/* cita */
.t-quote {
  font-size: .84rem;
  line-height: 1.8;
  color: rgba(255,255,255,.82);
  margin-bottom: 22px;
  font-style: italic;
  position: relative; z-index: 1;
}

/* separador */
.t-divider {
  height: 1px;
  background: linear-gradient(90deg, var(--blue3), rgba(37,99,235,.0));
  margin-bottom: 18px;
}

/* autor */
.t-author {
  display: flex; align-items: center; gap: 13px;
  position: relative; z-index: 1;
}
.t-photo {
  width: 46px; height: 46px;
  border-radius: 50%; overflow: hidden;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; font-size: .95rem; color: #fff;
  position: relative;
}
.t-photo::before {
  content: '';
  position: absolute; inset: -2px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue3), var(--red));
  z-index: -1;
}
.t-photo-inner {
  width: 100%; height: 100%;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue), #0d1e36);
  display: flex; align-items: center; justify-content: center;
  font-weight: 900; font-size: .95rem; color: #fff;
  overflow: hidden;
}
.t-photo-inner img { width: 100%; height: 100%; object-fit: cover; }
.t-info {}
.t-name {
  font-size: .86rem; font-weight: 700;
  margin-bottom: 2px;
}
.t-role {
  font-size: .7rem; color: rgba(255,255,255,.45);
  font-weight: 500;
}

/* dots de paginación */
.t-dots {
  display: flex; align-items: center; justify-content: center;
  gap: 7px; margin-top: 28px;
  position: relative; z-index: 2;
}
.t-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(255,255,255,.25);
  cursor: pointer; transition: var(--ease);
  border: none;
}
.t-dot.active {
  background: var(--blue3);
  width: 22px; border-radius: 4px;
  box-shadow: 0 0 8px rgba(37,99,235,.7);
}

/* navegación legacy (compatibilidad JS) */
.t-nav { display: none; }
.t-btn { display: none; }

/* ════════════════════════════════════
   BLOG
   ════════════════════════════════════ */
.section-blog{background:var(--bg);padding:44px 0}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.blog-card{
  background:#fff;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--sh-sm);border:1px solid #efefef;
  transition:var(--ease);display:block;color:inherit
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.blog-thumb{
  aspect-ratio:16/9;overflow:hidden;
  background:linear-gradient(135deg,#0d1b2e,#1e4db7);
  display:flex;align-items:center;justify-content:center
}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.blog-card:hover .blog-thumb img{transform:scale(1.06)}
.blog-info{padding:15px}
.blog-cat{font-size:.67rem;font-weight:700;color:var(--blue3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}
.blog-title{font-size:.86rem;font-weight:700;color:var(--text);line-height:1.45;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-excerpt{font-size:.76rem;color:var(--muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px}
.blog-meta{display:flex;align-items:center;justify-content:space-between;font-size:.68rem;color:var(--muted)}
.blog-meta-read{color:var(--blue3);font-weight:600}

/* ════════════════════════════════════
   PAGE HERO (páginas internas)
   ════════════════════════════════════ */
.page-hero{
  background:linear-gradient(135deg,var(--navy),#0f2347);
  padding:52px 0;text-align:center;color:#fff
}
.page-hero h1{font-size:clamp(1.7rem,3.5vw,2.4rem);font-weight:900;margin-bottom:8px}
.page-hero p{color:rgba(255,255,255,.7);font-size:.88rem;max-width:460px;margin:0 auto}
.breadcrumb{
  display:flex;align-items:center;gap:7px;justify-content:center;
  margin-top:12px;font-size:.76rem;color:rgba(255,255,255,.5)
}
.breadcrumb a{color:rgba(255,255,255,.75)}
.breadcrumb a:hover{color:#fff}
.breadcrumb span{color:rgba(255,255,255,.3)}

/* forms */
.form-group{margin-bottom:17px}
.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--text);margin-bottom:5px}
.form-control{
  width:100%;padding:10px 14px;border:1.5px solid var(--border);
  border-radius:8px;font-size:.86rem;color:var(--text);
  background:#fff;transition:var(--ease)
}
.form-control:focus{border-color:var(--blue3);box-shadow:0 0 0 3px rgba(37,99,235,.09)}
textarea.form-control{min-height:120px;resize:vertical}
.btn-submit{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--blue);color:#fff;font-weight:700;font-size:.88rem;
  padding:12px 28px;border-radius:8px;border:none;cursor:pointer;
  width:100%;transition:var(--ease)
}
.btn-submit:hover{background:var(--blue2)}
.alert{padding:12px 15px;border-radius:8px;font-size:.86rem;margin-bottom:16px;font-weight:500}
.alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:38px}
.contact-form-box{background:#fff;border-radius:var(--r-lg);padding:30px;box-shadow:var(--sh-md)}
.contact-info-item{display:flex;gap:13px;margin-bottom:16px}
.contact-info-icon{width:40px;height:40px;background:rgba(37,99,235,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--blue);flex-shrink:0}
.contact-info-text h4{font-size:.84rem;font-weight:700;margin-bottom:2px}
.contact-info-text p{font-size:.8rem;color:var(--muted)}

/* inner page content grid */
.inner-grid{display:grid;grid-template-columns:1fr 320px;gap:32px;align-items:start}
.inner-content{background:#fff;border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-sm)}
.inner-sidebar>*+*{margin-top:22px}

/* compat: videos grid for inner pages */
.videos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.video-category{font-size:.62rem;font-weight:700;text-transform:uppercase;color:#fff;padding:2px 7px;border-radius:50px;display:inline-block;margin-bottom:5px;background:var(--blue3)}
.thumb-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#0d1b2e,#1e4db7);display:flex;align-items:center;justify-content:center;font-size:2rem;color:rgba(255,255,255,.35)}
.play-icon-large{font-size:2rem;color:rgba(255,255,255,.45)}
.play-btn{width:42px;height:42px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.95rem;padding-left:3px}
.video-play-overlay{position:absolute;inset:0;background:rgba(0,0,0,.28);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--ease)}
.video-card:hover .video-play-overlay{opacity:1}
.play-btn-overlay{width:44px;height:44px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;padding-left:3px}

/* compat: news for inner pages */
.news-card{background:var(--card);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm);border:1px solid #efefef;transition:var(--ease);display:block;color:inherit}
.news-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.news-image{aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,#0d1b2e,#1e4db7)}
.news-image img{width:100%;height:100%;object-fit:cover}
.news-info{padding:15px}
.news-category{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}
.news-title{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.45;margin-bottom:7px}
.news-excerpt{font-size:.77rem;color:var(--muted);line-height:1.6;margin-bottom:10px}
.news-meta{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.68rem}
.section-title{font-size:1rem;font-weight:800;color:var(--text);display:flex;align-items:center;gap:9px;margin-bottom:20px}
.section-title::before{content:'';width:4px;height:18px;background:linear-gradient(180deg,var(--blue3),var(--red));border-radius:2px;flex-shrink:0}

/* ════════════════════════════════════
   FOOTER
   ════════════════════════════════════ */
.site-footer{background:var(--navy);color:rgba(255,255,255,.72)}
.footer-main{padding:48px 0 36px}
.footer-grid{
  display:grid;
  grid-template-columns:1.8fr 1fr 1fr 1.2fr;
  gap:36px
}
.footer-logo img{height:58px;width:auto;margin-bottom:13px}
.footer-desc{font-size:.8rem;line-height:1.8;color:rgba(255,255,255,.57);margin-bottom:16px}
.footer-socials{display:flex;gap:7px}
.social-icon{
  width:34px;height:34px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;transition:var(--ease)
}
.social-icon:hover{transform:translateY(-3px)}
.facebook,.fb{background:#1877f2}
.instagram,.ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.youtube,.yt{background:#ff0000}
.twitter,.tw{background:#000}
.tiktok,.tt{background:#111;border:1px solid rgba(255,255,255,.15)}

.footer-title{
  font-size:.79rem;font-weight:700;color:#fff;
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px
}
.footer-links li{margin-bottom:8px}
.footer-links a{
  font-size:.8rem;color:rgba(255,255,255,.57);
  display:flex;align-items:center;gap:5px;transition:var(--ease)
}
.footer-links a::before{content:'›';color:var(--blue3)}
.footer-links a:hover{color:#fff;gap:8px}
.footer-contact-list li{
  display:flex;gap:9px;align-items:flex-start;
  margin-bottom:12px;color:rgba(255,255,255,.57);font-size:.8rem
}
.footer-contact-list svg{flex-shrink:0;margin-top:2px;color:var(--blue3)}
.footer-follow-text{font-size:.78rem;color:rgba(255,255,255,.52);margin-bottom:13px;line-height:1.6}
.footer-social-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px}
.social-badge{
  display:flex;align-items:center;gap:5px;
  padding:6px 9px;border-radius:7px;
  font-size:.72rem;font-weight:600;color:#fff;transition:var(--ease)
}
.social-badge:hover{opacity:.85;transform:translateY(-2px)}
.facebook-badge,.fb-badge{background:#1877f2}
.instagram-badge,.ig-badge{background:linear-gradient(45deg,#f09433,#dc2743,#bc1888)}
.youtube-badge,.yt-badge{background:#ff0000}
.tiktok-badge,.tt-badge{background:#111;border:1px solid rgba(255,255,255,.2)}
.app-badges{display:flex;flex-direction:column;gap:6px}
.app-badge{
  display:flex;flex-direction:column;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);
  border-radius:8px;padding:7px 13px;color:#fff;transition:var(--ease)
}
.app-badge:hover{background:rgba(255,255,255,.13)}
.app-badge span{font-size:.7rem;color:rgba(255,255,255,.6)}
.app-badge small{font-size:.82rem;font-weight:700}

.footer-bottom{border-top:1px solid rgba(255,255,255,.09);padding:16px 0}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:7px}
.footer-bottom-inner p{font-size:.76rem;color:rgba(255,255,255,.42)}
.footer-credit{color:rgba(255,255,255,.42);font-size:.76rem}

/* WhatsApp float */
.whatsapp-float{
  position:fixed;bottom:24px;right:24px;z-index:999;
  width:54px;height:54px;background:var(--green);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 18px rgba(37,211,102,.45);transition:var(--ease);
  animation:floatWA 3.5s ease-in-out infinite
}
.whatsapp-float:hover{transform:scale(1.12);background:#1ebe57}
@keyframes floatWA{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* video modal */
.video-modal{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);
  z-index:9999;align-items:center;justify-content:center;padding:20px
}
.video-modal.open{display:flex}
.video-modal-inner{position:relative;width:100%;max-width:880px}
.video-modal-close{
  position:absolute;top:-42px;right:0;
  color:#fff;font-size:1.4rem;padding:4px 10px;cursor:pointer
}
.video-modal iframe{width:100%;aspect-ratio:16/9;border:none;border-radius:var(--r)}

/* ════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════ */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .top-grid{grid-template-columns:1fr 260px}
  .vids-grid{grid-template-columns:repeat(2,1fr)}
  .bot-grid{grid-template-columns:1fr 1fr}
  .bot-grid>div:last-child{grid-column:1/-1}
  .progs-grid{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:900px){
  .slide-content .container{grid-template-columns:150px 1fr;gap:22px}
  .slide-info-card{display:none}
  .slide-logo img{width:130px}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .testimonial-card{flex:0 0 calc(50% - 10px)}
}
@media(max-width:768px){
  /* stats bar */
  .stats-bar-inner{grid-template-columns:1fr 1fr}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}

  /* mobile drawer */
  .main-nav{
    position:fixed;top:0;left:-275px;width:275px;height:100vh;
    background:var(--navy);z-index:1001;padding:68px 14px 28px;
    transition:left .3s ease;overflow-y:auto;
    box-shadow:4px 0 22px rgba(0,0,0,.4)
  }
  .main-nav.open{left:0}
  .nav-list{flex-direction:column;align-items:flex-start;gap:1px;height:auto}
  .nav-link{width:100%;padding:10px 15px;border-radius:8px;font-size:.88rem}
  .mobile-menu-toggle{display:flex}
  .whatsapp-btn-header{display:none}

  /* hero */
  .slide-content .container{grid-template-columns:1fr;text-align:center}
  .slide-logo{display:none}
  .hero-slider,.hero-slide{min-height:360px}
  .slide-title{font-size:1.8rem}
  .btn-live{margin:0 auto}
  .slide-subtitle{margin:0 auto 22px}

  /* grids */
  .top-grid{grid-template-columns:1fr}
  .bot-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .inner-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom-inner{flex-direction:column;text-align:center}
  .testimonial-card{flex:0 0 100%}
  .blog-grid{grid-template-columns:1fr}
  .progs-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .container{padding:0 14px}
  .stats-bar-inner{grid-template-columns:1fr 1fr}
  .vids-grid{grid-template-columns:1fr}
  .progs-grid{grid-template-columns:1fr}
  .hero-slider,.hero-slide{min-height:300px}
  .slide-title{font-size:1.55rem}
  .main-content{padding:22px 0 28px}
}
