/* 체험 플레이어 · 설정 마법사 (5_site player/trial 이식) */

/* 체험 설정 마법사 — 모바일만 전폭 (PC는 .whick-main--solo 1180px 중앙, 체험 홈·FAQ와 동일) */
@media (max-width: 768px) {
  body.whick-body--wizard .whick-header__inner {
    max-width: none;
    width: 100%;
    box-sizing: border-box;
  }
  body.whick-body--wizard .whick-main--solo {
    max-width: none;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    padding-left: clamp(0.75rem, 3vw, 1.25rem);
    padding-right: clamp(0.75rem, 3vw, 1.25rem);
    box-sizing: border-box;
    padding-bottom: 2rem;
  }
}
@media (min-width: 769px) {
  body.whick-body--wizard .whick-main--solo {
    padding-bottom: 2rem;
  }
}
/* 체험 홈 — 모바일만 전폭 (PC는 style.css .whick-main--solo 1180px와 동일) */
@media (max-width: 768px) {
  body:has(.whick-trial-page--mobile) .whick-header__inner {
    max-width: none;
    width: 100%;
    box-sizing: border-box;
  }
  body:has(.whick-trial-page--mobile) .whick-main--solo {
    max-width: none;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    padding-left: clamp(0.75rem, 3vw, 1.25rem);
    padding-right: clamp(0.75rem, 3vw, 1.25rem);
    box-sizing: border-box;
  }
  .whick-trial-page--mobile,
  .whick-trial-page--mobile .whick-trial-page__body {
    max-width: none;
    width: 100%;
  }
  .whick-trial-page--mobile .whick-trial-page__body {
    padding-left: 0;
    padding-right: 0;
  }
}
.whick-trial-shell,
.whick-trial-mobile-hub,
.whick-trial-guest {
  width: 100%;
  max-width: none;
  box-sizing: border-box;
}
.whick-trial-page--mobile .whick-trial-shell,
.whick-trial-page--mobile .whick-trial-page__extras {
  width: 100%;
}
.whick-body--player {
  overflow: hidden;
  height: 100vh;
  height: 100dvh;
  max-height: 100dvh;
  background: #0c0e12;
  color: #e8eaef;
}
.whick-body--wizard {
  overflow-x: hidden;
  overflow-y: auto;
  min-height: 100vh;
  min-height: 100dvh;
  height: auto;
  background: #0c0e12;
  color: #e8eaef;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: auto;
  touch-action: pan-y;
}
.whick-body--wizard .whick-main--solo {
  overflow: visible;
  min-height: 0;
  height: auto;
}
.whick-body--wizard .whick-trial-wizard {
  touch-action: pan-y;
}
@media (max-width: 768px) {
  .whick-body--wizard.whick-spatial-qr-open {
    overflow-y: auto;
  }
}
.whick-player-app {
  height: 100%;
  min-height: 0;
  max-height: 100dvh;
  display: flex;
  flex-direction: column;
  max-width: none;
  margin: 0;
  width: 100%;
  overflow: hidden;
}
.whick-main--player {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 0;
  max-width: none;
  margin: 0;
  width: 100%;
  overflow: hidden;
}

/* ── 마법사 ── */
.whick-trial-wizard {
  width: 100%;
  margin: 0;
  box-sizing: border-box;
  text-align: left;
}
.whick-trial-wizard:not(.whick-trial-wizard--mobile) {
  max-width: 100%;
  padding: 2rem 0 3rem;
}
.whick-trial-wizard--mobile {
  max-width: none;
  padding: 2rem clamp(1rem, 4vw, 1.5rem) 3rem;
}
.whick-trial-wizard__head h1 {
  font-size: 1.75rem;
  margin: 0.25rem 0;
}
.whick-trial-wizard__lead {
  color: #9aa3b5;
  margin: 0.5rem 0 1rem;
}
.whick-trial-wizard__timer {
  font-size: 0.9rem;
  color: #7dd3fc;
}
.whick-trial-wizard__steps {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin: 1.25rem 0;
}
.whick-trial-wizard__pill {
  font-size: 0.75rem;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  background: #1a1f28;
  color: #8b95a8;
  border: 1px solid #2a3140;
}
.whick-trial-wizard__pill.is-current {
  background: #1e3a5f;
  color: #93c5fd;
  border-color: #3b82f6;
}
.whick-trial-wizard__pill.is-done {
  color: #6ee7b7;
  border-color: #065f46;
}
.whick-trial-wizard__panel {
  background: #141820;
  border: 1px solid #252b38;
  border-radius: 12px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.whick-room-wizard .whick-btn {
  min-height: 44px;
  touch-action: manipulation;
  -webkit-tap-highlight-color: rgba(59, 130, 246, 0.35);
}
.whick-room-wizard .whick-btn.is-pressed,
.whick-room-wizard .whick-btn:active {
  transform: scale(0.97);
  opacity: 0.92;
}
.whick-trial-wizard .whick-btn {
  min-height: 44px;
  touch-action: manipulation;
  -webkit-tap-highlight-color: rgba(59, 130, 246, 0.35);
}
.whick-trial-wizard .whick-btn:active {
  transform: scale(0.97);
  opacity: 0.92;
}
.whick-trial-wizard__panel h2 {
  margin-top: 0;
  font-size: 1.25rem;
}
.whick-trial-wizard__account-box {
  background: #0c0e12;
  padding: 1rem;
  border-radius: 8px;
  margin: 1rem 0;
}
.whick-trial-wizard__account-box strong {
  display: block;
  font-size: 1.1rem;
  margin-top: 0.25rem;
}
.whick-trial-wizard__error {
  color: #fca5a5;
}
.whick-trial-wizard__footnote {
  font-size: 0.8rem;
  color: #6b7280;
  margin-top: 1rem;
}
.whick-trial-wizard__enjoy-list {
  padding-left: 1.25rem;
  color: #b8c0d0;
}
.whick-trial-wizard__footer {
  font-size: 0.85rem;
}
.whick-trial-wizard__retain {
  display: flex;
  gap: 0.5rem;
  align-items: flex-start;
  cursor: pointer;
}

/* 모바일 마법사 — 체험① 리모컨 안내 */
.whick-trial-wizard--mobile .whick-trial-wizard__steps {
  justify-content: center;
}
.whick-wizard-remote__visual {
  margin: 1.25rem auto;
  max-width: 200px;
  text-align: center;
}
.whick-wizard-remote__visual svg {
  width: 100%;
  height: auto;
  opacity: 0.92;
}
.whick-wizard-remote__list {
  margin: 1rem 0;
  padding-left: 1.25rem;
  color: #b8c0d0;
  line-height: 1.55;
}
.whick-wizard-remote__list li + li {
  margin-top: 0.5rem;
}
.whick-wizard-remote__pc {
  margin-bottom: 1.25rem;
  font-size: 0.85rem;
}
#whick-wizard-open-remote {
  width: 100%;
  max-width: none;
  display: block;
  margin: 0 auto 0.75rem;
}
#whick-wizard-reg-skip {
  display: block;
  width: 100%;
  max-width: none;
  margin: 0.75rem auto 0;
}

