/* vrc.dj  Modals: liveset submit modal, community search, toast, angry toast */
/* -- Liveset submit modal ------------------------------------------- */
#livesetSubmitModal .modal-dialog {
  max-width: min(760px, calc(100vw - 24px));
}
#livesetSubmitModal .modal-content {
  position: relative;
  isolation: isolate;
  background: color-mix(in srgb, var(--accent-neutralized) 12%, rgba(8,11,20,.72));
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 14px;
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.1);
  backdrop-filter: blur(28px) saturate(1.3);
  -webkit-backdrop-filter: blur(28px) saturate(1.3);
  overflow: hidden;
}
#livesetSubmitModal .modal-content::before {
  content: '';
  position: absolute;
  inset: -32% -18% auto;
  height: 70%;
  background:
    radial-gradient(60% 80% at 15% 22%, color-mix(in srgb, var(--accent-neutralized) 35%, transparent), transparent 70%),
    radial-gradient(52% 72% at 82% 18%, color-mix(in srgb, var(--accent-neutralized) 30%, transparent), transparent 68%),
    linear-gradient(100deg, rgba(255,255,255,.15), transparent 52%);
  opacity: .18;
  pointer-events: none;
  z-index: 0;
  animation: liveset-modal-spectral-drift 9s ease-in-out infinite alternate;
}
#livesetSubmitModal .modal-header,
#livesetSubmitModal .modal-body {
  position: relative;
  z-index: 1;
}
#livesetSubmitModal .modal-header {
  border-bottom: 1px solid rgba(255,255,255,.11);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-neutralized) 10%, transparent), transparent);
  padding: .95rem 1rem;
}
#livesetSubmitModal .modal-title {
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: .01em;
}
#livesetSubmitModal .modal-body {
  padding: 1.1rem 1rem 1rem;
}
.ls-nopages-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 50% at 50% 0%, color-mix(in srgb, var(--accent-base) 18%, transparent), transparent 70%);
  pointer-events: none;
}
.ls-nopages-icon {
  font-size: 2.6rem;
  line-height: 1;
  color: color-mix(in srgb, var(--accent-base) 75%, white);
  filter: drop-shadow(0 0 18px color-mix(in srgb, var(--accent-base) 70%, transparent));
}
#livesetSubmitModal .btn-close {
  opacity: .75;
  transition: opacity .18s var(--ease), transform .18s var(--ease);
}
#livesetSubmitModal .btn-close:hover {
  opacity: 1;
  transform: scale(1.05);
}
#livesetSubmitModal .text-muted {
  color: color-mix(in srgb, var(--text-secondary) 84%, var(--text)) !important;
}
#livesetSubmitModal .form-label {
  font-size: .84rem;
  color: var(--text-secondary);
  margin-bottom: .35rem;
}
#livesetSubmitModal .form-control,
#livesetSubmitModal .form-select,
#livesetSubmitModal textarea {
  background: color-mix(in srgb, var(--bg-elevated) 44%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
  color: var(--text);
}
#livesetSubmitModal .form-control::placeholder,
#livesetSubmitModal textarea::placeholder {
  color: color-mix(in srgb, var(--text-muted) 82%, transparent);
}
#livesetSubmitModal .form-control:focus,
#livesetSubmitModal .form-select:focus,
#livesetSubmitModal textarea:focus {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--border-bright));
  box-shadow: 0 0 0 .17rem color-mix(in srgb, var(--accent) 18%, transparent);
}
#livesetSubmitModal .input-group {
  border-radius: var(--radius-sm);
  overflow: hidden;
}
#livesetSubmitModal #ls-modal-url {
  min-height: 42px;
}
#livesetSubmitModal #ls-fetch-btn {
  min-width: 84px;
  font-weight: 600;
}
#livesetSubmitModal #ls-step1 {
  padding: .45rem 0 .2rem;
}
#livesetSubmitModal #ls-step2 {
  animation: fadeIn .22s var(--ease);
}
#livesetSubmitModal #ls-preview-embed {
  margin-bottom: .95rem;
  padding: .35rem;
  border-radius: 10px;
  background: color-mix(in srgb, var(--bg-card) 62%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
#ls-preview-embed iframe {
  border-radius: 8px;
  width: 100%;
}
#livesetSubmitModal #ls-modal-tags .tag-input-container {
  max-height: 140px;
  overflow-y: auto;
  padding: .5rem;
  border-radius: 10px;
  background: color-mix(in srgb, var(--bg-card) 55%, transparent);
  border: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
}
#livesetSubmitModal #ls-modal-tags .tag-input-container::-webkit-scrollbar {
  width: 8px;
}
#livesetSubmitModal #ls-modal-tags .tag-input-container::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--scrollbar-thumb) 85%, transparent);
  border-radius: 8px;
}
#livesetSubmitModal .form-text {
  color: var(--text-muted);
  font-size: .77rem;
}
#livesetSubmitModal #ls-fetch-error,
#livesetSubmitModal #ls-submit-error {
  border: 1px solid color-mix(in srgb, #ff4d67 42%, transparent);
  background: color-mix(in srgb, #ff4d67 12%, transparent);
  border-radius: var(--radius-sm);
  padding: .45rem .6rem;
}
#livesetSubmitModal #ls-back-btn {
  border-color: color-mix(in srgb, var(--border-bright) 78%, transparent);
  color: var(--text-secondary);
  background: color-mix(in srgb, var(--bg-card) 55%, transparent);
}
#livesetSubmitModal #ls-back-btn:hover {
  color: var(--text);
  border-color: var(--border-bright);
  background: color-mix(in srgb, var(--bg-card-hover) 85%, transparent);
}

