/* Extracted inline CSS (safe) */


/* === Chat === */

    .hidden{display:none!important}
    /* ===== Chat quick styles + emoji ===== */
    .chat-card{ margin-top:28px; }
    .chat-head{ display:flex; align-items:center; justify-content:space-between; padding:10px 14px; }
    .chat-box{
      height: 360px; overflow-y: auto; padding:16px 18px;
      background: rgba(9,10,20,.55); border-radius:16px; box-shadow: inset 0 0 0 1px rgba(255,255,255,.05);
    }
    .msg{ display:flex; gap:10px; margin:10px 0; align-items:flex-start; }
    .badge{ width:28px; height:28px; border-radius:50%; display:grid; place-items:center; background:#9333ea; color:#fff; font-size:13px; }
    .bubble{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); padding:10px 12px; border-radius:12px; max-width: 80%;
             font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji","Twemoji Mozilla","Segoe UI Symbol",system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif; }
    .meta{ color:#93c5fd; font-size:12px; display:block; margin-bottom:2px; }

    .chat-form{ display:flex; align-items:center; gap:8px; padding:10px; position:relative; }
    .chat-input{ flex:1; height:44px; border-radius:12px; padding:0 14px; border:1px solid rgba(255,255,255,.08); background:rgba(6,8,16,.6); color:#e6f8ff;
                 font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji","Twemoji Mozilla","Segoe UI Symbol",system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif; }
    .btn{ height:44px; border-radius:12px; padding:0 14px; }
    .btn--primary{ background:linear-gradient(90deg, rgba(124,58,237,.35), rgba(34,211,238,.28)); border:1px solid rgba(124,58,237,.5) }
    .emoji-btn{ width:44px; display:grid; place-items:center; }
    .emoji-panel{
      position:absolute; right:64px; bottom:56px; width:320px; padding:8px;
      background: rgba(7,10,18,.98); border:1px solid rgba(255,255,255,.08); border-radius:12px;
      box-shadow: 0 20px 40px rgba(0,0,0,.45); display:none; z-index: 50;
      font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji","Twemoji Mozilla","Segoe UI Symbol",system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
    }
    .emoji-panel.open{ display:block; }
    .emoji-grid{ display:grid; grid-template-columns: repeat(10, 1fr); gap:6px; font-size:20px; }
    .emoji-item{ cursor:pointer; border-radius:6px; padding:6px; text-align:center; }
    .emoji-item:hover{ background:rgba(255,255,255,.08); }

    /* ===== Auth modal ===== */
    .auth-overlay{position:fixed; inset:0; background:rgba(6,8,16,.8); backdrop-filter:blur(4px);
                  display:none; align-items:center; justify-content:center; z-index:9999}
    .auth-overlay.show{display:flex}
    .auth-card{width:min(520px,92vw); background:rgba(14,16,32,.95); border:1px solid rgba(255,255,255,.08);
               border-radius:16px; box-shadow:0 30px 70px rgba(0,0,0,.45); padding:18px}
    .auth-head{display:flex; gap:10px; align-items:center; justify-content:space-between; margin-bottom:8px}
    .auth-tabs{display:flex; gap:8px}
    .auth-tab{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); padding:8px 12px; border-radius:10px; cursor:pointer}
    .auth-tab.active{background:linear-gradient(90deg, rgba(124,58,237,.25), rgba(34,211,238,.18)); border-color:rgba(124,58,237,.45)}
    .auth-form{display:none; gap:10px; margin-top:8px}
    .auth-form.show{display:grid}
    .auth-form label{font-size:.9rem; margin-top:6px; color:#cfe7ff}
    .auth-form input{height:44px; border-radius:10px; border:1px solid rgba(255,255,255,.08); background:rgba(6,8,16,.6); color:#e6f8ff; padding:0 12px}
    .auth-actions{display:flex; gap:8px; align-items:center; margin-top:10px}
    .auth-msg{color:#fda4af; font-size:.9rem; min-height:1.2rem}
  
/* === Cassette speaker (legacy reset) === */

    /* Fix VU canvas explicit size and namespace speaker to avoid clashes */.vu-speaker{ --g:.25; width:190px; height:190px; border-radius:50%; position:relative; display:grid; place-items:center;
      background:radial-gradient(60% 60% at 50% 50%, #0b0b12 0%, #101022 45%, #0a0a14 70%, #070711 100%);
      box-shadow:0 0 calc(26px + 44px * var(--g)) rgba(255,43,106,.42),0 0 calc(16px + 34px * var(--g)) rgba(124,58,237,.30),inset 0 0 14px rgba(0,0,0,.6);
    }
    .vu-speaker.vibe::after{content:""; position:absolute; inset:-10px; border-radius:50%; pointer-events:none;
      box-shadow:0 0 calc(16px + 36px * var(--g)) rgba(34,211,238,.24),0 0 calc(28px + 48px * var(--g)) rgba(255,43,106,.26),0 0 calc(20px + 38px * var(--g)) rgba(124,58,237,.22);
    }
    @media (max-width:930px){ .vu-wrap{ grid-template-columns:1fr; gap:16px } .vu-speaker{ margin:0 auto } }
  
/* === Cassette scoped layout (marquee, vu) === */

    /* ===== Scoped fixes for cassette/player ===== */
    .cassette { position: relative; }
    .cassette .transport { display:flex; gap:16px; justify-content:center; margin:12px 0 8px }
    .cassette .marquee{position:relative; overflow:hidden; height:26px; max-width:720px; margin:8px auto 10px; border-radius:10px;
      background:rgba(20,20,35,.45); box-shadow:inset 0 0 0 1px rgba(255,255,255,.05),0 6px 18px rgba(124,58,237,.18)}
    .cassette .marquee .track{ position:absolute; white-space:nowrap; padding-left:100%; animation:cassette-mrun 14s linear infinite }
    .cassette .marquee span{ display:inline-block; padding:0 26px; line-height:26px; font-size:13px; color:#dff9ff;
      text-shadow:0 0 8px rgba(34,211,238,.35),0 0 14px rgba(255,43,106,.25) }
    @keyframes cassette-mrun { from{ transform:translateX(0) } to{ transform:translateX(-100%) } }

    .cassette .vol-row{ display:flex; align-items:center; justify-content:center; gap:10px; margin:4px 0 8px }
    .cassette .vol-row svg{ width:20px; height:20px; fill:#c7f9ff; filter:drop-shadow(0 0 6px rgba(34,211,238,.35)) }
    .cassette .volume{ width:640px; max-width:88vw }

    .cassette .vu-wrap{ display:grid; grid-template-columns:220px 1fr 220px; align-items:center; gap:32px; margin:14px auto 4px; width:min(1120px,95%) }
    .cassette .speaker{ --g:.25; width:190px; height:190px; border-radius:50%; position:relative; display:grid; place-items:center;
      background:radial-gradient(60% 60% at 50% 50%, #0b0b12 0%, #101022 45%, #0a0a14 70%, #070711 100%);
      box-shadow:0 0 calc(26px + 44px * var(--g)) rgba(255,43,106,.42),0 0 calc(16px + 34px * var(--g)) rgba(124,58,237,.30),inset 0 0 14px rgba(0,0,0,.6) }
    .cassette .speaker.vibe::after{ content:""; position:absolute; inset:-10px; border-radius:50%; pointer-events:none;
      box-shadow:0 0 calc(16px + 36px * var(--g)) rgba(34,211,238,.24),0 0 calc(28px + 48px * var(--g)) rgba(255,43,106,.26),0 0 calc(20px + 38px * var(--g)) rgba(124,58,237,.22) }

    .cassette .vu{ min-height:190px; padding:18px 20px 20px; display:flex; flex-direction:column; justify-content:flex-end; align-items:center;
      border-radius:14px; border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.02) }
    .cassette .vu .vu-title{ margin:0 0 10px }
    .cassette .vu-bars{ display:flex; gap:24px; align-items:flex-end; justify-content:center; width:100% }
    .cassette .vu-bars canvas{ width:46%; height:170px; border-radius:8px; background:rgba(255,255,255,.03) }

    @media (max-width:930px){
      .cassette .vu-wrap{ grid-template-columns:1fr; gap:16px }
      .cassette .speaker{ margin:0 auto }
      .cassette .volume{ width:88vw }
    }

    /* neutraliza icon-fonts globales solo para pseudo elementos */
    .cassette .speaker::before, .cassette .speaker::after{ content:none !important; font-size:initial !important; font-family:initial !important }
  
  


    /* === Restore LIVE badge === */
    .cassette .cassette-head{ display:flex; justify-content:flex-start; }
    .cassette .live-badge{
      display:inline-flex; align-items:center; gap:8px; padding:6px 14px;
      border-radius:999px; font-weight:700; letter-spacing:.02em;
      color:#fff; background:rgba(255, 43, 106, .15);
      box-shadow:0 0 0 1px rgba(255,255,255,.06), 0 0 22px rgba(255, 43, 106, .45);
    }
    .cassette .live-dot{
      width:10px; height:10px; border-radius:50%; background:#ff2b6a;
      box-shadow:0 0 10px #ff2b6a, 0 0 18px rgba(255,43,106,.65);
      animation: livePulse 1.6s ease-in-out infinite;
    }
    @keyframes livePulse { 0%,100%{ transform:scale(1); opacity:1 } 50%{ transform:scale(1.35); opacity:.7 } }

    /* === Restore Transport buttons === */
    .cassette .transport{ display:flex; gap:12px; justify-content:center; margin:10px 0 6px }
    .cassette .btn-ctrl{
      width:44px; height:44px; border-radius:12px; cursor:pointer;
      display:grid; place-items:center;
      border:1px solid rgba(255,255,255,.12);
      background:rgba(255,255,255,.06);
      box-shadow:inset 0 0 0 1px rgba(255,255,255,.03), 0 6px 18px rgba(0,0,0,.25);
    }
    .cassette .btn-ctrl:hover{ filter:brightness(1.05) }
    .cassette .btn-ctrl:active{ transform:translateY(1px) }

    /* Icons inside the transport */
    .cassette #playIcon{ width:0; height:0; border-top:10px solid transparent; border-bottom:10px solid transparent;
                         border-left:16px solid #e5efff; filter:drop-shadow(0 0 8px rgba(34,211,238,.35)); margin-left:2px; }
    .cassette .icon-pause-bar{ display:inline-block; width:4px; height:16px; background:#e5efff; border-radius:2px;
                               box-shadow:0 0 8px rgba(34,211,238,.35) }
    .cassette .stop-icon{ width:14px; height:14px; background:#e5efff; border-radius:3px; box-shadow:0 0 8px rgba(34,211,238,.35) }
  


    /* ==== Header tweaks (scoped) ==== */
    .topbar.topbar--grid{
      display:grid;
      grid-template-columns:auto 1fr auto;
      align-items:center;
      column-gap:22px;
      padding:18px 28px;
      min-height:92px; /* thicker header */
    }
    .topbar .brand-link .logo{
      height:56px; /* bigger logo */
    }
    .topbar .dial{
      font-size:28px; /* bigger dial */
      font-weight:800;
      padding:6px 14px;
      border-radius:12px;
      box-shadow:0 0 0 1px rgba(255,255,255,.08), 0 8px 22px rgba(255,0,128,.25);
    }
    /* Desktop upsizing */
    @media (min-width: 1200px){
      .topbar .brand-link .logo{ height:64px; }
      .topbar .dial{ font-size:32px; padding:8px 16px; }
      .topbar.topbar--grid{ min-height:104px; padding:20px 36px; column-gap:28px; }
    }
    /* Mobile safeguards */
    @media (max-width: 640px){
      .topbar.topbar--grid{
        grid-template-columns: auto 1fr auto;
        padding:14px 16px;
        min-height:78px;
      }
      .topbar .brand-link .logo{ height:48px; }
      .topbar .dial{ font-size:22px; padding:6px 10px; }
    }
  


    /* Digital clock on the right side of the cassette head */
    .cassette .cassette-head{
      display:flex;
      align-items:center;
      justify-content:space-between !important;
      gap: 12px;
    }
    .cassette .digital-clock{
      font-family: "Monoton", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
      font-size: 18px;
      letter-spacing: 1px;
      color:#e5efff;
      text-shadow:0 0 8px rgba(34,211,238,.6), 0 0 14px rgba(255,43,106,.35);
      padding:6px 10px;
      border-radius:10px;
      background:rgba(255,255,255,.04);
      border:1px solid rgba(255,255,255,.08);
    }
    @media (min-width: 900px){
      .cassette .digital-clock{ font-size: 20px; padding:8px 12px; }
    }
  


    /* Clock format: (HH:MMH) with blinking colon */
    .cassette .digital-clock .blink{
      display:inline-block;
      animation: clock-blink 1s steps(2, start) infinite;
    }
    @keyframes clock-blink { to { visibility: hidden; } }
  


    /* Digital clock — neon blue, no parentheses */
    .cassette .digital-clock{
      font-family: "Orbitron", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace !important;
      font-weight: 700;
      font-size: 22px;
      letter-spacing: 1px;
      color: #7dd3fc;
      text-shadow:
        0 0 6px rgba(34,211,238,.75),
        0 0 12px rgba(34,211,238,.45),
        0 0 22px rgba(124,58,237,.35);
      padding:6px 10px;
      border-radius:10px;
      background:rgba(255,255,255,.03);
      border:1px solid rgba(255,255,255,.08);
    }
    @media (min-width: 900px){
      .cassette .digital-clock{ font-size: 24px; padding:8px 12px; }
    }
    .cassette .digital-clock .blink{
      display:inline-block;
      animation: clock-blink 1s steps(2, start) infinite;
    }
    @keyframes clock-blink { to { visibility: hidden; } }
  


    /* ==== Footer: collaborators ==== */
    .site-footer{
      margin-top: 40px;
      padding: 32px 20px 22px;
      background: linear-gradient(180deg, rgba(10,12,22,.4), rgba(10,12,22,.75));
      border-top: 1px solid rgba(255,255,255,.08);
      box-shadow: 0 -10px 30px rgba(0,0,0,.35) inset;
    }
    .site-footer .partners{
      max-width: 1200px;
      margin: 0 auto 18px;
    }
    .site-footer .partners h3{
      margin: 0 0 14px;
      font-size: 18px;
      letter-spacing: .08em;
      color: #dbeafe;
      text-transform: uppercase;
      opacity: .9;
    }
    .site-footer .logos{
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
      gap: 22px;
      align-items: center;
      justify-items: center;
    }
    .site-footer .logos a{ display: inline-flex; align-items: center; justify-content: center; padding: 8px 10px; }
    .site-footer .logos img{
      height: 56px;
      width: auto;
      object-fit: contain;
      filter: drop-shadow(0 0 6px rgba(124,58,237,.28)) drop-shadow(0 0 10px rgba(34,211,238,.18));
      opacity: .9;
      transition: transform .2s ease, opacity .2s ease, filter .2s ease;
    }
    .site-footer .logos img:hover{
      transform: scale(1.05);
      opacity: 1;
      filter: drop-shadow(0 0 10px rgba(124,58,237,.38)) drop-shadow(0 0 16px rgba(34,211,238,.28));
    }
    .site-footer .footer-bottom{
      max-width: 1200px;
      margin: 12px auto 0;
      padding-top: 12px;
      border-top: 1px dashed rgba(255,255,255,.08);
      color: #cbd5e1;
      text-align: center;
      font-size: 14px;
      opacity: .9;
    }
    @media (min-width: 1100px){
      .site-footer .logos img{ height: 64px; }
    }
    @media (max-width: 520px){
      .site-footer .logos{ grid-template-columns: repeat(2, minmax(120px, 1fr)); }
      .site-footer .logos img{ height: 48px; }
    }
  


    /* ===== Auth tabs vivid + close button ===== */
    .auth-card{ position:relative; }
    .auth-tabs .auth-tab{
      background: linear-gradient(90deg, rgba(124,58,237,.45), rgba(34,211,238,.35));
      border: 1px solid rgba(124,58,237,.65);
      color:#e6f8ff;
      box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset, 0 6px 16px rgba(124,58,237,.25);
      transition: filter .15s ease, transform .1s ease, box-shadow .15s ease;
    }
    .auth-tabs .auth-tab:hover{ filter:brightness(1.1) }
    .auth-tabs .auth-tab.active{
      background: linear-gradient(90deg, rgba(124,58,237,.75), rgba(34,211,238,.55));
      border-color: rgba(124,58,237,.9);
      box-shadow: 0 0 0 1px rgba(255,255,255,.08) inset, 0 10px 24px rgba(34,211,238,.28);
    }
    .auth-close{
      position:absolute; top:10px; right:10px;
      width:34px; height:34px; border-radius:10px;
      background:rgba(255,255,255,.06);
      border:1px solid rgba(255,255,255,.12);
      color:#e5efff; display:grid; place-items:center;
      font-size:18px; line-height:1; cursor:pointer;
      box-shadow: 0 8px 18px rgba(0,0,0,.35);
      transition: filter .15s ease, transform .1s ease;
    }
    .auth-close:hover{ filter:brightness(1.1) }
    .auth-close:active{ transform:translateY(1px) }
  


    /* === Hamburger base styles (desktop hidden) === */
    .hamburger{
      display:none;
      width:42px; height:38px; border-radius:10px;
      align-items:center; justify-content:center; gap:4px;
      background:rgba(255,255,255,.06);
      border:1px solid rgba(255,255,255,.12);
      cursor:pointer;
      box-shadow: 0 8px 18px rgba(0,0,0,.35);
    }
    .hamburger .bar{
      display:block; width:22px; height:2px; border-radius:2px;
      background:#e6f8ff; box-shadow:0 0 8px rgba(34,211,238,.35);
    }
    .hamburger .bar + .bar{ margin-top:5px; }
  


    html, body { width:100%; max-width:100%; overflow-x:hidden; }
    img, canvas, svg { max-width:100%; height:auto; }
    main, .card, .section, .cassette, .chat-card { max-width:100%; }
    .cassette, .chat-card { width: min(1200px, 100%); margin-inline:auto; }
    * { box-sizing: border-box; }

    .cassette .marquee{ max-width:100% !important; }
    .cassette .volume{ width:100% !important; }

    @media (max-width: 540px){
      .cassette .vu-wrap{ grid-template-columns: 1fr !important; gap:16px !important; width:100% !important; }
      .cassette .speaker{ width:140px !important; height:140px !important; margin-inline:auto; }
      .cassette .vu-bars{ gap:14px !important; }
      .cassette .vu-bars canvas{ width:48% !important; height:150px !important; }
    }

    @media (max-width: 390px){
      :root{ --safe-gap: 12px; }
      .card.section{ width: calc(100vw - var(--safe-gap)*2) !important; padding: clamp(10px, 3.2vw, 14px) !important; }
      .cassette .speaker{ width:120px !important; height:120px !important; }
      .cassette .vu-bars canvas{ height:130px !important; }
      .chat-card .chat-box{ height: 300px; }
    }

    @media (max-width: 480px){
      .topbar.topbar--grid{ grid-template-columns:auto 1fr auto; padding-inline:14px; }
      .topbar .brand-link .logo{ height:42px !important; }
      .topbar .dial{ font-size:20px !important; padding:4px 10px !important; }
    }
  



  /* ===== Reset seguro para evitar cortes ===== */
  *, *::before, *::after { box-sizing: border-box; }
  html, body { width:100%; max-width:100%; overflow-x:hidden; margin:0; background:#0b0c14; color:#eaf0ff; font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; }
  img, canvas, svg { max-width:100%; height:auto; display:block; }

  :root{
    --bg:#101225;
    --card:#141632;
    --muted:#9db0c7;
    --brand:#7c3aed;
    --cyan:#22d3ee;
    --rose:#ff2b6a;
    --radius:16px;
  }

  .player {
    width:min(100%, 780px);
    margin:20px auto;
    padding:16px;
    border-radius:var(--radius);
    background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
    box-shadow: 0 18px 50px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.06);
    backdrop-filter:saturate(1.1);
  }

  .row { display:flex; align-items:center; gap:12px; }
  .row.wrap { flex-wrap:wrap; }
  .between { justify-content:space-between; }
  .center  { justify-content:center; }

  .badge-live{
    display:inline-flex; align-items:center; gap:8px;
    padding:6px 12px; border-radius:999px;
    color:#ffd6e2; font-weight:700; letter-spacing:.3px;
    background:radial-gradient(80% 120% at 20% 20%, rgba(255,43,106,.35), rgba(124,58,237,.18));
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
    white-space:nowrap;
  }
  .badge-dot{ width:9px; height:9px; border-radius:50%; background:#ff3b7a; box-shadow:0 0 10px #ff3b7a; }

  .clock{
    font-family: "Monoton", system-ui, -apple-system, Segoe UI;
    font-size:22px; letter-spacing:1px; color:#a4e9ff;
    text-shadow:0 0 14px rgba(34,211,238,.55), 0 0 28px rgba(124,58,237,.4);
    padding:6px 10px; border-radius:12px;
    background:rgba(12,16,32,.45);
    border:1px solid rgba(255,255,255,.06);
    white-space:nowrap;
  }
  .blink{ animation:blink .9s steps(2) infinite; }
  @keyframes blink{ 50%{ opacity:0 } }

  .controls { gap:10px; margin:10px 0 6px; }
  .btn {
    width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
    background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.1); cursor:pointer;
  }
  .btn:active{ transform:translateY(1px) }
  .icon-play{ border:9px solid transparent; border-left-color:#e5efff; margin-left:4px; filter:drop-shadow(0 0 8px rgba(34,211,238,.35)); }
  .icon-pause { display:flex; gap:4px; }
  .icon-pause span{ display:inline-block; width:4px; height:16px; background:#e5efff; border-radius:2px; box-shadow:0 0 8px rgba(34,211,238,.35) }

  .marquee {
    position:relative; overflow:hidden; height:26px; border-radius:10px;
    background:rgba(20,20,35,.45); box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
    width:100%;
  }
  .track { position:absolute; white-space:nowrap; padding-left:100%; animation:mrun 14s linear infinite; }
  .track span { display:inline-block; padding:0 26px; line-height:26px; font-size:13px; color:#dff9ff; text-shadow:0 0 8px rgba(34,211,238,.35),0 0 14px rgba(255,43,106,.25) }
  @keyframes mrun{ from{ transform:translateX(0) } to{ transform:translateX(-100%) } }

  .volume-row{ gap:10px; }
  .volume{ width:100%; appearance:none; height:8px; border-radius:999px; background:rgba(255,255,255,.15); outline:none; }
  .volume::-webkit-slider-thumb{ appearance:none; width:18px; height:18px; border-radius:50%; background:#66d3ff; border:2px solid white; box-shadow:0 0 8px rgba(34,211,238,.5) }
  .volume::-moz-range-thumb   { width:18px; height:18px; border-radius:50%; background:#66d3ff; border:2px solid white; }

  .vu-card{ margin-top:10px; padding:14px; border-radius:14px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06); overflow:hidden; }
  .vu-title{ text-align:center; margin:0 0 10px; color:#cfe7ff; font-weight:700; letter-spacing:.4px; }
  .vu-bars{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; width:100%; overflow:hidden; }
  .vu-bars canvas{ width:100%; height:170px; background:rgba(255,255,255,.04); border-radius:10px; display:block; }

  /* ===== Diseño anti-corte para pantallas pequeñas =====*/
  .player, .row, .vu-bars { min-width:0; }
  .badge-live, .clock, .marquee, .volume { min-width:0; }

  /* Breakpoints fluidos */
  @media (max-width:560px){
    .clock{ font-size:20px; }
    .vu-bars canvas{ height:150px; }
  }
  @media (max-width:420px){
    .controls{ justify-content:center; }
    .clock{ font-size:18px; padding:6px 8px; }
    .vu-bars{ grid-template-columns: 1fr; }
    .vu-bars canvas{ width:100%; height:130px; }
  }



/* LIVE badge neon fix (external, safe) */
.player .badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 14px;border-radius:999px;font-weight:800;letter-spacing:.02em;
  color:#ffe9f1;background:radial-gradient(90% 140% at 20% 20%,rgba(255,43,106,.35),rgba(124,58,237,.12));
  box-shadow:0 0 0 1px rgba(255,255,255,.06),0 0 24px rgba(255,43,106,.45);white-space:nowrap;
}
.player .badge .dot{width:10px;height:10px;border-radius:50%;background:#ff2b6a;box-shadow:0 0 10px #ff2b6a,0 0 18px rgba(255,43,106,.6);animation:livePulse 1.6s ease-in-out infinite}
@keyframes livePulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.35);opacity:.85}}
