:root{--bg: #0f172a;--panel: #1e293b;--panel-2: #273449;--text: #e2e8f0;--muted: #94a3b8;--primary: #6366f1;--primary-hover: #4f46e5;--table: #b08968;--table-edge: #8a6a4f;--felt: #3f6b52}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:radial-gradient(circle at 50% -10%,#1e293b,var(--bg));color:var(--text);min-height:100vh;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}button{font:inherit}.card{background:var(--panel);border:1px solid rgba(255,255,255,.06);border-radius:14px;box-shadow:0 20px 50px #0006}.btn{border:1px solid rgba(255,255,255,.12);background:var(--panel-2);color:var(--text);padding:10px 16px;border-radius:10px;cursor:pointer;transition:background .15s,transform .05s}.btn:hover:not(:disabled){background:#31435c}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--primary);border-color:transparent}.btn.primary:hover:not(:disabled){background:var(--primary-hover)}.btn.big{padding:14px 20px;font-size:1.05rem;width:100%}.btn.small{padding:6px 12px;font-size:.85rem}.lobby{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:20px}.lobby .card{width:100%;max-width:420px;padding:32px}.lobby h1{margin:0 0 6px;font-size:1.7rem}.subtitle{color:var(--muted);margin:0 0 24px;line-height:1.5}.field{display:block;margin-bottom:18px}.field span{display:block;font-size:.85rem;color:var(--muted);margin-bottom:6px}input{width:100%;padding:11px 13px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#0b1220;color:var(--text);font-size:1rem}input:focus{outline:2px solid var(--primary);border-color:transparent}.divider{text-align:center;color:var(--muted);font-size:.8rem;margin:40px 0 14px;text-transform:uppercase;letter-spacing:.08em}.join-row{display:flex;gap:10px}.code-input{text-transform:uppercase;letter-spacing:.25em;text-align:center;font-weight:700}.error{color:#f87171;margin:14px 0 0;font-size:.9rem}.lobby-footer{color:var(--muted);font-size:.8rem}.setup{max-width:1100px;margin:0 auto;padding:24px;display:grid;grid-template-columns:1fr 260px;gap:20px;align-items:start}.setup-main{padding:26px}.setup h2{font-size:1.05rem;margin:22px 0 12px}.code-banner{display:flex;flex-direction:column;gap:6px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.08)}.code-banner>span{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.code-chip{align-self:flex-start;font-size:1.8rem;font-weight:800;letter-spacing:.2em;background:#0b1220;color:var(--text);border:1px solid rgba(255,255,255,.12);padding:8px 18px;border-radius:10px;cursor:pointer}.code-banner small{color:var(--muted)}.image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.image-choice{padding:6px;border-radius:10px;border:2px solid transparent;background:var(--panel-2);cursor:pointer;color:var(--text);display:flex;flex-direction:column;gap:6px}.image-choice img{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:6px;display:block}.image-choice.selected{border-color:var(--primary)}.difficulty-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:22px}.diff-choice{padding:14px;border-radius:10px;border:2px solid transparent;background:var(--panel-2);color:var(--text);cursor:pointer;display:flex;flex-direction:column;gap:4px}.diff-choice span{color:var(--muted);font-size:.85rem}.diff-choice.selected{border-color:var(--primary)}.waiting{text-align:center;padding:40px 0;color:var(--muted)}.spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--primary);border-radius:50%;margin:0 auto 16px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.players-panel{padding:18px}.players-panel h3{margin:0 0 12px;font-size:.95rem}.players-panel ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.players-panel li{display:flex;align-items:center;gap:8px;font-size:.9rem}.dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.players-panel .pseudo{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag{font-size:.7rem;background:var(--primary);padding:2px 6px;border-radius:5px}.count{font-variant-numeric:tabular-nums;color:var(--muted);font-weight:700}.game{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden}.canvas{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 30%,#24324a,#0e1622 75%);touch-action:none;-webkit-user-select:none;user-select:none;cursor:grab;overflow:hidden}.canvas:active{cursor:grabbing}.world{position:absolute;top:0;left:0;transform-origin:0 0;border-radius:2px}.piece{position:absolute;background-repeat:no-repeat;transition:left .08s linear,top .08s linear}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:50}.overlay>*{pointer-events:auto}.hud-panel{position:absolute;background:#0f172ad1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 14px}.top-left{top:max(12px,env(safe-area-inset-top));left:max(12px,env(safe-area-inset-left))}.top-right{top:max(12px,env(safe-area-inset-top));right:max(12px,env(safe-area-inset-right));display:flex;flex-direction:column;gap:10px;align-items:flex-end;max-width:46vw}.hud-code{letter-spacing:.15em;color:inherit;background:none;border:none;padding:0;cursor:pointer;font:inherit;font-weight:800;transition:opacity .15s}.hud-code:hover{opacity:.75}.menu-hint{font-size:.72rem;color:var(--muted)}kbd{font-family:inherit;font-size:.68rem;font-weight:700;color:#e2e8f0;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:5px;padding:1px 5px;margin:0 2px}.menu-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:120;display:flex;align-items:center;justify-content:center;background:#0307128c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.menu-card{width:min(360px,92vw);padding:26px 28px}.menu-card h2{margin:0 0 18px}.shortcuts{list-style:none;margin:0 0 26px;padding:0;display:flex;flex-direction:column;gap:12px}.shortcuts li{font-size:.85rem;color:var(--muted)}.menu-toggle{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text);cursor:pointer;margin-bottom:22px}.menu-toggle input{width:auto;flex:0 0 auto;margin:0;padding:0;accent-color:var(--primary)}.menu-actions{display:flex;gap:10px}.menu-actions .btn{flex:1}.hud-diff{color:var(--muted);font-size:.85rem}.hud-progress{display:flex;align-items:center;gap:10px;margin-top:10px}.bar{flex:1;height:8px;background:#0b1220;border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);transition:width .3s ease}.hud-progress span{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.8rem;white-space:nowrap}.players-inline{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.player-chip{display:inline-flex;align-items:center;gap:5px;background:#ffffff0f;padding:3px 8px;border-radius:999px;font-size:.8rem}.controls{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px}.ghost-toggle{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--muted);cursor:pointer}.reference{position:absolute;right:max(12px,env(safe-area-inset-right));bottom:max(12px,env(safe-area-inset-bottom));background:#0f172ad9;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:6px;text-align:center;cursor:pointer}.reference img{display:block;width:160px;aspect-ratio:4 / 3;object-fit:cover;border-radius:6px;transition:width .18s ease}.reference.big img{width:360px}.reference span{font-size:.72rem;color:var(--muted)}.btn.small.mode.block{background:var(--primary);border-color:transparent}.hint-bar{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#0f172abf;color:var(--muted);font-size:.8rem;padding:7px 14px;border-radius:999px;white-space:nowrap}.cursor{position:absolute;pointer-events:none;z-index:60;transition:left .09s linear,top .09s linear}.cursor-label{position:absolute;left:14px;top:10px;font-size:.72rem;color:#fff;padding:1px 6px;border-radius:6px;white-space:nowrap;box-shadow:0 2px 4px #0000004d}.end-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#020617b8;display:flex;align-items:center;justify-content:center;padding:20px;z-index:100}.end-card{width:100%;max-width:420px;padding:28px;text-align:center}.end-card h2{margin:0 0 16px}.end-image{width:100%;max-width:280px;border-radius:10px;aspect-ratio:4 / 3;object-fit:cover}.end-time{font-size:1.1rem;margin:14px 0}.end-card h3{margin:8px 0 10px;font-size:.95rem}.end-ranking{list-style:none;margin:0 0 20px;padding:0;text-align:left;display:flex;flex-direction:column;gap:8px}.end-ranking li{display:flex;align-items:center;gap:8px}.end-ranking .pseudo{flex:1}.end-actions{display:flex;gap:10px;justify-content:center}.hint{color:var(--muted);font-size:.85rem;margin:14px 0 0}@media (max-width: 820px){.setup{grid-template-columns:1fr}.reference img{width:110px}.reference.big img{width:min(230px,58vw)}.tray-shelf{right:max(12px,env(safe-area-inset-right))}.tray-shelf.shifted{right:calc(min(230px,58vw) + 30px)}}@media (pointer: coarse){.btn{padding:12px 18px}.btn.small{padding:9px 14px}input{padding:13px 14px;font-size:16px}}@media (max-width: 560px){.setup{padding:14px;gap:14px}.setup-main{padding:18px}.lobby .card{padding:24px 20px}.lobby h1{font-size:1.45rem}.code-chip{font-size:1.4rem;letter-spacing:.15em}.image-grid{grid-template-columns:repeat(2,1fr)}.difficulty-row{grid-template-columns:1fr}.diff-choice{flex-direction:row;align-items:baseline;justify-content:space-between}.hud-panel{padding:8px 10px}.hud-code{font-size:.9rem;letter-spacing:.08em}.top-right{max-width:60vw;gap:8px}.players-inline{max-width:100%}.player-chip{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.end-actions{flex-direction:column}.menu-actions{flex-direction:column-reverse}}.join-row input{flex:1;min-width:0}.import-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:96px;border:2px dashed rgba(255,255,255,.2);color:var(--muted)}.import-tile .plus{font-size:1.7rem;line-height:1}.tray-shelf{position:absolute;left:max(12px,env(safe-area-inset-left));right:188px;bottom:max(12px,env(safe-area-inset-bottom));display:flex;align-items:center;gap:12px;background:#0f172ad1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px 12px;min-height:74px;transition:right .18s ease}.tray-shelf.shifted{right:384px}.tray-label{font-size:.8rem;color:var(--muted);white-space:nowrap}.tray-items{display:flex;align-items:center;gap:8px;overflow-x:auto;flex:1;min-height:64px}.tray-piece{position:relative;flex:0 0 auto;cursor:grab;touch-action:none}.tray-piece:active{cursor:grabbing}.tray-ghost{position:fixed;z-index:200;pointer-events:none;transform:translate(-50%,-50%)}@keyframes piece-error{0%{transform:translate(0)}15%{transform:translate(-5px)}30%{transform:translate(5px)}45%{transform:translate(-4px)}60%{transform:translate(4px)}75%{transform:translate(0)}to{transform:translate(0)}}.piece.error{animation:piece-error .42s ease;filter:drop-shadow(0 0 3px #ef4444) drop-shadow(0 0 5px #ef4444)!important}.tray-piece.error{animation:piece-error .42s ease}
