.board-outer{position:relative;display:inline-block;touch-action:none}.board-inner{position:relative;transform-origin:0 0;transition:transform .3s ease}.board-inner,.layer{width:var(--board-w);height:var(--board-h)}.layer{position:absolute;top:0;left:0;pointer-events:none}.layer-board{z-index:0;pointer-events:auto;background:var(--board-bg);border-radius:16px}.board-center{position:absolute;background:var(--center-bg);border-radius:8px}.layer-tiles{z-index:auto}.tile{position:absolute;width:var(--tile-w);height:var(--tile-h);cursor:default}.tile svg{width:100%;height:100%;overflow:visible}.tile polygon{fill:var(--tile-bg);stroke:var(--tile-stroke);stroke-width:1.5}.tile.tile-start polygon{fill:var(--tile-start)}.tile.tile-special polygon{fill:var(--tile-special)}.tile.tile-reward polygon{fill:var(--tile-reward)}.tile{transition:transform .25s ease;transform-origin:center}.tile.tile-current{transform:scale(1.2);z-index:10}.tile-icon{font-size:var(--font-tile-icon);line-height:1}.tile-label{font-size:var(--font-tile-label);color:#ccc;white-space:pre-line;word-break:keep-all;text-align:center;line-height:1.2}.tile-number{font-size:var(--font-tile-number);color:#666}.tile-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;pointer-events:none}.layer-token{z-index:999}.piece{position:absolute;width:var(--token-size);height:var(--token-size);color:var(--token-color);font-size:var(--token-size);line-height:1;transform:translate(-50%,-50%);transition:left .3s ease,top .3s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.6))}.layer-dice{z-index:9999;pointer-events:none}.layer-overlay{z-index:9999;pointer-events:auto}.overlay-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);animation:reward-backdrop-in .25s ease both}.overlay-reward-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#1a1a1a;border:1px solid var(--tile-stroke);border-radius:16px;padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;min-width:200px;z-index:1;animation:reward-card-pop .5s cubic-bezier(.34,1.56,.64,1) both;will-change:transform}.overlay-reward-icon{font-size:40px}.overlay-reward-label{font-size:16px;color:#fff;font-weight:600}.overlay-reward-amount{font-size:20px;color:#FFD700;font-weight:700}.overlay-confirm-btn{margin-top:8px;padding:10px 32px;background:var(--tile-stroke);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer}@keyframes reward-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes reward-card-pop{0%{transform:translate(-50%,-50%) scale(.3);opacity:0}55%{transform:translate(-50%,-50%) scale(1.12);opacity:1}75%{transform:translate(-50%,-50%) scale(.96)}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes reward-glow-expand{0%{transform:translate(-50%,-50%) scale(.2);opacity:.85}to{transform:translate(-50%,-50%) scale(3.5);opacity:0}}@keyframes reward-particle-fly{0%{transform:translate(-50%,-50%) rotate(var(--particle-angle)) translateX(0) scale(1);opacity:1}80%{opacity:.7}to{transform:translate(-50%,-50%) rotate(var(--particle-angle)) translateX(100px) scale(0);opacity:0}}.overlay-glow-ring{width:200px;height:200px;background:radial-gradient(circle,rgba(209,17,19,.5) 0,rgba(255,215,0,.2) 50%,transparent 70%);z-index:0;animation:reward-glow-expand .65s ease-out both}.overlay-glow-ring,.overlay-particle{position:absolute;top:50%;left:50%;border-radius:50%;pointer-events:none}.overlay-particle{z-index:2;will-change:transform,opacity;animation:reward-particle-fly .75s ease-out both;animation-delay:var(--particle-delay,0s)}.attendance-hud{display:flex;align-items:center;gap:12px;padding:8px 16px;font-size:13px;color:#ccc}.hud-days strong{color:#fff}.hud-checked{color:#4caf50;font-weight:600}.zoom-controls{position:absolute;bottom:12px;right:12px;z-index:10000;display:flex;flex-direction:column;gap:4px;pointer-events:auto}.zoom-btn{width:30px;height:30px;background:rgba(20,20,20,.92);border:1px solid rgba(209,17,19,.45);border-radius:6px;color:#fff;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,opacity .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.zoom-btn:hover:not(:disabled){background:rgba(209,17,19,.45)}.zoom-btn:disabled{opacity:.3;cursor:default}.zoom-btn-home{font-size:14px}