:root{color-scheme:light;font-family:Fredoka,system-ui,sans-serif;background:#fef6ff;color:#2b1b35}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#ffeef9,#f4f9ff 45%,#fdf6ff)}#app{min-height:100vh;display:flex;align-items:stretch;justify-content:center;padding:24px 16px 48px}.container{width:min(420px,100%);background:#fff;border-radius:32px;box-shadow:0 18px 40px #42285626;padding:24px 22px 32px;position:relative;overflow:hidden}.container:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Ccircle cx='32' cy='32' r='18' fill='%23ffe4f4'/%3E%3Ccircle cx='130' cy='60' r='12' fill='%23dff5ff'/%3E%3Ccircle cx='90' cy='140' r='16' fill='%23fff2d6'/%3E%3C/svg%3E") center/180px repeat;opacity:.35;pointer-events:none}.content{position:relative;z-index:1}.status-banner{position:sticky;top:0;z-index:2;margin:-12px -12px 16px;padding:12px 14px;border-radius:18px;font-weight:700;letter-spacing:.01em;box-shadow:0 10px 20px #2e23351f}.status-indicator{position:absolute;top:12px;right:12px;z-index:3;width:24px;height:24px;border-radius:999px;padding:0;margin:0;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;line-height:1;opacity:.75;box-shadow:none;transition:opacity .2s ease,transform .2s ease}.status-indicator:hover{opacity:1;transform:translateY(-1px)}.status-indicator--connected{color:#1b4c3b;background:#b4ffd9b3;border-color:#1b4c3b40}.status-indicator--connecting{color:#6a4a12;background:#fff2b4bf;border-color:#6a4a1247}.status-indicator--disconnected{color:#7a1d46;background:#ffc1d9bf;border-color:#7a1d4640}.status-banner__title{font-size:.95rem}.status-banner__meta{font-size:.8rem;margin-top:6px;font-weight:600}.status-banner__action{margin-top:10px;background:#ffffffd9;color:inherit;border:2px solid currentColor;padding:8px 16px;font-size:.85rem;box-shadow:none}.status-banner--fadeout{animation:statusFadeOut 1s ease forwards;animation-delay:9s}.status-banner--connected{background:linear-gradient(135deg,#b4ffd9,#c7f2ff);color:#1b4c3b}.status-banner--connecting{background:linear-gradient(135deg,#fff2b4,#ffe1a6);color:#6a4a12}.status-banner--disconnected{background:linear-gradient(135deg,#ffc1d9,#ffd1f3);color:#7a1d46}.spinner{display:inline-block;width:12px;height:12px;margin-right:8px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;vertical-align:-2px}h1,h2,h3{margin:0 0 12px}h1{font-size:1.9rem;font-weight:700}h2{font-size:1.4rem}p{margin:0 0 16px;line-height:1.5}input,textarea{width:100%;border-radius:16px;border:2px solid #f0d8ff;padding:14px 16px;font-size:1rem;font-family:inherit;background:#fffdfb;color:#33203d}textarea{min-height:120px;resize:vertical}label{font-weight:600;font-size:.95rem;margin-bottom:6px;display:block}.checkbox-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:#ff8fd1}button{appearance:none;border:none;border-radius:999px;padding:12px 20px;font-weight:600;font-size:1rem;font-family:inherit;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}button:active{transform:scale(.98)}button:disabled{cursor:not-allowed;opacity:.7}button.button--acknowledged{transform:translateY(1px) scale(.985);box-shadow:0 0 0 3px #ff8fd138}button.button--pending{cursor:progress;opacity:.85}button.button--pending:after{content:"";display:inline-block;width:11px;height:11px;margin-left:8px;border:2px solid currentColor;border-top-color:transparent;border-radius:999px;vertical-align:-1px;animation:spin .75s linear infinite}button.status-indicator{padding:0;font-size:.8rem;box-shadow:none}button.status-indicator:active{transform:none}button.status-indicator.button--acknowledged{transform:none;box-shadow:none}button.status-indicator.button--pending:after{display:none}.button-primary{background:linear-gradient(135deg,#ff8fd1,#ffb86c);color:#fff;box-shadow:0 12px 20px #ff8ec459}.button-secondary{background:#f0f6ff;color:#3a2b42;border:2px dashed #c7d8ff}.button-ghost{background:#fff7ff;color:#7c4d93;border:2px solid #f3dfff}.button-row{display:flex;flex-direction:column;gap:12px;margin-top:12px}.section{margin-bottom:20px}.room-code{display:inline-flex;align-items:center;gap:10px;font-size:1.4rem;font-weight:700;letter-spacing:.3rem;background:#fff0f7;color:#4d225f;padding:10px 16px;border-radius:18px;border:2px solid #ffd2eb}.badge{display:inline-flex;align-items:center;gap:6px;background:#fef1d8;color:#5a3b14;padding:6px 12px;border-radius:999px;font-size:.85rem;font-weight:600}.player-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.player-card{background:#fff;border-radius:18px;border:2px solid #f4e5ff;padding:12px;display:flex;align-items:center;gap:10px}.avatar{width:56px;height:56px;position:relative;flex-shrink:0}.avatar .head{width:100%;height:100%;border-radius:50%;background:var(--skin);border:3px solid rgba(0,0,0,.05);position:relative;box-shadow:inset 0 -6px #00000014}.avatar .eye{position:absolute;top:18px;width:8px;height:12px;background:#2c1c33;border-radius:999px}.avatar .eye.left{left:16px}.avatar .eye.right{right:16px}.avatar .blush{position:absolute;top:32px;width:10px;height:6px;background:#ff91b699;border-radius:999px}.avatar .blush.left{left:12px}.avatar .blush.right{right:12px}.avatar .mouth{position:absolute;bottom:14px;left:50%;width:18px;height:8px;border-radius:0 0 16px 16px;background:#ff8fb4;transform:translate(-50%)}.avatar .hat{position:absolute;top:-10px;left:6px;right:6px;height:20px;border-radius:20px;background:var(--accent);box-shadow:0 6px #0000001a}.avatar .sparkle{position:absolute;bottom:-4px;right:-6px;width:18px;height:18px;border-radius:50%;background:var(--sparkle);border:2px solid #fff}.prompt-card{background:#fff6ff;border-radius:20px;padding:18px;border:2px solid #f5d6ff}.prompt-assignment .prompt-card{margin-bottom:12px}.countdown-pill{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:#f1f7ff;border:1px solid #cfe0ff;color:#30528f;font-weight:600;font-size:.85rem}.locked-banner{background:#e8fff4;border:1px solid #b8f0d6;color:#246b4f;border-radius:12px;padding:8px 12px;font-weight:600}.fireworks{position:relative;height:160px;margin-top:12px;overflow:hidden}.firework{position:absolute;width:12px;height:12px;border-radius:50%;background:radial-gradient(circle,#ffd36b,#ff7ac8);animation:firework 1.8s ease-out infinite}.firework:nth-child(1){left:20%;top:40%;animation-delay:0s}.firework:nth-child(2){left:60%;top:20%;animation-delay:.4s}.firework:nth-child(3){left:35%;top:70%;animation-delay:.8s}.firework:nth-child(4){left:75%;top:55%;animation-delay:1.2s}@keyframes firework{0%{transform:scale(.3);opacity:.2}50%{transform:scale(1.4);opacity:1}to{transform:scale(.4);opacity:0}}.choice-grid{display:grid;gap:12px;margin-top:16px}.choice{padding:16px;border-radius:18px;background:#fff;border:2px solid #e4f0ff;font-weight:600;text-align:left;box-shadow:0 6px 12px #46527814}.choice--selected{border-color:#ff8fd1;box-shadow:0 0 0 2px #ff8fd147}.scoreboard{display:grid;gap:10px;margin-top:16px}.score-row{display:flex;align-items:center;justify-content:space-between;background:#f6fffb;border-radius:16px;padding:10px 14px;border:2px solid #d9f5e8;font-weight:600}.score-row__left{display:inline-flex;align-items:center;gap:8px;min-width:0}.score-rank{display:inline-flex;align-items:center;justify-content:center;min-width:34px;padding:3px 8px;border-radius:999px;font-size:.78rem;font-weight:700;background:#fff4d8;color:#674c17;border:1px solid #f4dca6}.round-summary{display:grid;gap:12px;margin-top:12px}.result-card{border:2px solid #e4f0ff;border-radius:16px;background:#fff;padding:12px 14px;box-shadow:0 6px 12px #46527814}.result-card__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.result-card__response{font-weight:600;color:#2d2140;margin-bottom:8px}.result-card__entries{display:grid;gap:10px;margin-bottom:10px}.result-entry{border:1px solid #e6e1f6;border-radius:12px;background:#fcfaff;padding:10px}.result-entry--winner{border-color:#b8ebd2;background:#f1fff8}.result-entry__name{font-weight:700;margin-bottom:4px}.result-entry__response{font-size:.94rem;margin-bottom:4px}.result-entry__meta{font-size:.8rem;color:#6c5479}.result-card__meta{display:grid;gap:4px;font-size:.82rem;color:#6c5479}.result-points{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:4px 10px;border-radius:999px;border:1px solid #c6f2d7;background:#e9fff3;color:#205f45;font-weight:700;opacity:0;transform:translateY(6px) scale(.92)}.round-summary--points-reveal .result-points{opacity:1;transform:translateY(0) scale(1);animation:popIn .35s ease both}.round-summary--points .result-points{opacity:1;transform:translateY(0) scale(1);animation:none}.scoreboard-reveal{transition:opacity .3s ease,transform .3s ease}.scoreboard-reveal--hidden{opacity:.45;transform:translateY(6px)}.scoreboard-reveal--visible{opacity:1;transform:translateY(0)}.footer-note{font-size:.85rem;color:#775a88;margin-top:14px}.error-text{margin-top:10px;color:#b0285a;font-weight:600}.prompt-list{display:grid;gap:12px;margin-top:16px}.prompt-item{display:flex;gap:12px;background:#f7f1ff;border-radius:16px;padding:12px;border:2px solid #eadcff}.prompt-number{background:#fff0f7;color:#6a2a4d;font-weight:700;border-radius:12px;padding:6px 10px;height:fit-content}.prompt-text{font-weight:600;margin-bottom:4px}.prompt-answer{font-size:.85rem;color:#6a4c79}.error-badge{display:inline-flex;align-items:center;background:#ffe1ee;color:#9c1f57;border:1px solid #f5b9d0;border-radius:999px;font-size:.75rem;font-weight:600;padding:4px 10px;margin-bottom:8px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes statusFadeOut{to{opacity:0;transform:translateY(-6px)}}@keyframes popIn{0%{opacity:0;transform:translateY(6px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:360px){.player-grid{grid-template-columns:1fr}}
