:root{--bg: #cdeaef;--surface: #ffffff;--text: #1a1a1a;--muted: #5d7679;--border: #a8d3da;--accent: #0e7490;--accent-text: #ffffff;--success: #16a34a;--danger: #dc2626;--tile-cover: #a8d3da;--radius: 10px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}a{color:var(--text);text-decoration:underline;text-underline-offset:3px}a:hover{opacity:.75}button{font-family:inherit;font-size:1rem;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);padding:.75rem 1rem;border-radius:var(--radius);min-height:44px;-webkit-tap-highlight-color:transparent;transition:transform .04s ease}button:hover:not(:disabled){background:#fafafa}button:active:not(:disabled){transform:scale(.97)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--text);color:var(--surface);border-color:var(--text)}button.primary:hover:not(:disabled){background:#333}button.ghost{background:transparent;border-color:transparent;color:var(--muted)}button.ghost:hover:not(:disabled){background:#0000000a}button.big{font-size:1.05rem;padding:.85rem 1.2rem;min-height:52px;font-weight:600}button.small{font-size:.8125rem;padding:.4rem .7rem;min-height:36px}input,textarea,select{font-family:inherit;font-size:16px;border:1px solid var(--border);background:var(--surface);padding:.75rem .85rem;border-radius:var(--radius);width:100%;max-width:100%;color:var(--text)}textarea{resize:vertical;min-height:5em}input:focus,textarea:focus,select:focus{outline:2px solid var(--accent);outline-offset:1px}label{display:block;font-size:.8125rem;font-weight:500;margin-bottom:.35rem;color:var(--muted)}.stack{display:flex;flex-direction:column;gap:1rem}.row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.muted{color:var(--muted);font-size:.9375rem}.small{font-size:.8125rem}.alert{color:var(--danger);font-weight:500;margin:0}.alert.info{color:var(--muted, #6b7280)}.ghost.danger{color:var(--danger)}.center{text-align:center}.bold{font-weight:600}.page{min-height:100%;padding:1.25rem;max-width:720px;margin:0 auto}.page-wide{max-width:none;padding:1rem 1.5rem}h1{font-size:1.4rem;font-weight:600;margin:0 0 1rem;letter-spacing:-.02em}h2{font-size:1.05rem;font-weight:600;margin:0 0 .75rem}.code-block{word-break:break-all;background:var(--surface);padding:.6rem .8rem;border:1px solid var(--border);border-radius:var(--radius);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.875rem}.home-page{display:flex;flex-direction:column;justify-content:center;text-align:center;padding-top:3rem}.home-title{font-size:clamp(1.6rem,6vw,2.2rem);margin:0 0 .5rem;-webkit-user-select:none;user-select:none}.home-sub{margin-bottom:2rem}.home-cards{display:grid;grid-template-columns:1fr;gap:1rem;max-width:420px;margin:0 auto;width:100%}@media(min-width:540px){.home-cards{grid-template-columns:1fr 1fr}}.home-card{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1rem;min-height:140px;transition:transform .08s,box-shadow .08s}.home-card:active{transform:scale(.98);box-shadow:0 1px 3px #0000000f}.home-card-emoji{font-size:2.2rem;margin-bottom:.4rem}.home-card-title{font-weight:600;font-size:1.05rem}.home-card-sub{color:var(--muted);font-size:.875rem;margin-top:.25rem}.join-page{display:flex;flex-direction:column;padding-bottom:2rem}.join-title{text-align:center;margin-bottom:.5rem}.join-form{max-width:360px;width:100%;margin:0 auto}.join-header{display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem}.join-name{font-weight:600;font-size:1.05rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.join-points{background:var(--text);color:var(--surface);padding:.35rem .7rem;border-radius:var(--radius);font-weight:600;font-variant-numeric:tabular-nums}.join-idle,.join-paused,.join-locked,.join-success,.join-result{text-align:center;padding:2rem 1rem}.big-emoji{font-size:3.5rem;margin:0 0 .5rem}.answer-form{display:flex;flex-direction:column;gap:.75rem}.answer-label{font-size:.875rem;font-weight:500;margin-bottom:0;color:var(--muted)}.answer-input{font-size:1.25rem;padding:1rem}.attempts{text-align:center;margin:.25rem 0 0;color:var(--muted)}.shake{animation:shake .35s}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:380px;margin:0 auto}.team-btn{color:#fff;font-size:1.25rem;font-weight:600;border:none;padding:1.5rem 1rem;min-height:110px;border-radius:var(--radius);text-shadow:0 1px 2px rgba(0,0,0,.3)}.display-page{min-height:100vh;display:flex;flex-direction:column}.display-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.display-header h1{margin:0;font-size:clamp(1.2rem,2.5vw,1.75rem)}.display-stage{flex:1;display:flex;align-items:center;justify-content:center;position:relative;min-height:60vh}.display-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffffeb;text-align:center;padding:1rem;border-radius:var(--radius)}.display-overlay.paused p{font-size:clamp(3rem,12vw,7rem);font-weight:700;letter-spacing:.2em;margin:0}.display-overlay.ended .ended-title{font-size:clamp(1.8rem,5vw,3rem);font-weight:700;margin:0 0 1rem}.winners-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem;font-size:clamp(1rem,2vw,1.5rem)}.winners-list li{display:grid;grid-template-columns:2ch 1fr auto;gap:1rem;align-items:center;padding:.4rem 1rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);min-width:280px}.w-rank{font-weight:600;color:var(--muted)}.w-name{font-weight:600}.w-points{font-weight:700;color:var(--success)}.idle-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem}.big-text{font-size:1rem;word-break:break-all}.lobby-page{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:2rem}.lobby-title{font-size:clamp(2rem,6vw,4rem);margin:0 0 2rem}.lobby-grid{display:grid;grid-template-columns:1fr;gap:2rem;width:100%;max-width:1200px;align-items:center}@media(min-width:800px){.lobby-grid{grid-template-columns:auto 1fr}}.lobby-qr{display:flex;flex-direction:column;align-items:center;background:#fff;padding:1.5rem;border-radius:var(--radius);border:1px solid var(--border)}.lobby-url{margin-top:1rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:clamp(.85rem,1.5vw,1.1rem);color:var(--muted);word-break:break-all}.lobby-list h2{font-size:clamp(1.2rem,2.5vw,1.5rem);text-align:left}.lobby-players{display:flex;flex-wrap:wrap;gap:.6rem;text-align:left}.lobby-player-chip{background:#fff;border:1px solid var(--border);padding:.5rem .9rem;border-radius:999px;font-size:clamp(.95rem,1.5vw,1.15rem);font-weight:500}.lobby-teams{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.lobby-team{padding:1.25rem 1rem;border-radius:var(--radius);color:#fff;font-weight:700;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.3);font-size:clamp(1.1rem,2vw,1.6rem)}.lobby-team-name{display:block}.puzzle-wrap{display:flex;justify-content:center;width:100%}.puzzle-grid{display:grid;grid-template-columns:repeat(8,1fr);width:min(90vmin,820px);aspect-ratio:1;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);overflow:hidden}.puzzle-cell{position:relative;overflow:hidden}.puzzle-piece{position:absolute;top:0;right:0;bottom:0;left:0;background-repeat:no-repeat}.puzzle-cover{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--tile-cover);transition:opacity .4s ease;border:1px solid rgba(0,0,0,.06)}.scoreboard-dynamic{display:flex;flex-wrap:wrap;gap:.5rem;max-width:100%;margin:0 auto 1rem;justify-content:center}.score-cell-dynamic{display:flex;align-items:center;gap:.5rem;border:1px solid var(--border);background:var(--surface);padding:.45rem .75rem;font-variant-numeric:tabular-nums;font-size:1rem;min-width:140px;border-radius:var(--radius)}.score-rank{font-weight:600;color:var(--muted);font-size:.875rem;min-width:1.2rem;text-align:right}.score-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.score-pts{font-weight:700;font-size:1.1rem}.admin-page{padding-bottom:3rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);overflow-x:auto}.admin-tabs .tab{border:none;background:transparent;color:var(--muted);font-weight:600;padding:.6rem .9rem;border-radius:0;border-bottom:3px solid transparent;min-height:0}.admin-tabs .tab.active{color:var(--text);border-bottom-color:var(--text)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.card h2{margin-top:0}.primary-card{border-color:var(--text);border-width:2px}.team-names{display:grid;grid-template-columns:1fr;gap:.5rem;margin-top:.75rem}.team-name-row{display:flex;align-items:center;gap:.6rem}.team-dot{width:20px;height:20px;border-radius:50%;flex-shrink:0}.image-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.6rem}.image-pick{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:0;overflow:hidden;min-height:auto}.image-pick img{width:100%;aspect-ratio:1;object-fit:cover}.image-pick-title{padding:.5rem;font-size:.875rem;font-weight:500;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.winners-mini{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.75rem;align-items:center}.winner-chip{background:var(--bg);padding:.25rem .6rem;border-radius:999px;font-size:.875rem;font-weight:500}.admin-score-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.admin-score-list li{display:grid;grid-template-columns:2ch 1fr auto auto;gap:.6rem;align-items:center;padding:.5rem .75rem;background:var(--bg);border-radius:var(--radius)}.admin-score-list .score-controls button{min-width:42px;min-height:38px;padding:.3rem .6rem}.image-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.image-row{display:grid;grid-template-columns:90px 1fr;gap:.75rem;background:var(--bg);border-radius:var(--radius);padding:.5rem}.image-row img{width:90px;height:90px;object-fit:cover;border-radius:8px}.image-row-body{display:flex;flex-direction:column;gap:.4rem;min-width:0}
