/* Bulk download UI — linked directly from index.html with ?v= cache bust.
   Nested @import CSS (bpm-panel.css) can stay stale on CDN due to immutable /css/* headers. */

/* ---- Status toast (below header) ---- */
.multiDownloadStatus{
  box-sizing:border-box;
  position:fixed;
  top:calc(var(--bulk-toast-top, 96px) + 12px);
  left:max(14px, calc(env(safe-area-inset-left, 0px) + 14px));
  right:auto;
  bottom:auto;
  transform:none;
  z-index:1900;
  max-width:min(460px, calc(100vw - 32px));
  padding:11px 18px;
  border-radius:16px;
  font-size:13px;
  font-weight:600;
  letter-spacing:0.02em;
  line-height:1.4;
  text-align:left;
  color:rgba(248, 244, 255, 0.96);
  background:linear-gradient(165deg, rgba(24, 12, 48, 0.96), rgba(12, 8, 28, 0.94));
  border:1px solid color-mix(in srgb, var(--header-neon-accent) 46%, rgba(255, 255, 255, 0.12));
  box-shadow:
    0 0 22px color-mix(in srgb, var(--header-neon-accent) 26%, transparent),
    0 12px 34px rgba(0, 0, 0, 0.5);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  pointer-events:none;
  opacity:0;
  transition:opacity 0.2s ease;
}
.multiDownloadStatus.is-visible{
  opacity:1;
}
.multiDownloadStatus.multiDownloadStatus--info{
  animation:multiDlStatusPulse 1.6s ease-in-out infinite;
}
@keyframes multiDlStatusPulse{
  0%,
  100%{
    opacity:1;
  }
  50%{
    opacity:0.9;
  }
}
.multiDownloadStatus.multiDownloadStatus--success{
  border-color:color-mix(in srgb, #5ef0a8 52%, rgba(255, 255, 255, 0.12));
  box-shadow:0 0 22px rgba(94, 240, 168, 0.22), 0 12px 34px rgba(0, 0, 0, 0.5);
}
.multiDownloadStatus.multiDownloadStatus--warn{
  border-color:color-mix(in srgb, #ffce6a 54%, rgba(255, 255, 255, 0.12));
  box-shadow:0 0 22px rgba(255, 206, 106, 0.22), 0 12px 34px rgba(0, 0, 0, 0.5);
}
.multiDownloadStatus.multiDownloadStatus--error{
  border-color:color-mix(in srgb, #ff7a8a 54%, rgba(255, 255, 255, 0.12));
  box-shadow:0 0 22px rgba(255, 122, 138, 0.24), 0 12px 34px rgba(0, 0, 0, 0.5);
}
.multiDownloadStatus.multiDownloadStatus--attention{
  animation:multiDlAttentionBlink 0.6s ease;
}
@keyframes multiDlAttentionBlink{
  0%,
  100%{
    transform:translateX(0) scale(1);
    box-shadow:0 0 22px rgba(255, 206, 106, 0.3), 0 12px 34px rgba(0, 0, 0, 0.5);
  }
  15%{
    transform:translateX(-5px) scale(1.045);
    box-shadow:0 0 36px rgba(255, 206, 106, 0.9), 0 12px 34px rgba(0, 0, 0, 0.5);
  }
  30%{
    transform:translateX(5px) scale(1.045);
    box-shadow:0 0 14px rgba(255, 206, 106, 0.18), 0 12px 34px rgba(0, 0, 0, 0.5);
  }
  45%{
    transform:translateX(-4px) scale(1.025);
    box-shadow:0 0 36px rgba(255, 206, 106, 0.9), 0 12px 34px rgba(0, 0, 0, 0.5);
  }
  60%{
    transform:translateX(4px) scale(1.02);
    box-shadow:0 0 14px rgba(255, 206, 106, 0.18), 0 12px 34px rgba(0, 0, 0, 0.5);
  }
  78%{
    transform:translateX(-2px) scale(1.01);
  }
}
@media (max-width: 768px){
  .multiDownloadStatus{
    left:12px;
    right:12px;
    max-width:none;
  }
}

/* ---- Cooldown labels ---- */
.multiControlBtn.multiControlBtn--run.multiControlBtn--cooldown .multiControlRunLabel{
  font-variant-numeric:tabular-nums;
  letter-spacing:0.03em;
}
.multiDownloadMenuAction--run.multiDownloadMenuAction--cooldown:disabled{
  opacity:0.88;
  font-variant-numeric:tabular-nums;
  letter-spacing:0.03em;
}

/* ---- Blocking bulk ZIP progress modal ---- */
.bulkDownloadProgressModal{
  position:fixed;
  inset:0;
  z-index:10200;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
  box-sizing:border-box;
}
.bulkDownloadProgressModal[hidden]{
  display:none !important;
}
.bulkDownloadProgressModal--open{
  display:flex !important;
}
.bulkDownloadProgressModal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(4, 2, 12, 0.82);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.bulkDownloadProgressModal__panel{
  position:relative;
  z-index:1;
  width:min(100%, 440px);
  max-height:min(90vh, 560px);
  overflow:auto;
  padding:22px 22px 18px;
  border-radius:18px;
  border:1px solid color-mix(in srgb, var(--header-neon-accent) 42%, rgba(255, 255, 255, 0.1));
  background:linear-gradient(165deg, rgba(22, 11, 46, 0.98), rgba(10, 6, 26, 0.98));
  box-shadow:
    0 0 28px color-mix(in srgb, var(--header-neon-accent) 22%, transparent),
    0 18px 48px rgba(0, 0, 0, 0.55);
  color:rgba(248, 244, 255, 0.96);
}
.bulkDownloadProgressModal__title{
  margin:0 0 10px;
  font-size:18px;
  font-weight:700;
  letter-spacing:0.02em;
}
.bulkDownloadProgressModal__notice{
  margin:0 0 16px;
  font-size:13px;
  line-height:1.45;
  color:rgba(220, 210, 245, 0.88);
}
.bulkDownloadProgressModal__steps{
  list-style:none;
  margin:0 0 14px;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.bulkDownloadProgressModal__step{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:10px;
  font-size:13px;
  font-weight:600;
  color:rgba(200, 190, 225, 0.55);
  background:rgba(255, 255, 255, 0.03);
  border:1px solid transparent;
  transition:color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}
.bulkDownloadProgressModal__step::before{
  content:"";
  flex:0 0 8px;
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(180, 170, 210, 0.35);
}
.bulkDownloadProgressModal__step--active{
  color:rgba(248, 244, 255, 0.96);
  background:rgba(143, 92, 255, 0.12);
  border-color:color-mix(in srgb, var(--header-neon-accent) 35%, transparent);
}
.bulkDownloadProgressModal__step--active::before{
  background:var(--header-neon-accent);
  box-shadow:0 0 10px color-mix(in srgb, var(--header-neon-accent) 70%, transparent);
}
.bulkDownloadProgressModal__step--done{
  color:rgba(210, 230, 220, 0.9);
}
.bulkDownloadProgressModal__step--done::before{
  background:#5ef0a8;
}
.bulkDownloadProgressModal__detail{
  margin:0 0 12px;
  min-height:1.25em;
  font-size:13px;
  font-weight:600;
  color:rgba(180, 220, 255, 0.92);
}
.bulkDownloadProgressModal__message{
  margin:0 0 14px;
  padding:10px 12px;
  border-radius:10px;
  font-size:13px;
  line-height:1.45;
  font-weight:600;
}
.bulkDownloadProgressModal__message--error{
  color:#ffd0d6;
  background:rgba(255, 90, 110, 0.12);
  border:1px solid rgba(255, 122, 138, 0.35);
}
.bulkDownloadProgressModal__message--cancelled{
  color:#ffe8b8;
  background:rgba(255, 206, 106, 0.1);
  border:1px solid rgba(255, 206, 106, 0.32);
}
.bulkDownloadProgressModal__message--success{
  color:#c8f8de;
  background:rgba(94, 240, 168, 0.1);
  border:1px solid rgba(94, 240, 168, 0.32);
}
.bulkDownloadProgressModal__actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:4px;
}
.bulkDownloadProgressModal--terminal .bulkDownloadProgressModal__actions{
  justify-content:center;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.bulkDownloadProgressModal__btn{
  min-width:96px;
  padding:9px 16px;
  border-radius:10px;
  font-size:13px;
  font-weight:700;
  letter-spacing:0.02em;
  cursor:pointer;
  border:1px solid rgba(255, 255, 255, 0.14);
  background:rgba(255, 255, 255, 0.06);
  color:rgba(248, 244, 255, 0.96);
}
.bulkDownloadProgressModal--terminal .bulkDownloadProgressModal__btn:not(.bulkDownloadProgressModal__btn--cancel){
  min-width:112px;
  max-width:168px;
  flex:0 1 auto;
  height:34px;
  padding:0 14px;
  font-size:12px;
  font-weight:600;
  line-height:1.2;
  box-sizing:border-box;
}
@media (max-width: 380px){
  .bulkDownloadProgressModal--terminal .bulkDownloadProgressModal__actions{
    flex-direction:column;
    align-items:stretch;
  }
  .bulkDownloadProgressModal--terminal .bulkDownloadProgressModal__btn:not(.bulkDownloadProgressModal__btn--cancel){
    max-width:none;
    width:100%;
  }
}
.bulkDownloadProgressModal__btn--cancel{
  border-color:rgba(255, 122, 138, 0.4);
  background:rgba(255, 90, 110, 0.12);
}
.bulkDownloadProgressModal__btn--cancel:hover,
.bulkDownloadProgressModal__btn--cancel:focus-visible{
  background:rgba(255, 90, 110, 0.2);
}
.bulkDownloadProgressModal__btn--secondary{
  border-color:rgba(255, 255, 255, 0.16);
  background:rgba(255, 255, 255, 0.05);
  color:rgba(220, 210, 240, 0.9);
}
.bulkDownloadProgressModal__btn--secondary:hover,
.bulkDownloadProgressModal__btn--secondary:focus-visible{
  background:rgba(255, 255, 255, 0.09);
  border-color:rgba(255, 255, 255, 0.22);
}
.bulkDownloadProgressModal__btn--primary{
  border-color:color-mix(in srgb, var(--header-neon-accent) 55%, rgba(255, 255, 255, 0.14));
  background:color-mix(in srgb, var(--header-neon-accent) 24%, rgba(255, 255, 255, 0.06));
}
.bulkDownloadProgressModal__btn--primary:hover,
.bulkDownloadProgressModal__btn--primary:focus-visible{
  background:color-mix(in srgb, var(--header-neon-accent) 34%, rgba(255, 255, 255, 0.08));
}
.bulkDownloadProgressModal--terminal .bulkDownloadProgressModal__notice,
.bulkDownloadProgressModal--terminal .bulkDownloadProgressModal__steps,
.bulkDownloadProgressModal--terminal .bulkDownloadProgressModal__detail{
  display:none;
}
.importedSongsPathInput{
  display:block;
  width:100%;
  box-sizing:border-box;
  margin:0 0 14px;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(255, 255, 255, 0.16);
  background:rgba(8, 4, 20, 0.72);
  color:rgba(248, 244, 255, 0.96);
  font-size:13px;
  font-family:inherit;
}
.importedSongsPathInput:focus{
  outline:none;
  border-color:color-mix(in srgb, var(--header-neon-accent) 55%, rgba(255, 255, 255, 0.16));
  box-shadow:0 0 0 2px color-mix(in srgb, var(--header-neon-accent) 22%, transparent);
}
.importedSongsPathModal__title{
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  gap:0.4em;
  margin:0 0 12px;
  line-height:1.25;
}
.importedSongsPathModal__titleMain{
  font-size:inherit;
  font-weight:inherit;
  color:inherit;
}
.importedSongsPathModal__titleNote{
  font-size:0.72em;
  font-weight:500;
  letter-spacing:0.01em;
  color:rgba(200, 196, 230, 0.52);
  white-space:nowrap;
}
@media (max-width: 480px){
  .importedSongsPathModal__titleNote{
    white-space:normal;
  }
}
.importedSongsPathModal__lead{
  margin-bottom:12px;
}
.importedSongsPathModal__steps{
  margin-bottom:14px;
}
.importedSongsPathModal__pathCopyRow{
  margin:10px 0 4px;
}
.importedSongsPathModal__fieldLabel{
  margin:14px 0 6px;
  font-size:12px;
  font-weight:700;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:rgba(200, 196, 230, 0.72);
}
.importedSongsPathModal__box .importedSongsPathInput{
  margin-bottom:0;
}
.importedSongsPathModal__helper{
  margin:8px 0 0;
  font-size:12px;
  line-height:1.45;
  color:rgba(200, 196, 230, 0.58);
}
.importedSongsPathModal__helperExample{
  color:rgba(190, 235, 255, 0.72);
  word-break:break-all;
}
.importedSongsPathModal__error{
  margin:8px 0 0;
  font-size:13px;
  line-height:1.45;
  color:#ffb4c4;
}
.importedSongsPathModal__error[hidden]{
  display:none;
}
/* Floating CTA stack — direct link bypasses stale nested @import cache */
.floatingActionStack{
  position:fixed;
  right:max(14px, env(safe-area-inset-right, 0px));
  top:max(74px, calc(env(safe-area-inset-top, 0px) + 66px));
  z-index:calc(var(--z-site-header-sticky) + 1);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
  width:max-content;
  min-width:158px;
  max-width:min(220px, calc(100vw - 24px));
  pointer-events:none;
}
.floatingActionStack .communityCta{
  position:relative;
  top:auto;
  right:auto;
  left:auto;
  bottom:auto;
  z-index:auto;
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  gap:8px;
  height:34px;
  width:100%;
  min-width:0;
  max-width:100%;
  padding:0 12px;
  box-sizing:border-box;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--header-neon-accent) 28%, rgba(255, 255, 255, 0.12));
  background:linear-gradient(165deg, rgba(18, 10, 40, 0.78), rgba(8, 5, 24, 0.74));
  box-shadow:
    0 0 10px color-mix(in srgb, var(--header-neon-accent) 12%, transparent),
    0 4px 12px rgba(0, 0, 0, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  color:rgba(236, 232, 252, 0.9);
  text-decoration:none;
  white-space:nowrap;
  overflow:hidden;
  isolation:isolate;
  pointer-events:auto;
  cursor:pointer;
}
.floatingActionStack button.communityCta{
  appearance:none;
  -webkit-appearance:none;
  font:inherit;
  margin:0;
  text-align:inherit;
}
.floatingActionStack .communityCta__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  width:14px;
  height:14px;
  color:color-mix(in srgb, var(--header-neon-accent) 70%, #ffffff 30%);
  pointer-events:none;
}
.floatingActionStack .communityCta__icon svg{
  width:100%;
  height:100%;
  display:block;
}
.floatingActionStack .communityCta__label{
  flex:1 1 auto;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  font-size:12px;
  font-weight:700;
  letter-spacing:0.01em;
  line-height:1;
  pointer-events:none;
}
.floatingActionStack .communityCta:hover,
.floatingActionStack .communityCta:focus-visible{
  color:#fff;
  border-color:color-mix(in srgb, var(--header-neon-accent) 44%, rgba(255, 255, 255, 0.2));
  background:linear-gradient(165deg, rgba(22, 12, 48, 0.86), rgba(10, 6, 30, 0.8));
  box-shadow:
    0 0 14px color-mix(in srgb, var(--header-neon-accent) 20%, transparent),
    0 6px 16px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
}
body.filter-sidebar-open .floatingActionStack{
  right:calc(var(--filter-sidebar-width) + max(14px, env(safe-area-inset-right, 0px)));
}
body.terms-open .floatingActionStack{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
@media (max-width: 620px){
  body.filter-sidebar-open .floatingActionStack{
    opacity:0;
    visibility:hidden;
    pointer-events:none;
  }
}
/* Game folder success toast — direct link bypasses immutable nested @import cache */
.quickUiToast.quickUiToast--gameFolder.quickUiToast--anchored:not(.is-visible){
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
.quickUiToast.quickUiToast--gameFolder.quickUiToast--anchored{
  position:fixed;
  bottom:auto;
  right:auto;
  display:inline-flex;
  align-items:center;
  gap:7px;
  height:34px;
  max-width:calc(100vw - 24px);
  padding:0 12px;
  border-radius:999px;
  line-height:1;
  white-space:nowrap;
  box-shadow:0 4px 14px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.05);
  transition:opacity 0.22s ease, transform 0.22s ease;
  opacity:0;
  pointer-events:none;
}
.quickUiToast.quickUiToast--gameFolder.quickUiToast--anchored.quickUiToast--anchorLeft{
  transform:translateX(10px);
}
.quickUiToast.quickUiToast--gameFolder.quickUiToast--anchored.quickUiToast--anchorLeft.is-visible{
  opacity:1;
  transform:translateX(0);
}
.quickUiToast.quickUiToast--gameFolder.quickUiToast--anchored.quickUiToast--anchorBelow{
  transform:translateY(6px);
}
.quickUiToast.quickUiToast--gameFolder.quickUiToast--anchored.quickUiToast--anchorBelow.is-visible{
  opacity:1;
  transform:translateY(0);
}
.quickUiToast.quickUiToast--gameFolder.quickUiToast--success{
  border-color:rgba(124, 255, 107, 0.44);
  background:linear-gradient(165deg, rgba(12, 28, 18, 0.94), rgba(8, 16, 12, 0.9));
  box-shadow:0 0 12px rgba(124, 255, 107, 0.12), 0 4px 14px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}
.quickUiToast.quickUiToast--gameFolder .quickUiToast__icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  width:14px;
  height:14px;
  margin:0;
  border-radius:999px;
  border:1px solid rgba(124, 255, 107, 0.5);
  color:#7cff6b;
  font-size:10px;
  font-weight:800;
  line-height:1;
}
.quickUiToast.quickUiToast--gameFolder .quickUiToast__text{
  font-size:12px;
  font-weight:600;
  letter-spacing:0.01em;
  color:rgba(246, 243, 255, 0.96);
}
@media (max-width: 768px){
  .quickUiToast.quickUiToast--gameFolder.quickUiToast--anchored{
    height:32px;
    padding:0 10px;
    font-size:11px;
  }
}
/* Share-link copied bubble — direct link bypasses immutable nested @import cache */
.shareLinkCopiedBubble{
  position:fixed;
  left:0;
  top:0;
  z-index:10350;
  transform:translate(-50%, -100%);
  padding:5px 10px;
  border-radius:8px;
  border:1px solid rgba(182,208,255,0.38);
  background:rgba(11, 14, 34, 0.92);
  color:#f0f5ff;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.01em;
  white-space:nowrap;
  box-shadow:0 8px 18px rgba(0,0,0,0.35);
  pointer-events:none;
  opacity:0;
  visibility:hidden;
}
.shareLinkCopiedBubble.is-visible{
  visibility:visible;
  animation:shareLinkCopiedBubbleFade 1.75s ease forwards;
}
@keyframes shareLinkCopiedBubbleFade{
  0%{
    opacity:0;
    transform:translate(-50%, calc(-100% + 8px));
  }
  18%{
    opacity:1;
    transform:translate(-50%, -100%);
  }
  72%{
    opacity:1;
    transform:translate(-50%, -100%);
  }
  100%{
    opacity:0;
    transform:translate(-50%, calc(-100% + 8px));
  }
}
