:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;background-color:#000}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-height:100vh;overflow:hidden}#video-background{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;background:#000}#video-background video.mood-video{width:100%;height:100%;object-fit:cover}#app{position:relative;z-index:1;width:100%;height:100vh;display:flex;align-items:center;justify-content:center;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.screen{width:90%;max-width:1200px;text-align:center;padding:2rem;background:#0009;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.welcome-screen .game-title{font-size:4rem;margin-bottom:2rem;font-weight:700;background:linear-gradient(45deg,#ff6b6b,#ffd93d);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.qr-container{margin:2rem auto;padding:1.5rem;background:#fff;border-radius:20px;width:fit-content}.qr-code{display:block;width:300px;height:300px}.join-code-container{margin:2rem 0;font-size:2rem}.join-label{display:block;margin-bottom:.5rem;opacity:.8}.join-code{display:inline-block;font-size:4rem;font-weight:700;letter-spacing:.3em;background:#ffffff1a;padding:.5rem 2rem;border-radius:15px;font-family:Courier New,monospace}.instruction{font-size:1.5rem;opacity:.9}.lobby-title{font-size:3rem;margin-bottom:2rem}.players-container{min-height:200px;margin:2rem 0}.player-item{display:flex;align-items:center;gap:1rem;padding:1rem 2rem;margin:1rem auto;max-width:400px;background:#ffffff1a;border-radius:10px;font-size:1.5rem}.player-item.ready{background:#4caf504d;border:2px solid #4caf50}.player-item.not-ready{background:#ff98004d;border:2px solid #ff9800}.player-status{font-size:2rem}.no-players{font-size:1.5rem;opacity:.7;padding:3rem}.lobby-status{margin-top:2rem;font-size:1.3rem}.countdown-notice{margin-top:2rem;font-size:2rem;color:#4caf50;animation:pulse 1s infinite}.countdown-title{font-size:3rem;margin-bottom:2rem}.countdown-number{font-size:15rem;font-weight:700;line-height:1;background:linear-gradient(45deg,#ff6b6b,#ffd93d);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:pulse 1s infinite}.countdown-message{font-size:2rem;margin-top:2rem}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;font-size:3rem}.mood-indicator{font-size:5rem}.timer{font-size:4rem;font-weight:700;padding:.5rem 1.5rem;background:#ffffff1a;border-radius:15px}.timer.urgent{background:#ff00004d;animation:pulse .5s infinite}.order-title{font-size:2.5rem;margin-bottom:2rem}.fruits-required{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}.fruit-item{padding:1.5rem 2rem;background:#ffffff1a;border-radius:15px;border:3px solid transparent;min-width:150px}.fruit-item.pending{border-color:#ff9800}.fruit-item.complete{background:#4caf504d;border-color:#4caf50}.fruit-item.over-submitted{background:#f443364d;border-color:#f44336;animation:shake .5s}.fruit-emoji{font-size:4rem;margin-bottom:.5rem}.fruit-count{font-size:2rem;font-weight:700}.progress-container{margin-top:3rem}.progress-bar{height:40px;background:#ffffff1a;border-radius:20px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .3s ease}.progress-text{margin-top:1rem;font-size:1.5rem}.results-title{font-size:4rem;margin-bottom:2rem}.burnout-message{font-size:2rem;color:#f44336;margin-bottom:2rem}.results-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.stat-item{padding:2rem;background:#ffffff1a;border-radius:15px}.stat-item.success{background:#4caf504d}.stat-item.fail{background:#f443364d}.stat-item.mood{background:#ffc1074d}.stat-label{font-size:1.2rem;opacity:.8;margin-bottom:.5rem}.stat-value{font-size:3rem;font-weight:700}.error-screen{padding:3rem;max-width:800px;margin:0 auto;text-align:center}.error-screen h1{color:#f44336;margin-bottom:2rem}.error-details{font-family:monospace;background:#ffffff1a;padding:1rem;border-radius:8px;margin:1rem 0;word-break:break-all}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}