/* 모바일 체험 홈 — 리모컨 CTA */
.whick-trial-page--mobile .whick-trial-shell {
  margin-top: 0;
}
.whick-trial-mobile-hub {
  margin-top: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 12px;
  background: #141820;
  border: 1px solid #3b82f6;
}
.whick-trial-mobile-hub__lines {
  list-style: none;
  margin: 0 0 0.85rem;
  padding: 0;
  color: #b8c0d0;
  line-height: 1.55;
  font-size: 0.9rem;
}
.whick-trial-mobile-hub__lines li {
  margin: 0 0 0.45rem;
  padding-left: 0.85rem;
  position: relative;
}
.whick-trial-mobile-hub__lines li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: #93c5fd;
}
.whick-trial-mobile-hub__actions {
  margin: 0 0 0.65rem;
  text-align: center;
}
.whick-trial-mobile-hub__actions .whick-btn {
  width: 100%;
  min-height: 48px;
}
.whick-trial-mobile-hub__note {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.45;
  text-align: center;
}
.whick-trial-shell__steps {
  list-style: none;
  margin: 1rem 0 0.75rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.whick-trial-shell__step {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.75rem 0.85rem;
  border-radius: 10px;
  background: #141820;
  border: 1px solid #2a3344;
}
.whick-trial-shell__step-n {
  flex-shrink: 0;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  line-height: 1.75rem;
  text-align: center;
}
.whick-trial-shell__step-body {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  font-size: 0.9rem;
  line-height: 1.45;
  color: #c8d0e0;
}
.whick-trial-shell__step-body strong {
  color: #e8ecf4;
  font-size: 0.95rem;
}
.whick-trial-shell__note {
  margin: 0 0 0.25rem;
  font-size: 0.82rem;
  line-height: 1.45;
}
.whick-trial-shell--mobile-simple .whick-trial-shell__actions {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  margin-top: 1.25rem;
}
.whick-trial-shell--mobile-simple .whick-trial-shell__actions .whick-btn {
  width: 100%;
  min-height: 52px;
}
.whick-trial-shell__sync-warn {
  margin: 0.75rem 0 0;
  padding: 0.75rem 0.85rem;
  border-radius: 10px;
  background: #1a1510;
  border: 1px solid #b45309;
  color: #fcd34d;
  font-size: 0.88rem;
  line-height: 1.5;
}
.whick-trial-provision {
  position: fixed;
  inset: 0;
  z-index: 12000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  background: rgba(8, 10, 16, 0.88);
}
.whick-trial-provision[hidden] {
  display: none !important;
}
.whick-trial-provision__panel {
  width: 100%;
  max-width: none;
  padding: 1.5rem 1.25rem;
  border-radius: 14px;
  background: #141820;
  border: 1px solid #3b82f6;
  text-align: center;
}
.whick-trial-provision__title {
  margin: 0 0 0.5rem;
  font-size: 1.1rem;
  color: #e8ecf4;
}
.whick-trial-provision__msg {
  margin: 0 0 1rem;
  color: #93c5fd;
  font-size: 0.95rem;
}
.whick-trial-provision__files {
  display: flex;
  justify-content: center;
  gap: 0.35rem;
  margin-bottom: 0.85rem;
  min-height: 2.5rem;
}
.whick-trial-provision__file {
  display: inline-block;
  width: 2.2rem;
  height: 2.6rem;
  border-radius: 4px;
  background: linear-gradient(145deg, #2563eb 0%, #1e3a5f 100%);
  opacity: 0.35;
  animation: whick-trial-file-copy 1.1s ease-in-out infinite;
}
.whick-trial-provision__file:nth-child(2) {
  animation-delay: 0.2s;
}
.whick-trial-provision__file:nth-child(3) {
  animation-delay: 0.4s;
}
@keyframes whick-trial-file-copy {
  0%,
  100% {
    transform: translateY(0) scale(0.92);
    opacity: 0.35;
  }
  50% {
    transform: translateY(-10px) scale(1);
    opacity: 1;
  }
}
body.whick-trial-provisioning {
  overflow: hidden;
}
.whick-trial-page--mobile .whick-trial-page__extras {
  margin-top: 1rem;
}
.whick-trial-reg-flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  margin: 1rem 0;
}
@media (max-width: 560px) {
  .whick-trial-reg-flow {
    grid-template-columns: 1fr;
  }
}
.whick-trial-reg-node {
  background: #0c0e12;
  padding: 0.75rem;
  border-radius: 8px;
  text-align: center;
}
.whick-trial-reg-node span {
  display: block;
  font-size: 0.75rem;
  color: #8b95a8;
}
.whick-trial-reg-progress {
  height: 6px;
  background: #252b38;
  border-radius: 3px;
  margin: 1rem 0;
  overflow: hidden;
}
.whick-trial-reg-progress__bar {
  height: 100%;
  background: linear-gradient(90deg, #3b82f6, #22d3ee);
  width: 0;
  transition: width 0.3s ease;
}
.whick-trial-reg-steps {
  list-style: none;
  padding: 0;
  margin: 0;
}
.whick-trial-reg-steps__item {
  display: flex;
  gap: 0.75rem;
  padding: 0.65rem 0;
  border-bottom: 1px solid #252b38;
  opacity: 0.45;
}
.whick-trial-reg-steps__item.is-active {
  opacity: 1;
  color: #93c5fd;
  scroll-margin-top: 5rem;
  scroll-margin-bottom: 2rem;
}
.whick-trial-reg-steps__item.is-done {
  opacity: 0.75;
  color: #6ee7b7;
}
.whick-trial-reg-steps__n {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background: #252b38;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
}
.whick-trial-spatial__meter {
  height: 8px;
  background: #252b38;
  border-radius: 4px;
  margin: 1rem 0;
  overflow: hidden;
}
.whick-trial-spatial__meter span {
  display: block;
  height: 100%;
  width: 0;
  background: #22d3ee;
  transition: width 0.1s linear;
}
.whick-trial-lib-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1rem 0;
}

/* ── Library player ── */
.whick-library-player {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.whick-player-topbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  padding: 0.65rem 1rem;
  border-bottom: 1px solid #252b38;
  background: #0f1218;
}
.whick-player-sync-warn {
  flex: 1 1 100%;
  margin: 0;
  padding: 0.55rem 0.65rem;
  border-radius: 8px;
  background: #1a1510;
  border: 1px solid #b45309;
  color: #fcd34d;
  font-size: 0.82rem;
  line-height: 1.45;
}
.whick-player-mobile-note {
  margin: 0;
  padding: 0.65rem 1rem;
  font-size: 0.84rem;
  line-height: 1.5;
  color: #b8c0d0;
  background: #141820;
  border-bottom: 1px solid #252b38;
}
.whick-player-topbar__logo {
  font-weight: 700;
  color: #e8eaef;
  text-decoration: none;
}
.whick-player-topbar__countdown {
  flex: 1;
  margin: 0;
  font-size: 0.85rem;
  color: #9aa3b5;
  text-align: center;
}
.whick-player-topbar__actions {
  display: flex;
  gap: 0.5rem;
}
.whick-btn--ghost {
  background: transparent;
  border: 1px solid #3d4656;
  color: #c8d0e0;
}
.whick-player-workspace {
  flex: 1;
  display: flex;
  min-height: 0;
  overflow: hidden;
}
.whick-player-frame {
  flex: 1;
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr);
  min-height: 0;
  height: 100%;
  overflow: hidden;
}
.whick-meta-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  justify-content: flex-end;
}
.whick-meta-overlay[hidden] {
  display: none !important;
}
.whick-meta-overlay__backdrop {
  position: absolute;
  inset: 0;
  border: none;
  background: rgba(0, 0, 0, 0.55);
  cursor: pointer;
}
.whick-meta-rail {
  position: relative;
  width: min(22rem, 92vw);
  max-height: 100%;
  overflow-y: auto;
  padding: 1rem 1.15rem 1.25rem;
  background: #0f1218;
  border-left: 1px solid #252b38;
  box-shadow: -8px 0 24px rgba(0, 0, 0, 0.35);
  display: flex;
  flex-direction: column;
  z-index: 1;
}
.whick-meta-rail__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.85rem;
  flex-shrink: 0;
}
.whick-meta-rail__head h2 {
  margin: 0;
  font-size: 1.05rem;
}
.whick-meta-rail__close {
  border: none;
  background: transparent;
  color: #9aa3b5;
  font: inherit;
  cursor: pointer;
  padding: 0.25rem 0.5rem;
}
.whick-meta-rail .whick-track-detail {
  flex: 1;
  flex-direction: column;
  align-items: stretch;
  padding: 0;
  border: none;
  min-height: 0;
}
.whick-meta-rail .whick-track-detail__cover {
  width: 100%;
  height: min(240px, 36vh);
  min-height: 160px;
  border-radius: 10px;
  flex-shrink: 0;
}
.whick-meta-rail .whick-track-detail__title {
  margin: 0.75rem 0 0;
  font-size: 1.15rem;
  font-weight: 600;
}
.whick-meta-rail__foot {
  margin-top: 1rem;
  flex-shrink: 0;
}
.whick-meta-dl {
  margin: 1rem 0 0;
}
.whick-meta-dl__row {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid #252b38;
  font-size: 0.9rem;
}
.whick-meta-dl__row dt {
  margin: 0;
  color: #9aa3b5;
  font-size: 0.8rem;
}
.whick-meta-dl__row dd {
  margin: 0;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.whick-library-player--player-only .whick-player-dock__tracks,
.whick-library-player--dock-empty .whick-player-dock__tracks {
  display: none !important;
}
.whick-library-player--player-only .whick-player-dock,
.whick-library-player--dock-empty .whick-player-dock {
  min-height: 0;
  max-height: none;
  border-top: none;
}
/* 하단 플레이어 — 페이지 레이아웃 밖 고정 레이어 (1~10번 탭) */
.whick-player-bar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 160;
  width: 100%;
  max-width: none;
  transform: none;
  display: flex;
  flex-direction: column;
  background: #0f1218;
  border-top: 1px solid #252b38;
  box-shadow: 0 -10px 28px rgba(0, 0, 0, 0.5);
  pointer-events: auto;
}
.whick-player-bar[hidden] {
  display: none !important;
}
.whick-library-player {
  --whick-player-bar-h: 3.75rem;
}
/* 하단 고정 바 여백은 스크롤 영역(.whick-player-main) padding-bottom 에서만 처리 */
.whick-lib-session {
  margin-top: 1rem;
}
.whick-lib-session .whick-track-board-wrap {
  max-height: none;
  overflow: visible;
}
@media (max-width: 960px) {
  .whick-player-frame:not(.is-player-accordion) {
    grid-template-columns: 56px 1fr;
  }
  .whick-browse-split {
    grid-template-columns: 1fr;
  }
}

