:root{
  --bg:#0b0d12;
  --text:#e9eefc;
  --muted:#a9b3cc;
  --accent:#f3c25b;          /* warm gold */
  --red1:#b01519;
  --red2:#5b0a0c;
  --line:rgba(255,255,255,.14);
  --panel: rgba(0,0,0,.50);

  /* Overlay geometry (tune to fit your jukebox PNG) */
  --p-top: 20%;
  --p-side: 16%;
  --panel-h: 30%;
  --p-bottom: 6%;

  --radius: 16px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: radial-gradient(1200px 600px at 50% 0%, rgba(255,180,80,.10), transparent 55%), var(--bg);
  color:var(--text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

a{color:inherit}

.app{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  padding:10px 10px 18px;
}
/* Mobile-only bands section (hidden on desktop) */
.mobile-bands{display:none;}


/* ===== Band buttons (mobile-first bar) ===== */
.bandbar{
  width:100%;
  max-width:1200px;
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding:4px 2px;
  scrollbar-width: none;
}
.bandbar::-webkit-scrollbar{display:none}

.bandbtn{
  flex:0 0 auto;
  text-decoration:none;
  font-size:12px;
  letter-spacing:.2px;
  padding:9px 12px;
  border-radius:999px;
  border:1px solid rgba(243,194,91,.28);
  background: linear-gradient(180deg, rgba(176,21,25,.85), rgba(91,10,12,.85));
  color: rgba(233,238,252,.92);
  backdrop-filter: blur(6px);
  box-shadow:
    0 8px 18px rgba(0,0,0,.35),
    0 0 0 1px rgba(255,255,255,.05) inset;
}
.bandbtn:hover{filter: brightness(1.04)}
.bandbtn:active{transform: translateY(1px)}
.bandbtn-add{
  border-style:dashed;
  opacity:.82;
}

/* ===== Stage ===== */
.stage{
  width:100%;
  max-width:1200px;
  position:relative;
  display:flex;
  justify-content:center;
  padding:2px 0;
}

.jukebox-frame{
  width:100%;
  max-width:980px;
  aspect-ratio: 16/9;
  background: url("../assets/jukebox.png") center / contain no-repeat;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.55));
}

/* Desktop side rails (hidden on mobile) */
.rail{display:none}

/* ===== UI overlay in the frame ===== */
.ui{
  position:absolute;
  inset:0;
  display:flex;
  justify-content:center;
  pointer-events:none;
}
.ui-inner{
  width:100%;
  max-width:980px;
  height:100%;
  position:relative;
  pointer-events:auto;
}

/* top controls sit inside the frame */
.top{
  position:absolute;
  left:var(--p-side);
  right:var(--p-side);
  top: calc(var(--p-top) - 44px);
  display:flex;
  gap:8px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}

.chip{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.30);
  backdrop-filter: blur(6px);
}
.chip-label{
  font-size:11px;
  letter-spacing:.6px;
  opacity:.85;
}
.chip-select{
  appearance:none;
  border:0;
  outline:0;
  background:transparent;
  color:var(--text);
  font-size:12px;
  padding:0 18px 0 0;
  cursor:pointer;
}
.chip-select option{color:#111}

.random{
  border:1px solid rgba(243,194,91,.34);
  background: linear-gradient(180deg, rgba(176,21,25,.70), rgba(91,10,12,.70));
  color: var(--text);
  padding:10px 14px;
  border-radius:999px;
  font-weight:700;
  letter-spacing:.7px;
  cursor:pointer;
}
.random:active{transform: translateY(1px)}

/* panel (list) */
.panel{
  position:absolute;
  left:var(--p-side);
  right:var(--p-side);
  top:var(--p-top);
  height:var(--panel-h);
  min-height:120px;
  max-height:230px;
  border-radius: var(--radius);
  background: var(--panel);
  border:1px solid rgba(255,255,255,.12);
  overflow:hidden;
}

.list{
  margin:0;
  padding:6px 0;
  list-style:none;
  height:100%;
  overflow:auto;
}
.list li{
  padding:6px 10px;
  border-bottom:1px solid rgba(255,255,255,.08);
  cursor:pointer;
}
.list li:last-child{border-bottom:0}

.track-line{
  font-size:12px;
  line-height:1.25;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color: rgba(233,238,252,.95);
}
.status{
  position:absolute;
  inset:auto 10px 8px 10px;
  font-size:11px;
  opacity:.75;
  pointer-events:none;
}
.muted{color:var(--muted)}

/* now playing under the panel */
.now{
  position:absolute;
  left:var(--p-side);
  right:var(--p-side);
  top: calc(var(--p-top) + var(--panel-h) + 12px);
  bottom: var(--p-bottom);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  text-align:center;
}

.now-line{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  white-space:nowrap;
  overflow:hidden;
}
.now-line > span{
  font-size:12px;
  color: rgba(233,238,252,.95);
}
.now-title, .now-artist, .now-year, .now-style{
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:35%;
}
.sep{opacity:.55}

.controls{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:center;
}
.btn{
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.28);
  color: rgba(233,238,252,.95);
  cursor:pointer;
  display:grid;
  place-items:center;
}
.btn svg{width:22px;height:22px}
#pauseIcon{display:none}
.play{
  width:52px;
  height:52px;
  border-color: rgba(243,194,91,.55);
  box-shadow: 0 0 0 2px rgba(243,194,91,.10) inset;
}

