:root{--emerald: #1b8a6b;--emerald-deep: #0f5c47;--garnet: #9c2b3a;--garnet-deep: #6e1a26;--gold: #c9a14a;--gold-bright: #e7c878;--parchment: #f3e7cf;--parchment-dark: #e6d4b2;--ink: #2b2118;--bg: #1c140d;--cell-light: #efe1c2;--cell-dark: #e3d0a8}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,sans-serif;color:var(--ink);background:radial-gradient(circle at 50% -10%,#2e2113 0%,var(--bg) 60%);min-height:100vh}.app{max-width:920px;margin:0 auto;padding:1.5rem 1rem 3rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.music-toggle{position:fixed;top:12px;right:12px;z-index:20;width:40px;height:40px;border-radius:50%;border:2px solid var(--gold);background:#2b1d09cc;color:var(--gold-bright);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,background .15s}.music-toggle:hover{transform:scale(1.08);background:#3a2810}.lang-toggle{position:fixed;top:12px;left:12px;z-index:20;min-width:40px;height:40px;padding:0 12px;border-radius:20px;border:2px solid var(--gold);background:#2b1d09cc;color:var(--gold-bright);font-size:.85rem;font-weight:700;letter-spacing:.04em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,background .15s}.lang-toggle:hover{transform:scale(1.08);background:#3a2810}.help-toggle{position:fixed;top:12px;left:60px;z-index:20;width:40px;height:40px;border-radius:50%;border:2px solid var(--gold);background:#2b1d09cc;color:var(--gold-bright);font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,background .15s}.help-toggle:hover{transform:scale(1.08);background:#3a2810}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#0009;display:flex;align-items:center;justify-content:center;padding:16px}.modal{max-width:460px;width:100%;background:#2b1d09;border:2px solid var(--gold);border-radius:12px;padding:20px 22px;color:var(--parchment);box-shadow:0 10px 40px #000a}.modal__title{margin:0 0 8px;color:var(--gold-bright)}.modal__goal{margin:0 0 12px;opacity:.9}.modal__rules{margin:0 0 12px;padding-left:1.1rem;line-height:1.5}.modal__rules li{margin:4px 0}.modal__twist{margin:0 0 16px;line-height:1.5}.modal .btn{width:100%}.hud__invite-row{display:flex;flex-direction:column;gap:.4rem}.hud__invite{width:100%;text-align:center;font-size:.85rem;padding:.5rem .6rem}.hud__invite-hint{font-size:.8rem;opacity:.85}.tutorial-banner{max-width:560px;margin:0 auto .75rem;background:#2b1d09;border:2px solid var(--gold);border-radius:12px;padding:.6rem .9rem;color:var(--parchment);display:flex;align-items:center;gap:.7rem;box-shadow:0 6px 20px #0005}.tutorial-banner__step{flex:0 0 auto;font-weight:700;font-size:.8rem;color:var(--gold-bright);background:#0003;border-radius:999px;padding:.2rem .55rem}.tutorial-banner__text{margin:0;flex:1;font-size:.9rem;line-height:1.35}.tutorial-banner__exit{flex:0 0 auto;font-size:.78rem;padding:.3rem .6rem}.tutorial-banner--done{flex-direction:column;text-align:center;gap:.6rem;color:var(--gold-bright);font-size:1.05rem}.tutorial-banner__actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.winner{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#000a;padding:16px;overflow:hidden}.winner__card{position:relative;background:var(--parchment);border:3px solid var(--gold);border-radius:16px;padding:1.6rem 2rem;text-align:center;max-width:90vw;box-shadow:0 16px 50px #000a,0 0 40px var(--gold)}.winner__card--emerald{border-color:var(--emerald);box-shadow:0 16px 50px #000a,0 0 55px var(--emerald)}.winner__card--garnet{border-color:var(--garnet);box-shadow:0 16px 50px #000a,0 0 55px var(--garnet)}.winner__seal{font-size:3rem;line-height:1;color:var(--ink)}.winner__card--emerald .winner__seal{color:var(--emerald-deep)}.winner__card--garnet .winner__seal{color:var(--garnet-deep)}.winner__title{margin:.4rem 0 1.1rem;font-size:clamp(1.6rem,6vw,2.4rem);color:var(--ink)}.winner__card--emerald .winner__title{color:var(--emerald-deep)}.winner__card--garnet .winner__title{color:var(--garnet-deep)}.winner__actions{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}.winner__confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.winner__confetti span{position:absolute;left:50%;top:28%;width:10px;height:14px;border-radius:2px}.reconnect-banner{position:fixed;top:0;left:0;right:0;z-index:30;text-align:center;padding:6px 12px;background:#2b1d09ee;color:var(--gold-bright);border-bottom:1px solid var(--gold);font-size:.9rem;letter-spacing:.02em}.app__header{text-align:center;color:var(--parchment)}.app__logo{display:block;margin:0 auto;width:min(70vw,360px);height:auto;filter:drop-shadow(0 3px 6px #00000070)}.app__subtitle{margin:.2rem 0 0;opacity:.8;font-size:.95rem}.app__footer{color:var(--parchment);opacity:.55;font-size:.8rem;text-align:center}.app__credit{margin:.35rem 0 0;font-size:.8rem;text-align:center;color:#f3e7cfa0}.app__heart{color:#e0556a;font-style:normal}.app__credit a{color:var(--gold-bright);text-decoration:none}.app__credit a:hover{text-decoration:underline}.app__board-area{display:flex;gap:1.5rem;align-items:flex-start;flex-wrap:wrap;justify-content:center}.board{position:relative;display:grid;gap:4px;padding:14px;background:linear-gradient(135deg,#6b4a25,#4d3318);border:6px solid var(--gold);border-radius:12px;box-shadow:0 10px 40px #000a,inset 0 0 0 2px #00000040;width:min(70vw,520px);aspect-ratio:1}.board[data-disabled=true]{pointer-events:none;opacity:.92}.cell{position:relative;border:none;border-radius:6px;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:filter .15s,box-shadow .15s}.cell--light{background:var(--cell-light)}.cell--dark{background:var(--cell-dark)}.cell:hover{filter:brightness(1.05)}.cell--clone-target{box-shadow:inset 0 0 0 3px var(--emerald)}.cell--jump-target{box-shadow:inset 0 0 0 3px var(--garnet)}.cell--reinforced{animation:reinforce-glow .65s ease-out}@keyframes reinforce-glow{0%{box-shadow:inset 0 0 0 4px var(--gold-bright),0 0 20px 3px var(--gold-bright);background:var(--gold-bright)}to{box-shadow:inset 0 0 #e7c87800,0 0 #e7c87800}}.cell__dot{position:absolute;width:22%;height:22%;border-radius:50%;background:#0003;pointer-events:none}.vfx{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;z-index:5}.vfx>*{grid-area:1 / 1}.vfx__ring{width:72%;height:72%;border-radius:50%;border:3px solid;box-sizing:border-box}.vfx__flash{width:82%;height:82%;border-radius:50%}.vfx__spark{width:6px;height:6px;border-radius:50%}.mover{position:absolute;z-index:6;display:flex;align-items:center;justify-content:center;pointer-events:none}.piece{width:78%;height:78%;display:flex;align-items:center;justify-content:center;position:relative;color:var(--parchment);perspective:360px}.piece--sprite{width:94%;height:94%}.piece__img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;backface-visibility:hidden;-webkit-user-drag:none}.piece--token{border-radius:50%;box-shadow:0 3px 8px #00000070,inset 0 2px 4px #ffffff40,inset 0 -3px 6px #00000060;border:2px solid var(--gold)}.piece--token.piece--emerald{background:radial-gradient(circle at 35% 30%,var(--emerald),var(--emerald-deep))}.piece--token.piece--garnet{background:radial-gradient(circle at 35% 30%,var(--garnet),var(--garnet-deep))}.piece--token.piece--rank2{border-width:3px}.piece--token.piece--rank3{border-width:3px;box-shadow:0 0 14px var(--gold-bright),0 3px 8px #00000070}.piece--selected{outline:3px solid var(--gold-bright);outline-offset:2px;border-radius:50%}.piece__glyph{font-size:1.4rem;line-height:1;opacity:.9}.piece__rank{position:absolute;bottom:-2px;display:flex;gap:2px}.piece__pip{width:5px;height:5px;border-radius:50%;background:var(--gold-bright);box-shadow:0 0 3px #000}.piece__badge{position:absolute;top:-3px;right:-3px;min-width:15px;height:15px;padding:0 3px;box-sizing:border-box;border-radius:8px;background:var(--gold-bright);color:var(--ink);border:1px solid #00000066;font-size:10px;font-weight:700;line-height:13px;text-align:center;box-shadow:0 1px 2px #0008;pointer-events:none;z-index:2}.hud{background:var(--parchment);border:3px solid var(--gold);border-radius:12px;padding:1rem;width:240px;flex:0 0 240px;display:flex;flex-direction:column;gap:.85rem;box-shadow:0 8px 28px #0006}.hud__scores{display:flex;gap:.6rem}.score{flex:1;border-radius:8px;padding:.5rem;text-align:center;color:#fff;opacity:.75;transition:opacity .2s,transform .2s}.score--active{opacity:1;transform:translateY(-2px);box-shadow:0 4px 12px #0005}.score--emerald{background:var(--emerald-deep)}.score--garnet{background:var(--garnet-deep)}.score__house{display:block;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.score__value{font-size:1.7rem;font-weight:700}.hud__status{font-size:.95rem;min-height:2.8em;display:flex;align-items:center}.hud__winner{font-size:1.2rem}.hud__winner--emerald{color:var(--emerald-deep)}.hud__winner--garnet{color:var(--garnet-deep)}.hud__hint{font-size:.82rem;opacity:.7;margin:0}.hud__hint--warn{color:var(--garnet-deep);opacity:.95}.hud__actions{display:flex;flex-direction:column;gap:.5rem}.hud__newgame{margin-top:auto}.tag{font-style:normal;font-weight:700}.tag--emerald{color:var(--emerald-deep)}.tag--garnet{color:var(--garnet-deep)}.mode-select{background:var(--parchment);border:3px solid var(--gold);border-radius:14px;padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1rem;min-width:300px;box-shadow:0 10px 36px #0007}.mode-select h2{margin:0;color:var(--ink)}.mode-select__hint{margin:0;font-size:.85rem;opacity:.75}.code-input{flex:1;font:inherit;font-size:1.3rem;letter-spacing:.35em;text-align:center;text-transform:uppercase;padding:.4rem .6rem;border:2px solid var(--gold);border-radius:8px;background:#fff8ea;color:var(--ink);width:6ch}.hud__room{display:flex;align-items:center;gap:.5rem;padding-bottom:.4rem;border-bottom:1px solid #00000022}.hud__room-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7}.hud__code{font:inherit;font-size:1.3rem;font-weight:700;letter-spacing:.2em;color:var(--ink);background:#fff8ea;border:2px solid var(--gold);border-radius:8px;padding:.1rem .5rem;cursor:pointer}.hud__code:hover{background:var(--gold)}.hud__presence{margin-left:auto;display:flex;gap:.3rem}.presence-dot{width:14px;height:14px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:8px;color:#fff;opacity:.35;border:2px solid transparent}.presence-dot--on{opacity:1}.presence-dot--emerald{background:var(--emerald)}.presence-dot--garnet{background:var(--garnet)}.mode-select__group{display:flex;flex-direction:column;gap:.4rem}.mode-select__label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7}.mode-select__row{display:flex;gap:.5rem}.toggle,.btn{font:inherit;cursor:pointer;border-radius:8px;border:2px solid var(--gold);padding:.5rem .9rem;background:#fff8ea;color:var(--ink);transition:background .15s,transform .1s,box-shadow .15s}.toggle:hover,.btn:hover{transform:translateY(-1px)}.toggle--active{background:var(--gold);color:#2b1d09;font-weight:700}.toggle--emerald.toggle--active{background:var(--emerald);color:#fff;border-color:var(--emerald-deep)}.toggle--garnet.toggle--active{background:var(--garnet);color:#fff;border-color:var(--garnet-deep)}.btn--primary{background:var(--gold);font-weight:700;color:#2b1d09}.btn--reinforce{background:var(--gold-bright);font-weight:700}.btn--ghost{background:transparent}.modal .btn--ghost,.tutorial-banner .btn--ghost{color:var(--parchment)}.modal .btn--ghost:hover,.tutorial-banner .btn--ghost:hover{background:#ffffff1a}.btn:disabled{opacity:.55;cursor:default;transform:none}.error{color:var(--garnet);font-size:.85rem;margin:0}@media (max-width: 680px){.app__board-area{flex-direction:column-reverse;align-items:center}.board{width:min(92vw,460px)}}
