:root {
  --bg: #0b0d10;
  --panel: #141820;
  --muted: #aab1c3;
  --text: #e6e9ef;
  --accent: #5b9cff;
  --accent-2: #a26bff;
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0; font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text); background: linear-gradient(180deg, #0a0c10, #0b0d10 35%);
}
.topbar {
  display: flex; justify-content: space-between; gap: 16px; align-items: center;
  padding: 14px 18px; background: rgba(10,12,16,.7); border-bottom: 1px solid #1b212d; backdrop-filter: blur(8px);
  position: sticky; top: 0; z-index: 10;
}
.brand { font-weight: 700; letter-spacing: .2px; padding-left: 7rem;}
.menu { display: flex; gap: 14px; justify-content: center; padding-right: 7rem}
.menu-link { color: var(--muted); text-decoration: none; font-size: 14px; padding: 6px 8px; border-radius: 8px; }
.menu-link:hover { background: #111725; color: var(--text); }
.menu-link[aria-current="page"] { color: var(--text); font-weight: 600; }
.search { display: flex; gap: 8px; flex-grow: inherit; min-width:45rem; padding-left: 7rem;}
.search input {
  width: min(420px, 100%);
  padding: 10px 12px; border-radius: 10px; border: 1px solid #2a3242; background: #10141b; color: var(--text);
}
.btn { padding: 10px 14px; border-radius: 10px; border: 1px solid #2a3242; background: linear-gradient(180deg, #1a2130, #141a26); color: var(--text); cursor: pointer; }
.btn:hover { border-color: #3a4560; }
.icon-btn { font-size: 18px; padding: 8px 10px; border-radius: 10px; border: 1px solid #2a3242; background: #151b26; color: var(--text); cursor: pointer; }
.icon-btn:hover { border-color: #3a4560; }

.layout { display: grid; grid-template-columns: 1fr 440px; gap: 16px; padding: 16px 7rem 16px 7rem;}
@media (max-width: 900px) { .layout { grid-template-columns: 1fr; } }

.player-pane { background: var(--panel); border: 1px solid #202839; border-radius: 16px; overflow: clip; }
.player-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; border-bottom: 1px solid #1f2636; }
.title { font-size: 18px; margin: 0; }
.ellipsis { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: calc(100% - 120px); }
.player-container { position: relative; aspect-ratio: 16 / 9; background: #000; display: block; }
.player-container iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: none; }
.placeholder { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 12px; color: #aab1c3; }
.placeholder .mic { opacity: .8; }
.placeholder-text { font-size: 16px; }
.vote-row { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-top: 1px solid #1f2636; }
.vote-btn { padding: 8px 12px; border-radius: 10px; border: 1px solid #2a3242; background: #151b26; color: var(--text); cursor: pointer; }
.vote-btn:disabled { opacity: .55; cursor: default; }
.vote-status { margin-left: 6px; color: var(--muted); font-size: 14px; }

.results-pane { background: var(--panel); border: 1px solid #202839; border-radius: 16px; overflow: hidden; }
.results-title { margin: 0; padding: 12px 14px; border-bottom: 1px solid #1f2636; font-size: 16px; font-weight: 600; }
.results { list-style: none; margin: 0; padding: 0; max-height: calc(100vh - 220px); overflow: auto; }
.result { display: grid; grid-template-columns: 120px 1fr; gap: 10px; padding: 10px; border-bottom: 1px solid #1a2130; cursor: pointer; align-items: center; }
.result img { width: 100%; height: auto; border-radius: 8px; }
.result .meta { display: grid; gap: 4px; }
.r-title { font-size: 14px; line-height: 1.25; }
.r-channel { color: var(--muted); font-size: 12px; }
.result:hover { background: #121a26; }
.result.active { outline: 2px solid var(--accent); outline-offset: -2px; background: linear-gradient(180deg, #121a26, #0f1520); }

.footer { text-align: center; color: var(--muted); font-size: 12px; padding: 24px 0 40px; }

/* Base: keep your desktop look; we’ll override below */
:root { --container-pad: 7rem; }
.layout { padding: 16px var(--container-pad); }
.brand { padding-left: var(--container-pad); }
.menu { padding-right: var(--container-pad); }
.search { padding-left: var(--container-pad); min-width: 45rem; }

/* ≤ 1200px: ease off the giant side padding & min-widths */
@media (max-width: 1200px) {
  :root { --container-pad: 2rem; }
  .search { min-width: 28rem; }
}

/* ≤ 992px: switch to grid topbar, shrink inputs */
@media (max-width: 992px) {
  .topbar {
    flex-wrap: wrap;
    gap: 10px;
  }
  .brand { padding-left: 0; }
  .menu { padding-right: 0; order: 3; width: 100%; justify-content: center; }
  .search { padding-left: 0; min-width: 100%; order: 2; justify-content: stretch; }
  .search input { width: 100%; }
  .layout { grid-template-columns: 1fr; }
  .results { max-height: none; }
}

@media (max-width: 768px) {
  .topbar { padding: 10px 12px; }
  .menu { display: none; }          /* hide menu to save space; optional */
  .layout { padding: 12px; gap: 12px; }
  .player-header { padding: 10px 12px; }
  .title { font-size: 16px; }
  .player-container { aspect-ratio: 16/9; }
  .results-pane { border-radius: 12px; }
  .result { grid-template-columns: 96px 1fr; padding: 8px; }
  .r-title { font-size: 13px; }
  .r-channel { font-size: 11px; }
}

@media (max-width: 480px) {
  .search { gap: 6px; }
  .btn { padding: 8px 10px; }
  .result { grid-template-columns: 84px 1fr; gap: 8px; }
  .placeholder .mic { width: 96px; height: 96px; }
  .placeholder-text { font-size: 14px; }
}
@media (max-width: 768px) {
  .mobile-menu { display: inline-block; }
  .menu { display: none; width: 100%; justify-content: space-around; }
  .menu.open { display: flex; }
}

@media (min-width: 769px) {
  .mobile-menu { display: none; }
}

.banner {
  box-sizing: border-box;
  display: block;
}

.banner-img {
  width: 100%
}