.seek{
  width:100%;
  max-width:420px;
  accent-color: var(--accent);
}

.meta{
  font-size:12px;
  opacity:.85;
}


/* ===== AdSense reserved area ===== */
.adsense-wrap{
  width:100%;
  display:flex;
  justify-content:center;
  padding: 10px 0 18px;
}
.adsense-slot{
  width:min(560px, 100%);
  min-height: 90px;
  border-radius:14px;
  border:1px dashed rgba(243,194,91,.35);
  background: rgba(0,0,0,.18);
}

/* Playlist toggle button (mobile + desktop) */
.queueToggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin:10px auto 0;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(243,194,91,.45);
  background: linear-gradient(180deg, rgba(150,20,20,.75), rgba(60,0,0,.75));
  color:#f7e6b2;
  font-weight:900;
  font-size:12px;
  letter-spacing:.12em;
  cursor:pointer;
  text-transform:uppercase;
  text-decoration:none;
}
.queueToggle:hover{filter:brightness(1.05);}
.queueToggle:active{transform:translateY(1px);}

/* queue (below the jukebox) */
.queue{
  width:100%;
  max-width:980px;
  display:flex;
  flex-direction:column;
  gap:10px;
}


body.show-queue .queue{display:flex;}
body.show-queue .legal-note{display:block;}
.queue-list{
  list-style:none;
  padding:0;
  margin:0;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(10,10,10,.72);
    backdrop-filter: blur(10px);
  overflow:hidden;
}

.queue-list li{
  padding:8px 12px;
  border-top:1px solid rgba(255,255,255,.07);
  cursor:pointer;
}
.queue-list li:first-child{border-top:0}
.queue-list li:hover{background: rgba(255,255,255,.04)}

.track-line{
  font-size:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  opacity:.92;
}

/* legal note */
.legal-note{
  margin-top: 16px;
  font-size: 12px;
  opacity: 0.7;
  text-align: center;
}

/* footer buttons */
.legal-grid{
  width:100%;
  max-width:980px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:10px;
  margin-top:6px;
}
.legal-box{
  text-decoration:none;
  text-align:center;
  padding:12px 8px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(10,10,10,.72);
    backdrop-filter: blur(10px);
  font-weight:700;
  letter-spacing:.8px;
  font-size:12px;
}

/* ===== Mobile App mode (clean UI, no jukebox image) ===== */