/* 모바일: 플레이어 소메뉴 아코디언 */
@media (max-width: 768px) {
  .whick-player-frame.is-player-accordion {
    display: block;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: calc(var(--whick-player-bar-h, 5.5rem) + 0.75rem + env(safe-area-inset-bottom, 0px));
  }
  .whick-player-frame.is-player-accordion > .whick-player-sidebar,
  .whick-player-frame.is-player-accordion > .whick-player-main {
    display: none !important;
    pointer-events: none !important;
    visibility: hidden !important;
  }
  .whick-player-accordion {
    padding: 0.5rem 0.65rem 0.75rem;
    position: relative;
    z-index: 2;
  }
  .whick-player-acc-summary {
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
  }
  .whick-player-acc-item {
    border: 1px solid #252b38;
    border-radius: 8px;
    margin-bottom: 0.45rem;
    background: #141820;
    overflow: hidden;
  }
  .whick-player-acc-item[open] {
    border-color: #3b82f6;
  }
  .whick-player-acc-summary {
    padding: 0.65rem 0.85rem;
    font-weight: 600;
    font-size: 0.9rem;
    color: #e8eaef;
    cursor: pointer;
    list-style: none;
  }
  .whick-player-acc-summary::-webkit-details-marker {
    display: none;
  }
  .whick-player-acc-summary::after {
    content: '+';
    float: right;
    color: #6b7280;
    font-weight: 400;
  }
  .whick-player-acc-item[open] .whick-player-acc-summary::after {
    content: '−';
  }
  .whick-player-acc-body {
    padding: 0 0.75rem 0.85rem;
    border-top: 1px solid #252b38;
  }
  .whick-player-acc-body .whick-player-panel {
    display: block !important;
    padding: 0.75rem 0 0;
  }
  .whick-player-acc-body .whick-player-panel[hidden] {
    display: none !important;
  }
  .whick-player-acc-body .whick-player-panel h1 {
    font-size: 1.15rem;
    margin-top: 0;
  }

  .whick-trial-shell.is-trial-shell-accordion .whick-trial-shell__block {
    margin-bottom: 0.45rem;
  }
  .whick-trial-shell-acc {
    border: 1px solid #252b38;
    border-radius: 8px;
    background: #141820;
  }
  .whick-trial-shell-acc .whick-acc-summary {
    padding: 0.65rem 0.85rem;
    font-weight: 600;
    color: #e8eaef;
  }
  .whick-trial-shell-acc .whick-acc-body {
    padding: 0 0.85rem 0.75rem;
    font-size: 0.88rem;
    color: #b8c0d0;
  }
  .whick-trial-shell-acc .whick-trial-shell__list {
    margin: 0;
    padding-left: 1.1rem;
  }
}
.whick-player-bar .whick-player-dock {
  flex-shrink: 0;
  background: #0f1218;
  min-height: 0;
  max-height: min(32vh, 260px);
}
.whick-track-detail {
  display: flex;
  gap: 0.85rem;
  min-width: 0;
}
.whick-track-detail__cover {
  width: 72px;
  height: 72px;
  border-radius: 8px;
  flex-shrink: 0;
  display: block;
  overflow: hidden;
  position: relative;
}
.whick-album-card__cover,
.whick-album-detail__cover {
  overflow: hidden;
  position: relative;
}
.whick-cover--preparing .whick-cover-status {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.4rem;
  text-align: center;
  font-size: 0.62rem;
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.55);
  pointer-events: none;
}
.whick-track-detail__cover.whick-cover--preparing .whick-cover-status {
  font-size: 0.52rem;
  padding: 0.2rem;
}
img.whick-cover-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.28s ease;
}
.whick-cover--ready img.whick-cover-img {
  opacity: 1;
}
.whick-track-detail__eyebrow {
  margin: 0 0 0.2rem;
  font-size: 0.68rem;
  color: #6b7280;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.whick-track-detail__title {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  line-height: 1.3;
}
.whick-track-detail__line {
  margin: 0.15rem 0;
  font-size: 0.8rem;
  color: #9aa3b5;
}
.whick-track-detail__extra {
  margin: 0.35rem 0 0;
  font-size: 0.75rem;
}
.whick-player-dock__tracks {
  display: flex;
  flex-direction: column;
  min-height: 0;
  min-width: 0;
}
.whick-player-dock .whick-trial-search {
  padding: 0.5rem 0.75rem 0;
  flex-shrink: 0;
}
.whick-player-dock .whick-trial-search input {
  width: 100%;
  padding: 0.45rem 0.6rem;
  border-radius: 6px;
  border: 1px solid #3d4656;
  background: #0c0e12;
  color: #e8eaef;
}
.whick-player-dock .whick-trial-tracklist {
  flex: 1;
  overflow-y: auto;
  margin: 0;
  padding: 0;
  list-style: none;
  display: block;
}
.whick-trial-track-row {
  border-bottom: 1px solid #1e2430;
}
.whick-trial-track-check input[type='checkbox'],
.whick-track-board__cb,
.whick-dock-select-all input {
  width: 1.1rem;
  height: 1.1rem;
  accent-color: #3b82f6;
}
.whick-board-artists[hidden],
.whick-artist-list[hidden] {
  display: none !important;
}
.whick-album-browse {
  margin-top: 0.5rem;
}
.whick-album-browse:not(.is-album-detail) .whick-album-detail {
  display: none !important;
}
.whick-album-browse.is-album-detail .whick-album-grid {
  display: none !important;
}
.whick-album-browse.is-album-detail .whick-album-detail {
  display: block !important;
}
.whick-album-detail[hidden] {
  display: none !important;
}
.whick-album-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 1rem;
  margin-top: 0.75rem;
}
.whick-album-card {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 0;
  border: none;
  background: transparent;
  color: inherit;
  cursor: pointer;
  text-align: left;
}
.whick-album-card__cover {
  width: 100%;
  aspect-ratio: 1;
  min-height: 120px;
  border-radius: 8px;
  display: block;
  box-sizing: border-box;
}
.whick-album-detail__cover {
  width: 96px;
  height: 96px;
  min-height: 96px;
  border-radius: 8px;
  flex-shrink: 0;
  display: block;
}
.whick-album-card__title {
  font-size: 0.85rem;
  font-weight: 600;
  line-height: 1.25;
}
.whick-album-card__meta {
  font-size: 0.72rem;
  color: #9aa3b5;
}
.whick-album-detail__tracks {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: none;
  overflow: visible;
}
.whick-album-detail__tracks li {
  margin: 0;
}
.whick-album-detail__track {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.5rem 0.65rem;
  border: none;
  background: transparent;
  color: #e8eaef;
  cursor: pointer;
  border-radius: 6px;
  font-size: 0.85rem;
}
.whick-album-detail__track:hover,
.whick-album-detail__track.is-active {
  background: #1e3a5f;
}
.whick-browse-list {
  list-style: none;
  padding: 0;
  margin: 0.75rem 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.whick-browse-item {
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  border: 1px solid #3d4656;
  background: #141820;
  color: #e8eaef;
  cursor: pointer;
  font-size: 0.82rem;
}
.whick-browse-item.is-active {
  border-color: #3b82f6;
  background: #1e3a5f;
}
.whick-track-board-wrap {
  margin-top: 0;
  overflow: visible;
}
.whick-track-board {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}
.whick-track-board thead th {
  position: sticky;
  top: 0;
  background: #1a1f28;
  color: #9aa3b5;
  font-weight: 600;
  text-align: left;
  padding: 0.5rem 0.65rem;
  border-bottom: 1px solid #252b38;
  z-index: 1;
}
.whick-track-board tbody td {
  padding: 0.45rem 0.65rem;
  border-bottom: 1px solid #1e2430;
  vertical-align: middle;
}
.whick-track-board tbody tr {
  cursor: pointer;
}
.whick-track-board tbody tr:hover {
  background: #1a2230;
}
.whick-track-board tbody tr.is-active {
  background: #1e3a5f;
}
.whick-track-board__cb {
  width: 1rem;
  height: 1rem;
  accent-color: #3b82f6;
}
.whick-track-board__album--link {
  color: #93c5fd;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.whick-track-board__album--link:hover {
  color: #bfdbfe;
}
.whick-artist-board {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  max-height: none;
  overflow: visible;
}
.whick-artist-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.5rem;
  align-items: center;
  width: 100%;
  text-align: left;
  padding: 0.55rem 0.75rem;
  border: 1px solid #252b38;
  border-radius: 8px;
  background: #141820;
  color: #e8eaef;
  cursor: pointer;
  font-size: 0.85rem;
}
.whick-artist-row.is-active {
  border-color: #3b82f6;
  background: #1e3a5f;
}
.whick-artist-row__count {
  font-size: 0.75rem;
  color: #9aa3b5;
}
.whick-lib-sample-progress {
  margin: 1rem 0;
  padding: 0.85rem 1rem;
  background: #141820;
  border: 1px solid #252b38;
  border-radius: 8px;
}
.whick-lib-sample-progress__bar {
  height: 8px;
  background: #252b38;
  border-radius: 4px;
  overflow: hidden;
  margin: 0.5rem 0;
}
.whick-lib-sample-progress__bar span {
  display: block;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, #3b82f6, #22d3ee);
  transition: width 0.08s linear;
}
.whick-lib-sample-progress__pct {
  margin: 0;
  font-size: 0.8rem;
  color: #7dd3fc;
  text-align: right;
}
.whick-ai-source-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
}
.whick-ai-source {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.7rem;
  border: 1px solid #3d4656;
  border-radius: 999px;
  background: #141820;
  font-size: 0.8rem;
  cursor: pointer;
  color: #c8d0e0;
}
.whick-ai-source:has(input:checked) {
  border-color: #3b82f6;
  background: #1e3a5f;
  color: #e8eaef;
}
.whick-ai-source input {
  width: 1rem;
  height: 1rem;
  accent-color: #3b82f6;
}
.whick-ai-source__icon {
  font-size: 0.9rem;
  line-height: 1;
}
.whick-dsp-fallback {
  color: #fca5a5;
}
.whick-browse-empty-hint {
  margin: 0 0 0.75rem;
  padding: 0.65rem 0.85rem;
  background: #1a2230;
  border-radius: 8px;
}
.whick-link-btn {
  border: none;
  background: none;
  color: #60a5fa;
  text-decoration: underline;
  cursor: pointer;
  font: inherit;
  padding: 0;
}
/* CamillaNode 스타일 EQ */
.whick-camilla-node__inner {
  background: #151b24;
  border: 1px solid #252b38;
  border-radius: 10px;
  padding: 1rem;
}
.whick-camilla-node__title {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 0.65rem;
}
.whick-camilla-node__title h1 {
  margin: 0;
  font-size: 1.25rem;
}
.whick-camilla-node__badge {
  font-size: 0.72rem;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  background: #1e3a5f;
  color: #93c5fd;
}
.whick-camilla-status {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.85rem;
  font-size: 0.72rem;
  color: #9aa3b5;
  margin-bottom: 0.65rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid #252b38;
}
.whick-camilla-status__run {
  color: #6ee7b7;
}
.whick-camilla-visual {
  margin-bottom: 0.75rem;
}
.whick-camilla-spectrum {
  display: block;
  width: 100%;
  height: 56px;
  border-radius: 6px 6px 0 0;
}
.whick-camilla-curve-wrap {
  position: relative;
  background: #0f141c;
  border-radius: 0 0 8px 8px;
}
.whick-camilla-curve {
  display: block;
  width: 100%;
  height: 200px;
}
.whick-dsp-preset-desc {
  margin: 0.4rem 0 0.65rem;
  font-size: 0.8rem;
  color: #9aa3b5;
  min-height: 1.2em;
}
.whick-track-board tbody td:nth-child(3),
.whick-track-board tbody td:nth-child(4) {
  min-width: 6rem;
  max-width: 14rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.whick-track-board--title-first {
  table-layout: fixed;
}
.whick-track-board--title-first col.col-check {
  width: 2.25rem;
}
.whick-track-board--title-first col.col-title {
  width: 58%;
}
.whick-track-board--title-first col.col-artist {
  width: 22%;
}
.whick-track-board--title-first col.col-album {
  width: 18%;
}
.whick-track-board--title-first tbody td:nth-child(2) {
  word-break: break-word;
  white-space: normal;
  line-height: 1.35;
}
.whick-track-board--title-first tbody td:nth-child(3),
.whick-track-board--title-first tbody td:nth-child(4) {
  min-width: 0;
  max-width: none;
  font-size: 0.75rem;
  color: #9aa3b5;
}
@media (max-width: 768px) {
  .whick-track-board--title-first col.col-title {
    width: 72%;
  }
  .whick-track-board--title-first col.col-artist {
    width: 22%;
  }
  .whick-track-board--title-first thead th:nth-child(4),
  .whick-track-board--title-first tbody td:nth-child(4) {
    display: none;
  }
}
.whick-player-dock,
.whick-player-transport {
  flex-shrink: 0;
}
.whick-library-player--player-only .whick-player-dock {
  display: block;
}
.whick-camilla-knobs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}
.whick-camilla-knob {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.75rem;
  color: #9aa3b5;
}
.whick-camilla-knob input[type='range'] {
  width: 100%;
  accent-color: #22c55e;
}
.whick-camilla-presets {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  list-style: none;
  margin: 0 0 0.75rem;
  padding: 0;
}
.whick-camilla-presets .whick-dsp-preset {
  padding: 0.35rem 0.7rem;
  border-radius: 6px;
  border: 1px solid #3d4656;
  background: #1a1f28;
  color: #c8d0e0;
  font-size: 0.78rem;
  cursor: pointer;
}
.whick-camilla-presets .whick-dsp-preset.is-selected {
  border-color: #22c55e;
  background: #14532d;
  color: #bbf7d0;
}
.whick-camilla-peq-sliders {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  gap: 0.35rem;
  margin: 1rem 0 0.5rem;
  padding: 0.5rem 0.25rem;
  min-height: 150px;
  align-items: flex-end;
}
.whick-camilla-peq-band {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  min-width: 0;
  gap: 0.35rem;
  font-size: 0.7rem;
  color: #9aa3b5;
}
.whick-camilla-peq-band input[type='range'] {
  writing-mode: vertical-lr;
  direction: rtl;
  height: 120px;
  width: 1.5rem;
  margin: 0;
  accent-color: #22d3ee;
}
.whick-camilla-peq-band__gain {
  font-variant-numeric: tabular-nums;
  color: #e8eaef;
}
.whick-camilla-peq-wrap {
  overflow-x: auto;
  margin-bottom: 0.75rem;
}
.whick-camilla-peq {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}
.whick-camilla-peq th {
  text-align: left;
  color: #6b7280;
  padding: 0.35rem 0.5rem;
  border-bottom: 1px solid #252b38;
}
.whick-camilla-peq td {
  padding: 0.35rem 0.4rem;
  border-bottom: 1px solid #1e2430;
}
.whick-camilla-peq input[type='number'],
.whick-camilla-peq select {
  width: 100%;
  max-width: 5.5rem;
  padding: 0.25rem 0.35rem;
  border-radius: 4px;
  border: 1px solid #3d4656;
  background: #0c0e12;
  color: #e8eaef;
  font-size: 0.78rem;
}
.whick-peq-toggle {
  display: inline-flex;
  align-items: center;
}
.whick-peq-toggle input {
  accent-color: #22c55e;
  width: 1rem;
  height: 1rem;
}
.whick-camilla-actions {
  margin-top: 0.5rem;
}
.whick-player-sidebar {
  border-right: 1px solid #252b38;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  background: #0f1218;
}
.whick-player-nav ul {
  list-style: none;
  margin: 0;
  padding: 0.5rem 0;
}
.whick-player-nav__btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  text-align: left;
  padding: 0.55rem 0.75rem;
  border: none;
  background: transparent;
  color: #9aa3b5;
  font-size: 0.8rem;
  cursor: pointer;
}
.whick-player-nav__btn:hover,
.whick-player-nav__btn.is-active {
  background: #1a2230;
  color: #e8eaef;
}
.whick-player-nav__n {
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 4px;
  background: #252b38;
  font-size: 0.65rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.whick-player-frame > .whick-player-main {
  min-height: 0;
  min-width: 0;
  height: 100%;
  max-height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior-y: contain;
  padding: 1.25rem 1.5rem;
  padding-bottom: calc(1.25rem + var(--whick-player-bar-h, 4.5rem));
  -webkit-overflow-scrolling: touch;
}
/* 5~10 목록: 세로 스크롤바 숨김 — 휠·트랙패드·터치만 */
.whick-player-frame > .whick-player-main,
.whick-player-sidebar {
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.whick-player-frame > .whick-player-main::-webkit-scrollbar,
.whick-player-sidebar::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
}
.whick-player-panel[hidden] {
  display: none !important;
}
/* 패널 본문은 자연 높이 — 세로 스크롤은 .whick-player-main 한 곳만 */
.whick-player-panel--browse:not([hidden]) {
  display: block;
}
.whick-browse-body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.whick-browse-split {
  flex: 1;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(160px, 220px) 1fr;
  gap: 0.75rem;
  align-items: stretch;
}
.whick-browse-split__aside {
  overflow-y: visible;
  min-height: 120px;
}
.whick-browse-split__main {
  min-height: 0;
  overflow: visible;
}
.whick-player-panel--browse .whick-track-board-wrap {
  margin-top: 0;
  max-height: none;
  overflow: visible;
}
/* 5·9·10 — 라이브러리·재생이력·전체목록: 메인 스크롤만 */
.whick-player-panel[data-panel='library'] .whick-track-board-wrap,
.whick-player-panel[data-panel='playlists'] .whick-track-board-wrap,
.whick-player-panel[data-panel='favorites'] .whick-track-board-wrap,
.whick-player-panel[data-panel='metadata'] .whick-track-board-wrap {
  max-height: none;
  overflow: visible;
}
.whick-browse-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 0.65rem;
}
.whick-artist-toolbar[hidden] {
  display: none !important;
}
.whick-fav-browse {
  margin-top: 0.35rem;
}
.whick-fav-browse:not(.is-fav-detail) .whick-fav-detail {
  display: none !important;
}
.whick-fav-browse.is-fav-detail .whick-fav-list {
  display: none !important;
}
.whick-fav-browse.is-fav-detail .whick-fav-detail {
  display: block !important;
}
.whick-fav-create {
  margin-bottom: 1rem;
  padding: 1rem 1.1rem;
  background: #141820;
  border: 1px solid #252b38;
  border-radius: 12px;
}
.whick-fav-create__label {
  display: block;
  font-size: 0.78rem;
  color: #9aa3b5;
  margin-bottom: 0.45rem;
}
.whick-fav-create__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}
.whick-fav-create__input {
  flex: 1;
  min-width: 12rem;
  padding: 0.5rem 0.65rem;
  border-radius: 8px;
  border: 1px solid #3d4656;
  background: #0c0e12;
  color: #e8eaef;
}
.whick-fav-playlist-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 0.75rem;
}
.whick-fav-card {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  text-align: left;
  padding: 0.85rem 1rem;
  border: 1px solid #252b38;
  border-radius: 10px;
  background: #141820;
  color: inherit;
  cursor: pointer;
}
.whick-fav-card:hover,
.whick-fav-card.is-active {
  border-color: #3b82f6;
  background: #1a2230;
}
.whick-fav-card__title {
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.3;
}
.whick-fav-card__meta {
  font-size: 0.72rem;
  color: #9aa3b5;
}
.whick-fav-detail__head {
  margin: 0.5rem 0 0.75rem;
}
.whick-fav-detail__title {
  margin: 0 0 0.25rem;
  font-size: 1.35rem;
}
.whick-fav-detail__toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  align-items: center;
  margin-bottom: 0.65rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid #252b38;
}
.whick-fav-picker {
  border: 1px solid #252b38;
  border-radius: 12px;
  padding: 1.15rem 1.25rem;
  max-width: 22rem;
  width: calc(100% - 2rem);
  background: #141820;
  color: #e8eaef;
}
.whick-fav-picker::backdrop {
  background: rgba(0, 0, 0, 0.55);
}
.whick-fav-picker h3 {
  margin: 0 0 0.5rem;
  font-size: 1.1rem;
}
.whick-fav-picker__hint {
  margin: 0 0 0.75rem;
  font-size: 0.82rem;
}
.whick-fav-picker__field {
  display: block;
  margin-bottom: 0.65rem;
}
.whick-fav-picker__field span {
  display: block;
  font-size: 0.75rem;
  color: #9aa3b5;
  margin-bottom: 0.25rem;
}
.whick-fav-picker__field select,
.whick-fav-picker__field input {
  width: 100%;
  padding: 0.45rem 0.6rem;
  border-radius: 8px;
  border: 1px solid #3d4656;
  background: #0c0e12;
  color: #e8eaef;
}
.whick-fav-picker__actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
}
/* 7·8 — 아티스트·앨범: 우측/내부 세로 스크롤바 제거, 메인과 함께 스크롤 */
.whick-player-panel[data-panel='artists'] .whick-artist-list,
.whick-player-panel[data-panel='artists'] .whick-track-board-wrap,
.whick-player-panel[data-panel='albums'] .whick-album-grid,
.whick-player-panel[data-panel='albums'] .whick-album-detail,
.whick-player-panel[data-panel='albums'] .whick-track-board-wrap {
  max-height: none;
  overflow: visible;
}
.whick-player-panel--browse .whick-album-grid {
  max-height: none;
  overflow: visible;
}
.whick-player-panel h1 {
  margin-top: 0;
  font-size: 1.5rem;
}
/* 플레이어 홈 — 뮤직서버 체험 박스 */
.whick-player-home-box {
  padding: 1rem 1.1rem;
  margin-bottom: 1.25rem;
  border: 1px solid #252b38;
  border-radius: 12px;
  background: #141820;
}
.whick-player-home-box h1 {
  margin: 0 0 1rem;
  font-size: 1.35rem;
}
.whick-player-home__extras {
  margin-top: 0.25rem;
}
.whick-player-home-remote {
  display: grid;
  grid-template-columns: minmax(140px, 220px) 1fr;
  gap: 2rem 2.5rem;
  align-items: start;
  margin-top: 0;
}
.whick-player-home-remote__visual {
  margin: 0;
  display: flex;
  justify-content: center;
  padding: 1rem;
  background: linear-gradient(165deg, #141820 0%, #0c0e12 100%);
  border: 1px solid #252b38;
  border-radius: 16px;
}
.whick-player-home-remote__visual .whick-shot--inline {
  width: 100%;
  max-width: 200px;
}
.whick-player-home-remote__visual .whick-shot--inline svg {
  display: block;
  width: 100%;
  height: auto;
  filter: drop-shadow(0 12px 28px rgba(0, 0, 0, 0.45));
}
.whick-player-home-remote__side {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
}
.whick-player-home-remote__tagline {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 600;
  color: #e8eaef;
  line-height: 1.5;
}
.whick-player-home-remote__chain {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  padding: 0.85rem 1rem;
  background: #0c0e12;
  border: 1px solid #252b38;
  border-radius: 10px;
  font-size: 0.82rem;
  color: #93c5fd;
  font-weight: 600;
}
.whick-player-home-remote__arrow {
  color: #6b7280;
  font-weight: 400;
}
.whick-player-home-remote__hints {
  margin: 0;
  padding-left: 1.15rem;
  color: #9aa3b5;
  font-size: 0.9rem;
  line-height: 1.55;
}
.whick-player-home-remote__hints li {
  margin: 0.35rem 0;
}

.whick-remote-connect-modal[hidden] {
  display: none !important;
}
.whick-remote-connect-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.whick-remote-connect-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
}
.whick-remote-connect-modal__panel {
  position: relative;
  z-index: 1;
  max-width: 520px;
  width: 100%;
  max-height: 92vh;
  overflow-y: auto;
  background: #141820;
  border: 1px solid #353b45;
  border-radius: 14px;
  padding: 1.35rem 1.5rem 1.5rem;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}