/* -- Liveset community search dropdown ------------------------------ */
.ls-community-search {
  position: relative;
}
.ls-community-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: var(--z-dialog); /* liveset-submit autocomplete */
  max-height: 220px;
  overflow-y: auto;
  margin-top: 4px;
  padding: .3rem;
  border-radius: 10px;
  background: color-mix(in srgb, var(--bg-card) 92%, transparent);
  backdrop-filter: blur(16px) saturate(1.4);
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
.ls-community-dropdown .search-result-item {
  padding: .4rem .5rem;
  font-size: .88rem;
}
.ls-community-dropdown .search-result-avatar {
  width: 26px;
  height: 26px;
}
.ls-community-empty {
  padding: .6rem .5rem;
  color: var(--text-muted);
  font-size: .82rem;
  text-align: center;
}
.ls-community-dropdown::-webkit-scrollbar {
  width: 6px;
}
.ls-community-dropdown::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--scrollbar-thumb) 85%, transparent);
  border-radius: 6px;
}

@keyframes liveset-modal-spectral-drift {
  0% {
    transform: translateX(-2%) translateY(0) scale(1);
    opacity: .15;
  }
  100% {
    transform: translateX(2%) translateY(-3%) scale(1.03);
    opacity: .22;
  }
}

@media (max-width: 575.98px) {
  #livesetSubmitModal .modal-body {
    padding: .95rem .8rem .85rem;
  }
  #livesetSubmitModal .modal-title {
    font-size: .98rem;
  }
}

