*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
    /* Scrollbar personalizada global */
    *{scrollbar-width:thin;scrollbar-color:rgba(0,245,255,.2) transparent}
    *::-webkit-scrollbar{width:4px;height:4px}
    *::-webkit-scrollbar-track{background:transparent}
    *::-webkit-scrollbar-thumb{background:rgba(0,245,255,.2);border-radius:4px}
    *::-webkit-scrollbar-thumb:hover{background:rgba(0,245,255,.4)}
    /* H1 SEO — visible para Google y lectores de pantalla, discreto visualmente */
    .seo-h1{
      font-family:"Orbitron",sans-serif;font-size:.55rem;
      letter-spacing:1px;color:rgba(224,224,255,.18);
      text-align:center;padding:4px 20px 0;
      overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
    }
    :root{--pink:#ff2d78;--cyan:#00f5ff;--purple:#bf00ff;--bg:#07050f;--ph:120px}
    html{scroll-behavior:smooth;overflow-x:hidden;max-width:100vw}
    @media(min-width:861px){html{font-size:clamp(16px,1.35vw,22px)}}
    body{background:var(--bg);color:#e0e0ff;font-family:"Exo 2",sans-serif;overflow-x:hidden;max-width:100vw;padding-bottom:var(--ph);-webkit-text-size-adjust:100%;text-size-adjust:100%}

    /* ── NAV ── */
    nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 48px;height:64px;background:rgba(4,3,10,.88);backdrop-filter:blur(24px);border-bottom:1px solid rgba(0,245,255,.18);gap:12px;transform:translateZ(0);-webkit-transform:translateZ(0);will-change:transform}

    /* ── BANNER AUTO DJ ── */
    #autodj-banner{
      display:none;
      position:fixed;top:64px;left:0;right:0;z-index:190;
      align-items:center;justify-content:center;gap:14px;
      padding:10px 20px;
      background:linear-gradient(90deg,#1a0533 0%,#0d0820 40%,#0a1528 100%);
      border-bottom:1px solid rgba(0,245,255,.2);
      box-shadow:0 4px 24px rgba(0,0,0,.5);
      transform:translateZ(0);-webkit-transform:translateZ(0);
      cursor:pointer;
    }
    #autodj-banner:hover .autodj-btn{background:rgba(0,245,255,.25);border-color:var(--cyan)}
    .autodj-pulse{width:9px;height:9px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:blink 1.4s ease-in-out infinite;flex-shrink:0}
    .autodj-text{font-family:'Orbitron',sans-serif;font-size:.62rem;letter-spacing:2px;color:rgba(224,224,255,.6);text-transform:uppercase}
    .autodj-btn{
      display:inline-flex;align-items:center;gap:7px;
      background:rgba(0,245,255,.12);border:1.5px solid rgba(0,245,255,.4);
      border-radius:22px;padding:8px 18px;
      font-family:'Exo 2',sans-serif;font-size:.75rem;font-weight:700;
      color:var(--cyan);letter-spacing:1px;
      transition:background .2s,border-color .2s;white-space:nowrap;
    }
    @media(max-width:860px){
      #autodj-banner{gap:10px;padding:9px 14px}
      .autodj-text{font-size:.55rem;letter-spacing:1px}
      .autodj-btn{font-size:.72rem;padding:7px 14px}
    }

    /* ── POPUP PEDIDO DE TEMAS ── */
    /* ── REQUEST POPUP ── */
    #request-popup{
      display:none;position:fixed;inset:0;z-index:700;
      background:rgba(0,0,0,.88);backdrop-filter:blur(20px);
      align-items:center;justify-content:center;padding:16px;
    }
    #request-box{
      background:linear-gradient(160deg,#0f0a1e,#070412);
      border:1px solid rgba(0,245,255,.2);border-radius:22px;
      width:100%;max-width:660px;max-height:100vh;
      display:flex;flex-direction:column;
      box-shadow:0 0 80px rgba(0,245,255,.08),0 30px 80px rgba(0,0,0,.9);
      animation:popIn .28s cubic-bezier(.34,1.56,.64,1);
      overflow-y:auto;overflow-x:hidden;
      scrollbar-width:thin;
      scrollbar-color:rgba(0,245,255,.3) transparent;
    }
    #request-box::-webkit-scrollbar{width:4px}
    #request-box::-webkit-scrollbar-track{background:transparent}
    #request-box::-webkit-scrollbar-thumb{background:rgba(0,245,255,.3);border-radius:4px}
    #request-box iframe{overflow:hidden}
    #req-header{
      padding:16px 20px 12px;border-bottom:1px solid rgba(255,255,255,.06);
      flex-shrink:0;background:rgba(255,255,255,.02);
    }
    #req-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
    #req-title{font-family:"Orbitron",sans-serif;font-size:.9rem;font-weight:900;color:#fff;letter-spacing:2px}
    #req-close{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.8rem;color:rgba(224,224,255,.45);transition:all .2s;flex-shrink:0}
    #req-close:hover{background:rgba(255,45,120,.15);border-color:var(--pink);color:var(--pink)}
    #req-subtitle{font-size:.68rem;color:rgba(224,224,255,.32);letter-spacing:.5px;margin-bottom:10px}
    #req-search-wrap{
      display:flex;align-items:center;gap:8px;
      background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
      border-radius:10px;padding:9px 12px;transition:border-color .2s;
    }
    #req-search-wrap:focus-within{border-color:rgba(0,245,255,.4)}
    #req-search-icon{font-size:.85rem;opacity:.35;flex-shrink:0}
    #req-search-input{flex:1;background:none;border:none;outline:none;font-family:"Exo 2",sans-serif;font-size:.85rem;color:#fff}
    #req-search-input::placeholder{color:rgba(224,224,255,.28)}
    #req-search-clear{font-size:.7rem;color:rgba(224,224,255,.3);cursor:pointer;flex-shrink:0;opacity:0;transition:opacity .2s;padding:2px 4px}
    #req-search-clear.visible{opacity:1}
    #req-status{padding:5px 20px;font-size:.76rem;min-height:26px;display:flex;align-items:center;gap:8px;flex-shrink:0}
    /* Lista — ocupa todo el espacio disponible y scrollea */
    #req-list-wrap{
      flex:1;min-height:0;overflow-y:auto;padding:4px 20px 6px;
      scrollbar-width:thin;scrollbar-color:rgba(0,245,255,.25) transparent;
    }
    #req-list-wrap::-webkit-scrollbar{width:4px}
    #req-list-wrap::-webkit-scrollbar-track{background:transparent}
    #req-list-wrap::-webkit-scrollbar-thumb{background:rgba(0,245,255,.25);border-radius:4px}
    #req-list-wrap::-webkit-scrollbar-thumb:hover{background:rgba(0,245,255,.45)}
    /* Card — carátula a la izquierda, título+artista en el medio, botón a la derecha */
    .req-item{
      display:grid;grid-template-columns:46px 1fr auto;
      align-items:center;gap:12px;
      padding:9px 10px;border-radius:10px;
      border:1px solid transparent;
      transition:background .2s,border-color .2s;
      margin-bottom:2px;
    }
    .req-item:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.07)}
    .req-art{width:46px;height:46px;border-radius:7px;object-fit:cover;background:rgba(255,255,255,.06);flex-shrink:0}
    .req-info{min-width:0}
    .req-song{font-size:.84rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .req-artist{font-size:.7rem;color:var(--cyan);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
    .req-btn{
      font-family:"Orbitron",sans-serif;font-size:.56rem;font-weight:700;
      letter-spacing:1px;padding:6px 11px;border-radius:8px;
      background:rgba(255,45,120,.12);border:1px solid rgba(255,45,120,.35);
      color:var(--pink);cursor:pointer;white-space:nowrap;
      transition:all .2s;flex-shrink:0;
    }
    .req-btn:hover{background:rgba(255,45,120,.25);border-color:var(--pink)}
    .req-btn.disabled{opacity:.3;pointer-events:none;background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1);color:rgba(224,224,255,.3)}
    .req-btn.loading{opacity:.6;pointer-events:none}
    .req-loading-row{text-align:center;padding:36px;color:rgba(224,224,255,.3);font-size:.82rem}
    #req-total{text-align:center;padding:8px;font-family:"Orbitron",sans-serif;font-size:.52rem;letter-spacing:2px;color:rgba(224,224,255,.22)}
    #req-footer{
      border-top:1px solid rgba(255,255,255,.08);
      padding:10px 20px;flex-shrink:0;
      display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;
      background:rgba(255,255,255,.02);min-height:40px;
    }
    #req-total-footer{
      font-family:"Orbitron",sans-serif;font-size:.52rem;letter-spacing:2px;
      color:rgba(224,224,255,.4);text-align:center;
    }
    #req-footer-count{font-family:"Orbitron",sans-serif;font-size:.65rem;font-weight:700;color:var(--cyan);letter-spacing:1px;white-space:nowrap;transition:color .3s}
    @media(max-width:860px){
      #request-popup{padding:0}
      #request-box{border-radius:0;height:100vh;height:100dvh;max-width:100%}
      #req-header{padding:14px 16px 10px}
      #req-list-wrap{padding:4px 16px 6px}
      #req-footer{padding:10px 16px}
    }
    .logo{font-family:"Orbitron",sans-serif;font-size:1.4rem;font-weight:900;background:linear-gradient(90deg,var(--cyan),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:2px;text-decoration:none;flex-shrink:0}
    .logo-sub{font-size:.62rem;display:block;letter-spacing:5px;font-weight:400;opacity:.55;margin-top:-4px;background:linear-gradient(90deg,var(--cyan),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
    nav ul{list-style:none;display:flex;gap:32px;flex:1;justify-content:center}
    nav ul a{color:rgba(224,224,255,.6);text-decoration:none;font-size:.82rem;letter-spacing:1px;text-transform:uppercase;transition:color .2s}

    /* ── Widget del tiempo ── */
    #weather-widget{
      display:flex;align-items:center;gap:6px;
      background:rgba(255,255,255,.06);
      border:1px solid rgba(255,255,255,.1);
      border-radius:20px;padding:5px 11px;
      font-family:"Orbitron",sans-serif;font-size:.58rem;
      color:rgba(224,224,255,.75);letter-spacing:.5px;
      cursor:pointer;flex-shrink:0;
      transition:background .18s,border-color .18s;
      -webkit-tap-highlight-color:transparent;
    }
    #weather-widget:hover{background:rgba(0,245,255,.1);border-color:rgba(0,245,255,.3);color:#fff}
    #weather-icon{width:20px;height:20px;display:inline-flex;align-items:center;color:rgba(200,230,255,.8);flex-shrink:0}
    #weather-icon svg{width:100%;height:100%}
    #weather-temp{font-weight:700;font-size:.72rem}
    #weather-deg{font-size:.65rem;color:rgba(224,224,255,.55);margin-left:0px;font-weight:700}

    /* ── Popup del tiempo — estilo Blue 100.7 adaptado a KL80mix ── */
    #weather-popup{
      position:fixed;inset:0;z-index:600;
      background:rgba(0,0,0,.78);backdrop-filter:blur(16px);
      display:none;align-items:center;justify-content:center;padding:20px;
    }
    #weather-popup.open{display:flex}
    #weather-box{
      background:linear-gradient(145deg,#0a1628 0%,#07050f 100%);
      border:1px solid rgba(0,245,255,.18);border-radius:18px;
      width:100%;max-width:520px;
      box-shadow:0 0 50px rgba(0,245,255,.07),0 24px 64px rgba(0,0,0,.75);
      overflow:hidden;
    }
    /* Header */
    #weather-box-head{
      display:flex;align-items:center;justify-content:space-between;
      padding:14px 18px;
      background:rgba(0,245,255,.06);
      border-bottom:1px solid rgba(0,245,255,.12);
    }
    #weather-city{font-family:"Orbitron",sans-serif;font-size:.62rem;letter-spacing:2.5px;color:var(--cyan);font-weight:700}
    #weather-close{background:none;border:none;color:rgba(255,255,255,.35);font-size:1.1rem;cursor:pointer;padding:4px 6px;line-height:1;border-radius:6px;transition:background .15s,color .15s}
    #weather-close:hover{color:#fff;background:rgba(255,255,255,.1)}
    /* Layout: hoy | pronóstico */
    #weather-body{display:flex;gap:0;min-height:200px}
    /* Panel HOY */
    #weather-today{
      flex:0 0 170px;
      background:rgba(0,245,255,.06);
      border-right:1px solid rgba(0,245,255,.1);
      padding:20px 16px;
      display:flex;flex-direction:column;justify-content:center;
    }
    #weather-today-day{font-family:"Orbitron",sans-serif;font-size:.52rem;letter-spacing:2px;color:var(--cyan);margin-bottom:2px;text-transform:uppercase}
    #weather-today-date{font-family:"Orbitron",sans-serif;font-size:.46rem;letter-spacing:1px;color:rgba(224,224,255,.35);margin-bottom:12px}
    #weather-today-icon{width:56px;height:56px;color:rgba(200,230,255,.95);margin-bottom:12px;display:flex;align-items:center;drop-shadow:0 0 10px currentColor}
    #weather-today-icon svg{width:100%;height:100%;filter:drop-shadow(0 0 4px rgba(0,245,255,.3))}
    #weather-today-temp{font-family:Arial,Helvetica,sans-serif;font-size:2.8rem;font-weight:700;color:#fff;line-height:1;margin-bottom:6px;letter-spacing:0px}
    #weather-today-unit{font-size:.9rem;color:rgba(224,224,255,.3)}
    #weather-today-minmax{font-size:.7rem;color:rgba(224,224,255,.45);margin-bottom:4px}
    #weather-today-hum{font-size:.7rem;font-weight:700;color:rgba(0,245,255,.7)}
    /* Panel PRONÓSTICO */
    #weather-forecast{
      flex:1;padding:16px 14px;
      display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);
      gap:10px;
    }
    .wf-tile{
      background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
      border-radius:12px;padding:14px 8px;
      display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
      transition:background .15s,border-color .15s;
    }
    .wf-tile:hover{background:rgba(0,245,255,.08);border-color:rgba(0,245,255,.2)}
    .wf-day{font-family:"Orbitron",sans-serif;font-size:.44rem;letter-spacing:1.5px;color:rgba(224,224,255,.55);text-transform:uppercase}
    .wf-icon{width:32px;height:32px;color:rgba(200,230,255,.9);display:flex;align-items:center;margin:0 auto}
    .wf-icon svg{width:100%;height:100%;filter:drop-shadow(0 0 3px rgba(0,245,255,.2))}
    .wf-temp{font-family:Arial,Helvetica,sans-serif;font-size:.95rem;font-weight:700;color:#fff;letter-spacing:0px}
    .wf-deg{font-size:.55rem;color:rgba(224,224,255,.3)}
    /* Footer */
    #weather-updated{font-size:.58rem;color:rgba(224,224,255,.2);text-align:right;padding:8px 16px;border-top:1px solid rgba(255,255,255,.04)}
    /* Mobile */
    @media(max-width:520px){
      #weather-body{flex-direction:column}
      #weather-today{flex:none;border-right:none;border-bottom:1px solid rgba(0,245,255,.1);flex-direction:row;gap:16px;align-items:center;padding:14px 16px}
      #weather-forecast{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}
      #weather-today-icon{font-size:2rem;margin-bottom:0}
    }
    nav ul a:hover{color:var(--cyan)}
    .live-badge{display:flex;align-items:center;gap:6px;font-family:"Orbitron",sans-serif;font-size:.6rem;color:var(--pink);letter-spacing:1.5px;flex-shrink:0;white-space:nowrap}

    /* ── BOTÓN PEDIR CANCIÓN EN NAV ── */
    #nav-request-btn{position:relative}
    #nav-request-btn:hover{background:rgba(0,245,255,.22)!important;transform:scale(1.04)}
    #nav-request-btn:active{transform:scale(.95)}
    .dot{width:8px;height:8px;border-radius:50%;background:var(--pink);box-shadow:0 0 8px var(--pink);animation:blink 1.4s ease-in-out infinite}
    @keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.25;transform:scale(.6)}}
    @keyframes btnBorderPulse{
      0%,100%{border-color:rgba(0,245,255,.4);box-shadow:0 0 0 0 rgba(0,245,255,0)}
      50%{border-color:rgba(0,245,255,.9);box-shadow:0 0 8px 2px rgba(0,245,255,.25)}
    }

    /* ── HERO ── */
    :root{ --mundial-h: 0px; }
    #hero{
      position:relative;
      width:100%;
      min-height:100vh;
      min-height:max(100vh, 640px);
      padding-top:calc(64px + var(--mundial-h));
      display:flex;
      flex-direction:column;
      transition:padding-top .35s ease;
      overflow:clip;
    }

    /* Fondo nítido */
    #hero-bg{
      position:absolute;inset:0;z-index:0;
      background-size:cover;
      background-position:center 30%;
      filter:blur(7px) brightness(.48) saturate(1.4);
      -webkit-transform:scale(1.08);
      transform:scale(1.08);
      animation:bgZoom 50s ease-in-out infinite;
      -webkit-animation:bgZoom 50s ease-in-out infinite;
      will-change:transform;
      -webkit-backface-visibility:hidden;
      backface-visibility:hidden;
    }
    @-webkit-keyframes bgZoom{
      0%  {-webkit-transform:scale(1.08) translate(0%,0%);    transform:scale(1.08) translate(0%,0%)}
      25% {-webkit-transform:scale(1.13) translate(-0.8%,0.6%);transform:scale(1.13) translate(-0.8%,0.6%)}
      50% {-webkit-transform:scale(1.11) translate(-0.5%,1%); transform:scale(1.11) translate(-0.5%,1%)}
      75% {-webkit-transform:scale(1.14) translate(0.4%,0.4%);transform:scale(1.14) translate(0.4%,0.4%)}
      100%{-webkit-transform:scale(1.08) translate(0%,0%);    transform:scale(1.08) translate(0%,0%)}
    }
    @keyframes bgZoom{
      0%  {transform:scale(1.08) translate(0%,0%)}
      25% {transform:scale(1.13) translate(-0.8%,0.6%)}
      50% {transform:scale(1.11) translate(-0.5%,1%)}
      75% {transform:scale(1.14) translate(0.4%,0.4%)}
      100%{transform:scale(1.08) translate(0%,0%)}
    }
    #hero-overlay{
      position:absolute;inset:0;z-index:1;pointer-events:none;
      background:
        linear-gradient(to right, rgba(7,5,15,.6) 0%, rgba(7,5,15,.08) 50%, rgba(7,5,15,.45) 100%),
        linear-gradient(to bottom, rgba(7,5,15,.2) 0%, rgba(7,5,15,.0) 30%, rgba(7,5,15,.75) 85%, rgba(7,5,15,1) 100%);
    }

    /* Contenido: vinilo izquierda, info derecha — igual que referencia */
    .hero-content{
      position:relative;z-index:2;
      flex:1;
      display:flex;
      align-items:flex-start;
      padding:clamp(48px,6vw,88px) clamp(40px,6vw,100px) clamp(32px,4vw,56px) clamp(40px,5vw,80px);
      gap:clamp(32px,4vw,80px);
      width:100%;
      max-width:1400px;
      margin:0 auto;
    }

    /* ── TOCADISCOS — más espacio para que las ondas no se corten ── */
    .tt-wrap{
      flex-shrink:0;
      position:relative;
      width:clamp(300px,30vw,440px);
      height:clamp(300px,30vw,440px);
      overflow:visible;
      margin-top:clamp(8px,2vw,32px);
    }

    /* Anillos de onda */
    .ring{position:absolute;border-radius:50%;border:1.5px solid var(--cyan);opacity:0;pointer-events:none;
      animation:ringPulse 3s ease-out infinite;animation-play-state:paused}
    .ring:nth-child(1){inset:-18px;animation-delay:0s}
    .ring:nth-child(2){inset:-36px;animation-delay:.75s}
    .ring:nth-child(3){inset:-54px;animation-delay:1.5s;border-color:var(--pink)}
    .ring:nth-child(4){inset:-72px;animation-delay:2.25s;border-color:var(--purple)}
    @keyframes ringPulse{0%{opacity:0;transform:scale(.96)}20%{opacity:.5}100%{opacity:0;transform:scale(1.05)}}
    .tt-wrap.playing .ring{animation-play-state:running}

    /* Platter */
    .platter{
      position:absolute;inset:0;border-radius:50%;
      background:transparent;
      box-shadow:0 0 0 4px rgba(255,255,255,.08),0 20px 80px rgba(0,0,0,.95);
      z-index:1;pointer-events:none;
    }

    /* Artwork */
    .vinyl-art{
      position:absolute;inset:0;
      border-radius:50%;overflow:hidden;
      border:5px solid rgba(255,255,255,.1);
      box-shadow:0 0 50px rgba(0,0,0,.95),inset 0 0 40px rgba(0,0,0,.6);
      animation:spinRecord 5s linear infinite;animation-play-state:paused;
      z-index:3;
      transition:opacity .6s ease;
      background:radial-gradient(circle, #1c1c24 0%, #0d0d12 70%, #050507 100%);
    }
    .tt-wrap.playing .vinyl-art{animation-play-state:running}
    /* Surcos de vinilo — más visibles pero sin tapar la carátula */
    .vinyl-art::after{
      content:"";position:absolute;inset:0;border-radius:50%;
      background:repeating-radial-gradient(
        circle at 50%,
        transparent 0px,
        transparent 6px,
        rgba(0,0,0,.13) 7px,
        transparent 8px
      );
      mix-blend-mode:multiply;
      pointer-events:none;z-index:4;
    }

    /* Reflejo de luz sobre el vinilo */
    .vinyl-art::before{
      content:"";position:absolute;inset:0;border-radius:50%;
      background:radial-gradient(ellipse at 30% 25%, rgba(255,255,255,.12) 0%, transparent 55%);
      pointer-events:none;z-index:5;
    }
    @keyframes spinRecord{to{transform:rotate(360deg)}}
    #np-art{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .45s ease}

    /* Spindle — negro como un vinilo real */
    .spindle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:#050505;box-shadow:0 0 0 1.5px rgba(255,255,255,.06),0 2px 8px rgba(0,0,0,1);z-index:5}

    /* Brazo */
    .tonearm{
      position:absolute;
      top:clamp(-8px,-1vw,-10px);right:clamp(-18px,-2vw,-24px);
      width:clamp(66px,7vw,95px);height:clamp(148px,15vw,210px);
      z-index:10;
      transform-origin:22px 22px;
      transform:rotate(-22deg);
      transition:transform 1.4s cubic-bezier(.4,0,.2,1);
    }
    .tt-wrap.playing .tonearm{transform:rotate(18deg)}
    .arm-pivot{position:absolute;top:0;left:0;width:44px;height:44px;border-radius:50%;background:radial-gradient(circle at 32% 32%,#f0f0f0,#888 60%,#555);box-shadow:0 4px 14px rgba(0,0,0,.8),0 0 0 2px rgba(255,255,255,.15)}
    .arm-rod{position:absolute;top:18px;left:20px;width:5px;height:160px;background:linear-gradient(180deg,#e0e0e0 0%,#c0c0c0 40%,#999 80%,#777 100%);border-radius:3px;transform-origin:top center;transform:translateX(-50%) rotate(0deg);box-shadow:2px 2px 6px rgba(0,0,0,.6)}
    .arm-head{position:absolute;bottom:-4px;left:50%;width:20px;height:26px;background:linear-gradient(160deg,#ccc,#999);border-radius:4px 4px 3px 3px;transform:translateX(-70%);box-shadow:0 4px 10px rgba(0,0,0,.7)}
    .arm-needle{position:absolute;bottom:-12px;left:50%;width:2px;height:14px;background:linear-gradient(180deg,#bbb,#555);border-radius:1px;transform:translateX(-50%)}

    /* ── TRANSICIÓN SUAVE AL CAMBIAR TEMA ── */
    .hero-info{flex:1;min-width:0;transition:opacity .45s ease;padding-bottom:8px;}
    .hero-info.fading{opacity:0;}
    .vinyl-art.fading{opacity:0;}
    #hero-bg{
      position:absolute;inset:0;z-index:0;
      background-size:cover;
      background-position:center 30%;
      filter:blur(7px) brightness(.48) saturate(1.4);
      transform:scale(1.08);
      transition:opacity .8s ease;
      animation:bgZoom 50s ease-in-out infinite;
      -webkit-animation:bgZoom 50s ease-in-out infinite;
      will-change:transform;
      -webkit-backface-visibility:hidden;
      backface-visibility:hidden;
    }
    #hero-bg-new{
      position:absolute;inset:0;z-index:0;
      background-size:cover;
      background-position:center 30%;
      filter:blur(7px) brightness(.48) saturate(1.4);
      transform:scale(1.08);
      opacity:0;
      transition:opacity .8s ease;
      will-change:transform;
      -webkit-backface-visibility:hidden;
      backface-visibility:hidden;
    }
    .onair-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}
    .onair-tag{background:var(--pink);color:#fff;font-family:"Orbitron",sans-serif;font-size:.6rem;font-weight:700;letter-spacing:3px;padding:5px 12px;border-radius:4px;box-shadow:0 0 14px rgba(255,45,120,.45)}
    .playlist-tag{font-size:.62rem;color:rgba(224,224,255,.38);letter-spacing:1.5px;text-transform:uppercase;font-family:"Orbitron",sans-serif}
    .hero-title{font-size:clamp(2.2rem,4.5vw,4rem);font-weight:700;color:#fff;line-height:1.05;margin-bottom:10px;text-shadow:0 2px 30px rgba(0,0,0,.6)}
    .hero-artist{font-size:clamp(1.2rem,2.2vw,1.8rem);font-weight:600;color:var(--cyan);text-shadow:0 0 28px rgba(0,245,255,.5);margin-bottom:22px}

    /* Barra de progreso */
    .prog-wrap{margin-bottom:20px;padding-right:8px}
    .prog-track{width:100%;height:4px;background:rgba(255,255,255,.12);border-radius:2px;overflow:hidden;margin-bottom:7px}
    .prog-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--pink));border-radius:2px;width:0%}
    .prog-times{display:flex;justify-content:space-between;font-family:"Orbitron",sans-serif;font-size:.6rem;color:rgba(224,224,255,.32);letter-spacing:1px}

    /* Trivia */
    .trivia-box{background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.1);border-left:3px solid var(--pink);border-radius:12px;padding:14px 18px;margin-bottom:24px;display:flex;align-items:flex-start;gap:12px;max-width:580px;backdrop-filter:blur(12px)}
    #trivia-text{transition:opacity .4s ease;display:block}
    .trivia-mic{width:34px;height:34px;border-radius:50%;background:rgba(255,45,120,.15);border:1px solid rgba(255,45,120,.35);display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
    .trivia-label{font-family:"Orbitron",sans-serif;font-size:.46rem;letter-spacing:3px;color:var(--pink);opacity:.8;display:block;margin-bottom:4px}
    .trivia-lamp{
      display:inline-flex;align-items:center;gap:5px;
      cursor:pointer;margin-left:8px;
      background:rgba(255,45,120,.12);
      border:1px solid rgba(255,45,120,.3);
      border-radius:20px;
      padding:2px 10px 2px 7px;
      font-size:.68rem;font-family:"Orbitron",sans-serif;
      font-style:normal;
      color:rgba(255,120,160,.9);
      letter-spacing:.5px;
      vertical-align:middle;
      transition:background .2s,border-color .2s,color .2s;
      white-space:nowrap;
      text-transform:uppercase;
    }
    .trivia-lamp:hover{
      background:rgba(255,45,120,.25);
      border-color:rgba(255,45,120,.6);
      color:#fff;
    }
    .trivia-text{font-size:.85rem;color:rgba(224,224,255,.78);line-height:1.58;font-style:italic}

    /* Acciones */
    .hero-actions{display:flex;align-items:center;gap:clamp(7px,0.8vw,12px);flex-wrap:nowrap}
    #play-btn{display:flex;align-items:center;justify-content:center;gap:11px;background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.35);border-radius:50px;padding:12px clamp(18px,2vw,28px);min-width:clamp(150px,14vw,190px);width:clamp(150px,14vw,190px);font-family:"Exo 2",sans-serif;font-size:clamp(.82rem,.85vw,.95rem);font-weight:700;letter-spacing:1px;cursor:pointer;transition:transform .12s,box-shadow .12s,background .2s,border-color .2s;text-transform:uppercase;flex-shrink:0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
    #play-btn:hover{transform:scale(1.04);background:rgba(255,255,255,.14)!important;border-color:rgba(255,255,255,.6)!important;box-shadow:0 0 24px rgba(255,255,255,.15)}
    #play-btn:active{transform:scale(.94);box-shadow:none}
    #play-btn.pulse{animation:btnPress .25s ease-out}
    @keyframes btnPress{0%{transform:scale(1)}30%{transform:scale(.93)}70%{transform:scale(1.04)}100%{transform:scale(1)}}
    #play-btn svg{width:17px;height:17px;fill:#fff;flex-shrink:0}
    .btn-icon{width:clamp(38px,3vw,46px);height:clamp(38px,3vw,46px);border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:clamp(.85rem,.9vw,1.05rem);transition:background .2s}
    .btn-icon:hover{background:rgba(255,255,255,.16)}
    .hero-vol{display:flex;align-items:center;gap:9px}
    .vol-icon{color:rgba(224,224,255,.4);font-size:.9rem}
    .vol-range{-webkit-appearance:none;width:clamp(60px,6vw,90px);height:4px;background:rgba(255,255,255,.15);border-radius:2px;outline:none;cursor:pointer}
    .vol-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 0 6px rgba(255,255,255,.4)}

    /* ── DIVIDER ── */
    .hero-divider{
      position:relative;z-index:2;
      display:flex;align-items:center;justify-content:center;
      padding:0 56px;
      margin-top:auto;
      background:rgba(4,3,10,.6);
      border-top:1px solid rgba(0,245,255,.12);
      border-bottom:1px solid rgba(0,245,255,.12);
    }
    .divider-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(0,245,255,.5),rgba(255,45,120,.5),transparent)}
    .divider-badge{
      font-family:"Orbitron",sans-serif;font-size:.58rem;letter-spacing:4px;
      color:rgba(224,224,255,.7);
      padding:10px 22px;
      border:1px solid rgba(0,245,255,.25);
      border-radius:20px;
      margin:0 24px;
      white-space:nowrap;
      background:rgba(0,245,255,.06);
      backdrop-filter:blur(12px);
      display:flex;align-items:center;gap:8px;
    }
    .divider-dot{
      width:7px;height:7px;border-radius:50%;
      background:var(--pink);box-shadow:0 0 8px var(--pink);
      animation:blink 1.4s ease-in-out infinite;
      flex-shrink:0;
    }

    /* ── SLOGAN SECTION ── */
    /* ── TICKER SLOGAN ── */
    .slogan-section{
      position:relative;z-index:2;
      height:52px;overflow:hidden;
      background:linear-gradient(90deg,rgba(4,3,10,.98),rgba(13,10,31,.98));
      border-top:1px solid rgba(255,45,120,.15);
      border-bottom:1px solid rgba(0,245,255,.12);
      display:flex;align-items:center;
    }
    /* Fade en los extremos */
    .slogan-section::before,.slogan-section::after{
      content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
    }
    .slogan-section::before{left:0;background:linear-gradient(90deg,rgba(4,3,10,.98),transparent)}
    .slogan-section::after{right:0;background:linear-gradient(270deg,rgba(4,3,10,.98),transparent)}
    .slogan-track{
      display:flex;align-items:center;gap:0;
      white-space:nowrap;
      animation:ticker 28s linear infinite;
      will-change:transform;
    }
    @keyframes ticker{
      0%{transform:translateX(0)}
      100%{transform:translateX(-50%)}
    }
    .slogan-item{
      display:inline-flex;align-items:center;gap:10px;
      padding:0 36px;
      font-family:"Orbitron",sans-serif;
      font-size:.58rem;font-weight:700;
      letter-spacing:3px;text-transform:uppercase;
    }
    .slogan-item-main{color:#fff;opacity:.85}
    .slogan-item-accent{
      background:linear-gradient(90deg,var(--pink),var(--cyan));
      -webkit-background-clip:text;-webkit-text-fill-color:transparent;
      font-weight:900;font-size:.68rem;
    }
    .slogan-sep{
      color:var(--pink);font-size:.9rem;opacity:.5;flex-shrink:0;
    }
    /* ocultar elementos viejos */
    .slogan-kicker,.slogan-main,.slogan-80s,.slogan-sub,.slogan-btn{display:none}
    .slogan-kicker{
      cursor:default;
    }
    .slogan-dot{
      width:10px;height:10px;border-radius:50%;
      background:#00e676;
      box-shadow:0 0 8px #00e676;
      flex-shrink:0;
      animation:blink 1.4s ease-in-out infinite;
    }


    /* ── NOTICIAS ── */
    .noticias-section{max-width:1200px;margin:0 auto;padding:0 48px 60px;width:100%}
    .noticias-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
    .noticias-carousel{position:relative}
    .noticias-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px}
    .noticias-arrow{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.5);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
    .noticias-arrow:hover:not(:disabled){background:rgba(0,245,255,.1);border-color:rgba(0,245,255,.35);color:var(--cyan)}
    .noticias-arrow:disabled{opacity:.2;cursor:default}
    .noticias-dots{display:flex;gap:6px;align-items:center}
    .noticias-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.15);transition:all .25s;cursor:pointer}
    .noticias-dot.active{width:20px;border-radius:3px;background:var(--cyan)}
    .noticias-ver-mas{display:block;text-align:center;margin-top:24px}
    .noticias-ver-mas a{font-family:"Orbitron",sans-serif;font-size:.55rem;letter-spacing:3px;color:rgba(255,255,255,.35);text-decoration:none;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:10px 28px;transition:all .2s;display:inline-block}
    .noticias-ver-mas a:hover{color:var(--cyan);border-color:rgba(0,245,255,.35);background:rgba(0,245,255,.05)}
    /* Animación slide */
    .noticias-grid.slide-out-left{animation:slideOutLeft .22s ease forwards}
    .noticias-grid.slide-in-right{animation:slideInRight .22s ease forwards}
    .noticias-grid.slide-out-right{animation:slideOutRight .22s ease forwards}
    .noticias-grid.slide-in-left{animation:slideInLeft .22s ease forwards}
    @keyframes slideOutLeft{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-40px)}}
    @keyframes slideInRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
    @keyframes slideOutRight{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(40px)}}
    @keyframes slideInLeft{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
    .noticia-card{
      background:rgba(255,255,255,.03);
      border:1px solid rgba(255,255,255,.07);
      border-radius:14px;overflow:hidden;
      display:flex;flex-direction:column;
      transition:border-color .2s,transform .2s;
      cursor:pointer;
    }
    .noticia-card:hover{border-color:rgba(0,245,255,.25);transform:translateY(-3px)}
    .noticia-img-wrap{width:100%;height:170px;position:relative;overflow:hidden;flex-shrink:0;background:#0d1528;border-radius:12px 12px 0 0}
    .noticia-img-bg{position:absolute;inset:-10px;width:calc(100% + 20px);height:calc(100% + 20px);object-fit:cover;object-position:center;filter:blur(12px) brightness(.45) saturate(1.3);transform:scale(1.05)}
    .noticia-img-front{position:absolute;inset:10px;width:calc(100% - 20px);height:calc(100% - 20px);object-fit:contain;object-position:center;z-index:2;border-radius:8px;box-shadow:0 2px 16px rgba(0,0,0,.4)}
    .noticia-img-placeholder{width:100%;height:170px;background:linear-gradient(135deg,#0d1528,#07050f);display:flex;align-items:center;justify-content:center;font-size:2rem;letter-spacing:2px;color:rgba(255,255,255,.15);font-family:"Orbitron",sans-serif;flex-shrink:0}
    /* Popup imagen dual */
    #noticia-popup-img-wrap{width:100%;height:240px;position:relative;overflow:hidden;background:#0d1528;border-radius:0}
    #noticia-popup-img-bg{position:absolute;inset:-10px;width:calc(100% + 20px);height:calc(100% + 20px);object-fit:cover;filter:blur(14px) brightness(.4) saturate(1.3);transform:scale(1.05)}
    #noticia-popup-img{position:absolute;inset:10px;width:calc(100% - 20px);height:calc(100% - 20px);object-fit:contain;object-position:center;z-index:2;border-radius:10px;box-shadow:0 2px 16px rgba(0,0,0,.4)}
    .noticia-body{padding:16px;display:flex;flex-direction:column;flex:1}
    .noticia-meta{display:flex;align-items:center;gap:8px;margin-bottom:8px}
    .noticia-cat{font-family:"Orbitron",sans-serif;font-size:.42rem;letter-spacing:2px;padding:3px 8px;border-radius:4px}
    .noticia-cat.NOTICIA{background:rgba(0,245,255,.1);color:#00f5ff;border:1px solid rgba(0,245,255,.2)}
    .noticia-cat.HISTORIA{background:rgba(191,0,255,.1);color:#bf00ff;border:1px solid rgba(191,0,255,.2)}
    .noticia-cat.CURIOSIDAD{background:rgba(255,45,120,.1);color:#ff2d78;border:1px solid rgba(255,45,120,.2)}
    .noticia-fecha{font-family:"Orbitron",sans-serif;font-size:.4rem;color:rgba(224,224,255,.3);letter-spacing:1px}
    .noticia-titulo{font-family:"Exo 2",sans-serif;font-size:.9rem;font-weight:800;color:#fff;line-height:1.35;margin-bottom:8px}
    .noticia-extracto{font-size:.78rem;color:rgba(224,224,255,.45);line-height:1.6;flex:1;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
    .noticia-leer{font-family:"Orbitron",sans-serif;font-size:.42rem;letter-spacing:1.5px;color:rgba(0,245,255,.6);margin-top:12px;display:inline-block}
    /* Popup noticia */
    #noticia-popup{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.8);backdrop-filter:blur(14px);display:none;align-items:center;justify-content:center;padding:24px}
    #noticia-popup.open{display:flex}
    #noticia-popup-box{background:linear-gradient(160deg,#0d1a2e,#07050f);border:1px solid rgba(0,245,255,.18);border-radius:18px;width:100%;max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:0 0 50px rgba(0,245,255,.07),0 24px 64px rgba(0,0,0,.7)}
    #noticia-popup-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;background:#0d1a2e;z-index:1;border-radius:18px 18px 0 0}
    #noticia-popup-cat{font-family:"Orbitron",sans-serif;font-size:.5rem;letter-spacing:2px}
    #noticia-popup-close{background:none;border:none;color:rgba(255,255,255,.4);font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px}
    #noticia-popup-close:hover{color:#fff;background:rgba(255,255,255,.1)}

    #noticia-popup-body{padding:20px}
    #noticia-popup-titulo{font-family:"Exo 2",sans-serif;font-size:1.1rem;font-weight:900;color:#fff;line-height:1.3;margin-bottom:6px}
    #noticia-popup-fecha{font-family:"Orbitron",sans-serif;font-size:.42rem;color:rgba(224,224,255,.3);letter-spacing:1px;margin-bottom:16px}
    #noticia-popup-texto{font-size:.85rem;color:rgba(224,224,255,.6);line-height:1.8}
    #noticia-popup-fuente{font-size:.65rem;color:rgba(224,224,255,.2);margin-top:16px;font-style:italic}
    /* Popup info canción */
    #song-info-popup{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);display:none;align-items:center;justify-content:center;padding:20px}
    #song-info-popup.open{display:flex}
    .sip-box{background:linear-gradient(135deg,#0d1020,#07050f);border:1px solid rgba(0,245,255,.15);border-radius:20px;overflow:hidden;width:100%;max-width:360px;box-shadow:0 24px 64px rgba(0,0,0,.8)}
    .sip-head{display:flex;align-items:center;justify-content:flex-end;padding:12px 16px 0}
    .sip-close{background:none;border:none;color:rgba(255,255,255,.4);font-size:1.3rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .15s}
    .sip-close:hover{background:rgba(255,255,255,.1);color:#fff}
    .sip-art-wrap{position:relative;width:220px;height:220px;margin:0 auto 20px;border-radius:14px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.7)}
    .sip-art{width:100%;height:100%;object-fit:cover}
    .sip-body{padding:0 24px 28px;text-align:center}
    .sip-title{font-family:"Orbitron",sans-serif;font-size:.85rem;font-weight:900;color:#fff;line-height:1.3;margin-bottom:10px;word-break:break-word}
    .sip-artist{font-size:.9rem;color:var(--cyan);margin-bottom:6px;word-break:break-word}
    .sip-album{font-size:.75rem;color:rgba(255,255,255,.35);word-break:break-word}
    .noticias-loading{text-align:center;padding:40px;font-family:"Orbitron",sans-serif;font-size:.6rem;letter-spacing:2px;color:rgba(224,224,255,.3)}
    .noticia-skeleton{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
    .skel-img{width:100%;height:170px;background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);background-size:200% 100%;animation:skelShimmer 1.5s infinite}
    .skel-body{padding:16px;display:flex;flex-direction:column;gap:10px}
    .skel-line{height:10px;border-radius:4px;background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 75%);background-size:200% 100%;animation:skelShimmer 1.5s infinite}
    .skel-line.short{width:40%}
    .skel-line.title{height:14px;width:90%}
    .skel-line.mid{width:70%}
    @keyframes skelShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
    .noticias-empty{text-align:center;padding:40px;font-family:"Orbitron",sans-serif;font-size:.6rem;letter-spacing:2px;color:rgba(224,224,255,.2)}
    @media(max-width:860px){
      .noticias-grid{grid-template-columns:1fr!important}
      .noticias-section{padding:0 16px 48px}
      .noticias-arrow{width:36px;height:36px;font-size:.85rem}
    }
    @media(min-width:861px) and (max-width:1100px){
      .noticias-grid{grid-template-columns:repeat(2,1fr)!important}
    }

    /* ── ZONA INTERACTIVA ── */
    .zona-interactiva{max-width:1200px;margin:0 auto;padding:0 48px 60px;width:100%}
    .zona-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
    .zona-col-label{font-family:"Orbitron",sans-serif;font-size:.46rem;letter-spacing:2px;color:rgba(255,255,255,.2);margin-bottom:12px}
    .zona-grid > div{display:flex;flex-direction:column}
    .quiz-vhs-wrap{background:#080808;border:2px solid #1c1c1c;border-radius:6px;overflow:hidden;box-shadow:0 0 0 1px #262626,0 16px 40px rgba(0,0,0,.8);position:relative;flex:1;display:flex;flex-direction:column}
    .quiz-vhs-wrap::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:20;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.12) 2px,rgba(0,0,0,.12) 4px)}
    .qvhs-rec{display:flex;align-items:center;gap:7px;padding:8px 14px;background:#0d0d0d;border-bottom:1px solid #1c1c1c}
    .qvhs-dot{width:8px;height:8px;border-radius:50%;background:#ff2d00;box-shadow:0 0 7px #ff2d00;animation:qblink 1s infinite}
    @keyframes qblink{0%,100%{opacity:1}50%{opacity:.1}}
    .qvhs-rectxt{font-family:"VT323",monospace;font-size:.85rem;color:#ff2d00;letter-spacing:2px}
    .qvhs-ch{font-family:"VT323",monospace;font-size:.75rem;color:rgba(255,45,0,.35);margin-left:auto;letter-spacing:1px}
    .qvhs-screen{padding:18px 16px;background:linear-gradient(180deg,#050f05,#030803);min-height:300px;flex:1;position:relative;z-index:5}
    .qvhs-bottom{background:#0d0d0d;border-top:1px solid #1c1c1c;padding:6px 14px;display:flex;align-items:center;justify-content:space-between}
    .qvhs-brand{font-family:"Orbitron",sans-serif;font-size:.32rem;letter-spacing:2px;color:rgba(57,255,20,.25)}
    .qvhs-tc{font-family:"VT323",monospace;font-size:.75rem;color:rgba(57,255,20,.18);letter-spacing:1px}
    /* Estilos internos quiz */
    .qvhs-logo{font-family:"Orbitron",sans-serif;font-size:1.1rem;font-weight:900;color:#39ff14;text-shadow:0 0 18px rgba(57,255,20,.7);letter-spacing:4px;animation:qlogoPulse 2s ease-in-out infinite}
    @keyframes qlogoPulse{0%,100%{text-shadow:0 0 18px rgba(57,255,20,.7)}50%{text-shadow:0 0 36px rgba(57,255,20,1)}}
    .qvhs-intro{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}
    .qvhs-idiv{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(57,255,20,.3),transparent)}
    .qvhs-idesc{font-family:"VT323",monospace;font-size:.8rem;color:rgba(180,255,180,.4);line-height:1.5}
    .qvhs-isub{font-family:"VT323",monospace;font-size:.9rem;color:rgba(57,255,20,.5);letter-spacing:2px}
    .qvhs-sbtn{font-family:"VT323",monospace;font-size:1rem;letter-spacing:3px;padding:11px 28px;border:1px solid #39ff14;background:transparent;color:#39ff14;cursor:pointer;transition:all .15s;animation:qbtnGlow 1.5s ease-in-out infinite;width:100%}
    @keyframes qbtnGlow{0%,100%{box-shadow:0 0 6px rgba(57,255,20,.2)}50%{box-shadow:0 0 18px rgba(57,255,20,.5)}}
    .qvhs-sbtn:hover{background:#39ff14;color:#000}
    .qvhs-rbtn-sm{font-family:"VT323",monospace;font-size:.85rem;letter-spacing:2px;padding:8px 20px;border:1px solid rgba(57,255,20,.25);background:transparent;color:rgba(57,255,20,.45);cursor:pointer;transition:all .15s;width:100%}
    .qvhs-rbtn-sm:hover{border-color:#39ff14;color:#39ff14}
    .qvhs-nick-scr{display:flex;flex-direction:column;gap:12px}
    .qvhs-ntit{font-family:"VT323",monospace;font-size:1.1rem;color:#39ff14;letter-spacing:3px}
    .qvhs-npm{font-family:"VT323",monospace;font-size:.82rem;color:rgba(57,255,20,.5);letter-spacing:1px}
    .qvhs-ni{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(57,255,20,.4);color:#39ff14;font-family:"VT323",monospace;font-size:1.2rem;padding:6px 0;letter-spacing:2px;outline:none}
    .qvhs-ni::placeholder{color:rgba(57,255,20,.2)}
    .qvhs-nlbl{font-family:"VT323",monospace;font-size:.8rem;color:rgba(57,255,20,.45);letter-spacing:2px;margin-top:4px}
    .qvhs-lvl{padding:9px 12px;border:1px solid rgba(57,255,20,.18);background:transparent;color:rgba(180,255,180,.55);font-family:"VT323",monospace;font-size:.9rem;cursor:pointer;transition:all .14s;text-align:left;border-radius:3px;display:flex;align-items:center;justify-content:space-between;width:100%}
    .qvhs-lvl:hover,.qvhs-lvl.sel{background:rgba(57,255,20,.07);border-color:#39ff14;color:#39ff14}
    .qvhs-lpts{font-size:.7rem;color:rgba(57,255,20,.35)}
    .qvhs-go{width:100%;padding:10px;border:1px solid #39ff14;background:transparent;color:#39ff14;font-family:"VT323",monospace;font-size:1rem;letter-spacing:3px;cursor:pointer;transition:all .14s;margin-top:4px}
    .qvhs-go:hover{background:#39ff14;color:#000}
    .qvhs-go:disabled{opacity:.3;cursor:not-allowed}
    .qvhs-quiz-scr{display:flex;flex-direction:column;gap:9px}
    .qvhs-qhdr{display:flex;align-items:center;justify-content:space-between}
    .qvhs-qnum{font-family:"VT323",monospace;font-size:.85rem;color:rgba(57,255,20,.5);letter-spacing:2px}
    .qvhs-qsc{font-family:"VT323",monospace;font-size:.95rem;color:#39ff14;letter-spacing:1px}
    .qvhs-prog{width:100%;height:3px;background:#0d2a0d;border-radius:1px;overflow:hidden;margin:-3px 0 3px}
    .qvhs-pfill{height:100%;background:#39ff14;box-shadow:0 0 5px #39ff14;transition:width .5s ease}
    .qvhs-q{font-family:"VT323",monospace;font-size:1.05rem;color:#e0ffe0;line-height:1.4;min-height:56px}
    .qvhs-trow{display:flex;align-items:center;gap:7px}
    .qvhs-timer{font-family:"VT323",monospace;font-size:1.3rem;color:#39ff14;text-shadow:0 0 8px rgba(57,255,20,.5);min-width:22px}
    .qvhs-timer.urg{color:#ff2d00;text-shadow:0 0 10px rgba(255,45,0,.7);animation:qurgPulse .4s ease-in-out infinite}
    @keyframes qurgPulse{0%,100%{opacity:1}50%{opacity:.3}}
    .qvhs-tbar{flex:1;height:3px;background:#0d2a0d;border-radius:1px;overflow:hidden}
    .qvhs-tfill{height:100%;background:#39ff14;box-shadow:0 0 4px #39ff14;transition:width .1s linear}
    .qvhs-opts{display:flex;flex-direction:column;gap:6px}
    .qvhs-opt{background:transparent;border:none;border-left:2px solid rgba(57,255,20,.18);padding:8px 10px;font-family:"VT323",monospace;font-size:.95rem;color:rgba(180,255,180,.6);cursor:pointer;transition:all .12s;text-align:left;width:100%;display:flex;align-items:flex-start;gap:8px;line-height:1.3}
    .qvhs-opt:hover:not(.dis){border-left-color:#39ff14;color:#39ff14;background:rgba(57,255,20,.04)}
    .qvhs-opt.ok{border-left-color:#39ff14;color:#39ff14;background:rgba(57,255,20,.07)}
    .qvhs-opt.ko{border-left-color:#ff2d00;color:#ff2d00;background:rgba(255,45,0,.04)}
    .qvhs-opt.dis{pointer-events:none;opacity:.3}
    .qvhs-opt.ok.dis,.qvhs-opt.ko.dis{opacity:1}
    .qvhs-ol{color:rgba(57,255,20,.35);flex-shrink:0;padding-top:1px}
    .qvhs-opt.ok .qvhs-ol{color:#39ff14}
    .qvhs-opt.ko .qvhs-ol{color:#ff2d00}
    .qvhs-streak{font-family:"VT323",monospace;font-size:1rem;color:#ff2d00;letter-spacing:2px;text-align:center;animation:qstreakIn .4s ease-out}
    @keyframes qstreakIn{0%{transform:scale(1.3);opacity:0}100%{transform:scale(1);opacity:1}}
    .qvhs-fact{border-left:1px solid rgba(57,255,20,.25);padding:7px 10px;font-family:"VT323",monospace;font-size:.85rem;color:rgba(57,255,20,.4);line-height:1.4}
    .qvhs-next{width:100%;padding:9px;border:1px solid rgba(57,255,20,.35);background:transparent;color:rgba(57,255,20,.75);font-family:"VT323",monospace;font-size:.9rem;letter-spacing:2px;cursor:pointer;transition:all .12s}
    .qvhs-next:hover{background:#39ff14;color:#000;border-color:#39ff14}
    .qvhs-result-scr{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px}
    .qvhs-rtape{font-family:"VT323",monospace;font-size:.75rem;color:rgba(57,255,20,.3);letter-spacing:2px}
    .qvhs-rscore{font-family:"VT323",monospace;font-size:4.5rem;color:#39ff14;text-shadow:0 0 20px rgba(57,255,20,.6);line-height:1;animation:qresGlitch 4s infinite}
    @keyframes qresGlitch{0%,90%,100%{transform:translate(0);filter:none}92%{transform:translate(-2px,1px);filter:hue-rotate(90deg)}94%{transform:translate(2px,-1px);filter:none}}
    .qvhs-rtitle{font-family:"VT323",monospace;font-size:1.2rem;color:#e0ffe0;letter-spacing:2px}
    .qvhs-rsub{font-family:"VT323",monospace;font-size:.82rem;color:rgba(180,255,180,.4);max-width:260px;line-height:1.4}
    .qvhs-rpts{font-family:"VT323",monospace;font-size:.85rem;color:rgba(57,255,20,.45);letter-spacing:2px}
    .qvhs-premio{background:rgba(57,255,20,.05);border:1px solid rgba(57,255,20,.25);border-radius:4px;padding:10px;text-align:center;animation:qpremioGlow 1.5s ease-in-out infinite;width:100%}
    @keyframes qpremioGlow{0%,100%{box-shadow:0 0 8px rgba(57,255,20,.1)}50%{box-shadow:0 0 20px rgba(57,255,20,.25)}}
    .qvhs-ptitle{font-family:"VT323",monospace;font-size:.95rem;color:#39ff14;letter-spacing:3px;margin-bottom:3px}
    .qvhs-psub{font-family:"VT323",monospace;font-size:.75rem;color:rgba(57,255,20,.45);line-height:1.4}
    .qvhs-rbtns{display:flex;flex-direction:column;gap:6px;width:100%}
    .qvhs-rbtn{padding:9px;border:1px solid rgba(57,255,20,.35);background:transparent;color:rgba(57,255,20,.75);font-family:"VT323",monospace;font-size:.88rem;letter-spacing:2px;cursor:pointer;transition:all .12s;width:100%}
    .qvhs-rbtn:hover{background:rgba(57,255,20,.08);border-color:#39ff14}
    .qvhs-rbtn.alt{border-color:rgba(255,45,0,.35);color:rgba(255,45,0,.6)}
    .qvhs-rbtn.alt:hover{background:rgba(255,45,0,.08);border-color:#ff2d00;color:#ff2d00}
    .qvhs-rank-scr{display:flex;flex-direction:column;gap:9px}
    .qvhs-ktit{font-family:"VT323",monospace;font-size:1rem;color:#39ff14;letter-spacing:3px;text-align:center}
    .qvhs-kempty{font-family:"VT323",monospace;font-size:.85rem;color:rgba(57,255,20,.3);text-align:center;padding:16px 0;letter-spacing:1px}
    .qvhs-klist{display:flex;flex-direction:column;gap:4px}
    .qvhs-ki{display:flex;align-items:center;gap:8px;padding:7px 9px;border-left:2px solid rgba(57,255,20,.18)}
    .qvhs-ki.t1{border-left-color:#39ff14;background:rgba(57,255,20,.05)}
    .qvhs-ki.t2{border-left-color:rgba(57,255,20,.55)}
    .qvhs-ki.t3{border-left-color:rgba(57,255,20,.35)}
    .qvhs-kpos{font-family:"VT323",monospace;font-size:.9rem;color:rgba(57,255,20,.35);min-width:18px}
    .qvhs-ki.t1 .qvhs-kpos{color:#39ff14}
    .qvhs-kname{flex:1;font-family:"VT323",monospace;font-size:.9rem;color:rgba(180,255,180,.65);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
    .qvhs-kinfo{font-family:"VT323",monospace;font-size:.78rem;color:rgba(57,255,20,.35);text-align:right;flex-shrink:0}
    .qvhs-kback{width:100%;padding:8px;border:1px solid rgba(57,255,20,.25);background:transparent;color:rgba(57,255,20,.55);font-family:"VT323",monospace;font-size:.85rem;letter-spacing:2px;cursor:pointer;margin-top:3px;transition:all .12s}
    .qvhs-kback:hover{border-color:#39ff14;color:#39ff14}
    @media(max-width:860px){
      .zona-grid{grid-template-columns:1fr}
      .zona-interactiva{padding:0 16px 48px}
    }

    /* ── EFEMÉRIDES GLASS ── */
    .ef-section{max-width:1200px;margin:0 auto;padding:0 48px 60px;width:100%}
    .ef-img-in{opacity:0;transition:opacity .55s ease}
    .ef-img-in.loaded{opacity:1}
    /* Shared layout */
    .ef-card{position:relative;border-radius:16px;overflow:hidden;width:100%;max-width:480px;margin:0 auto}
    .ef-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}
    .ef-year-block{padding:10px 16px 0;display:flex;gap:12px;align-items:flex-start}
    .ef-year-num{line-height:1;flex-shrink:0}
    .ef-title-beside{flex:1;min-width:0;padding-top:4px}
    .ef-photo{width:calc(100% - 24px);height:155px;margin:12px 12px 0;border-radius:10px;overflow:hidden;position:relative;background:#0d1528}
    .ef-photo-bg{position:absolute;inset:-10px;width:calc(100% + 20px);height:calc(100% + 20px);object-fit:cover;object-position:center;filter:blur(10px) brightness(.4) saturate(1.3);transform:scale(1.05)}
    .ef-photo-front{position:absolute;inset:8px;width:calc(100% - 16px);height:calc(100% - 16px);object-fit:contain;object-position:center;z-index:2;border-radius:6px;transition:opacity .55s ease}
    .ef-body{padding:10px 16px 0}
    .ef-text{font-size:.8rem;line-height:1.65}
    .ef-footer{display:flex;align-items:center;justify-content:space-between;padding:0 16px 14px}
    /* Glass wrapper */
    .ef-wrap{background:linear-gradient(135deg,#1a0533,#0d1a4a,#1a0a2e);border-radius:18px;padding:2px;box-shadow:0 20px 56px rgba(0,0,0,.55);width:100%;max-width:480px;margin:0 auto;flex:1}
    .ef-wrap .ef-card{background:rgba(12,4,24,.86);backdrop-filter:blur(20px);border-radius:16px;max-width:100%;height:100%}
    /* Orbs */
    .ef-orb1{position:absolute;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(255,45,120,.2),transparent 70%);top:-40px;right:-20px;pointer-events:none;z-index:0}
    .ef-orb2{position:absolute;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,rgba(0,245,255,.14),transparent 70%);bottom:-20px;left:-5px;pointer-events:none;z-index:0}
    /* Header */
    .ef-wrap .ef-header{position:relative;z-index:2;padding-bottom:12px;border-bottom:1px solid rgba(255,45,120,.12);background:rgba(255,45,120,.03)}
    .ef-badge{font-family:"Orbitron",sans-serif;font-size:.46rem;letter-spacing:2.5px;color:#ff2d78;text-shadow:0 0 10px rgba(255,45,120,.6)}
    .ef-date-txt{font-family:"Orbitron",sans-serif;font-size:.38rem;letter-spacing:.8px;color:rgba(255,255,255,.25)}
    /* Año */
    .ef-wrap .ef-year-block{position:relative;z-index:2;padding-top:10px}
    .ef-wrap .ef-year-num{font-family:"Bebas Neue",cursive;font-size:3.2rem;background:linear-gradient(135deg,#ff2d78,#bf00ff,#00f5ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
    .ef-wrap .ef-title-beside{font-family:"Exo 2",sans-serif;font-size:.78rem;font-weight:800;color:#fff;line-height:1.3}
    /* Foto */
    .ef-wrap .ef-photo{border:1px solid rgba(191,0,255,.18);box-shadow:0 0 0 1px rgba(191,0,255,.08),0 4px 14px rgba(0,0,0,.5);position:relative;z-index:2}
    /* Body */
    .ef-wrap .ef-body{position:relative;z-index:2}
    .ef-wrap .ef-text{color:rgba(224,224,255,.45)}
    /* Footer */
    .ef-footer-glass{display:flex;align-items:center;justify-content:space-between;padding:0 16px 14px;position:relative;z-index:2}
    .ef-cats{display:flex;gap:5px;flex-wrap:wrap}
    .ef-cat{background:rgba(191,0,255,.07);border:1px solid rgba(191,0,255,.2);border-radius:4px;padding:2px 7px;font-size:.5rem;color:rgba(191,0,255,.72);font-weight:600}
    .ef-nav-row{display:flex;gap:6px}
    .ef-nav-btn{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:#fff;cursor:pointer;font-size:.85rem;transition:all .14s;display:flex;align-items:center;justify-content:center}
    .ef-nav-btn:hover{background:rgba(255,45,120,.12);border-color:rgba(255,45,120,.28)}
    /* Fondo blur */
    .ef-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%;filter:brightness(.28) saturate(1.4) blur(5px);z-index:0;border-radius:16px}
    @media(max-width:860px){
      .ef-section{padding:0 16px 48px}
      .ef-wrap,.ef-card{max-width:100%}
    }
    /* ── SECCIONES ── */
    .section{max-width:1200px;margin:0 auto;padding:0 48px 60px;width:100%}
    /* Bloques alternados — contraste visible entre secciones */
    .sec-block{width:100%;position:relative}
    .sec-block-b{background:#0d1528;border-top:1px solid rgba(0,245,255,.14);border-bottom:1px solid rgba(0,245,255,.08)}
    .sec-block-c{background:#07050f;border-top:1px solid rgba(255,45,120,.1)}
    .sec-title{font-family:"Orbitron",sans-serif;font-size:.72rem;letter-spacing:5px;color:var(--purple);text-shadow:0 0 14px var(--purple);margin-bottom:22px;display:flex;align-items:center;gap:14px}
    .sec-title::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(191,0,255,.4),transparent)}
    /* ── HISTORIAL CARRUSEL ── */
    /* ── KL-HEADING UNIFICADO ── */
    .kl-heading-wrap{text-align:center;margin-bottom:32px}
    .kl-heading-wrap h2,.kl-h2{
      font-family:"Exo 2",sans-serif;
      font-size:clamp(1.6rem,4vw,2.6rem);
      font-weight:900;text-transform:uppercase;letter-spacing:4px;
      color:#fff;text-shadow:0 0 30px rgba(255,255,255,.12),0 2px 0 rgba(0,0,0,.8);
      position:relative;display:inline-block;line-height:1.1;
    }
    .kl-heading-wrap h2::after,.kl-h2::after{
      content:"";display:block;width:55%;height:3px;
      background:linear-gradient(90deg,transparent,var(--pink),transparent);
      margin:10px auto 0;border-radius:2px;
      box-shadow:0 0 16px rgba(255,45,120,.9),0 0 4px rgba(255,45,120,.6);
    }
    .hist-header{text-align:center;margin-bottom:36px}
    .hist-header h2{font-family:"Exo 2",sans-serif;font-size:clamp(1.6rem,4vw,2.6rem);font-weight:900;text-transform:uppercase;letter-spacing:4px;color:#fff;text-shadow:0 0 30px rgba(255,255,255,.12),0 2px 0 rgba(0,0,0,.8);position:relative;display:inline-block}
    .hist-header h2::after{content:"";display:block;width:55%;height:3px;background:linear-gradient(90deg,transparent,var(--pink),transparent);margin:10px auto 0;border-radius:2px;box-shadow:0 0 16px rgba(255,45,120,.9)}

    .carousel-outer{
      display:grid;
      grid-template-columns:54px 1fr 54px;
      align-items:center;
      gap:0;
    }
    .carousel-arrow{
      width:44px;height:44px;border-radius:50%;
      background:var(--pink);border:none;
      display:flex;align-items:center;justify-content:center;
      cursor:pointer;color:#fff;font-size:1.1rem;font-weight:bold;
      box-shadow:0 4px 20px rgba(255,45,120,.5);
      transition:background .2s,transform .2s;
      justify-self:center;
    }
    .carousel-arrow:hover{background:#e0005a;transform:scale(1.1)}
    .carousel-arrow.disabled{opacity:.2;cursor:default;pointer-events:none}

    .hist-viewport{
      overflow:hidden;
      padding:12px 0 20px;
    }
    .hist-track{
      display:flex;gap:20px;
      transition:transform .42s cubic-bezier(.4,0,.2,1);
      will-change:transform;
    }
    /* Cards: calc exacto basado en el viewport del carrusel */
    /* viewport = 100% del 1fr entre flechas. Sección max 1200px, padding 96px, flechas 108px */
    /* disponible ≈ min(100vw,1200px) - 96px - 108px = ~996px → /5 cards - 16px gaps = ~183px */
    .hist-card{flex:0 0 calc((100% - 80px) / 5);width:calc((100% - 80px) / 5);cursor:pointer;transition:transform .2s}
    .hist-card:hover{transform:translateY(-6px)}
    .hist-card-img-wrap{
      position:relative;width:100%;margin-bottom:12px;
      border-radius:12px;overflow:hidden;
      box-shadow:0 10px 30px rgba(0,0,0,.7);
    }
    @keyframes shimmer{
      0%{background-position:200% 0}
      100%{background-position:-200% 0}
    }
    .img-loading{
      background:linear-gradient(90deg,#1a0533 25%,#2a1044 50%,#1a0533 75%);
      background-size:200% 100%;
      animation:shimmer 1.6s ease-in-out infinite;
    }
    .hist-card-art{
      width:100%;aspect-ratio:1;border-radius:12px;object-fit:cover;
      border:1px solid rgba(255,255,255,.09);
      background-color:#0a0618;
      background-image:url('/icon-512.png');
      background-size:80%;
      background-repeat:no-repeat;
      background-position:center;
      display:block;
      transition:opacity .4s ease;
    }
    .hist-card-title{font-size:.92rem;font-weight:700;color:#fff;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .hist-card-artist{font-size:.78rem;color:rgba(224,224,255,.65);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .hist-card-time{font-family:"Orbitron",sans-serif;font-size:.54rem;color:#ff80ab;letter-spacing:.5px;display:flex;align-items:center;gap:4px;font-weight:600}

    /* Corazón en cada card — dentro del wrapper de imagen */
    .hist-card{position:relative}
    .card-heart{
      position:absolute;bottom:7px;right:7px;
      width:32px;height:32px;border-radius:50%;
      background:rgba(0,0,0,.62);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
      border:1px solid rgba(255,255,255,.18);
      display:flex;align-items:center;justify-content:center;
      cursor:pointer;font-size:.85rem;
      transition:transform .2s ease,background .25s ease,border-color .25s ease;
      z-index:4;
      user-select:none;
      touch-action:manipulation;
    }
    .card-heart:hover{transform:scale(1.15);background:rgba(255,45,120,.2);border-color:var(--pink)}
    .card-heart.voted{background:rgba(255,45,120,.3);border-color:var(--pink);animation:heartPop .3s cubic-bezier(.34,1.56,.64,1)}
    @keyframes heartPop{0%{transform:scale(1)}50%{transform:scale(1.35)}100%{transform:scale(1)}}

    /* TOP HITS */
    .top-header{text-align:center;margin-bottom:36px}
    .top-header h2{font-family:"Exo 2",sans-serif;font-size:clamp(1.6rem,4vw,2.6rem);font-weight:900;text-transform:uppercase;letter-spacing:4px;color:#fff;text-shadow:0 0 30px rgba(255,255,255,.12),0 2px 0 rgba(0,0,0,.8);display:inline-block}
    .top-header h2::after{content:"";display:block;width:55%;height:3px;background:linear-gradient(90deg,transparent,var(--pink),transparent);margin:10px auto 0;border-radius:2px;box-shadow:0 0 16px rgba(255,45,120,.9)}

    /* ── TOP HITS: hero izq + lista derecha ── */
    .top-layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start;max-width:900px;margin:0 auto}
    .top-list-v{display:flex;flex-direction:column;gap:8px;width:100%}

    /* Item #1 — hero card */
    .top-hero-card{
      position:relative;border-radius:16px;overflow:hidden;
      cursor:pointer;
      width:100%;aspect-ratio:1/1;
      border:2px solid rgba(255,45,120,.5);
      box-shadow:0 0 40px rgba(255,45,120,.2),0 0 80px rgba(255,45,120,.1);
      transition:transform .2s,box-shadow .2s;
    }
    .top-hero-card:hover{transform:scale(1.02);box-shadow:0 0 56px rgba(255,45,120,.35)}
    .top-hero-card img{
      position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
    }
    /* Overlay degradado en la parte inferior */
    .top-hero-card::after{
      content:'';position:absolute;inset:0;
      background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 50%,transparent 100%);
    }
    .top-hero-info{
      position:absolute;bottom:0;left:0;right:0;
      padding:16px;z-index:2;
    }
    .top-hero-badge{
      display:inline-flex;align-items:center;gap:6px;
      background:var(--pink);border-radius:6px;
      padding:3px 10px;margin-bottom:10px;
      font-family:"Orbitron",sans-serif;font-size:.58rem;
      font-weight:700;letter-spacing:2px;color:#fff;
    }
    .top-hero-title{
      font-size:clamp(1rem,3.5vw,1.4rem);font-weight:800;color:#fff;
      line-height:1.2;margin-bottom:4px;
      display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
    }
    .top-hero-artist{font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:10px}
    .top-hero-footer{display:flex;align-items:center;justify-content:space-between}
    .top-hero-votes{
      font-family:"Orbitron",sans-serif;font-size:.6rem;
      color:rgba(255,255,255,.5);
    }
    .top-hero-heart{
      width:38px;height:38px;border-radius:50%;
      background:rgba(255,45,120,.15);border:1px solid rgba(255,45,120,.5);
      display:flex;align-items:center;justify-content:center;
      cursor:pointer;font-size:.95rem;z-index:3;position:relative;
      transition:background .25s ease,transform .2s ease,border-color .25s ease;flex-shrink:0;
      touch-action:manipulation;
    }
    .top-hero-heart:hover{background:rgba(255,45,120,.35);transform:scale(1.12)}
    .top-hero-heart.voted{background:rgba(255,45,120,.4);border-color:var(--pink)}

    /* Items 2-5 — lista lateral */
    .top-item-rest{
      display:flex;align-items:center;gap:10px;
      background:rgba(255,255,255,.03);
      border:1px solid rgba(255,255,255,.06);
      border-radius:12px;padding:9px 12px;
      min-width:0;overflow:hidden;
      transition:border-color .2s,background .15s;
    }
    .top-item-rest:hover{border-color:rgba(255,45,120,.25);background:rgba(255,45,120,.05)}
    .top-item-rest .ti-num{
      font-family:"Orbitron",sans-serif;font-size:.8rem;font-weight:900;
      color:rgba(255,255,255,.18);width:18px;text-align:center;flex-shrink:0;
    }
    .top-item-rest.pos2 .ti-num{color:rgba(180,180,220,.55)}
    .top-item-rest.pos3 .ti-num{color:rgba(205,127,50,.7)}
    .top-item-rest .ti-art{
      width:44px;height:44px;border-radius:8px;object-fit:cover;
      border:1px solid rgba(255,255,255,.08);flex-shrink:0;background:#1a0533;
    }
    .top-item-rest .ti-info{flex:1;min-width:0}
    .top-item-rest .ti-title{font-size:.84rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .top-item-rest .ti-artist{font-size:.7rem;color:rgba(224,224,255,.4);margin-top:2px}
    .top-item-rest .ti-votes{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex-shrink:0;min-width:36px}
    .top-item-rest .ti-votes-num{font-family:"Orbitron",sans-serif;font-size:.52rem;color:rgba(255,45,120,.65);font-weight:700;line-height:1}
    .top-item-rest .ti-heart{
      width:38px;height:38px;border-radius:50%;
      background:rgba(255,45,120,.08);border:1px solid rgba(255,45,120,.25);
      display:flex;align-items:center;justify-content:center;
      cursor:pointer;font-size:.95rem;
      transition:background .25s ease,transform .2s ease,border-color .25s ease;
      flex-shrink:0;
      touch-action:manipulation;
    }
    .top-item-rest .ti-heart:hover{background:rgba(255,45,120,.25);transform:scale(1.1)}
    .top-item-rest .ti-heart.voted{background:rgba(255,45,120,.3);border-color:var(--pink)}

    .top-empty{text-align:center;color:rgba(224,224,255,.25);font-size:.84rem;padding:36px 0}
    .top-empty-icon{font-size:2.5rem;display:block;margin-bottom:10px;opacity:.4}

    /* ── PROGRAMACIÓN SEMANAL ── */
    /* Hero banner del programa activo */
    #prog-hero{
      position:relative;width:100%;height:220px;
      border-radius:16px;overflow:hidden;
      margin-bottom:28px;
      background:#0d0a1a;
      border:1px solid rgba(255,45,120,.25);
      box-shadow:0 0 40px rgba(255,45,120,.08),0 8px 40px rgba(0,0,0,.5);
    }
    #prog-hero-img{
      position:absolute;inset:0;width:100%;height:100%;
      object-fit:cover;object-position:center 20%;
      filter:brightness(.55) saturate(1.2);
      transition:opacity .8s ease;
    }
    #prog-hero-overlay{
      position:absolute;inset:0;
      background:linear-gradient(to right,rgba(7,5,15,.85) 0%,rgba(7,5,15,.3) 60%,rgba(7,5,15,.1) 100%),
                 linear-gradient(to top,rgba(7,5,15,.9) 0%,rgba(7,5,15,.0) 50%);
      z-index:1;
    }
    #prog-hero-content{
      position:absolute;bottom:0;left:0;right:0;
      padding:20px 28px;z-index:2;
      display:flex;align-items:flex-end;gap:16px;
    }
    #prog-hero-badge{
      display:inline-flex;align-items:center;gap:5px;
      background:var(--pink);border-radius:4px;
      font-family:"Orbitron",sans-serif;font-size:.48rem;font-weight:700;
      color:#fff;letter-spacing:1px;padding:2px 8px;margin-bottom:6px;
    }
    #prog-hero-name{
      font-size:1.6rem;font-weight:800;color:#fff;
      text-shadow:0 2px 20px rgba(0,0,0,.8);
      line-height:1.1;margin-bottom:4px;
    }
    #prog-hero-time{
      font-family:"Orbitron",sans-serif;font-size:.6rem;
      color:rgba(224,224,255,.65);letter-spacing:1px;
    }
    #prog-hero-desc{
      font-size:.78rem;color:rgba(224,224,255,.55);
      margin-top:4px;max-width:420px;line-height:1.4;
    }
    @media(max-width:860px){
      #prog-hero{height:160px;margin-bottom:20px}
      #prog-hero-name{font-size:1.1rem}
      #prog-hero-content{padding:14px 16px}
    }
    .prog-section-title{
      text-align:center;margin-bottom:32px;
    }
    .prog-section-title h2{
      font-family:"Exo 2",sans-serif;font-size:clamp(1.6rem,4vw,2.6rem);
      font-weight:900;text-transform:uppercase;letter-spacing:4px;
      color:#fff;text-shadow:0 0 30px rgba(255,255,255,.12),0 2px 0 rgba(0,0,0,.8);
      display:inline-block;line-height:1.1;margin:0;
    }
    .prog-section-title h2::after{
      content:"";display:block;width:55%;height:3px;
      background:linear-gradient(90deg,transparent,var(--pink),transparent);
      margin:10px auto 0;border-radius:2px;
      box-shadow:0 0 16px rgba(255,45,120,.9);
    }

    .dias-wrap{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
    .dia-btn{
      font-family:"Orbitron",sans-serif;font-size:.62rem;font-weight:700;
      letter-spacing:2px;color:rgba(224,224,255,.5);
      background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
      border-radius:50px;padding:8px 16px;cursor:pointer;
      transition:all .2s;
    }
    .dia-btn:hover{color:#fff;border-color:rgba(0,245,255,.4);background:rgba(0,245,255,.06)}
    .dia-btn.active{
      color:#000;background:var(--cyan);border-color:var(--cyan);
      box-shadow:0 0 16px rgba(0,245,255,.4);
    }

    .prog-timeline{display:flex;flex-direction:column;gap:0}
    .prog-item{
      display:flex;align-items:stretch;gap:0;
      position:relative;
    }
    /* línea vertical */
    .prog-item::before{
      content:"";position:absolute;left:62px;top:0;bottom:0;
      width:2px;background:rgba(255,255,255,.06);
      z-index:0;
    }
    .prog-item:first-child::before{top:50%}
    .prog-item:last-child::before{bottom:50%}

    .prog-time{
      width:62px;flex-shrink:0;
      font-family:"Orbitron",sans-serif;font-size:.58rem;
      color:rgba(224,224,255,.35);letter-spacing:1px;
      display:flex;align-items:center;justify-content:flex-end;
      padding-right:18px;padding-top:2px;
    }
    .prog-dot{
      width:12px;height:12px;border-radius:50%;flex-shrink:0;
      background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.15);
      margin-top:20px;z-index:1;position:relative;
    }
    .prog-dot.now{
      background:var(--pink);border-color:var(--pink);
      box-shadow:0 0 10px var(--pink);
      animation:dotPulse 1.5s ease-in-out infinite;
    }
    @keyframes dotPulse{0%,100%{box-shadow:0 0 6px var(--pink)}50%{box-shadow:0 0 18px var(--pink),0 0 30px rgba(255,45,120,.3)}}

    .prog-card{
      flex:1;margin:6px 0 6px 14px;
      background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
      border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:14px;
      transition:border-color .2s,background .2s;min-width:0;overflow:hidden;
    }
    .prog-card.now{
      background:rgba(255,45,120,.07);
      border-color:rgba(255,45,120,.35);
      box-shadow:0 0 20px rgba(255,45,120,.08);
    }
    .prog-card:hover{border-color:rgba(0,245,255,.2);background:rgba(0,245,255,.03)}
    .prog-emoji{
      width:52px;height:52px;border-radius:10px;flex-shrink:0;
      display:flex;align-items:center;justify-content:center;
      font-size:1.5rem;background:rgba(255,255,255,.05);
    }
    .prog-info{flex:1;min-width:0}
    .prog-now-badge{
      display:inline-flex;align-items:center;gap:5px;
      background:var(--pink);border-radius:4px;
      font-family:"Orbitron",sans-serif;font-size:.48rem;font-weight:700;
      color:#fff;letter-spacing:1px;padding:2px 7px;margin-bottom:5px;
    }
    .prog-name{font-size:.92rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .prog-desc{font-size:.72rem;color:rgba(224,224,255,.42);margin-top:3px;line-height:1.4}
    .prog-dur{
      font-family:"Orbitron",sans-serif;font-size:.54rem;
      color:rgba(224,224,255,.25);flex-shrink:0;text-align:right;
    }

    @media(max-width:860px){
      .prog-time{width:48px;font-size:.52rem;padding-right:12px}
      .prog-item::before{left:48px}
      .prog-emoji{width:42px;height:42px;font-size:1.2rem}
      .prog-card{gap:10px;padding:10px 12px}
    }

    /* ── PROGRAMACIÓN — DIAL + GRILLA ── */
    .prog-now-panel{
      display:grid;grid-template-columns:96px 1fr;gap:14px;
      background:rgba(255,45,120,.06);
      border:1px solid rgba(255,45,120,.22);border-left:3px solid var(--pink);
      border-radius:12px;padding:14px;margin-bottom:14px;
      align-items:center;min-height:88px;
    }
    .prog-now-thumb{
      width:96px;height:68px;border-radius:8px;
      object-fit:cover;object-position:center 20%;
      border:1px solid rgba(255,255,255,.08);
      background:rgba(255,255,255,.04);transition:opacity .35s;
    }
    .prog-now-badge{
      font-family:"Orbitron",sans-serif;font-size:7px;letter-spacing:3px;
      color:var(--pink);margin-bottom:5px;display:flex;align-items:center;gap:6px;
    }
    .pnbdot{
      width:6px;height:6px;border-radius:50%;
      background:var(--pink);box-shadow:0 0 6px var(--pink);
      animation:dotPulse 1.1s infinite;flex-shrink:0;
    }
    .prog-now-name{
      font-family:"Orbitron",sans-serif;font-size:13px;font-weight:700;
      color:#fff;margin-bottom:3px;
      white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
    }
    .prog-now-time{
      font-family:"Orbitron",sans-serif;font-size:9px;letter-spacing:1px;
      color:var(--cyan);margin-bottom:3px;
    }
    /* ── PROGRAMACIÓN SEMANAL — NUEVO DISEÑO ── */

    /* Barra de días */
    .sched-days{display:flex;gap:5px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;margin-bottom:16px;scrollbar-width:none;justify-content:center}
    .sched-days::-webkit-scrollbar{display:none}
    .dia-btn{
      font-family:"Orbitron",sans-serif;font-size:.42rem;font-weight:700;
      letter-spacing:1.2px;text-transform:uppercase;
      color:rgba(224,224,255,.5);background:rgba(255,255,255,.04);
      border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:5px 11px;
      cursor:pointer;transition:all .18s;white-space:nowrap;flex-shrink:0;
      -webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:26px;
    }
    .dia-btn:hover{color:rgba(224,224,255,.85);border-color:rgba(255,255,255,.25)}
    .dia-btn.active{color:#fff;background:var(--pink);border-color:var(--pink);box-shadow:0 0 14px rgba(255,45,120,.4)}

    /* ── VISOR ÚNICO ── */
    .sched-visor{
      position:relative;width:100%;height:92px;
      border-radius:14px;overflow:hidden;
      background:#07050f;
      border:1px solid rgba(0,245,255,.28);
      box-shadow:0 0 0 1px rgba(0,245,255,.08),0 0 22px rgba(0,245,255,.1),0 6px 32px rgba(0,0,0,.5);
    }
    /* topline oculta - el borde hace el trabajo */
    .sched-visor-topline{ display:none; }
    /* Fondo blur compartido */
    .sched-visor-bg{
      position:absolute;inset:0;width:100%;height:100%;
      object-fit:cover;object-position:center 20%;
      filter:brightness(.22) saturate(1.4) blur(3px);
      transition:opacity .55s ease;z-index:0;
    }
    .sched-visor-overlay{
      position:absolute;inset:0;z-index:1;pointer-events:none;
      background:linear-gradient(to right,rgba(4,2,12,.9) 0%,rgba(4,2,12,.5) 60%,rgba(4,2,12,.2) 100%),
                 linear-gradient(to top,rgba(4,2,12,.95) 0%,transparent 55%);
    }

    /* Paneles internos — todos el mismo tamaño, uno visible a la vez */
    .sched-panel{
      position:absolute;inset:0;z-index:2;
      display:flex;align-items:center;
      transition:opacity .25s ease;
    }
    .sched-panel-hidden{opacity:0;pointer-events:none}

    /* ── Panel 1: Carrusel ── */
    .sched-strip{
      display:flex;gap:0;
      position:absolute;top:0;left:0;height:100%;
      will-change:transform;
    }
    /* fades laterales del carrusel */
    .sched-fade-l,.sched-fade-r{
      position:absolute;top:0;bottom:0;width:48px;z-index:4;pointer-events:none;
    }
    .sched-fade-l{left:0;background:linear-gradient(90deg,rgba(4,2,12,.95),transparent)}
    .sched-fade-r{right:0;background:linear-gradient(270deg,rgba(4,2,12,.95),transparent)}
    /* Cards del carrusel */
    .sched-item{
      display:flex;align-items:center;gap:10px;
      padding:0 16px;height:92px;
      cursor:grab;flex-shrink:0;width:190px;
      border-right:1px solid rgba(255,255,255,.05);
      transition:background .15s;
      -webkit-tap-highlight-color:transparent;touch-action:manipulation;
      position:relative;
      user-select:none;-webkit-user-select:none;
    }
    .sched-item:active{cursor:grabbing}
    .sched-item:hover{background:rgba(255,255,255,.05)}
    .sched-item.active{background:rgba(255,45,120,.1)}
    .sched-item.now-playing::after{
      content:"AHORA";
      position:absolute;top:8px;left:50%;transform:translateX(-50%);
      font-family:"Orbitron",sans-serif;font-size:.38rem;letter-spacing:2px;
      color:#fff;background:var(--pink);
      padding:2px 7px;border-radius:8px;
      box-shadow:0 0 8px rgba(255,45,120,.6);pointer-events:none;
    }
    .sched-item.now-playing{border-top:2px solid var(--cyan);background:rgba(0,245,255,.07)}
    .sched-thumb{
      width:48px;height:48px;border-radius:8px;object-fit:cover;
      border:1px solid rgba(255,255,255,.08);flex-shrink:0;
    }
    .sched-item.active .sched-thumb{border-color:rgba(255,45,120,.45)}
    .sched-meta{min-width:0;flex:1}
    .sched-hora{font-family:"Orbitron",sans-serif;font-size:.48rem;color:rgba(0,245,255,.6);margin-bottom:3px;letter-spacing:.5px}
    .sched-item.now-playing .sched-hora{color:var(--pink)}
    .sched-name{font-family:"Orbitron",sans-serif;font-size:.58rem;font-weight:700;color:rgba(224,224,255,.82);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
    .sched-item.active .sched-name{color:#fff}

    /* ── Panel 2: Detalle del programa ── */
    #sched-panel-detail{flex-direction:row;align-items:center;padding:0;gap:0}
    .sched-detail-inner{display:flex;align-items:center;gap:12px;width:100%;padding:0 16px;height:100%;box-sizing:border-box}
    .sched-detail-thumb{width:58px;height:58px;border-radius:8px;object-fit:cover;border:1px solid rgba(0,245,255,.2);flex-shrink:0}
    .sched-detail-info{min-width:0;flex:1}
    .sched-detail-tags{display:flex;gap:5px;margin-bottom:4px;flex-wrap:wrap}
    .sched-tag-ahora{font-family:"Orbitron",sans-serif;font-size:.38rem;font-weight:700;letter-spacing:1.5px;color:#fff;background:var(--pink);padding:1px 6px;border-radius:4px;box-shadow:0 0 8px rgba(255,45,120,.6)}
    .sched-tag-genre{font-family:"Orbitron",sans-serif;font-size:.38rem;font-weight:700;letter-spacing:1.5px;color:rgba(0,245,255,.85);background:rgba(0,0,0,.4);border:1px solid rgba(0,245,255,.3);padding:1px 6px;border-radius:4px}
    .sched-detail-name{font-family:"Exo 2",sans-serif;font-size:clamp(.78rem,2vw,1.05rem);font-weight:900;text-transform:uppercase;letter-spacing:1.5px;color:#fff;-webkit-text-stroke:.5px rgba(0,245,255,.3);line-height:1.1;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .sched-detail-time{font-family:"Orbitron",sans-serif;font-size:.46rem;color:rgba(0,245,255,.6);letter-spacing:.8px;margin-bottom:2px}
    .sched-detail-desc{font-size:.65rem;color:rgba(224,224,255,.42);line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}
    /* hint tap en detalle */
    #sched-panel-detail::after{
      content:"TAP PARA VOLVER";
      position:absolute;bottom:5px;right:10px;
      font-family:"Orbitron",sans-serif;font-size:.32rem;letter-spacing:1.5px;
      color:rgba(0,245,255,.22);pointer-events:none;
    }

    /* ── Panel 3: HiFi ── */
    #sched-panel-hifi{padding:0 16px;overflow:hidden}
    #sched-panel-hifi .hifi-inner{display:grid;grid-template-columns:58px 1fr;gap:12px;align-items:center;width:100%;overflow:hidden}
    .hifi-art{width:62px;height:62px;border-radius:9px;object-fit:cover;border:1px solid rgba(0,245,255,.15);box-shadow:0 0 14px rgba(0,0,0,.7);flex-shrink:0;transition:opacity .45s ease}
    .hifi-info{min-width:0}
    .hifi-label{font-family:"Orbitron",sans-serif;font-size:6px;letter-spacing:1.5px;color:rgba(0,245,255,.5);margin-bottom:3px;overflow:hidden;white-space:nowrap}
    .hifi-title{font-family:"Orbitron",sans-serif;font-size:10px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 0 10px rgba(0,245,255,.2);margin-bottom:1px}
    .hifi-artist{font-size:.72rem;color:var(--cyan);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:1px}
    .hifi-album{font-size:.58rem;color:rgba(224,224,255,.3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
    .hifi-time{font-family:"Orbitron",sans-serif;font-size:8px;color:rgba(0,245,255,.65);letter-spacing:.8px;margin-bottom:2px}
    .hifi-prog-bar{width:100%;height:3px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
    .hifi-prog-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--pink));width:0%;transition:width .8s linear}

    /* ── Botón HI·FI ── */
    .sched-hifi-row{display:flex;justify-content:center;margin-top:14px}
    .dial-hifi-btn{
      font-family:"Orbitron",sans-serif;font-size:8px;font-weight:900;
      letter-spacing:3px;text-transform:uppercase;
      color:rgba(0,245,255,.5);
      background:linear-gradient(180deg,#1a1a2e 0%,#0d0d1a 60%,#0a0a14 100%);
      border:1px solid rgba(0,245,255,.2);border-bottom:3px solid rgba(0,0,0,.6);
      border-radius:5px;padding:7px 16px 5px;
      cursor:pointer;box-shadow:0 4px 8px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.05);
      transition:all .1s;
      -webkit-tap-highlight-color:transparent;touch-action:manipulation;user-select:none;
    }
    .dial-hifi-btn:hover{color:var(--cyan);border-color:rgba(0,245,255,.45);box-shadow:0 4px 12px rgba(0,0,0,.7),0 0 8px rgba(0,245,255,.1)}
    .dial-hifi-btn:active{transform:translateY(2px);border-bottom-width:1px}
    .dial-hifi-btn.active{color:#0ff;background:linear-gradient(180deg,#0d1a2e 0%,#081018 100%);border-color:rgba(0,245,255,.6);box-shadow:0 2px 6px rgba(0,0,0,.7),0 0 14px rgba(0,245,255,.25),inset 0 1px 6px rgba(0,0,0,.5);text-shadow:0 0 8px rgba(0,245,255,.8)}

    /* ── legacy ocultos ── */
    .dial-readout-wrap,.dial-box,.dial-controls-row,.dial-days-row{display:none}
    .dial-arr{display:none!important}
    .prog-grid{display:none!important}
    .sched-banner{display:none!important}
    .sched-hifi-box{display:none!important}

    /* mobile */
    @media(max-width:860px){
      .sched-visor{height:80px}
      .sched-item{width:160px;padding:0 12px;height:80px}
      .sched-thumb{width:40px;height:40px}
      .sched-detail-thumb{width:64px;height:64px}
      #sched-panel-hifi .hifi-inner{grid-template-columns:54px 1fr;gap:12px}
      .hifi-art{width:54px;height:54px}
      .hifi-title{font-size:10px}
      .sched-detail-name{font-size:.82rem}
    }

        .hist-more{text-align:center;margin-top:32px}
    .hist-more-btn{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:13px 32px;font-family:"Exo 2",sans-serif;font-size:.88rem;font-weight:600;color:rgba(224,224,255,.7);cursor:pointer;transition:background .2s,color .2s;text-decoration:none}
    .hist-more-btn:hover{background:rgba(255,255,255,.12);color:#fff}
    @media(max-width:860px){
      .hist-card{flex:0 0 calc((100% - 20px) / 2);width:calc((100% - 20px) / 2)}
    }

    /* ── POPUP ── */
    #popup-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.82);backdrop-filter:blur(18px);display:none;align-items:center;justify-content:center;padding:24px}
    #popup-overlay.open{display:flex}
    #popup-box{
      background:linear-gradient(160deg,#130d22,#0a0714);
      border:1px solid rgba(0,245,255,.16);border-radius:22px;
      width:100%;max-width:620px;max-height:88vh;overflow:hidden;
      display:flex;flex-direction:column;
      box-shadow:0 0 100px rgba(0,245,255,.07),0 30px 80px rgba(0,0,0,.7);
      animation:popIn .28s cubic-bezier(.34,1.56,.64,1);
    }
    @keyframes spin{to{transform:rotate(360deg)}}
    @keyframes popIn{from{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:none}}
    .popup-head{display:flex;align-items:center;justify-content:space-between;padding:22px 26px 18px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}
    .popup-head h3{font-family:"Exo 2",sans-serif;font-size:1.1rem;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:#fff}
    .popup-head h3 span{color:var(--pink)}
    .popup-close{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;color:rgba(224,224,255,.55);transition:all .2s}
    .popup-close:hover{background:rgba(255,45,120,.2);color:var(--pink);border-color:var(--pink)}
    .popup-list{overflow-y:auto;padding:12px 26px 24px;flex:1}
    /* Paginación del historial */
    .popup-pager{display:flex;align-items:center;justify-content:center;gap:6px;padding:14px 26px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;flex-wrap:wrap}
    .popup-page-btn{font-family:'Orbitron',sans-serif;font-size:.58rem;font-weight:700;letter-spacing:1px;min-width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:rgba(224,224,255,.5);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0 8px}
    .popup-page-btn:hover{background:rgba(255,45,120,.15);border-color:rgba(255,45,120,.4);color:#fff}
    .popup-page-btn.active{background:rgba(255,45,120,.25);border-color:var(--pink);color:#fff}
    .popup-page-btn.arrow{font-size:.8rem;min-width:32px}
    .popup-page-btn:disabled,.popup-page-btn[disabled]{opacity:.25;cursor:default;pointer-events:none}
    .popup-24h-label{font-family:'Orbitron',sans-serif;font-size:.5rem;letter-spacing:2px;color:rgba(0,245,255,.6);padding:2px 10px;border:1px solid rgba(0,245,255,.2);border-radius:10px;margin-left:4px}
    .popup-list::-webkit-scrollbar{width:3px}
    .popup-list::-webkit-scrollbar-thumb{background:rgba(0,245,255,.25);border-radius:2px}
    .popup-item {
  display: flex;
  align-items: center;
  padding: 11px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  justify-content: space-between; /* 🔥 SEPARA IZQUIERDA DE DERECHA */
  gap: 0; /* 🚫 ELIMINA EL GAP ANTERIOR */
}
.popup-item:last-child {
  border-bottom: none;
}
.popup-num {
  font-family: "Orbitron", sans-serif;
  font-size: .55rem;
  color: rgba(224,224,255,.18);
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}
.popup-art {
  width: 50px;
  height: 50px;
  border-radius: 8px;
  object-fit: cover;
  border: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
  background: #1a0533;
  margin-left: 16px; /* 🔥 SEPARACIÓN NÚMERO - IMAGEN */
}
.popup-info {
  margin-left: 20px !important;/* limpiamos cualquier margen viejo */
  min-width: 0;
  flex: 1;
}
  .popup-title {
  font-size: .9rem;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
}
.popup-artist {
  font-size: .75rem;
  color: var(--cyan);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
}
.popup-time {
  flex-shrink: 0;
  text-align: right;
  min-width: 58px;
  margin-left: auto; /* 🔥 ESTO EMPUJA LA HORA A LA DERECHA */
}
.popup-clock {
  font-family: "Orbitron", sans-serif;
  font-size: .56rem;
  color: rgba(224,224,255,.28);
  display: block;
}
.popup-ago {
  font-size: .67rem;
  color: rgba(224,224,255,.2);
  margin-top: 3px;
  display: block;
}
    @media (max-width: 860px) {
  .popup-item {
    flex-wrap: wrap;
    justify-content: flex-start;
  }
  .popup-time {
    width: 100%;
    text-align: right;
    margin-left: 0;
    padding-left: 64px;
    margin-top: 6px;
    border-top: 1px solid rgba(255,255,255,.04);
    padding-top: 6px;
    min-width: auto;
  }
}



    footer{text-align:center;padding:30px;border-top:1px solid rgba(255,255,255,.05);font-size:.72rem;color:rgba(224,224,255,.18);letter-spacing:2px}
    footer strong{color:var(--cyan)}

    /* ── PLAYER BAR ── */
    #player-bar{
      position:fixed;bottom:0;left:0;right:0;
      height:var(--ph);
      background:rgba(5,3,12,.97);
      border-top:1px solid rgba(0,245,255,.15);
      box-shadow:0 -6px 40px rgba(0,245,255,.06);
      z-index:300;
      display:flex;flex-direction:column;
      overflow:hidden;
      /* Forzar GPU layer propio — crítico para Android Chrome */
      transform:translateZ(0);
      -webkit-transform:translateZ(0);
      will-change:transform;
      -webkit-backface-visibility:hidden;
      backface-visibility:hidden;
    }
    /* ── Visualizador onda mobile ── */
    #bar-viz-canvas{
      position:absolute;inset:0;width:100%;height:100%;
      z-index:0;pointer-events:none;
      opacity:.35;
    }
    .bar-prog-track{width:100%;height:4px;background:rgba(255,255,255,.08);flex-shrink:0;position:relative;z-index:1}
    .bar-prog-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--pink));width:0%}
    .bar-inner{display:flex;align-items:center;padding:0 28px;gap:22px;flex:1;position:relative;z-index:1}
    #bar-art-wrap{width:66px;height:66px;border-radius:10px;flex-shrink:0;background-color:#0a0618;background-image:url('/icon-512.png');background-size:50%;background-repeat:no-repeat;background-position:center;box-shadow:0 4px 20px rgba(0,0,0,.6);overflow:hidden;border:1px solid rgba(255,255,255,.12)}
    #bar-art{width:66px;height:66px;border-radius:10px;object-fit:cover;display:block;transition:opacity .5s ease}
    .bar-info{flex:1;min-width:0}
    .bar-track{font-size:1.08rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}
    .bar-artist{font-size:.86rem;color:var(--cyan);font-weight:500;margin-bottom:4px}
    .bar-times{font-family:"Orbitron",sans-serif;font-size:.58rem;color:rgba(224,224,255,.28);display:flex;gap:6px}
    .bar-controls{display:flex;align-items:center;gap:16px;flex-shrink:0}
    #bar-play-btn{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--purple));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 0 22px rgba(255,45,120,.4);transition:transform .12s,box-shadow .12s}
    #bar-play-btn:hover{transform:scale(1.07);box-shadow:0 0 36px rgba(255,45,120,.65)}
    #bar-play-btn:active{transform:scale(.91)}
    #bar-play-btn.pulse{animation:barPress .25s ease-out}
    @keyframes barPress{0%{transform:scale(1)}30%{transform:scale(.88)}70%{transform:scale(1.08)}100%{transform:scale(1)}}
    #bar-play-btn:hover{transform:scale(1.07);box-shadow:0 0 36px rgba(255,45,120,.65)}
    #bar-play-btn svg{width:24px;height:24px;fill:white}
    .bar-vol{display:flex;align-items:center;gap:9px}
    .bar-live{font-family:"Orbitron",sans-serif;font-size:.6rem;letter-spacing:3px;color:var(--pink);display:flex;align-items:center;gap:5px}

    /* ── PLAYER EXPANDIDO PC (prueba piloto) ── */
    @media(min-width:861px){
      /* Ocultar player original en PC */
      #player-bar{ display:none !important; }
      /* Mostrar player expandido */
      #player-bar-pc{ display:flex !important; }
    }
    #player-bar-pc{
      display:none;
      position:fixed;bottom:0;left:0;right:0;
      height:120px;
      background:rgba(5,3,12,.97);
      border-top:1px solid rgba(0,245,255,.18);
      box-shadow:0 -8px 48px rgba(0,245,255,.08);
      z-index:300;
      flex-direction:column;
      transform:translateZ(0);-webkit-transform:translateZ(0);
      will-change:transform;-webkit-backface-visibility:hidden;backface-visibility:hidden;
    }
    /* ── Visualizador de onda en la bandeja ── */
    #ppc-viz-canvas{
      position:absolute;inset:0;width:100%;height:100%;
      z-index:0;pointer-events:none;
      opacity:.55;
    }
    #ppc-prog-track{width:100%;height:4px;background:rgba(255,255,255,.08);flex-shrink:0;position:relative;z-index:1}
    #ppc-prog-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--pink));width:0%}
    #ppc-inner{display:flex;align-items:center;padding:0 24px;gap:16px;flex:1;min-width:0;height:116px;position:relative;z-index:1}
    /* Sección centro — info + tiempo */
    #ppc-center{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
    #ppc-track-row{display:flex;align-items:baseline;gap:10px;min-width:0}
    /* Sección derecha — controles */
    #ppc-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
    /* Oyentes estilo Spotify */
    #ppc-listeners-wrap{display:flex;align-items:center;gap:8px;padding:0 14px;border-left:1px solid rgba(255,255,255,.08);border-right:1px solid rgba(255,255,255,.08)}
    #ppc-listeners-dot{width:8px;height:8px;border-radius:50%;background:var(--pink);flex-shrink:0;animation:livePulse 1.5s ease-in-out infinite}
    #ppc-listeners-label{font-family:"Orbitron",sans-serif;font-size:.38rem;letter-spacing:2px;color:rgba(255,255,255,.35);display:flex;flex-direction:column;align-items:center;gap:1px}
    #ppc-listeners-num{font-family:"Orbitron",sans-serif;font-size:.72rem;font-weight:700;color:#fff}
    /* Tema toggle */
    #theme-toggle-btn{background:none;border:1px solid rgba(255,255,255,.15);border-radius:50%;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .25s;color:rgba(255,255,255,.4);font-size:1rem;padding:0}
    #theme-toggle-btn:hover{border-color:rgba(255,215,0,.4);color:#ffd700}

    /* Carátula — sobresale levemente por arriba del player */
    #ppc-art{
      width:96px;height:96px;
      border-radius:16px;
      object-fit:cover
      transition:opacity .5s ease;;
      border:2px solid rgba(255,255,255,.18);
      background:#1a0533;
      flex-shrink:0;
      box-shadow:0 -6px 28px rgba(0,0,0,.8),0 4px 20px rgba(0,0,0,.6),0 0 0 1px rgba(0,245,255,.1);
      margin-top:-8px;
    }

    /* Info zona */
    #ppc-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
    #ppc-track{font-size:1.05rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    #ppc-artist{font-size:.88rem;color:var(--cyan);font-weight:500}
    #ppc-album{font-size:.72rem;color:rgba(224,224,255,.45);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    #ppc-meta{
      font-family:"Orbitron",sans-serif;font-size:.54rem;
      color:rgba(224,224,255,.55);
      letter-spacing:.8px;
      display:flex;align-items:center;gap:8px;
      margin-top:2px;
    }
    #ppc-meta span{
      background:rgba(255,255,255,.06);
      border:1px solid rgba(255,255,255,.1);
      border-radius:4px;padding:1px 7px;
    }

    /* Tiempo — más visible */
    #ppc-times{
      font-family:"Orbitron",sans-serif;
      font-size:.65rem;
      color:rgba(224,224,255,.75);
      display:flex;align-items:center;gap:5px;
      flex-shrink:0;white-space:nowrap;
    }
    #ppc-times .ppc-sep{color:rgba(224,224,255,.3)}

    /* Botón play */
    #ppc-play-btn{
      width:58px;height:58px;border-radius:50%;
      background:linear-gradient(135deg,var(--pink),var(--purple));
      border:none;cursor:pointer;
      display:flex;align-items:center;justify-content:center;
      box-shadow:0 0 24px rgba(255,45,120,.45);
      transition:transform .12s,box-shadow .12s;
      flex-shrink:0;
    }
    #ppc-play-btn:hover{transform:scale(1.07);box-shadow:0 0 38px rgba(255,45,120,.7)}
    #ppc-play-btn:active{transform:scale(.91)}
    #ppc-play-btn svg{width:26px;height:26px;fill:white}

    /* Vol y live */
    #ppc-vol{display:flex;align-items:center;gap:9px}
    #ppc-live{font-family:"Orbitron",sans-serif;font-size:.6rem;letter-spacing:3px;color:var(--pink);display:flex;align-items:center;gap:5px}

    @media(max-width:860px){
      :root{--ph:90px}
      #hero{padding-top:calc(64px + var(--mundial-h))}
      .hero-content{flex-direction:column;text-align:center;gap:28px;padding:28px 20px 36px;align-items:center}
      .tt-wrap{width:260px;height:260px;margin-left:0;}
      /* Brazo escalado para 260px — pua queda sobre el disco, no en el centro */
      .tonearm{
        width:56px!important;height:120px!important;
        top:-6px!important;right:-6px!important;
        transform-origin:13px 13px!important;
        transform:rotate(-22deg)!important;
      }
      .tt-wrap.playing .tonearm{transform:rotate(12deg)!important}
      .arm-pivot{width:26px!important;height:26px!important}
      .arm-rod{top:11px!important;left:12px!important;width:3px!important;height:92px!important}
      .arm-head{width:12px!important;height:16px!important;bottom:-3px!important}
      .arm-needle{height:9px!important;bottom:-8px!important}
      .ring:nth-child(1){inset:-14px}
      .ring:nth-child(2){inset:-28px}
      .ring:nth-child(3){inset:-42px}
      .ring:nth-child(4){inset:-56px}
      .trivia-box{max-width:100%;margin-bottom:16px!important}
      nav ul,.hero-vol{display:none}
      /* Logo mobile — circular */
      .logo-desktop{display:none!important}
      .logo-mobile{display:block!important}
      .hero-actions{justify-content:center}
      /* Título en mobile: más chico para evitar 3 líneas */
      .hero-title{font-size:clamp(1.6rem,7.5vw,2.4rem)!important;line-height:1.1!important;
        max-height:3em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
      .hero-artist{font-size:clamp(1rem,5vw,1.3rem)!important;margin-bottom:14px!important}
      /* Área de info fija para que los botones no salten */
      .hero-info{display:flex;flex-direction:column}
      .prog-wrap{margin-bottom:14px!important}
      .prog-now-panel{grid-template-columns:76px 1fr;gap:10px;padding:11px}
      .prog-now-thumb{width:76px;height:56px}
      .prog-now-name{font-size:11px}
      .prog-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px}
      /* Programación mobile */
      .sched-days{justify-content:flex-start;gap:6px}
      .dia-btn{padding:7px 14px;font-size:.48rem;letter-spacing:1.5px}
      .sched-item{min-width:180px;max-width:200px;padding:12px 14px;gap:10px}
      .sched-item:first-child{padding-left:16px}
      .sched-item:last-child{padding-right:16px}
      .sched-thumb{width:44px;height:44px}
      .sched-name{max-width:120px;font-size:.65rem}
      .sched-banner-content{padding:16px 18px 16px}
      .sched-banner-name{font-size:clamp(1.1rem,5vw,1.5rem)}
      .sched-banner{min-height:150px}
      .hifi-art{width:52px;height:52px}
      .hifi-title{font-size:10px}
      .dial-hifi-btn{font-size:7px;padding:6px 10px 4px;letter-spacing:1.5px}
      #play-btn{min-width:160px!important;width:160px!important;font-size:.85rem!important;padding:12px 20px!important}
      .slogan-section{height:44px}
      .slogan-80s{-webkit-text-stroke-width:2px}
      #bar-art-wrap{width:52px;height:52px}
      #bar-art{width:52px;height:52px}
      .bar-track{font-size:.9rem}
      .bar-artist{font-size:.76rem}
      .bar-vol{display:none}
      /* Nav mobile: solo logo + ícono pedir + oyentes */
      nav{padding:0 10px;gap:4px}
      #nav-request-btn{padding:7px 9px!important;gap:0!important;border-radius:50%!important;width:36px;height:36px;justify-content:center;flex-shrink:0}
      .req-btn-label{display:none!important} /* solo ícono en mobile */
      /* Weather mobile: solo icono, sin temperatura */
      #weather-widget{padding:4px 7px!important;gap:2px!important}
      #weather-temp{display:none!important}
      #weather-deg{display:none!important}
      #weather-icon{font-size:.9rem!important}
      /* ON AIR badge mobile: solo punto + número, sin texto */
      #listeners-badge{padding:5px 8px!important;gap:4px!important}
      #listeners-badge .onair-text{display:none!important}
      #listeners-badge .onair-sep{display:none!important}
      #listeners-badge .onair-headphone{display:none!important}
      #listener-count{min-width:14px!important;font-size:.68rem!important}
      #autodj-banner{font-size:.6rem}
      .autodj-text{display:none}
      #bar-play-btn{width:48px;height:48px}
      .bar-inner{padding:0 16px;gap:14px}
      /* Secciones mobile sin overflow */
      .section{padding:0 16px 48px;overflow:hidden}
      .sec-block::before{height:2px}
      /* Top Hits mobile: apilar hero arriba centrado, lista abajo */
      .top-layout{grid-template-columns:1fr!important;justify-items:center}
      .top-layout{max-width:100%!important;grid-template-columns:1fr!important}
      .top-layout > div:first-child{width:100%;max-width:320px;margin:0 auto}
      .top-hero-card{width:100%!important;height:auto!important;min-height:0!important;aspect-ratio:1/1}
      .top-list-v{width:100%;max-width:320px;margin:0 auto}
      /* Popup request mobile */
      #request-popup{padding:0}
      #request-box{border-radius:0;max-width:100%;max-height:100vh;max-height:100dvh}
      /* Popups artista/tema mobile */
      #popup-box{border-radius:14px}
      #trivia-popup-inner{border-radius:14px}
      #track-popup-inner{border-radius:14px}
      /* Botones touch — área mínima 44px */
      .btn-icon{min-width:44px;min-height:44px}
      .dial-arr{min-width:44px;min-height:44px}
      .dia-btn{min-height:36px}
      /* Player bar mobile */
      #player-bar{padding-bottom:env(safe-area-inset-bottom)}
      /* Evitar zoom en inputs iOS */
      input,select,textarea{font-size:16px!important}
      /* Historial 2 columnas mobile */
      .hist-card{flex:0 0 calc((100% - 20px)/2)!important;width:calc((100% - 20px)/2)!important}
      /* Sección hero sin padding-top extra en notch */
      #hero{padding-top:calc(max(64px, env(safe-area-inset-top)) + var(--mundial-h))}
      /* Nav safe area */
      nav{padding-left:max(12px, env(safe-area-inset-left));padding-right:max(12px, env(safe-area-inset-right))}
    }
    /* Ocultar nombre del programa en mobile */
    @media(max-width:860px){.playlist-tag{display:none!important}}

    /* iOS Safari — fix 100vh */
    @supports(-webkit-touch-callout:none){
      #request-box{max-height:-webkit-fill-available}
      #player-bar{padding-bottom:max(12px,env(safe-area-inset-bottom))}
    }
.vinyl-label{
  position:absolute;top:50%;left:50%;
  width:38%;height:38%;
  transform:translate(-50%,-50%);
  border-radius:50%;
  overflow:hidden;
  z-index:1;
  box-shadow:0 0 0 3px rgba(0,0,0,.6);
}
.vinyl-label img{width:100%;height:100%;object-fit:cover;display:block}
#np-art{position:relative;z-index:2}
