:root{font-family:Hiragino Sans,Noto Sans JP,system-ui,sans-serif;line-height:1.5;color:#1a1a2e;background:#f0f4f8}*{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}.app{max-width:480px;margin:0 auto;padding:2rem 1rem}h1{font-size:1.75rem;margin:0 0 .25rem}.subtitle{color:#5a6a7a;margin:0 0 2rem;font-size:.9rem}.card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 2px 8px #00000014;margin-bottom:1rem}label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem}input{width:100%;padding:.6rem .75rem;border:1px solid #ccd5df;border-radius:8px;font-size:1rem;margin-bottom:1rem}button{width:100%;padding:.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;background:#2563eb;color:#fff}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:#e2e8f0;color:#1a1a2e;margin-top:.5rem}.error{color:#dc2626;font-size:.9rem;margin-bottom:1rem}.room-code{font-size:2rem;font-weight:700;letter-spacing:.2em;text-align:center;margin:1rem 0}.player-list{list-style:none;padding:0;margin:0}.player-list li{padding:.5rem 0;border-bottom:1px solid #eef2f6}.status{font-size:.8rem;color:#64748b}