.whick-remote-connect-modal__panel h2 {
  margin: 0 0 0.5rem;
  font-size: 1.25rem;
}
.whick-remote-connect-modal__lead {
  margin: 0 0 1rem;
  font-size: 0.92rem;
  color: #b8c0d0;
  line-height: 1.5;
}
.whick-remote-connect-modal__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: center;
  margin-bottom: 1rem;
}
.whick-remote-connect-modal__phone {
  margin: 0;
  padding: 0.75rem;
  background: #0c0e12;
  border-radius: 12px;
  border: 1px solid #252b38;
  text-align: center;
}
.whick-remote-connect-modal__phone .whick-shot--inline,
.whick-remote-connect-modal__preview .whick-shot--inline {
  max-width: 160px;
  margin: 0 auto;
}
.whick-remote-connect-modal__phone .whick-shot--inline svg,
.whick-remote-connect-modal__preview .whick-shot--inline svg {
  display: block;
  width: 100%;
  height: auto;
}
.whick-remote-connect-modal__qr-wrap {
  text-align: center;
}
.whick-remote-connect-modal__code {
  display: inline-block;
  padding: 0.5rem;
  background: #fff;
  border-radius: 8px;
  margin: 0.5rem 0;
}
.whick-remote-connect-modal__url {
  font-size: 0.75rem;
  word-break: break-all;
}
.whick-remote-connect-modal__url a {
  color: #93c5fd;
}
.whick-remote-connect-modal__close {
  position: absolute;
  top: 0.65rem;
  right: 0.75rem;
  border: none;
  background: transparent;
  color: #9aa3b5;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
}

