html,body,#root{height:100%}body{margin:0}:root{--bg:#0f172a;--fg:#e2e8f0;--accent:#22c55e;--muted:#334155;--card:#111827;--cell:#0b1220;--marked:#14532d;--shadow:0 2px 12px rgba(0,0,0,.3)}[data-theme=neon]{--bg:#0a0f1f;--fg:#e6f0ff;--accent:#3bf29b;--muted:#2b3b67;--card:#0f1430;--cell:#10183d;--marked:#173b6c;--shadow:0 4px 16px rgba(19,29,68,.5)}[data-theme=classic]{--bg:#0f172a;--fg:#e2e8f0;--accent:#22c55e;--muted:#334155;--card:#111827;--cell:#0b1220;--marked:#14532d}*{box-sizing:border-box}body{margin:0;background:radial-gradient(120% 120% at 50% -10%,#1a237e 0%,var(--bg) 60%);color:var(--fg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial}.page{position:relative;z-index:2;max-width:460px;margin:0 auto;padding:16px;display:flex;flex-direction:column;gap:16px}.snow-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden}.snowflake{position:absolute;top:-20px;color:#fff;-webkit-user-select:none;user-select:none;animation-name:snowfall;animation-timing-function:linear;animation-iteration-count:infinite}@keyframes snowfall{0%{transform:translateY(0) translate(0) rotate(0);opacity:.8}50%{transform:translateY(55vh) translate(15px) rotate(180deg);opacity:.6}to{transform:translateY(110vh) translate(-15px) rotate(360deg);opacity:0}}h1,h2{margin:8px 0;text-shadow:0 2px 12px rgba(59,242,155,.25)}.card{background:linear-gradient(180deg,var(--card),rgba(0,0,0,.2));padding:16px;border-radius:16px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06)}label{display:flex;flex-direction:column;gap:6px;font-size:14px}input,select{padding:12px;border-radius:10px;border:1px solid var(--muted);background:var(--cell);color:var(--fg)}input::placeholder{color:#94a3b8}.row{display:flex;gap:12px;align-items:center;justify-content:space-between}.switch{display:flex;gap:8px;align-items:center}.seg{display:inline-flex;border:1px solid var(--muted);border-radius:10px;overflow:hidden}.seg-btn{padding:10px 12px;background:transparent;border:none;color:var(--fg)}.seg-btn.active{background:var(--cell)}.link{background:none;border:none;color:#9fb3ff;text-decoration:underline;cursor:pointer}button{padding:12px 14px;border-radius:10px;border:1px solid var(--muted);background:var(--cell);color:var(--fg)}button.primary{background:var(--accent);border-color:var(--accent);color:#052e16;font-weight:600}button:active{transform:scale(.98)}.icon-btn{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.icon-btn.sm{width:34px;height:34px;border-radius:8px}.icon-btn.sm svg{width:22px;height:22px}.icon-btn.primary{color:#052e16}.room-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.room-title{margin:0}.room-meta{margin-top:4px;font-size:12px;color:#9fb3ff;display:flex;gap:6px;align-items:center}.host{display:flex;gap:8px;flex-wrap:nowrap;align-items:center}.row-wrap{display:flex;gap:8px;align-items:center}.grid{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(5,1fr);aspect-ratio:1/1;gap:4px;width:100%}.cell{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;padding:2px;background:var(--cell);border:1px solid var(--muted);border-radius:4px;overflow:hidden;position:relative}.cell .cell-text{width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;overflow:hidden;line-height:1.1;font-size:12px;word-break:break-word}.cell .cell-text .artist{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;opacity:.8;font-size:.9em}.cell .cell-text .song{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;font-weight:600}.cell .cell-text.small{font-size:10px}.cell .cell-text.tiny{font-size:9px}.cell .cell-text.mini{font-size:8px}.cell.marked{background:var(--marked);color:#d2e7ff;border-color:transparent;box-shadow:0 0 0 2px #ffffff0f inset}.toast{position:fixed;left:50%;bottom:16px;transform:translate(-50%);background:#1f2937;color:#fff;padding:10px 14px;border-radius:10px}.badge{display:inline-block;background:var(--cell);border:1px solid var(--muted);padding:6px 10px;border-radius:8px;margin:4px 0}.badge.code{font-size:18px;letter-spacing:2px}.badge.round{font-weight:700}.badgeRow{display:flex;gap:8px;align-items:center;margin-top:6px}.player{flex:1;min-width:160px;background:linear-gradient(90deg,#3bf29b26,#10183d99);border:1px solid var(--muted);border-radius:12px;padding:6px 8px;display:flex;align-items:center;gap:8px}.player audio{display:none}.player .progress{flex:1;height:8px;background:#ffffff14;border-radius:6px;overflow:hidden;cursor:pointer;position:relative}.player .progress .bar{height:100%;background:var(--accent)}.modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:16px}.modal-card{background:var(--card);border:1px solid var(--muted);border-radius:12px;padding:16px;max-width:360px;width:100%;box-shadow:var(--shadow)}.modal-card h3{margin:0 0 8px}.modal-card ul{margin:0 0 12px;padding-left:16px}.dots{display:grid;grid-template-columns:repeat(5,12px);gap:6px;margin:8px 0}.dot{width:12px;height:12px;border-radius:50%;background:#fff3}.dot.on{background:#8bbcff}}{}