/* -- Toast notifications ------------------------------------------- */
.vrcdj-toast-container {
  position: fixed;
  bottom: 16px;
  right: 92px;
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 420px;
  width: calc(100% - 32px);
  pointer-events: none;
}
.page-tag .vrcdj-toast-container {
  top: 16px;
  bottom: auto;
  left: 16px;
  right: auto;
}
.vrcdj-toast {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--bg-card) 60%, transparent);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border: 1px solid color-mix(in srgb, var(--border) 60%, transparent);
  color: var(--text);
  font-size: .875rem;
  box-shadow: 0 4px 24px rgba(0,0,0,.35);
  pointer-events: auto;
  opacity: 0;
  transform: translateX(40px);
  transition: opacity .3s ease, transform .3s ease;
}
[data-theme="light"] .vrcdj-toast {
  background: rgba(30, 41, 59, 0.88);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border-color: rgba(255,255,255,.12);
  color: #f1f5f9;
}
[data-theme="light"] .vrcdj-toast-close { color: rgba(255,255,255,.55); }
[data-theme="light"] .vrcdj-toast-close:hover { color: #f1f5f9; }
@media (prefers-color-scheme: light) {
  :root:not([data-theme="dark"]) .vrcdj-toast {
    background: rgba(30, 41, 59, 0.88);
    backdrop-filter: blur(16px) saturate(1.4);
    -webkit-backdrop-filter: blur(16px) saturate(1.4);
    border-color: rgba(255,255,255,.12);
    color: #f1f5f9;
  }
  :root:not([data-theme="dark"]) .vrcdj-toast-close { color: rgba(255,255,255,.55); }
  :root:not([data-theme="dark"]) .vrcdj-toast-close:hover { color: #f1f5f9; }
}
.vrcdj-toast-show {
  opacity: 1;
  transform: translateX(0);
}
.vrcdj-toast-hide {
  opacity: 0;
  transform: translateX(40px);
}
.vrcdj-toast-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.vrcdj-toast-msg { flex: 1; line-height: 1.4; }
.vrcdj-toast-action {
  align-self: center;
  color: #fff;
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  padding: .15rem 0 .15rem .25rem;
}
.vrcdj-toast-action:hover { color: rgba(255,255,255,.75); }
.vrcdj-toast-close {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 1.2rem;
  line-height: 1;
  padding: 0 0 0 8px;
  cursor: pointer;
  flex-shrink: 0;
}
.vrcdj-toast-close:hover { color: var(--text); }

.vrcdj-toast-success { border-left: 4px solid #22c55e; }
.vrcdj-toast-success .vrcdj-toast-icon { color: #22c55e; }
.vrcdj-toast-danger  { border-left: 4px solid #ef4444; }
.vrcdj-toast-danger  .vrcdj-toast-icon { color: #ef4444; }
.vrcdj-toast-warning { border-left: 4px solid #f59e0b; }
.vrcdj-toast-warning .vrcdj-toast-icon { color: #f59e0b; }
.vrcdj-toast-info    { border-left: 4px solid #3b82f6; }
.vrcdj-toast-info    .vrcdj-toast-icon { color: #3b82f6; }

@keyframes toast-rainbow-stripe {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}
@keyframes toast-rainbow-glow {
  0%   { box-shadow: 0 0 12px 2px #f472b6, 0 4px 24px rgba(0,0,0,.35); }
  16%  { box-shadow: 0 0 12px 2px #fb923c, 0 4px 24px rgba(0,0,0,.35); }
  33%  { box-shadow: 0 0 12px 2px #facc15, 0 4px 24px rgba(0,0,0,.35); }
  50%  { box-shadow: 0 0 12px 2px #4ade80, 0 4px 24px rgba(0,0,0,.35); }
  66%  { box-shadow: 0 0 12px 2px #60a5fa, 0 4px 24px rgba(0,0,0,.35); }
  83%  { box-shadow: 0 0 12px 2px #a78bfa, 0 4px 24px rgba(0,0,0,.35); }
  100% { box-shadow: 0 0 12px 2px #f472b6, 0 4px 24px rgba(0,0,0,.35); }
}
.vrcdj-toast-rainbow {
  border: none;
  padding-top: 14px;
  position: relative;
  overflow: visible;
  animation: toast-rainbow-glow 2s linear infinite;
  background: color-mix(in srgb, var(--bg-card) 55%, transparent);
}
.vrcdj-toast-rainbow::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 2px;
  background: linear-gradient(
    90deg,
    #f472b6, #fb923c, #facc15, #4ade80, #60a5fa, #a78bfa, #f472b6,
    #fb923c, #facc15, #4ade80, #60a5fa, #a78bfa, #f472b6
  );
  background-size: 200% 100%;
  animation: toast-rainbow-stripe 2s linear infinite;
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.vrcdj-toast-rainbow .vrcdj-toast-icon {
  background: linear-gradient(135deg, #f472b6, #fb923c, #facc15, #4ade80, #60a5fa, #a78bfa);
  background-size: 200% 200%;
  animation: toast-rainbow-stripe 2s linear infinite;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: 1.2rem;
}

@media (max-width: 575.98px) {
  .vrcdj-toast-container { top: 8px; bottom: auto; left: 8px; right: 8px; max-width: calc(100% - 16px); }
  .page-tag .vrcdj-toast-container { left: 8px; right: auto; }
}

/* -- Angry toast (Increasing Frustration easter egg) --------------- */
@keyframes vrcdj-jitter {
  0%   { transform: translate3d(0, 0, 0); }
  10%  { transform: translate3d(-2px, 1px, 0); }
  20%  { transform: translate3d(2px, -1px, 0); }
  30%  { transform: translate3d(-2px, 0, 0); }
  40%  { transform: translate3d(0, 1px, 0); }
  50%  { transform: translate3d(2px, -1px, 0); }
  60%  { transform: translate3d(-2px, 1px, 0); }
  70%  { transform: translate3d(0, 0, 0); }
  80%  { transform: translate3d(2px, 0, 0); }
  90%  { transform: translate3d(-2px, -1px, 0); }
  100% { transform: translate3d(0, 0, 0); }
}
@keyframes vrcdj-shake {
  0%   { transform: translate3d(0, 0, 0) rotate(0deg); }
  10%  { transform: translate3d(-6px, 2px, 0) rotate(-.5deg); }
  20%  { transform: translate3d(7px, -2px, 0) rotate(.5deg); }
  30%  { transform: translate3d(-5px, 3px, 0) rotate(-.3deg); }
  40%  { transform: translate3d(6px, -1px, 0) rotate(.4deg); }
  50%  { transform: translate3d(-7px, 2px, 0) rotate(-.5deg); }
  60%  { transform: translate3d(5px, -3px, 0) rotate(.3deg); }
  70%  { transform: translate3d(-4px, 1px, 0) rotate(-.2deg); }
  80%  { transform: translate3d(6px, -2px, 0) rotate(.4deg); }
  90%  { transform: translate3d(-5px, 2px, 0) rotate(-.3deg); }
  100% { transform: translate3d(0, 0, 0) rotate(0deg); }
}
@keyframes vrcdj-glitch-clip {
  0%   { clip-path: inset(0 0 0 0); }
  45%  { clip-path: inset(0 0 0 0); }
  47%  { clip-path: inset(30% 0 40% 0); }
  50%  { clip-path: inset(0 0 0 0); }
  90%  { clip-path: inset(0 0 0 0); }
  93%  { clip-path: inset(60% 0 20% 0); }
  96%  { clip-path: inset(10% 0 70% 0); }
  100% { clip-path: inset(0 0 0 0); }
}
@keyframes vrcdj-sag {
  0%   { transform: translateY(0);    opacity: 1; }
  100% { transform: translateY(14px); opacity: 0; }
}
.vrcdj-toast-angry {
  will-change: transform, opacity;
  border-left: 4px solid #e11d48;
  background: color-mix(in srgb, #200010 75%, var(--bg-card));
  animation: vrcdj-jitter var(--anger-dur, 0.35s) cubic-bezier(.36,.07,.19,.97) infinite;
  position: relative;
  overflow: hidden;
}
.vrcdj-toast-angry .vrcdj-toast-icon { color: #e11d48; }
/* Intensity 5–6: glitch clip overlay */
.vrcdj-toast-angry[data-intensity="5"]::before,
.vrcdj-toast-angry[data-intensity="6"]::before {
  content: '';
  position: absolute;
  inset: 0;
  animation: vrcdj-glitch-clip 1.4s steps(1) infinite;
  background: color-mix(in srgb, #e11d48 14%, transparent);
  pointer-events: none;
  z-index: 0;
}
/* Intensity 7–8: chromatic aberration */
.vrcdj-toast-angry[data-intensity="7"],
.vrcdj-toast-angry[data-intensity="8"] { border-left-color: #9f1239; }
.vrcdj-toast-angry[data-intensity="7"] .vrcdj-toast-msg,
.vrcdj-toast-angry[data-intensity="8"] .vrcdj-toast-msg {
  text-shadow: -2px 0 0 cyan, 2px 0 0 #e11d48;
}
/* Intensity 9–10: heavy shake + noise overlay */
.vrcdj-toast-angry[data-intensity="9"],
.vrcdj-toast-angry[data-intensity="10"] {
  border-left-color: #7f1d1d;
  animation: vrcdj-shake var(--anger-dur, 0.06s) cubic-bezier(.36,.07,.19,.97) infinite;
}
.vrcdj-toast-angry[data-intensity="9"] .vrcdj-toast-msg,
.vrcdj-toast-angry[data-intensity="10"] .vrcdj-toast-msg {
  text-shadow: -3px 0 0 cyan, 3px 0 0 #ff0040;
}
.vrcdj-toast-angry[data-intensity="9"]::after,
.vrcdj-toast-angry[data-intensity="10"]::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity: 0.07;
  pointer-events: none;
  mix-blend-mode: overlay;
  z-index: 0;
}
/* Depressed finale */
.vrcdj-toast-angry.vrcdj-toast-depressed {
  animation: vrcdj-sag 4s cubic-bezier(.4,0,1,1) forwards !important;
  border-left-color: #4b5563;
  background: color-mix(in srgb, #111 80%, var(--bg-card));
  filter: grayscale(1);
}
.vrcdj-toast-angry.vrcdj-toast-depressed .vrcdj-toast-icon { color: #6b7280; }
.vrcdj-toast-angry.vrcdj-toast-depressed .vrcdj-toast-msg  { color: #9ca3af; }