/* 스마트폰 리모컨 앱 — 사이트 GNB 없음 · 100dvh 단일 셸 */
.whick-body--remote {
  overflow: hidden;
  height: 100vh;
  height: 100dvh;
  max-height: 100dvh;
  background: #0c0e12;
  color: #e8eaef;
  touch-action: manipulation;
  overscroll-behavior: none;
}
.whick-remote-app {
  height: 100%;
  min-height: 0;
  max-height: 100dvh;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: none;
  margin: 0;
  overflow: hidden;
}
.whick-main--remote {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 0;
  max-width: none;
  margin: 0;
  width: 100%;
  overflow: hidden;
}
.whick-remote-app__chrome {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding-top: env(safe-area-inset-top, 0px);
}
.whick-remote-app__top {
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem 0.75rem;
  padding: 0.65rem 1rem;
  border-bottom: 1px solid #252b38;
  background: #0f1218;
}
.whick-remote-app__home {
  font-size: 0.8rem;
  color: #8ab4f8;
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.whick-remote-app__top .whick-remote-app__sync {
  width: 100%;
  flex-basis: 100%;
  margin: 0;
}
.whick-remote-app__brand {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
}
.whick-remote-app__logo {
  color: #3b82f6;
  font-size: 1.1rem;
}
.whick-remote-app__title {
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.whick-remote-app__sync {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 0.3rem 0.55rem;
  border-radius: 999px;
  background: #1a1f28;
  color: #9aa3b5;
  border: 1px solid #2a3140;
  max-width: 52%;
  text-align: right;
  line-height: 1.25;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
@media (max-width: 768px) {
  .whick-remote-app__sync {
    max-width: 100%;
    text-align: left;
  }
}
.whick-remote-app__sync.is-ok {
  color: #6ee7b7;
  border-color: #065f46;
  background: #0f1f18;
}
.whick-remote-app__sync.is-warn {
  color: #fcd34d;
  border-color: #78350f;
  background: #1f1a0c;
}
.whick-remote-app__sync.is-pending {
  color: #93c5fd;
  border-color: #1e3a5f;
  background: #141820;
  animation: whick-sync-pulse 1.4s ease-in-out infinite;
}

@keyframes whick-sync-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.55;
  }
}
.whick-room-offline-alert {
  margin: 0 0 0.85rem;
  padding: 0.85rem 0.95rem;
  border-radius: 10px;
  border: 1px solid #b45309;
  background: #1a1510;
  color: #fde68a;
  font-size: 0.88rem;
  line-height: 1.55;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.whick-room-offline-alert code {
  font-size: 0.8em;
  color: #fcd34d;
}
.whick-remote-app__scroll {
  flex: 1;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding: 1rem 1rem 0.5rem;
}
.whick-remote-app__panel[hidden] {
  display: none !important;
  visibility: hidden;
  pointer-events: none;
}
.whick-remote-app__panel:not([hidden]) {
  display: block;
  visibility: visible;
  pointer-events: auto;
}
.whick-remote-app__lead {
  margin: 0 0 1rem;
  font-size: 0.9rem;
  color: #9aa3b5;
  line-height: 1.5;
}
.whick-remote-spatial .whick-room-wizard {
  padding: 0;
}
.whick-remote-spatial .whick-room-wizard--remote-app .whick-btn {
  width: 100%;
  min-height: 48px;
  margin-bottom: 0.5rem;
}
.whick-remote-spatial .whick-room-hub-actions {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin: 1rem 0;
}
.whick-remote-spatial .whick-room-sync--remote {
  font-size: 0.85rem;
  padding: 0.65rem 0.75rem;
  background: #141820;
  border: 1px solid #252b38;
  border-radius: 10px;
}
.whick-remote-complete {
  margin: 1rem 0 0.5rem;
  padding: 1rem;
  background: #12161f;
  border: 1px solid #2d6a4f;
  border-radius: 12px;
}
.whick-remote-complete__title {
  margin: 0 0 0.75rem;
  font-size: 1.15rem;
  color: #86efac;
}
.whick-remote-complete .whick-btn {
  width: 100%;
  min-height: 48px;
  margin-top: 0.5rem;
}
.whick-remote-complete--applied {
  border-color: #3b82f6;
}

/* 마이크 허용 시트 (리모컨 앱 · 전체 화면) */
body.whick-mic-sheet-open {
  overflow: hidden;
}
.whick-mic-sheet {
  position: fixed;
  inset: 0;
  z-index: 500;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 1rem;
  padding-bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
  background: rgba(0, 0, 0, 0.62);
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box;
}
.whick-mic-sheet__panel {
  width: 100%;
  max-width: min(420px, calc(100vw - 2rem));
  max-height: min(88vh, 640px);
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  border-radius: 16px 16px 12px 12px;
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.45);
  box-sizing: border-box;
}
.whick-body--remote .whick-mic-sheet__panel,
.whick-body--remote .whick-mic-permit {
  width: 100%;
  max-width: 100%;
  writing-mode: horizontal-tb;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.whick-body--remote .whick-mic-permit__headline,
.whick-body--remote .whick-mic-permit__detail,
.whick-body--remote .whick-mic-permit__ok-lead,
.whick-body--remote .whick-mic-permit__settings-hint,
.whick-body--remote .whick-mic-permit__sweep-note,
.whick-body--remote .whick-mic-permit__banner,
.whick-body--remote .whick-mic-sheet__pos {
  writing-mode: horizontal-tb;
  white-space: normal;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.whick-body--remote .whick-mic-permit__steps li {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
}
.whick-body--remote .whick-remote-spatial,
.whick-body--remote .whick-remote-spatial .whick-room-wizard {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}
.whick-mic-sheet__pos {
  margin: 0 0 0.5rem;
  padding: 0 0.25rem;
  font-size: 0.82rem;
}
.whick-mic-permit.is-granted {
  border-color: #065f46;
  background: #0f1a14;
}
.whick-mic-permit__ok-lead {
  margin: 0 0 0.75rem;
  font-size: 0.95rem;
  line-height: 1.55;
  color: #d1fae5;
}
.whick-mic-sheet .whick-mic-permit {
  margin: 0;
}

/* 마이크 허용 · OS별 설정 안내 */
.whick-mic-permit {
  margin: 1rem 0;
  padding: 1rem 1rem 1.1rem;
  border-radius: 12px;
  border: 1px solid #2a3140;
  background: #141820;
}
.whick-mic-permit.is-pending {
  border-color: #3b82f6;
  box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.25);
}
.whick-mic-permit.is-denied {
  border-color: #b45309;
  background: #1a1510;
}
.whick-mic-permit__headline {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  line-height: 1.45;
}
.whick-mic-permit__detail {
  margin: 0 0 0.75rem;
  color: #fca5a5;
  font-size: 0.9rem;
  line-height: 1.5;
}
.whick-mic-permit__pulse {
  display: flex;
  justify-content: center;
  margin: 0.75rem 0 1rem;
}
.whick-mic-permit__pulse span {
  display: block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #3b82f6;
  animation: whick-mic-pulse 1.2s ease-in-out infinite;
}
@keyframes whick-mic-pulse {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.5;
  }
  50% {
    transform: scale(1.35);
    opacity: 1;
  }
}
.whick-mic-permit__guide {
  margin: 0.75rem 0 1rem;
  padding: 0.85rem 0.9rem;
  border-radius: 10px;
  background: #0c0e12;
  border: 1px solid #252b38;
}
.whick-mic-permit__guide-title {
  margin: 0 0 0.65rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: #93c5fd;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.whick-mic-permit__steps {
  margin: 0;
  padding: 0;
  list-style: none;
}
.whick-mic-permit__steps li {
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  font-size: 0.88rem;
  line-height: 1.55;
  color: #c8d0de;
}
.whick-mic-permit__steps li + li {
  margin-top: 0.65rem;
}
.whick-mic-permit__step-n {
  flex-shrink: 0;
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 50%;
  background: #1e3a5f;
  color: #93c5fd;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.35rem;
  text-align: center;
}
.whick-mic-permit__settings-hint {
  margin: 0 0 1rem;
  font-size: 0.85rem;
  line-height: 1.5;
  color: #9aa3b5;
}
.whick-mic-permit__sweep-note {
  margin: 0.75rem 0 0;
  font-size: 0.82rem;
}
.whick-mic-permit__banner {
  margin: 0.75rem 0;
  padding: 0.75rem 0.85rem;
  border-radius: 10px;
  background: #1a1510;
  border: 1px solid #b45309;
  color: #fcd34d;
  font-size: 0.88rem;
  line-height: 1.5;
}

.whick-remote-play__home,
.whick-remote-play__screen {
  position: relative;
  z-index: 1;
}
.whick-remote-play__sound-note {
  margin: 0 0 0.65rem;
  font-size: 0.88rem;
  line-height: 1.55;
  color: #c5cad6;
}
.whick-remote-play__hint {
  margin: 0 0 0.85rem;
  font-size: 0.82rem;
}
.whick-remote-menu-root__toggle {
  display: block;
  width: 100%;
  padding: 1rem 1.1rem;
  border: 1px solid #3b82f6;
  border-radius: 12px;
  background: #141820;
  color: #e8ecf4;
  font-weight: 700;
  font-size: 1rem;
  text-align: left;
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.whick-remote-menu-root__toggle[aria-expanded='true'] {
  border-radius: 12px 12px 0 0;
  border-bottom: none;
}
.whick-remote-menu-root__toggle[aria-expanded='true'] .whick-remote-menu-root__caret {
  transform: rotate(180deg);
}
.whick-remote-menu-root__caret {
  float: right;
  color: #93c5fd;
  transition: transform 0.15s ease;
}
.whick-remote-submenu {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid #3b82f6;
  border-top: none;
  border-radius: 0 0 12px 12px;
  background: #141820;
  overflow: hidden;
}
.whick-remote-submenu:not(.is-open) {
  display: none;
}
.whick-remote-submenu.is-open {
  display: block;
}
@media (max-width: 768px) {
  .whick-remote-play__home .whick-remote-menu-root__toggle {
    display: none;
  }
  .whick-remote-play__home .whick-remote-submenu,
  .whick-remote-play__home .whick-remote-submenu:not(.is-open),
  .whick-remote-play__home .whick-remote-submenu.is-open {
    display: block;
    border: none;
    border-radius: 0;
    padding-top: 0.25rem;
  }
  .whick-remote-play__home::before {
    content: '재생 메뉴';
    display: block;
    font-weight: 700;
    font-size: 0.95rem;
    color: #e8ecf4;
    margin-bottom: 0.35rem;
  }
}
.whick-remote-play__home[hidden],
.whick-remote-play__screen[hidden] {
  display: none !important;
}
.whick-remote-play__screen:not([hidden]) {
  display: block;
}
.whick-remote-submenu__btn {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.85rem 1.1rem;
  border: none;
  border-bottom: 1px solid #1e2430;
  background: transparent;
  color: #e8ecf4;
  font-size: 0.95rem;
  font-weight: 600;
  min-height: 48px;
  touch-action: manipulation;
  cursor: pointer;
  position: relative;
  z-index: 2;
  -webkit-tap-highlight-color: rgba(59, 130, 246, 0.2);
  pointer-events: auto;
}
.whick-remote-submenu__btn:active {
  background: rgba(59, 130, 246, 0.15);
}
.whick-remote-screen__head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
}
.whick-remote-screen__title {
  flex: 1;
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.whick-remote-screen__msg {
  margin: 0 0 0.65rem;
  font-size: 0.85rem;
  line-height: 1.45;
}
.whick-remote-screen__loading {
  margin: 0 0 0.5rem;
  font-size: 0.85rem;
  color: #93c5fd;
}
.whick-remote-player-bar {
  flex-shrink: 0;
  padding: 0.5rem 0.75rem calc(0.5rem + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid #252b38;
  background: #0f1218;
}
.whick-remote-player-bar[hidden] {
  display: none !important;
}
.whick-remote-player-bar__now {
  margin: 0 0 0.45rem;
  font-size: 0.82rem;
  color: #9aa3b5;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.whick-remote-player-bar__transport {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}
.whick-remote-player-bar .whick-transport-vol {
  flex: 1;
  min-width: 0;
}
body.whick-body--remote-play .whick-remote-app__scroll {
  padding-bottom: 0.25rem;
}
body.whick-body--remote-play .whick-remote-app__chrome {
  padding-bottom: 0;
}
.whick-remote-tracklist {
  list-style: none;
  margin: 0.75rem 0;
  padding: 0;
}
.whick-remote-track {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.75rem 0.85rem;
  margin-bottom: 0.35rem;
  border-radius: 10px;
  border: 1px solid #252b38;
  background: #141820;
  color: #e8ecf4;
  min-height: 48px;
}
.whick-remote-track__title {
  display: block;
  font-weight: 600;
  font-size: 0.95rem;
}
.whick-remote-track__artist {
  display: block;
  font-size: 0.8rem;
  color: #9aa3b5;
  margin-top: 0.15rem;
}

.whick-remote-app--room-only .whick-remote-app__dock {
  flex-wrap: wrap;
  justify-content: center;
}
.whick-remote-yt-cta {
  margin-top: 1rem;
  padding: 1rem 1.1rem;
}
.whick-remote-yt-cta__title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
}
.whick-remote-yt-cta__actions {
  margin: 0.85rem 0 0;
}
.whick-remote-yt-cta__actions .whick-btn {
  width: 100%;
  min-height: 48px;
}
.whick-remote-app__dock--mobile-skip {
  display: flex;
  justify-content: center;
  padding: 0.65rem 0.75rem calc(0.65rem + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid #252b38;
  background: #0f1218;
}
.whick-remote-app__dock--mobile-skip .whick-remote-dock__player {
  width: 100%;
  max-width: 420px;
  min-height: 52px;
}
.whick-remote-dock__mobile-actions {
  flex: 1 1 100%;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.5rem 0.75rem calc(0.35rem + env(safe-area-inset-bottom, 0px));
  width: 100%;
  box-sizing: border-box;
}
.whick-remote-dock__mobile-actions .whick-btn {
  width: 100%;
  min-height: 44px;
  justify-content: center;
  text-decoration: none;
  touch-action: manipulation;
}
.whick-player-mobile-yt {
  margin: 0 0 0.75rem;
  padding: 0 0.25rem;
}
.whick-player-mobile-yt__status {
  margin: 0 0 0.45rem;
  padding: 0.45rem 0.65rem;
  border-radius: 8px;
  background: #1a2030;
  border: 1px solid #2a3344;
  font-size: 0.85rem;
  color: #b8c0d0;
  line-height: 1.4;
}
.whick-player-mobile-yt__status.is-ok {
  border-color: #22c55e;
  color: #bbf7d0;
  background: #14532d;
}
.whick-player-mobile-yt__status.is-warn {
  border-color: #f59e0b;
  color: #fde68a;
}
.whick-player-mobile-yt .whick-btn {
  width: 100%;
  min-height: 48px;
}
.whick-yt-connect-toast {
  position: fixed;
  left: 50%;
  bottom: calc(var(--whick-player-bar-h, 5rem) + 1rem);
  transform: translateX(-50%);
  z-index: 300;
  max-width: 92vw;
  margin: 0;
  padding: 0.65rem 1rem;
  border-radius: 10px;
  background: #14532d;
  border: 1px solid #22c55e;
  color: #ecfdf5;
  font-size: 0.88rem;
  text-align: center;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
}
.whick-yt-connect-toast--error {
  background: #450a0a;
  border-color: #ef4444;
  color: #fecaca;
}
.whick-trial-reg-demo {
  border: none;
  border-radius: 12px;
  padding: 0;
  max-width: min(520px, 92vw);
  background: #141820;
  color: #e8eaef;
}
.whick-trial-reg-demo::backdrop {
  background: rgba(0, 0, 0, 0.65);
}
.whick-trial-reg-demo__inner {
  padding: 1.25rem 1.35rem 1.35rem;
}
.whick-trial-reg-demo__steps {
  margin: 0.85rem 0 1rem;
  padding-left: 1.1rem;
  font-size: 0.88rem;
  line-height: 1.5;
}
.whick-trial-reg-demo__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.whick-trial-shell__list--intro {
  margin: 0.75rem 0 1rem;
  padding-left: 1.1rem;
  font-size: 0.9rem;
  line-height: 1.55;
  color: #b8c0d0;
}
.whick-remote-app__dock {
  flex-shrink: 0;
  display: flex;
  justify-content: space-around;
  gap: 0.25rem;
  padding: 0.35rem 0.5rem calc(0.35rem + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid #252b38;
  background: #0f1218;
}
.whick-body--remote-play .whick-remote-app__dock {
  padding-bottom: calc(0.35rem + env(safe-area-inset-bottom, 0px));
}
.whick-remote-dock__btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
  padding: 0.4rem 0.25rem;
  border: none;
  background: transparent;
  color: #6b7280;
  font-size: 0.68rem;
  font-weight: 600;
  cursor: pointer;
  border-radius: 10px;
  touch-action: manipulation;
}
.whick-remote-dock__btn.is-active {
  color: #93c5fd;
  background: rgba(59, 130, 246, 0.12);
}
.whick-remote-dock__btn--soon {
  opacity: 0.45;
  cursor: default;
}
.whick-remote-dock__icon {
  font-size: 1.15rem;
  line-height: 1;
}

.whick-trial-spatial__status--rx {
  color: #93c5fd;
  padding: 0.65rem 0.75rem;
  background: #141820;
  border: 1px solid #252b38;
  border-radius: 10px;
}
.whick-trial-spatial__status--ok {
  color: #6ee7b7;
  padding: 0.65rem 0.75rem;
  background: #0f1f18;
  border: 1px solid #065f46;
  border-radius: 10px;
}
.whick-trial-spatial__status--fail {
  color: #fca5a5;
  padding: 0.65rem 0.75rem;
  background: #1f1418;
  border: 1px solid #7f1d1d;
  border-radius: 10px;
}

@media (max-width: 768px) {
  .whick-player-home-remote {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .whick-player-home-remote__visual {
    max-width: 200px;
    margin: 0 auto;
  }
  .whick-remote-connect-modal__body {
    grid-template-columns: 1fr;
  }
}
.whick-player-transport {
  flex-shrink: 0;
  border-top: 1px solid #252b38;
  padding: 0.65rem 1rem 0.85rem;
  background: #0f1218;
  position: relative;
  z-index: 10;
}
.whick-player-dock {
  flex-shrink: 0;
  z-index: 5;
}
.whick-artist-list {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  max-height: none;
  overflow: visible;
}
.whick-transport-bar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.whick-transport-btn {
  width: 2.1rem;
  height: 2.1rem;
  border: none;
  border-radius: 50%;
  background: #252b38;
  color: #e8eaef;
  cursor: pointer;
  font-size: 0.75rem;
  flex-shrink: 0;
}
.whick-transport-btn:hover {
  background: #3b82f6;
}
.whick-transport-btn.is-active {
  background: #1e3a5f;
}
.whick-transport-vol {
  flex: 0 0 100px;
  display: flex;
  align-items: center;
}
.whick-transport-vol input {
  width: 100%;
}
.whick-trial-now-playing {
  margin: 0;
  font-weight: 600;
  font-size: 0.85rem;
  flex: 1;
  min-width: 120px;
}
.whick-trial-audio {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}
.whick-dock-toolbar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.35rem 0.5rem 0;
  font-size: 0.8rem;
  color: #9aa3b5;
}
.whick-dock-select-all {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  cursor: pointer;
}
.whick-dock-select-all input,
.whick-trial-track-check input,
.whick-ai-result-row input {
  width: 1rem;
  height: 1rem;
  accent-color: #3b82f6;
}
.whick-trial-track-row {
  list-style: none;
}
.whick-trial-track-check {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  width: 100%;
  cursor: pointer;
}
.whick-trial-track-check .whick-trial-track {
  flex: 1;
  text-align: left;
  border: none;
  background: transparent;
  color: inherit;
  padding: 0.35rem 0.25rem;
  cursor: pointer;
}
.whick-trial-track-row.is-active .whick-trial-track,
.whick-trial-track.is-active {
  background: #1e3a5f;
  border-radius: 6px;
}
.whick-ai-search-toolbar {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.whick-ai-result-row label {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  padding: 0.35rem 0;
}
.whick-ai-result-btn {
  flex: 1;
  text-align: left;
  border: none;
  background: transparent;
  color: #e8eaef;
  cursor: pointer;
  padding: 0.25rem 0;
}
.whick-ai-result-row.is-active .whick-ai-result-btn,
.whick-ai-result-row.is-selected,
.whick-ai-result-btn.is-active {
  color: #60a5fa;
}
.whick-ai-result-row.is-selected {
  background: rgba(30, 58, 95, 0.35);
  border-radius: 6px;
}
.whick-ai-result-btn em {
  display: block;
  font-size: 0.72rem;
  color: #9aa3b5;
  font-style: normal;
}
.whick-album-detail__back {
  margin-bottom: 0.5rem;
}
.whick-album-detail__head {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  margin: 0.5rem 0 1rem;
  padding: 1rem 1.1rem;
  background: #141820;
  border: 1px solid #252b38;
  border-radius: 12px;
}
.whick-album-detail__head h2 {
  margin: 0 0 0.35rem;
  font-size: 1.35rem;
  line-height: 1.3;
}
.whick-album-detail__head p {
  margin: 0;
  font-size: 0.88rem;
  color: #9aa3b5;
}
.whick-album-detail__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 1rem;
  margin-bottom: 0.65rem;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid #252b38;
}
.whick-album-detail__tracks-label {
  margin: 0 0 0.35rem;
}
.whick-album-detail__head .whick-album-detail__cover {
  width: 140px;
  height: 140px;
  min-height: 140px;
  border-radius: 10px;
  flex-shrink: 0;
  display: block;
}
.whick-album-detail__cover {
  width: 96px;
  height: 96px;
  min-height: 96px;
  border-radius: 8px;
  flex-shrink: 0;
  display: block;
}
.whick-dsp-preset--user.is-selected {
  outline: 2px solid #f59e0b;
}
.whick-dsp-presets {
  list-style: none;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1rem 0;
}
.whick-dsp-preset {
  padding: 0.5rem 0.85rem;
  border-radius: 8px;
  border: 1px solid #3d4656;
  background: #141820;
  color: #e8eaef;
  cursor: pointer;
  font-size: 0.85rem;
}
.whick-dsp-preset.is-preview {
  border-color: #3b82f6;
  background: #1e3a5f;
}
.whick-dsp-preset.is-selected {
  outline: 2px solid #22d3ee;
  outline-offset: 2px;
}
.whick-eq-sliders {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 0.75rem;
  margin: 1rem 0;
}
.whick-eq-band {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  font-size: 0.75rem;
  color: #9aa3b5;
}
.whick-eq-band input[type='range'] {
  width: 100%;
}
.whick-dsp-msg {
  color: #6ee7b7;
  font-size: 0.9rem;
}
.whick-camilla-details {
  margin-top: 1rem;
  font-size: 0.85rem;
}
.whick-camilla-yaml {
  background: #0c0e12;
  padding: 0.75rem;
  border-radius: 8px;
  overflow-x: auto;
  font-size: 0.7rem;
  color: #93c5fd;
  max-height: 200px;
}
.whick-room-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  margin: 1rem 0;
}
.whick-room-table th,
.whick-room-table td {
  border: 1px solid #252b38;
  padding: 0.35rem 0.5rem;
  text-align: left;
}
.whick-room-hub-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1rem 0;
}
.whick-ai-search {
  display: flex;
  gap: 0.5rem;
  margin: 1rem 0;
}
.whick-ai-search input {
  flex: 1;
  padding: 0.55rem 0.75rem;
  border-radius: 8px;
  border: 1px solid #3d4656;
  background: #0c0e12;
  color: #e8eaef;
}
.whick-ai-search-results,
.whick-browse-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.whick-ai-search-results button,
.whick-browse-item {
  width: 100%;
  text-align: left;
  padding: 0.5rem 0.65rem;
  border: none;
  background: transparent;
  color: #c8d0e0;
  cursor: pointer;
  border-radius: 6px;
}
.whick-ai-search-results button:hover,
.whick-browse-item:hover {
  background: #1a2230;
}
.whick-trial-track {
  display: flex;
  justify-content: space-between;
  width: 100%;
  text-align: left;
  padding: 0.45rem 0.5rem;
  border: none;
  background: transparent;
  color: #c8d0e0;
  cursor: pointer;
  border-radius: 6px;
  font-size: 0.8rem;
}
.whick-trial-track.is-active {
  background: #1e3a5f;
  color: #e8eaef;
}
.whick-trial-track__meta {
  font-size: 0.7rem;
  color: #6b7280;
}

/* 라디오 — 하단 고정 플레이어 바 (체험 플레이어 .whick-player-bar 패턴) */
.whick-body--radio {
  --whick-radio-bar-h: 3.75rem;
  padding-bottom: calc(var(--whick-radio-bar-h) + env(safe-area-inset-bottom, 0px));
}
.whick-radio-page .whick-radio-hero .whick-hero__inner,
.whick-radio-page__body {
  text-align: center;
}
.whick-radio-app {
  max-width: 720px;
  margin: 0 auto;
}
.whick-radio-page .whick-radio-player {
  border: 1px solid var(--whick-border-soft, #252b38);
  border-radius: 12px;
  overflow: hidden;
  background: var(--whick-surface, #141820);
  text-align: left;
}
.whick-radio-list-wrap {
  padding: 0.5rem 0;
}
.whick-radio-page .whick-radio-group {
  margin-bottom: 0.5rem;
}
.whick-radio-page .whick-radio-group h2 {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--whick-muted, #6b7280);
  margin: 0.75rem 1rem 0.35rem;
  text-align: left;
}
.whick-radio-stations {
  list-style: none;
  padding: 0;
  margin: 0;
}
.whick-radio-stations li {
  margin: 0;
}
.whick-radio-station {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.65rem 1rem;
  border: none;
  border-left: 3px solid transparent;
  background: transparent;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.whick-radio-station:hover {
  background: rgba(59, 130, 246, 0.06);
}
.whick-radio-station.is-selected {
  background: rgba(59, 130, 246, 0.12);
  border-left-color: var(--whick-accent, #3b82f6);
}
.whick-radio-station__name {
  display: block;
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--whick-heading, #e8eaef);
}
.whick-radio-station__desc {
  display: block;
  font-size: 0.8rem;
  color: var(--whick-muted, #9aa3b5);
  margin-top: 0.15rem;
}
.whick-radio-bar {
  position: fixed;
  left: 50%;
  bottom: 0;
  z-index: 160;
  width: 100%;
  max-width: 1180px;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.65rem 1rem;
  padding-bottom: calc(0.65rem + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid var(--whick-border-soft, #252b38);
  background: #0f1218;
  box-shadow: 0 -10px 28px rgba(0, 0, 0, 0.45);
}
.whick-radio-bar__play {
  width: 2.25rem;
  height: 2.25rem;
  flex-shrink: 0;
  border: none;
  border-radius: 50%;
  background: var(--whick-accent, #3b82f6);
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.whick-radio-bar__play:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}
.whick-radio-bar__play.is-playing {
  background: #b91c1c;
}
.whick-radio-bar__icon {
  font-size: 0.7rem;
  line-height: 1;
}
.whick-radio-bar__icon--stop {
  display: none;
  font-size: 0.58rem;
}
.whick-radio-bar__play.is-playing .whick-radio-bar__icon--play {
  display: none;
}
.whick-radio-bar__play.is-playing .whick-radio-bar__icon--stop {
  display: block;
}
.whick-radio-bar__meta {
  flex: 1;
  min-width: 0;
}
.whick-radio-bar__title {
  margin: 0;
  font-weight: 600;
  font-size: 0.9rem;
  color: #e8eaef;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.whick-radio-bar__status {
  margin: 0.15rem 0 0;
  font-size: 0.75rem;
  color: #9aa3b5;
}
.whick-radio-bar__volume {
  flex-shrink: 0;
  width: 88px;
}
.whick-radio-bar__volume input {
  width: 100%;
}
.whick-radio-audio {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}
.whick-body--radio .whick-main {
  max-width: none;
}

/* 공간음향 — 스마트폰 QR 연결 팝업 */
body.whick-spatial-qr-open {
  overflow: hidden;
}
.whick-spatial-qr-modal[hidden] {
  display: none !important;
}
.whick-spatial-qr-modal {
  position: fixed;
  inset: 0;
  z-index: 320;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.whick-spatial-qr-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.62);
}
.whick-spatial-qr-modal__panel {
  position: relative;
  z-index: 1;
  width: min(100%, 22rem);
  max-height: 92vh;
  overflow-y: auto;
  padding: 1.35rem 1.25rem 1.25rem;
  border-radius: 14px;
  border: 1px solid #252b38;
  background: #141820;
  color: #e8eaef;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.55);
}
.whick-spatial-qr-modal__panel h2 {
  margin: 0 0 0.65rem;
  font-size: 1.15rem;
}
.whick-spatial-qr-modal__lead {
  margin: 0 0 0.85rem;
  font-size: 0.92rem;
  color: #fca5a5;
  line-height: 1.55;
}
.whick-spatial-qr-modal__steps {
  margin: 0 0 1rem 1.1rem;
  padding: 0;
  font-size: 0.88rem;
  color: #b8c0d0;
  line-height: 1.55;
}
.whick-spatial-qr-modal__code {
  display: flex;
  justify-content: center;
  margin: 0 0 0.85rem;
  padding: 0.75rem;
  border-radius: 10px;
  background: #fff;
}
.whick-spatial-qr-modal__code canvas,
.whick-spatial-qr-modal__code img {
  display: block;
  max-width: 100%;
  height: auto;
}
.whick-spatial-qr-modal__code table {
  margin: 0 auto;
  border-collapse: collapse;
}
.whick-spatial-qr-modal__url {
  margin: 0 0 0.75rem;
  font-size: 0.75rem;
  word-break: break-all;
}
.whick-spatial-qr-modal__url a {
  color: #93c5fd;
}
.whick-spatial-qr-modal__hint {
  margin: 0 0 1rem;
  font-size: 0.82rem;
}
.whick-spatial-qr-modal__close {
  position: absolute;
  top: 0.5rem;
  right: 0.55rem;
  border: none;
  background: transparent;
  color: #9aa3b5;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
}
/* 공간음향 — PC 측정 화면 (QR + 측정 패널, 플레이어·설치 마법사 공통) */
.whick-spatial-measure-layout {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 1.25rem;
  align-items: start;
  margin: 1rem 0 0.5rem;
}
.whick-spatial-measure-main {
  min-width: 0;
}
.whick-spatial-connect-inline {
  padding: 1rem;
  border-radius: 12px;
  background: rgba(10, 14, 24, 0.72);
  border: 1px solid rgba(100, 140, 200, 0.22);
}
.whick-spatial-connect-inline__badge {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #9ec5ff;
  margin: 0 0 0.5rem;
}
.whick-spatial-connect-inline__title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
}
.whick-spatial-connect-inline__lead {
  margin: 0 0 0.75rem;
  font-size: 0.88rem;
  color: #b8c0d0;
  line-height: 1.5;
}
.whick-spatial-connect-inline__steps {
  margin: 0 0 0.85rem;
  padding-left: 1.2rem;
  font-size: 0.82rem;
  color: #a8b0c0;
  line-height: 1.45;
}
.whick-spatial-connect-inline__steps li + li {
  margin-top: 0.35rem;
}
.whick-spatial-connect-inline__code {
  display: flex;
  justify-content: center;
  margin: 0.5rem 0;
  min-height: 220px;
  align-items: center;
}
.whick-spatial-connect-inline__code canvas,
.whick-spatial-connect-inline__code img {
  border-radius: 8px;
  background: #fff;
  padding: 6px;
}
.whick-spatial-connect-inline__url {
  font-size: 0.75rem;
  word-break: break-all;
  margin: 0.35rem 0;
}
.whick-spatial-connect-inline__url a {
  color: #8ab4f8;
}
.whick-spatial-connect-inline__hint {
  font-size: 0.8rem;
  margin: 0;
}
.whick-room-wizard--speaker-pc .whick-spatial-measure-intro {
  margin: 0 0 0.75rem;
  font-size: 0.95rem;
}
.whick-trial-wizard__spatial-skip {
  margin-top: 1rem;
  text-align: center;
}
@media (max-width: 900px) {
  .whick-spatial-measure-layout {
    grid-template-columns: 1fr;
  }
  .whick-spatial-connect-inline__code {
    min-height: 200px;
  }
}

.whick-spatial-qr-modal__ok {
  width: 100%;
}
.whick-room-sync-alert {
  margin: 0.5rem 0 0.65rem;
  padding: 0.65rem 0.85rem;
  border-radius: 8px;
  border: 1px solid #7f1d1d;
  background: rgba(127, 29, 29, 0.25);
  color: #fecaca;
  font-size: 0.9rem;
  line-height: 1.5;
}
.whick-room-sync-actions {
  margin: 0 0 0.85rem;
}

/* YouTube 연동 */
.whick-yt-connect {
  background: #141820;
  border: 1px solid #252b38;
  border-radius: 12px;
  padding: 1rem;
  margin: 1rem 0;
}
.whick-yt-connect__head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}
.whick-yt-connect__notice {
  margin: 0 0 0.75rem;
  padding: 0.65rem 0.85rem;
  border-radius: 8px;
  border-left: 3px solid #60a5fa;
  background: rgba(96, 165, 250, 0.08);
  color: #cbd5e1;
  font-size: 0.9rem;
  line-height: 1.5;
}
.whick-yt-connect__notice strong {
  color: #e2e8f0;
}
.whick-yt-connect__status.is-ok {
  color: #6ee7b7;
}
.whick-yt-connect__success {
  margin: 0 0 0.75rem;
  padding: 0.65rem 0.85rem;
  border-radius: 8px;
  background: #14532d;
  border: 1px solid #22c55e;
  color: #ecfdf5;
  font-size: 0.88rem;
  line-height: 1.45;
}
.whick-yt-connect__error {
  margin: 0.75rem 0 0;
  padding: 0.65rem 0.85rem;
  border-radius: 8px;
  background: #450a0a;
  border: 1px solid #ef4444;
  color: #fecaca;
  font-size: 0.88rem;
  line-height: 1.45;
}
.whick-yt-connect__actions .whick-btn--lg {
  width: 100%;
  min-height: 48px;
}
.whick-yt-connect__mobile-note {
  font-size: 0.88rem;
  line-height: 1.45;
}
.whick-yt-connect__redirect-uri {
  margin-top: 0.85rem;
  font-size: 0.78rem;
  line-height: 1.45;
  word-break: break-all;
}
.whick-yt-connect__uri {
  display: inline-block;
  margin-top: 0.35rem;
  padding: 0.25rem 0.4rem;
  border-radius: 6px;
  background: #0c0e12;
  font-size: 0.72rem;
}
.whick-yt-embed {
  margin-top: 1rem;
  min-height: 0;
}
/* YouTube API용 iframe — 플레이어 바 맨 아래, 화면만 숨김 (재생은 유지) */
.whick-yt-embed--bar {
  order: 99;
  flex-shrink: 0;
  align-self: stretch;
  position: relative;
  width: 100%;
  height: 1px;
  max-height: 1px;
  margin: 0;
  padding: 0;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
  opacity: 0;
  pointer-events: none;
}
.whick-yt-embed--bar > div {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.whick-yt-embed--bar iframe {
  width: 1px !important;
  height: 1px !important;
  max-width: 1px;
  max-height: 1px;
  border: 0;
}
.whick-yt-embed iframe {
  max-width: 100%;
  border-radius: 8px;
}