.mobileTitle{display:none;}
@media (max-width: 768px){
  /* Mobile header */
  .mobileTitle{
    display:block;
    width:100%;
    max-width:560px;
    margin:10px auto 0;
    padding:0 12px;
    text-align:center;
    font-weight:900;
    letter-spacing:0.22em;
    font-size:12px;
    color:rgba(247,230,178,.92);
    text-shadow:0 2px 10px rgba(0,0,0,.6);
  }

  /* Mobile bands under footer */
  .mobile-bands{display:block; width:100%; max-width:560px; margin:18px auto 28px; padding:0 12px;}
  .mobile-bands-title{font-size:11px; letter-spacing:0.18em; opacity:0.75; margin:0 0 10px 2px;}
  .mobile-bands-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:10px;}
  .mobile-bandbtn{
    display:flex; align-items:center; justify-content:center;
    min-height:44px;
    padding:10px 10px;
    border-radius:12px;
    text-decoration:none;
    font-weight:800;
    font-size:12px;
    letter-spacing:0.03em;
    text-align:center;
    line-height:1.1;
    /* Red jukebox look */
    background: linear-gradient(180deg, rgba(180,0,0,0.95), rgba(70,0,0,0.95));
    border: 1px solid rgba(255,190,90,0.45);
    box-shadow: 0 10px 22px rgba(0,0,0,0.45);
    color: rgba(255,240,220,0.95);
  }
  .mobile-bandbtn:active{transform: translateY(1px);}

  /* Mobile app background: jukebox atmosphere */
  body{
    background:
      linear-gradient(rgba(0,0,0,.72), rgba(0,0,0,.92)),
      url("assets/jukebox.png") center / 160% no-repeat;
    background-attachment: scroll;
  }


  /* hide decorative elements */
  .bandbar{display:none;}
  .jukebox-frame{display:none;}

  .stage{
    max-width:560px;
    padding:0;
  }

  /* turn overlay into normal layout */
  .ui{position:static; inset:auto; pointer-events:auto; width:100%;}
  .ui-inner{
    height:auto;
    max-width:560px;
    padding:14px;
    border-radius:18px;
    background: rgba(10,10,10,.72);
    backdrop-filter: blur(10px);
    border:1px solid rgba(255,255,255,.10);
    box-shadow: 0 18px 40px rgba(0,0,0,.45);
  }

  .top{position:static; left:auto; right:auto; top:auto; justify-content:space-between;}

  .panel{position:static; left:auto; right:auto; top:auto; height:auto; max-height:none; min-height:0; margin-top:12px;}
  .status{position:static; inset:auto; padding:12px 10px; text-align:center;}

  .now{position:static; left:auto; right:auto; top:auto; bottom:auto; margin-top:12px;}

  /* Mobile PRO playlist toggle */
  .queueToggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    margin:2px auto 0;
    padding:9px 14px;
    border-radius:999px;
    border:1px solid rgba(243,194,91,.34);
    background: linear-gradient(180deg, rgba(176,21,25,.70), rgba(91,10,12,.70));
    color: var(--text);
    font-weight:800;
    letter-spacing:.7px;
    cursor:pointer;
  }

  /* hide playlist by default on mobile; show when toggled */
  .queue{display:none; max-width:560px;}
  .legal-note{display:none;}
  body.show-queue .queue{display:flex;}
  body.show-queue .legal-note{display:block;}

  /* seekbar is visual-only (non-draggable) */
  .seek{pointer-events:none;}

  /* footer more compact */
  .legal-grid{grid-template-columns: repeat(2, 1fr);}
}

/* ===== Mobile tightening ===== */
@media (max-width: 520px){
  :root{
    --p-side: 12%;
    --p-top: 22%;
    --panel-h: 28%;
    --p-bottom: 5%;
  }

  .app{gap:10px; padding:8px 8px 14px;}
  .bandbtn{font-size:11px; padding:8px 10px;}
  .chip{padding:7px 9px}
  .chip-label{font-size:10px}
  .chip-select{font-size:11px}
  .random{padding:9px 12px; font-size:12px}

  .track-line{font-size:11px}
  .now-line > span{font-size:11px}
  .btn{width:40px;height:40px}
  .play{width:48px;height:48px}
  .legal-grid{grid-template-columns: repeat(2, 1fr);}
}

/* ===== Desktop: show side rails and hide top bandbar ===== */
@media (min-width: 900px){
  .mobile-bands{display:none;}

  .bandbar{display:none;}

  .stage{
    max-width:1400px;
    padding:10px 0;
  }

  .rail{
    display:flex;
    position:absolute;
    top:50%;
    transform: translateY(-50%);
    width:160px;
    gap:10px;
    flex-direction:column;
  }
  .rail-left{left:0}
  .rail-right{right:0}

  .rail-btn{
    text-decoration:none;
    text-align:center;
    padding:12px 10px;
    border-radius:14px;
    border:1px solid rgba(243,194,91,.26);
    background: linear-gradient(180deg, rgba(176,21,25,.82), rgba(91,10,12,.82));
    font-weight:800;
    letter-spacing:.6px;
    font-size:12px;
    line-height:1.1;
    white-space:normal;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center;
    text-wrap:balance;
    word-break:break-word;
    box-shadow:
      0 10px 22px rgba(0,0,0,.35),
      0 0 0 1px rgba(255,255,255,.05) inset;
  }
  .rail-btn:hover{filter: brightness(1.04)}
  .rail-add{
    border-style:dashed;
    opacity:.85;
  }
}

/* =========================
   v9 patch: desktop playlist default hidden + mobile banner
   ========================= */

/* Playlist closed by default everywhere (desktop included) */
.track-list { display: none; }
.track-list.is-visible { display: block; }

/* Mobile big title/banner placeholder (replace with your banner later) */
.mobile-banner { display: none; }

@media (max-width: 768px) {
  .mobile-banner {
    display: block;
    width: 100%;
    text-align: center;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: clamp(26px, 7vw, 40px);
    line-height: 1.05;
    padding: 16px 12px 10px;
    margin: 0 auto;
  }

  /* If playlist is opened in Mobile PRO, show it */
  .track-list.is-visible { display: block; }
}
/* =========================
   DESKTOP PLAYLIST TOGGLE
   ========================= */

/* Playlist toggle */
.queue { display: none; }
body.show-queue .queue { display: block; }
/* =========================
   PROMO BANNERS
   ========================= */
.promo-banners{
  width:100%;
  max-width:1200px;
  display:flex;
  gap:12px;
  margin:12px auto;
  justify-content:center;
  align-items:center;
}

.promo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  font-weight:900;
  letter-spacing:.08em;
  text-decoration:none;
  font-size:12px;
  border:1px solid rgba(0,0,0,.15);
  box-shadow: 0 10px 22px rgba(0,0,0,.35);
}

/* Desktop colors */
@media (min-width: 769px){
  .promo-setfonic{
    background:#f3c25b; /* amarillo */
    color:#111;
  }
  .promo-playlist{
    background:#22cfcf; /* turquesa */
    color:#012;
  }
}

@media (max-width: 768px){
  .promo-banners{
    flex-direction:column;
    gap:10px;
    margin:8px auto 14px;
    padding:0 12px;
  }

  .promo{
    width:100%;
    max-width:560px;
    min-height:44px;
    font-size:12px;
    letter-spacing:.12em;

    /* FORCE banner look */
    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:14px;
    border:1px solid rgba(255,190,90,.45);
    box-shadow: 0 10px 22px rgba(0,0,0,.45);
    text-decoration:none;
  }

  /* Mobile colors (stronger so they don't look like text) */
  .promo-setfonic{
    background: linear-gradient(180deg, #f3c25b, #e6ae3a);
    color:#111;
  }

  .promo-playlist{
    background: linear-gradient(180deg, #22cfcf, #159fa0);
    color:#012;
  }
}


/* ===== License badge ===== */
.license-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:2px 8px;
  border-radius:999px;
  font-size:12px;
  line-height:1.2;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.92);
  letter-spacing:.4px;
}
.license-badge.is-empty{
  opacity:.55;
}

/* ===== Promo buttons ===== */
.promo.promo-latest{
  background: linear-gradient(135deg, rgba(140, 80, 255, .95), rgba(200, 80, 255, .95));
  border:1px solid rgba(255,255,255,.14);
}
.promo.promo-affiliate{
  background: linear-gradient(135deg, rgba(120, 255, 200, .22), rgba(255, 190, 80, .22));
  border:1px solid rgba(255,255,255,.14);
}

/* ===== Bandbar slots ===== */
.bandbtn-affiliate{
  background: rgba(140, 80, 255, .18) !important;
  border-color: rgba(140, 80, 255, .45) !important;
}
.bandbtn-promo{
  background: rgba(255, 80, 200, .16) !important;
  border-color: rgba(255, 80, 200, .42) !important;
}

/* Bandbar promos (right side) */
.bandbar-promos{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
}
.bandbar-promos .bandbtn{
  white-space:nowrap;
}
@media (max-width: 640px){
  .bandbar-promos{
    max-width: 52vw;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    padding-bottom: 2px;
  }
  .bandbar-promos::-webkit-scrollbar{ height: 6px; }
}
