.piece{display:flex;align-items:center;justify-content:center;width:100%;height:100%;box-shadow:0 4px 8px #0000004d;cursor:grab;transition:all .2s ease;position:relative;z-index:2;touch-action:none;-webkit-user-select:none;user-select:none}.piece--active-turn{opacity:1}.piece--inactive-turn{opacity:.7}.piece--full-opacity{opacity:1!important}.piece:hover{transform:scale(1.05);box-shadow:0 6px 12px #0006;z-index:3}.piece:active{cursor:grabbing;transform:scale(1.025)}.piece__image{width:98%;height:98%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;-webkit-user-drag:none}.piece--dragging{opacity:.8;transform:scale(1.1);z-index:1000;cursor:grabbing!important;box-shadow:0 8px 20px #00000080}.piece--disabled{cursor:not-allowed!important;opacity:.4;pointer-events:none}.piece--selected{box-shadow:0 0 0 3px #07df94,0 6px 12px #0006;animation:pulse-glow 1.5s ease-in-out infinite alternate;transform:scale(1.05)}@keyframes pulse-glow{0%{box-shadow:0 0 0 2px #07dfd4,0 4px 8px #0000004d;transform:scale(1.02)}to{box-shadow:0 0 0 4px #07df94,0 6px 12px #0006;transform:scale(1.05)}}.piece--selected{box-shadow:0 0 0 3px #0091ff,0 6px 12px #0006;animation:pulse-glow 1.5s ease-in-out infinite alternate;transform:scale(1.05)}@keyframes pulse-glow{0%{box-shadow:0 0 0 5px #0bf,0 4px 8px #0000004d;transform:scale(1.02)}to{box-shadow:0 0 0 10px #0091ff,0 6px 12px #0006;transform:scale(1.05)}}.cell--valid-move .piece:hover{transform:scale(1.15);box-shadow:0 8px 16px #00000080;z-index:3}.piece--dragging.piece--invalid-target{box-shadow:0 0 0 3px #c00,0 8px 20px #00000080!important;filter:brightness(.9) saturate(.8)}.piece--dragging:not(.piece--invalid-target){box-shadow:0 0 0 3px #66bb6a,0 8px 20px #00000080!important}.piece--dragging{width:100%;height:100%}.cell{position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease,box-shadow .2s ease;font-size:.75rem;font-weight:700;overflow:visible}.cell:hover{z-index:10;box-shadow:0 0 10px #ffffff80}.cell--selected{box-shadow:inset 0 0 0 3px #07df94;z-index:5}.cell__river-flow{position:absolute;right:8px;font-size:1.2rem;font-weight:700;opacity:.8;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.5);z-index:1}.cell--drag-over{box-shadow:inset 0 0 0 3px #66bb6a;background-color:#66bb6a33!important}.cell--river.cell--drag-over,.cell--throne.cell--drag-over{background-color:#66bb6a4d!important}.cell__move-indicator{position:absolute;width:20px;height:20px;background-color:#66bb6a;border-radius:50%;opacity:.6;animation:pulse 1.5s ease-in-out infinite alternate;z-index:1}@keyframes pulse{0%{transform:scale(.8);opacity:.4}to{transform:scale(1.1);opacity:.7}}.cell--valid-move:hover .cell__move-indicator{opacity:.8;transform:scale(1.2)}.cell--valid-move{position:relative;cursor:pointer}.cell--valid-move:before{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background-color:#66bb6a99;z-index:1;animation:pulse 1.5s ease-in-out infinite alternate}.cell--valid-move:hover:before{opacity:.9;transform:scale(1.3);box-shadow:0 0 0 4px #66bb6a80}.cell--capture:after{content:"";position:absolute;width:100%;height:100%;border:3px solid #CC0000;border-radius:4px;z-index:2;animation:capture-pulse 1s ease-in-out infinite}@keyframes capture-pulse{0%,to{opacity:.7}50%{opacity:1}}.cell--valid-move.cell--capture:before{background-color:#ff6b6b;box-shadow:0 0 0 2px #ff6b6b4d;animation:pulse-capture 1.2s ease-in-out infinite alternate}.cell--valid-move.cell--capture:hover:before{box-shadow:0 0 0 4px #ff6b6b80}@keyframes pulse{0%{opacity:.4;transform:scale(.8)}to{opacity:.8;transform:scale(1.1)}}@keyframes pulse-capture{0%{transform:scale(.7);opacity:.6}to{transform:scale(1.2);opacity:.9}}.cell--last-move-from{box-shadow:inset 0 0 0 3px #ffd93d;animation:glow-origin 2s ease-in-out}.cell--last-move-to{box-shadow:inset 0 0 0 3px #6bcf7f;animation:glow-destination 2s ease-in-out}@keyframes glow-origin{0%{box-shadow:inset 0 0 0 4px #ffd93d}50%{box-shadow:inset 0 0 0 6px #ffd93d}to{box-shadow:inset 0 0 0 3px #ffd93d}}@keyframes glow-destination{0%{box-shadow:inset 0 0 0 4px #6bcf7f}50%{box-shadow:inset 0 0 0 6px #6bcf7f}to{box-shadow:inset 0 0 0 3px #6bcf7f}}.cell--last-move-from.cell--selected{box-shadow:inset 0 0 0 3px #ffd93d,0 0 0 3px #fc0}.cell--last-move-to.cell--selected{box-shadow:inset 0 0 0 3px #6bcf7f,0 0 0 3px #fc0}.cell--invalid-drop{box-shadow:inset 0 0 0 3px #c00!important;background-color:#cc00001a!important;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.cell--drag-over-invalid{box-shadow:inset 0 0 0 3px #c00!important;background-color:#cc000026!important;animation:pulse-invalid .6s ease-in-out infinite alternate}@keyframes pulse-invalid{0%{background-color:#cc00001a;box-shadow:inset 0 0 0 2px #c00}to{background-color:#c003;box-shadow:inset 0 0 0 3px #c00}}.cell--drag-over-valid{box-shadow:inset 0 0 0 3px #66bb6a!important;background-color:#66bb6a33!important}.cell--animation-from{animation:river-from 1s ease-in-out!important;z-index:1000!important}.cell--animation-intermediate{animation:river-intermediate 1s ease-in-out .3s both!important;z-index:1000!important}.cell--animation-final{animation:river-final 1s ease-in-out .6s both!important;z-index:1000!important}@keyframes river-from{0%{box-shadow:inset 0 0 0 8px gold,0 0 20px gold!important;background-color:#ffd70099!important;transform:scale(1.1)}50%{box-shadow:inset 0 0 0 12px gold,0 0 30px gold!important;background-color:#ffd700e6!important;transform:scale(1.15)}to{box-shadow:inset 0 0 0 8px gold,0 0 20px gold!important;background-color:#ffd70099!important;transform:scale(1.1)}}@keyframes river-intermediate{0%{box-shadow:inset 0 0 0 8px #00f,0 0 20px #00f!important;background-color:#00f9!important;transform:scale(1.1)}50%{box-shadow:inset 0 0 0 12px #00f,0 0 30px #00f!important;background-color:#0000ffe6!important;transform:scale(1.15)}to{box-shadow:inset 0 0 0 8px #00f,0 0 20px #00f!important;background-color:#00f9!important;transform:scale(1.1)}}@keyframes river-final{0%{box-shadow:inset 0 0 0 8px #32cd32,0 0 20px #32cd32!important;background-color:#32cd3299!important;transform:scale(1.1)}50%{box-shadow:inset 0 0 0 12px #32cd32,0 0 30px #32cd32!important;background-color:#32cd32e6!important;transform:scale(1.15)}to{box-shadow:inset 0 0 0 8px #32cd32,0 0 20px #32cd32!important;background-color:#32cd3299!important;transform:scale(1.1)}}.cell--premove-from{box-shadow:inset 0 0 0 3px #ef4444;background-color:#ef44442e!important}.cell--premove-to{box-shadow:inset 0 0 0 3px #ef4444;background-color:#ef44441f!important;animation:premove-pulse 1.4s ease-in-out infinite}@keyframes premove-pulse{0%,to{background-color:#ef44441f!important}50%{background-color:#ef444447!important}}.cell--river.cell--premove-from,.cell--river.cell--premove-to{box-shadow:inset 0 0 0 3px #ef4444}.river-animation-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:100000;overflow:visible!important}.animation-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.path-line{stroke-width:4;stroke-dasharray:10,5;animation:dash-flow 2s linear infinite;fill:none}.path-entry{stroke:#06f;animation-delay:0s}.path-push{stroke:#00ff64;animation-delay:1s}.path-point{animation:point-pulse 2s ease-in-out infinite}.path-start{fill:#fc0;animation-delay:0s}.path-intermediate{fill:#06f;animation-delay:.3s}.path-final{fill:#00ff64;animation-delay:.6s}.path-label{position:absolute;background:#000c;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700;white-space:nowrap;pointer-events:none;z-index:100001;animation:label-fade 2s ease-in-out infinite}.label-start{animation-delay:0s;border-left:3px solid #ffcc00}.label-intermediate{animation-delay:.5s;border-left:3px solid #0066ff}.label-final{animation-delay:1s;border-left:3px solid #00ff64}@keyframes dash-flow{0%{stroke-dashoffset:0}to{stroke-dashoffset:-15}}@keyframes point-pulse{0%,to{r:8;opacity:1}50%{r:12;opacity:.7}}@keyframes label-fade{0%,to{opacity:1;transform:translateY(0)}50%{opacity:.7;transform:translateY(-2px)}}.teach-arrow-overlay{position:absolute;top:0;left:0;pointer-events:none;z-index:20;overflow:visible}.timer{display:flex;align-items:center;gap:.5rem;transition:color .3s ease}.timer-northern .timer-display,.timer-northern .timer-status{color:#e05555}.timer-southern .timer-display,.timer-southern .timer-status{color:#94a3b8}.timer-active.timer-northern .timer-display{color:#f87171}.timer-active.timer-southern .timer-display{color:#cbd5e0}.timer-critical .timer-display{color:#facc15!important;font-weight:900;animation:critical-text-pulse .8s ease-in-out infinite}@keyframes critical-text-pulse{0%,to{opacity:1}50%{opacity:.6}}.timer-player{font-weight:600;font-size:.78rem;color:#64748b}.timer-status{font-size:.72rem;opacity:.7}.timer-display{font-family:PGF Monona,Courier New,monospace;font-size:1rem;font-weight:700;letter-spacing:.04em}.captured-pieces{display:inline-flex;flex-direction:row;align-items:center;gap:.5rem;padding:.1rem .6rem;border-radius:6px;min-width:100px}.captured-pieces-header{display:flex;justify-content:space-between;align-items:center;font-size:.6rem;font-weight:300;text-transform:uppercase;letter-spacing:1px;min-width:50px}.captured-label{color:#bbc7da;margin-right:.4rem}.captured-points{color:#bbc7da;font-family:PGF Monona,Courier New,monospace}.captured-pieces-list{display:flex;gap:.3rem;align-items:center;flex-wrap:wrap}.captured-piece{display:flex;align-items:center;transition:transform .2s ease}.captured-piece:hover{transform:scale(1.1)}.captured-piece-icon.northern{width:18px;height:18px;filter:brightness(0) saturate(100%) invert(16%) sepia(96%) saturate(3749%) hue-rotate(352deg) brightness(78%) contrast(117%)}.captured-piece-icon.southern{width:18px;height:18px;filter:brightness(0) saturate(100%) invert(78%) sepia(0%) saturate(546%) hue-rotate(195deg) brightness(96%) contrast(100%)}.captured-pieces-empty{font-size:.6rem;color:#9ca3af;font-style:italic;text-align:center;padding:.1rem 0;min-width:50px}.captured-pieces.northern,.captured-pieces.southern{background:#ffffff0d}@media (max-width: 768px){.captured-pieces{min-width:100px;padding:.1rem;gap:.3rem}.captured-pieces-header{min-width:70px;font-size:.6rem}.captured-piece-icon.northern,.captured-piece-icon.southern{width:18px;height:18px}.captured-pieces-list{gap:.25rem}.captured-pieces-empty{min-width:70px;font-size:.6rem}}@media (max-width: 480px){.captured-pieces{min-width:80px;gap:.3rem}.captured-label{display:none}.captured-pieces-header{min-width:50px;justify-content:center}.captured-piece-icon.northern,.captured-piece-icon.southern{width:16px;height:16px}.captured-pieces-list{gap:.2rem}.captured-pieces-empty{min-width:50px;font-size:.6rem}}@media (max-width: 360px){.captured-pieces{flex-direction:column;gap:.2rem;min-width:60px}.captured-pieces-header{min-width:auto}.captured-pieces-list{justify-content:center}}.game-result-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0a0a14d1;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);border-radius:8px;animation:overlay-fade-in .4s ease}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.game-result-card{position:relative;width:88%;max-width:480px;border-radius:12px;overflow:hidden;box-shadow:0 24px 64px #000000b3;animation:card-rise .5s cubic-bezier(.22,1,.36,1)}@keyframes card-rise{0%{transform:translateY(32px);opacity:0}to{transform:translateY(0);opacity:1}}.game-result-card.north-win{border:2px solid #cc2222}.game-result-card.south-win{border:2px solid #8c8c8c}.game-result-card.draw{border:2px solid #b8860b}.game-result-artwork{width:100%;height:180px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.game-result-artwork.north-win{background:linear-gradient(160deg,#1a0000,#4a0000,#c22)}.game-result-artwork.south-win{background:linear-gradient(160deg,#0d0d0d,#2a2a2a,#666)}.game-result-artwork.draw{background:linear-gradient(160deg,#1a1500,#3d3000,#b8860b)}.result-artwork-img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;right:0;bottom:0;left:0}.result-artwork-placeholder{font-size:5rem;opacity:.25;-webkit-user-select:none;user-select:none}.result-condition-badge{position:absolute;bottom:10px;left:50%;transform:translate(-50%);padding:3px 14px;border-radius:20px;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}.north-win .result-condition-badge{background:#cc2222d9;color:#fff}.south-win .result-condition-badge{background:#646464d9;color:#fff}.draw .result-condition-badge{background:#b8860bd9;color:#fff}.game-result-body{background:#111827;padding:1.25rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.75rem}.result-winner-label{font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;opacity:.55;color:#d1d5db;margin:0}.result-winner-name{margin:0;font-size:1.6rem;font-weight:800;line-height:1.1;letter-spacing:-.02em}.north-win .result-winner-name{color:#f87171}.south-win .result-winner-name{color:#d1d5db}.draw .result-winner-name{color:#fbbf24}.result-win-condition{margin:.1rem 0 0;font-size:.78rem;font-weight:600;letter-spacing:.01em;opacity:.75}.north-win .result-win-condition{color:#f87171}.south-win .result-win-condition{color:#d1d5db}.draw .result-win-condition{color:#fbbf24}.result-description{margin:0;font-size:.82rem;color:#9ca3af;line-height:1.45;border-left:3px solid #374151;padding-left:.75rem}.result-stats{display:flex;gap:1rem;padding:.6rem 0;border-top:1px solid #1f2937;border-bottom:1px solid #1f2937}.result-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.result-stat-value{font-size:1.2rem;font-weight:700;color:#f9fafb}.result-stat-label{font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#6b7280}.result-actions{display:flex;gap:.5rem}.result-btn{flex:1;padding:.6rem 0;border:none;border-radius:8px;font-size:.82rem;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s}.result-btn:hover{opacity:.88}.result-btn:active{transform:scale(.97)}.result-btn-primary{background:#1d7683;color:#fff}.result-btn-rematch{background:#dc2626;color:#fff}.result-btn-rematch:hover{opacity:.88}.result-btn-secondary{background:#1f2937;color:#d1d5db;border:1px solid #374151}.victory-banner{display:flex;flex-direction:column;gap:2px;padding:.5rem .75rem;border-radius:6px;font-size:.78rem;font-weight:700;margin-top:.5rem}.victory-banner.north-win{background:#fef2f2;color:#991b1b;border:1px solid #fca5a5}.victory-banner.south-win{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.victory-banner.draw{background:#fffbeb;color:#92400e;border:1px solid #fcd34d}.victory-banner-condition{font-size:.65rem;font-weight:500;opacity:.75;text-transform:uppercase;letter-spacing:.08em}.result-close-btn{position:absolute;top:.75rem;right:.75rem;width:2rem;height:2rem;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff9;font-size:1.25rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;z-index:10}.result-close-btn:hover{background:#ffffff2e;color:#fff}.result-golem-actions{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.08)}.result-btn-golem{background:#4ade8026;border:1px solid rgba(74,222,128,.4);color:#4ade80;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;width:100%;transition:background .15s}.result-btn-golem:hover{background:#4ade8040}.result-golem-dropdown-wrap{position:relative}.result-btn-golem-outline{background:transparent;border:1px solid rgba(74,222,128,.3);color:#4ade80b3;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;cursor:pointer;width:100%;transition:background .15s}.result-btn-golem-outline:hover{background:#4ade8014}.result-golem-dropdown{position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:#1e1e2e;border:1px solid #3a3a5a;border-radius:6px;overflow:hidden;z-index:20}.result-golem-option{display:flex;flex-direction:column;width:100%;padding:.5rem .75rem;background:none;border:none;border-bottom:1px solid #2a2a3a;cursor:pointer;text-align:left;transition:background .15s}.result-golem-option:last-child{border-bottom:none}.result-golem-option:hover,.result-golem-option.active{background:#2a2a4a}.result-golem-option-label{font-size:.82rem;font-weight:600;color:#c8c8d8}.result-golem-option-desc{font-size:.7rem;color:#6868a0;margin-top:1px}.coords-rank-strip{grid-column:1;grid-row:1;display:flex;flex-direction:column;align-items:flex-end;pointer-events:none;padding-right:.6rem}.coords-file-strip{grid-column:2;grid-row:2;display:flex;flex-direction:row;align-items:flex-start;pointer-events:none;padding-top:.4rem}.coord-label{flex:1;display:flex;align-items:center;justify-content:center;font-family:PGF Monona,Courier New,monospace;font-size:.62rem;font-weight:700;color:#b4b4c8d9;line-height:1;-webkit-user-select:none;user-select:none}.coord-label.river-rank{color:#50b4c8e6}:root{--header-h: 64px;--footer-h: 24px;--timer-h: 1.6rem;--layout-gap: .5rem;--board-v-padding: .75rem;--coords-rank-w: 1.4rem;--coords-file-h: 1.2rem}.board-with-timers-container{display:flex;flex-direction:column;gap:.2rem;width:100%;box-sizing:border-box;max-width:calc(100dvh - var(--header-h) - var(--footer-h) - var(--board-v-padding))}.board-top-section,.board-bottom-section{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:.1rem 0;width:100%;box-sizing:border-box;flex-shrink:0}.board-system{display:grid;grid-template-columns:1fr;grid-template-rows:1fr;width:100%;min-width:0}.board-system.coords-on{grid-template-columns:var(--coords-rank-w) 1fr;grid-template-rows:1fr var(--coords-file-h)}.board-container{position:relative;width:100%;height:100%;border-radius:8px;overflow:hidden}.board-system.coords-on .board-container{grid-column:2;grid-row:1}.board-system.coords-on:after{content:"";grid-column:1;grid-row:2}.board-system.coords-on .board-coordinates{grid-column:1;grid-row:1;display:flex;flex-direction:column;justify-content:space-between;height:100%}.board-system.coords-on .file-coords{grid-column:2;grid-row:2;display:flex;justify-content:space-around}.board{display:flex;width:100%;aspect-ratio:1 / 1}.board-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(7,1fr);width:100%;height:100%;background-color:#272620;gap:2px;box-shadow:0 10px 30px #0000004d}.board-grid.board-grid--9x9{grid-template-columns:repeat(9,1fr)!important;grid-template-rows:repeat(9,1fr)!important}.cell{position:relative;overflow:visible!important}.cell__coordinate{display:none}@media (max-width: 1099px) and (orientation: portrait){.board-with-timers-container{width:calc(100vw - 16px);max-width:calc(100vw - 16px)}}@media (min-width: 1600px){.board-with-timers-container{max-width:min(calc(100dvh - var(--header-h) - var(--footer-h) - var(--board-v-padding)),780px);max-height:min(calc(100dvh - var(--header-h) - var(--footer-h) - var(--board-v-padding)),780px)}}@media (min-width: 900px) and (max-width: 1400px) and (orientation: landscape){.board-with-timers-container{max-width:calc(100dvh - var(--header-h) - var(--footer-h) - var(--board-v-padding) - var(--timer-h) - .1rem - var(--timer-h) - .1rem - .4rem - .15rem - 18px)}.board-center-stack:has(.practice-mode-banner) .board-with-timers-container{max-width:calc(100dvh - var(--header-h) - var(--footer-h) - var(--board-v-padding) - var(--timer-h) - .1rem - var(--timer-h) - .1rem - .4rem - .15rem - 18px - 26px - .25rem)}}.board-flipped,.board-flipped .cell{transform:rotate(180deg)}.board-flipped .cell--river{transform:rotate(0)!important}.board-flipped .piece{transform:rotate(180deg)}.board-flipped .cell--river .piece{transform:rotate(360deg)}.board-flipped .cell__move-indicator,.board-flipped .cell__capture-indicator,.board-flipped .cell__river-flow{transform:rotate(180deg)}@media (max-width: 768px){.board-top-section,.board-bottom-section{padding:.1rem;gap:.5rem}}@media (max-width: 480px){.board-top-section,.board-bottom-section{flex-direction:column;gap:.25rem;min-height:auto}}.notation-system{background:#fff;border-radius:.5rem;padding:.5rem;box-shadow:0 4px 6px #0000001a;font-family:PGF Monona,Courier New,monospace;flex:1;min-height:0;display:flex;flex-direction:column}.notation-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;font-size:1.1rem;font-weight:700;color:#2d3748;margin-bottom:.75rem;font-family:PGF Webfont,system-ui,-apple-system,sans-serif;gap:.5rem}.notation-system-container{background:#fff;border-radius:.5rem;padding:1rem;box-shadow:0 4px 6px #0000001a;font-family:PGF Monona,Courier New,monospace;flex:1;min-height:0;display:flex;flex-direction:column}.notation-container{border:1px solid #e2e8f0;border-radius:.25rem;padding:.5rem;background:#f8f9fa;flex:1;min-height:0;overflow-y:auto}.notation-title{font-size:1.1rem;font-weight:700;color:#2d3748}.btn{padding:.4rem .8rem;border-radius:.25rem;border:1px solid #cbd5e0;background:#fff;cursor:pointer;font-size:.85rem;transition:all .2s;font-family:system-ui,-apple-system,sans-serif}.btn:hover{background:#f7fafc;border-color:#a0aec0}.btn-active{background:#3182ce;color:#fff;border-color:#2c5282}.btn-active:hover{background:#2c5282}.notation-controls{display:flex;gap:.5rem;flex-wrap:wrap}.notation-lines{display:flex;flex-direction:column;gap:.5rem}.notation-line{font-size:.65rem;line-height:1.2;color:#2d3748;display:flex;flex-wrap:wrap;align-items:center}.notation-time-control{font-weight:700;color:#2d3748;margin-right:.4rem;white-space:nowrap}.notation-slot{display:inline-flex;align-items:center;white-space:nowrap}.notation-slot:after{content:",";color:#2d3748;margin-left:.1rem;margin-right:.5rem}.notation-slot:last-child:after{content:"";margin:0}.notation-time{color:#2d3748}.notation-content{border:1px solid #e2e8f0;border-radius:.25rem;padding:1rem;background:#f8f9fa;max-height:400px;overflow-y:auto;font-size:.85rem}.time-control-label{font-weight:700;color:#2d3748}.compact-notation{line-height:1.8;color:#2d3748}.move-slot{display:inline;margin-right:.3rem}.move-number{font-weight:600}.notation-piece{color:#2d3748;font-weight:600}.notation-capture{color:#dc2626;font-weight:700;margin:0 1px}.notation-coord{color:#2d3748}.notation-hyphen{color:#2d3748;margin:0 1px}.notation-points{color:#dc2626;font-weight:700;margin-left:1px}.notation-timeout,.notation-draw{color:#dc2626;font-weight:700}.notation-win{color:#059669;font-weight:700}.notation-points{color:#dc2626;font-weight:700;margin-left:2px}.notation-timeout{color:#dc2626;font-weight:700}.notation-draw{color:#dc2626;font-weight:700;margin-left:.5rem}.notation-outcome{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #e2e8f0;font-weight:700}.no-moves{color:#6b7280;font-size:.9rem;text-align:center;padding:1rem;font-style:italic}.notation-explanation-container{background:#fff;border-radius:.5rem;padding:1rem;box-shadow:0 4px 6px #0000001a;font-family:PGF Webfont,system-ui,-apple-system,sans-serif}.explanation-header{font-size:1rem;font-weight:700;color:#2d3748;margin-bottom:.75rem}.explanation-content{display:flex;flex-direction:column;gap:.75rem;font-size:.85rem;line-height:1.4}.format-example,.example-section,.key-section,.piece-values{display:flex;flex-direction:column;gap:.25rem}.format-code,.example-code{font-family:PGF Monona,Courier New,monospace;background:#f8f9fa;padding:.5rem;border-radius:.25rem;border:1px solid #e2e8f0;font-size:.8rem;color:#2d3748}.key-section,.piece-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.key-item,.value-item{padding:.25rem .5rem;background:#f0f9ff;border-radius:.2rem;font-size:.75rem;color:#1e40af;border:1px solid #bae6fd}.value-item{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.notation-container::-webkit-scrollbar{width:6px}.notation-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.notation-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.notation-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.demo-controls{margin-top:1rem;padding:.75rem;background:#fef3c7;border-radius:.25rem;border:1px solid #fcd34d}.demo-controls h3{margin:0 0 .5rem;font-size:.9rem;color:#92400e}.demo-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.demo-btn{padding:.4rem .8rem;background:#fff;border:1px solid #d97706;border-radius:.25rem;cursor:pointer;font-size:.8rem;color:#92400e;font-weight:600}.demo-btn:hover{background:#fef3c7}.notation-legend{margin-top:1rem;padding:.75rem;background:#f0f9ff;border-radius:.25rem;font-size:.75rem;line-height:1.4}.notation-legend strong{color:#1e40af}.legend-example{font-family:PGF Monona,Courier New,monospace;background:#fff;padding:.25rem .5rem;border-radius:.2rem;display:inline-block;margin:.25rem 0}.legend-key{margin-top:.5rem;display:block}.legend-capture,.legend-points{color:#dc2626;font-weight:700}@media (max-width: 768px){.notation-line{font-size:.7rem}.notation-slot:after{margin-right:.4rem}.key-section,.piece-values{grid-template-columns:1fr}.notation-container{max-height:150px}}@media (max-width: 480px){.notation-history-container,.notation-explanation-container{padding:.75rem}.notation-header,.explanation-header{font-size:.9rem}}.detailed-notation{display:flex;flex-direction:column;gap:.5rem}.detailed-move{display:flex;align-items:center;gap:.4rem;font-size:.8rem;line-height:1.6;padding:.25rem;border-radius:.2rem;transition:background .2s}.detailed-move:hover{background:#3182ce1a}.move-time{color:#4a5568;font-weight:500}.move-duration{color:#718096;font-size:.75rem}.move-notation{font-weight:600;color:#2d3748}.move-contexts{display:flex;gap:.25rem;flex-wrap:wrap}.context-badge{background:#e6fffa;color:#047857;padding:.1rem .4rem;border-radius:.2rem;font-size:.7rem;border:1px solid #99f6e4}.game-outcome{display:inline;font-weight:700;margin-left:.5rem}.outcome-win{color:#059669}.outcome-draw{color:#dc2626}.notation-explanation{margin-top:1rem;padding:1rem;background:#f0f9ff;border-radius:.25rem;border:1px solid #bae6fd;font-size:.85rem;line-height:1.6;font-family:system-ui,-apple-system,sans-serif}.explanation-title{font-weight:700;color:#1e40af;margin-bottom:.5rem}.explanation-section{margin-bottom:.75rem}.explanation-label{font-weight:600;color:#2563eb;margin-bottom:.25rem}.example-code{background:#fff;padding:.5rem;border-radius:.2rem;margin:.25rem 0;border:1px solid #dbeafe;font-family:Courier New,monospace;font-size:.8rem}.legend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem;margin-top:.5rem}.legend-item{background:#fff;padding:.25rem .5rem;border-radius:.2rem;border:1px solid #dbeafe;font-size:.75rem}.no-moves{text-align:center;color:#6b7280;font-style:italic;padding:2rem;font-family:system-ui,-apple-system,sans-serif}.notation-content::-webkit-scrollbar{width:6px}.notation-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.notation-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.notation-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.notation-system-container .notation-controls{margin-top:.5rem;display:flex;gap:.5rem;flex-wrap:wrap}@media (max-width: 640px){.notation-header{flex-direction:column;align-items:flex-start}.notation-controls{width:100%}.btn{flex:1;font-size:.75rem;padding:.3rem .6rem}.notation-content{max-height:250px;font-size:.75rem}.legend-grid{grid-template-columns:1fr}}.fn-move-slot{display:inline-flex;align-items:center;white-space:nowrap;vertical-align:middle}.fn-text{display:inline;vertical-align:middle;line-height:1}.fn-piece-icon{display:inline-block;width:1.1em;height:1.1em;vertical-align:middle;position:relative;top:-.05em;flex-shrink:0}.fn-piece-icon--north{filter:brightness(0) saturate(100%) invert(16%) sepia(96%) saturate(3749%) hue-rotate(352deg) brightness(110%) contrast(117%)}.fn-piece-icon--south{filter:brightness(0) saturate(100%) invert(78%) sepia(0%) saturate(546%) hue-rotate(195deg) brightness(96%) contrast(100%)}.teach-piece-pool{width:100%;border:1px solid rgba(200,160,40,.25);border-radius:.375rem;background:#c8a0280d;overflow:hidden;margin-bottom:.25rem}.teach-pool-header{display:flex;align-items:center;justify-content:space-between;padding:.3rem .65rem;background:#c8a0281a;border-bottom:1px solid rgba(200,160,40,.18)}.teach-pool-title{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#c8a028}.teach-pool-count{font-size:.7rem;font-weight:600;color:#c8a028b3;background:#c8a0281f;border-radius:.9rem;padding:.05rem .45rem;min-width:1.4rem;text-align:center}.teach-pool-body{display:flex;flex-direction:column;gap:0}.teach-pool-section{display:flex;align-items:center;gap:.4rem;padding:.3rem .5rem;min-height:2.6rem}.teach-pool-section.north{border-bottom:1px solid rgba(200,160,40,.12)}.teach-pool-section-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;min-width:2rem;color:#b4b4b480}.teach-pool-section.north .teach-pool-section-label{color:#dc50508c}.teach-pool-pieces-row{display:flex;flex-wrap:wrap;gap:.2rem;flex:1}.teach-pool-piece{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:grab;border-radius:.25rem;border:1px solid rgba(200,160,40,.18);background:#0000002e;transition:background .12s,border-color .12s,transform .1s;flex-shrink:0}.teach-pool-piece:hover{background:#c8a02824;border-color:#c8a02873;transform:scale(1.08)}.teach-pool-piece:active{cursor:grabbing;transform:scale(.96)}.teach-pool-piece img{width:1.5rem;height:1.5rem;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none}.teach-pool-piece-fallback{font-size:.9rem;font-weight:700;color:#c8a028}.teach-pool-empty-hint{font-size:.65rem;color:#b4b4b44d;font-style:italic}.teach-pool-all-placed{text-align:center;font-size:.65rem;color:#b4b4b459;padding:.4rem;font-style:italic}.game-ui{color:#333;height:100%;display:flex;flex-direction:column;gap:1rem}.game-ui ::-webkit-scrollbar{width:6px}.game-ui ::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.game-ui ::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.game-ui ::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.turn-indicator{margin-top:0rem;padding:0 1rem .8rem;border-radius:.25rem;text-align:left;background:#fff;box-shadow:0 4px 6px #0000001a}.turn-indicator h2{font-size:.9rem;font-weight:700;color:#2d3748;margin-bottom:-.6rem;text-transform:uppercase}.turn-display{display:flex;align-items:center;gap:1rem}.turn-color{width:50px;height:50px;margin-top:.5rem;border-radius:50%;flex-shrink:0}.turn-info{flex:1}.turn-info p:first-child{font-weight:600;font-size:.9rem;margin:-1rem;text-transform:uppercase}.turn-info p:last-child{font-size:.75rem;color:#666;margin:0;margin-top:-1rem}.victory-message{margin-top:.75rem;padding:.5rem;background-color:#d1fae5;border:1px solid #a7f3d0;border-radius:.25rem}.victory-message p{color:#065f46;font-weight:700;font-size:.8rem;text-align:center;margin:0}.move-history{background:#fff;border-radius:.5rem;padding:1rem;box-shadow:0 4px 6px #0000001a;flex:1;display:flex;flex-direction:column;min-height:0}.move-history h2{font-size:1.1rem;font-weight:700;color:#2d3748;margin-bottom:.75rem}.moves-container{flex:1;overflow-y:auto;max-height:300px;border:1px solid #e2e8f0;border-radius:.25rem;padding:.4rem;background:#f8f9fa}.moves-list{display:flex;flex-direction:column;gap:.25rem}.move-item{font-family:PGF Monona,Courier New,monospace;font-size:.75rem;padding:.3rem .5rem;background:#fff;border-radius:.2rem;border:1px solid #e2e8f0}.capture-badge{color:#dc2626;font-size:.7rem;margin-left:.25rem}.no-moves{color:#6b7280;font-size:.8rem;text-align:center;padding:1rem}.moves-container::-webkit-scrollbar{width:6px}.moves-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.moves-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.moves-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.game-controls-wrapper{display:none}.mode-pill-row{display:flex;flex-wrap:wrap;gap:.3rem}.mode-pill-row.mode-row-locked .mode-pill:not(.active){opacity:.4;cursor:not-allowed;pointer-events:none}.mode-pill{flex:1 1 auto;padding:.28rem .45rem;background:none;color:#8999ad;border:1px solid #374151;border-radius:4px;font-size:.72rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap;text-align:center}.mode-pill:hover:not(:disabled):not(.disabled){background:#1f2937;color:#d1d5db;border-color:#4b5563}.mode-pill.active{background:#064e3b;border-color:#059669;color:#6ee7b7}.mode-pill.luna.active{background:#6d28d940;border-color:#8b5cf6b3;color:#c4b5fd}.mode-pill.disabled,.mode-pill:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.mode-pill-arrow{font-size:.6rem;opacity:.7;margin-left:2px}.golem-badge-new{display:inline-block;vertical-align:top;margin-top:-2px;color:gold;border:1px solid goldenrod;border-radius:10px;padding:1px 4px 2px;margin-left:.3rem;font-size:.4rem}.mode-pill-golem-wrap{position:relative;flex:1 1 auto}.mode-pill-golem-wrap .mode-pill{width:100%}.mode-pill-golem-wrap .golem-difficulty-menu{top:calc(100% + 4px);right:0;left:auto;min-width:200px}.luna-mode-banner{display:flex;align-items:center;justify-content:space-between;padding:.2rem .7rem;background:#6d28d91a;border:1px solid rgba(139,92,246,.4);border-radius:.5rem;box-shadow:0 0 10px #8b5cf626}.luna-mode-banner-text{font-size:.78rem;font-weight:700;color:#c4b5fd;letter-spacing:.06em;text-transform:uppercase}.luna-mode-exit-btn{padding:.2rem .65rem;background:none;border:1px solid rgba(139,92,246,.4);border-radius:.3rem;color:#a78bfa;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s}.luna-mode-exit-btn:hover{background:#8b5cf626;border-color:#8b5cf6b3}.time-pill-row{display:flex;gap:.3rem}.time-pill-row.time-row-locked .time-pill{opacity:.4;cursor:not-allowed;pointer-events:none}.time-pill{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;padding:.3rem .2rem;background:none;color:#8999ad;border:1px solid #374151;border-radius:4px;font-size:.62rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap;min-width:0}.time-pill:hover:not(:disabled){background:#1f2937;color:#d1d5db;border-color:#4b5563}.time-pill.active{background:#064e3b;border-color:#059669;color:#6ee7b7}.time-pill:disabled{opacity:.4;cursor:not-allowed}.time-pill-name{font-weight:700;font-size:.62rem;letter-spacing:.02em;color:inherit}.time-pill-time{font-family:PGF Monona,Courier New,monospace;font-size:.9rem;color:#22a0bc;display:flex;align-items:center;gap:1px}.time-pill.active .time-pill-time{color:inherit}.time-pill-icon{font-size:.8rem;margin-right:.2rem}.forge-panel{background:#1f2937;border:1px solid #374151;border-radius:4px;padding:.5rem .6rem;animation:slideDown .12s ease-out}.forge-row{display:flex;align-items:flex-end;gap:.5rem}.forge-label{display:flex;flex-direction:column;gap:.2rem;font-size:.68rem;color:#9ca3af;font-weight:600;flex:1}.forge-input{width:100%;padding:.3rem .4rem;background:#111827;border:1px solid #112b26;border-radius:3px;color:#f9fafb;font-family:PGF Monona,Courier New,monospace;font-size:.8rem;text-align:center}.forge-input:focus{outline:none;border-color:#3b82f6}.forge-apply-btn{padding:.3rem .65rem;background:#dc2626;color:#fff;border:none;border-radius:3px;font-size:.75rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap;align-self:flex-end;height:fit-content}.forge-apply-btn:hover{background:#b91c1c}.rematch-button{flex:1;border:none;border-radius:.375rem;padding:.5rem 1rem;font-weight:700;font-size:.85rem;cursor:pointer;transition:background-color .2s;background:#dc2626;color:#fff;width:100%}.rematch-button:hover{background:#b41919}.gameui-toggles-row{display:flex;gap:.4rem;margin-top:auto}.toggle-btn{flex:1;padding:.3rem .5rem;background:#2d3748;color:#9ca3af;border:1px solid #4a5568;border-radius:4px;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}.toggle-btn:hover:not(:disabled):not(.disabled){background:#374151;color:#d1d5db}.toggle-btn.active{background:#064e3b;border-color:#059669;color:#6ee7b7}.toggle-btn.disabled,.toggle-btn:disabled{opacity:.3;cursor:not-allowed}.gameui-page-links{display:flex;gap:.4rem}.gameui-page-link-btn{flex:1;padding:.35rem .5rem;background:none;border:1px solid #374151;border-radius:4px;color:#6b7280;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}.gameui-page-link-btn:hover{background:#1f2937;color:#d1d5db;border-color:#4b5563}.game-controls{background:#abf4e6;border-radius:.5rem;padding:1rem;box-shadow:0 4px 6px #0000001a}.game-controls h2{font-size:1.1rem;font-weight:700;color:#2d3748;margin-bottom:.75rem}.reset-button{width:100%;background:#869e9e;color:#fff;border:none;border-radius:.375rem;padding:.5rem 1rem;font-weight:700;font-size:.9rem;cursor:pointer;transition:background-color .2s}.reset-button:hover{background:#01aa99}.bg-red-600{background-color:#dc2626}.bg-gray-600{background-color:#8c8c8c}.multiplayer-status{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem}.multiplayer-status.connected{background-color:#f0f9ff;border:1px solid #bae6fd;color:#0369a1}.multiplayer-status.disconnected{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.multiplayer-status.active{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.mp-status-indicator{width:8px;height:8px;border-radius:50%;background-color:currentColor}.mp-room-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.mp-kingdom{font-size:.75rem;opacity:.8}.mp-connect-btn,.mp-manage-btn{padding:.375rem .75rem;border:none;border-radius:.375rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.mp-connect-btn{background-color:#dc2626;color:#fff}.mp-connect-btn:hover{background-color:#b91c1c}.mp-manage-btn{background-color:#059669;color:#fff}.mp-manage-btn:hover{background-color:#047857}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:.75rem;padding:0;max-width:400px;width:90%;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;justify-content:between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#374151;background-color:#f3f4f6;border-radius:.375rem}.modal-body{padding:1.5rem}.modal-action-btn{width:100%;padding:.75rem 1rem;background-color:#dc2626;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;margin-top:1rem}.modal-action-btn:hover{background-color:#b91c1c}.victory-message--draw{background-color:#fef3c7!important;border:1px solid #fcd34d!important}.victory-message--draw p{color:#92400e!important}.victory-message--timeout{background-color:#fef3c7!important;border:1px solid #f59e0b!important}.victory-message--timeout p{color:#92400e!important;font-weight:700}.game-actions-wrapper{display:flex;gap:.6rem}.resign-button,.abort-button{flex:1;border:none;border-radius:.375rem;padding:.5rem 1rem;font-weight:700;font-size:.85rem;cursor:pointer;transition:background-color .2s}.resign-button{background:#b91c1c;color:#fff}.resign-button:hover{background:#991b1b}.resign-button.confirm{background:#7f1d1d;animation:pulse-red .6s ease-in-out infinite alternate}.abort-button{background:#6b7280;color:#fff}.abort-button:hover{background:#4b5563}.abort-button.confirm{background:#374151;animation:pulse-gray .6s ease-in-out infinite alternate}@keyframes pulse-red{0%{background:#b91c1c}to{background:#7f1d1d}}@keyframes pulse-gray{0%{background:#6b7280}to{background:#374151}}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.new-game-row{display:flex;gap:.5rem}.new-game-row .new-game-main-btn{flex:1;width:auto}.new-game-main-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;background:#1d7683;color:#fff;border:none;border-radius:.375rem;font-weight:700;font-size:.95rem;cursor:pointer;transition:background .2s}.new-game-main-btn:hover:not(:disabled):not(.searching){background:#0f8faa}.new-game-main-btn.searching{background:#0369a1;cursor:default}.new-game-main-btn:disabled:not(.searching){background:#9ca3af;cursor:not-allowed}.new-game-spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .85s linear infinite;flex-shrink:0}.decline-btn{padding:.6rem .9rem;background:#dc2626;color:#fff;border:none;border-radius:.375rem;font-weight:700;font-size:.88rem;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.decline-btn:hover{background:#b91c1c}.lobby-available-badge{font-size:.72rem;font-weight:600;color:#059669;background:#d1fae5;border:1px solid #a7f3d0;border-radius:.25rem;padding:.15rem .4rem;white-space:nowrap;flex-shrink:0}.practice-mode-banner{display:flex;align-items:center;justify-content:space-between;padding:.2rem .7rem;margin-bottom:.5rem;background:#ca8a0414;border:1px solid rgba(202,138,4,.5);border-radius:.5rem;box-shadow:0 0 12px #ca8a0433}.practice-mode-banner-text{font-size:.85rem;font-weight:700;color:#ca8a04;letter-spacing:.05em;text-transform:uppercase}.practice-mode-exit-btn{padding:.25rem .75rem;background:none;border:1px solid rgba(202,138,4,.5);border-radius:.375rem;color:#ca8a04;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.practice-mode-exit-btn:hover{background:#ca8a0426;border-color:#ca8a04cc}.golem-thinking{background:#1a1a2e;border:1px solid #4a4a8a;color:#a0a0d0;font-size:.75rem;letter-spacing:.05em;padding:.4rem .75rem;border-radius:4px;text-align:center;animation:golem-pulse 1.2s ease-in-out infinite}@keyframes golem-pulse{0%,to{opacity:.6}50%{opacity:1}}.golem-item{position:relative}.golem-difficulty-menu{position:absolute;left:calc(100% + 4px);top:0;background:#1e1e2e;border:1px solid #3a3a5a;border-radius:6px;min-width:180px;z-index:200;overflow:hidden;box-shadow:0 4px 16px #0006}.golem-diff-btn{display:flex;flex-direction:column;width:100%;padding:.5rem .75rem;background:none;border:none;border-bottom:1px solid #2a2a3a;cursor:pointer;text-align:left;color:#c8c8d8;transition:background .15s}.golem-diff-btn:last-child{border-bottom:none}.golem-diff-btn:hover{background:#2a2a4a}.golem-diff-btn.active{background:#2a2a4a;color:#fff}.golem-diff-label{font-size:.85rem;font-weight:600}.golem-diff-desc{font-size:.7rem;color:#7878a0;margin-top:1px}.golem-diff-btn.stop{color:#e07070;font-size:.8rem;font-weight:600;text-align:center}.golem-diff-btn.stop:hover{background:#3a1a1a}.gameui-toggles-row{display:flex;gap:.35rem;flex-wrap:wrap}.toggle-switch-btn{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.3rem .45rem;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:border-color .15s,background .15s;flex:1;min-width:0}.toggle-switch-btn:hover:not(:disabled):not(.disabled){background:#ffffff0a;border-color:#4a5568}.toggle-switch-btn:disabled,.toggle-switch-btn.disabled{opacity:.28;cursor:not-allowed}.toggle-switch-label{font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#6b7280;white-space:nowrap;transition:color .15s;line-height:1}.toggle-switch-btn.active .toggle-switch-label{color:#6ee7b7}.toggle-switch-btn.teach-rules-toggle .toggle-switch-label{color:#c8a0288c}.toggle-switch-btn.teach-rules-toggle.active .toggle-switch-label{color:#c8a028}.toggle-switch-track{position:relative;display:block;width:2rem;height:.85rem;background:#374151;border-radius:999px;border:1px solid #4a5568;transition:background .18s,border-color .18s;flex-shrink:0}.toggle-switch-btn.active .toggle-switch-track{background:#064e3b;border-color:#059669}.toggle-switch-btn.teach-rules-toggle .toggle-switch-track{background:#2a2210;border-color:#c8a0284d}.toggle-switch-btn.teach-rules-toggle.active .toggle-switch-track{background:#3a2e08;border-color:#c8a02899}.toggle-switch-thumb{position:absolute;top:50%;left:2px;transform:translateY(-50%);width:.55rem;height:.55rem;background:#6b7280;border-radius:50%;transition:left .18s,background .18s}.toggle-switch-btn.active .toggle-switch-thumb{left:calc(1.45rem - 2px);background:#34d399}.toggle-switch-btn.teach-rules-toggle .toggle-switch-thumb{background:#c8a02866}.toggle-switch-btn.teach-rules-toggle.active .toggle-switch-thumb{left:calc(1.45rem - 2px);background:#c8a028}.mode-pill.teach{border-color:#c8a0284d;color:#c8a028bf}.mode-pill.teach.active{background:#c8a0282e;border-color:#c8a0288c;color:#c8a028}.teach-mode-banner{background:#c8a0281f!important;border:1px solid rgba(200,160,40,.3)!important;color:#c8a028!important}.teach-notation-wrapper{width:100%}.teach-notation-header{display:flex;align-items:center;justify-content:space-between;padding:.2rem .1rem .2rem 0;margin-bottom:.1rem}.teach-notation-label{font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#c8a02899}.teach-notation-reset-btn{font-size:.66rem;font-weight:600;padding:.15rem .5rem;background:#c8a02814;border:1px solid rgba(200,160,40,.25);border-radius:.25rem;color:#c8a028b3;cursor:pointer;transition:background .12s,border-color .12s}.teach-notation-reset-btn:hover{background:#c8a0282e;border-color:#c8a02873;color:#c8a028}.teach-arrow-controls{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.2rem 0;flex-wrap:wrap}.teach-arrow-hint{font-size:.62rem;color:#b4b4b461;font-style:italic;line-height:1.3;flex:1}.teach-clear-arrows-btn{font-size:.65rem;font-weight:600;padding:.15rem .5rem;background:#c8a02814;border:1px solid rgba(200,160,40,.22);border-radius:.25rem;color:#c8a028a6;cursor:pointer;white-space:nowrap;transition:background .12s,border-color .12s}.teach-clear-arrows-btn:hover{background:#c8a0282e;border-color:#c8a0286b;color:#c8a028}.teach-exit-row{width:100%;display:flex;justify-content:center;padding:.1rem 0}.teach-exit-btn{width:100%;padding:.4rem 0;font-size:.75rem;font-weight:600;background:#c8a02812;border:1px solid rgba(200,160,40,.22);border-radius:.375rem;color:#c8a02899;cursor:pointer;letter-spacing:.03em;transition:background .14s,border-color .14s,color .14s}.teach-exit-btn:hover{background:#c8a02826;border-color:#c8a0286b;color:#c8a028}.practice-mode-banner.luna-mode-banner{background:#6d28d91a!important;border-color:#8b5cf666!important;box-shadow:0 0 10px #8b5cf626!important}.practice-mode-banner-text.luna-mode-banner-text{color:#c4b5fd!important}.practice-mode-exit-btn.luna-mode-exit-btn{color:#a78bfa!important;border-color:#8b5cf666!important}.practice-mode-exit-btn.luna-mode-exit-btn:hover{background:#8b5cf626!important;border-color:#8b5cf6b3!important}.practice-mode-banner.mode-9x9-banner{background:#1ee5ce14!important;border-color:#1ee5ce66!important;box-shadow:0 0 10px #1ee5ce26!important}.practice-mode-banner-text.mode-9x9-banner-text{color:#1ee5ce!important}.practice-mode-exit-btn.mode-9x9-exit-btn{color:#1ee5ce!important;border-color:#1ee5ce66!important}.practice-mode-exit-btn.mode-9x9-exit-btn:hover{background:#1ee5ce1f!important;border-color:#1ee5ceb3!important}.reset-password-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.reset-password-card{background:#1a2332;border:1px solid rgba(255,255,255,.1);border-radius:1rem;padding:2rem;width:100%;max-width:420px;box-shadow:0 20px 60px #00000080}.reset-password-header{margin-bottom:1.5rem;text-align:center}.reset-password-header h2{color:#17a7c7;margin:0 0 .5rem;font-size:1.5rem}.reset-greeting{color:#94a3b8;font-size:.9rem;margin:0}.reset-status-msg{text-align:center;color:#64748b;padding:2rem 0;font-style:italic}.reset-invalid{text-align:center;padding:1rem 0}.reset-error-icon{font-size:2.5rem;color:#f87171;margin-bottom:1rem}.reset-invalid p{color:#f87171;margin:0 0 .5rem}.reset-form{display:flex;flex-direction:column;gap:1rem}.reset-field{display:flex;flex-direction:column;gap:.4rem}.reset-field label{font-size:.8rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.reset-field input{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:.5rem;padding:.65rem .875rem;color:#e2e8f0;font-size:.95rem;width:100%;box-sizing:border-box;transition:border-color .15s}.reset-field input:focus{outline:none;border-color:#17a7c7}.reset-field input:disabled{opacity:.6}.reset-field-error{font-size:.75rem;color:#f87171}.password-strength{display:flex;align-items:center;gap:.5rem;font-size:.72rem}.strength-track{flex:1;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.strength-fill{height:100%;border-radius:2px;transition:all .3s}.reset-expiry{font-size:.75rem;color:#64748b;text-align:center;margin:0 0 1rem}.reset-error{padding:.65rem .875rem;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:.375rem;color:#f87171;font-size:.82rem}.reset-hint{font-size:.78rem;color:#475569;margin:.25rem 0 1rem}.reset-submit-btn{width:100%;padding:.75rem;background:#17a7c7;color:#fff;border:none;border-radius:.5rem;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .2s}.reset-submit-btn:hover:not(:disabled){background:#0f8faa}.reset-submit-btn:disabled{background:#374151;cursor:not-allowed}.reset-back-btn{width:100%;padding:.6rem;background:none;border:1px solid rgba(255,255,255,.1);border-radius:.5rem;color:#64748b;font-size:.85rem;cursor:pointer;transition:all .15s}.reset-back-btn:hover{background:#ffffff0d;color:#94a3b8}.reset-success{text-align:center;padding:1rem 0}.reset-success-icon{font-size:3rem;color:#34d399;margin-bottom:.75rem}.reset-success h3{color:#34d399;margin:0 0 .75rem}.reset-success p{color:#94a3b8;font-size:.875rem;margin:0 0 .5rem}.forgot-btn{background:none;border:none;color:#64748b;font-size:.8rem;cursor:pointer;padding:.25rem 0;transition:color .15s;text-decoration:underline}.forgot-btn:hover{color:#94a3b8}.forgot-desc{color:#94a3b8;font-size:.85rem;margin:0 0 1rem;line-height:1.5}.forgot-success{text-align:center;padding:1rem 0}.forgot-success p{color:#94a3b8;margin:0 0 .5rem}.elo-badge{display:inline-flex;align-items:center;gap:.25rem;font-family:PGF Monona,Courier New,monospace;transition:all .2s ease}.elo-badge:hover{background:#ffffff26;transform:translateY(-1px)}.elo-label{font-size:.7rem;color:#cbd5e0;text-transform:uppercase;letter-spacing:.05em}.elo-number{font-weight:700;letter-spacing:-.025em}.elo-tier{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.elo-badge-sm{padding:.2rem .4rem;font-size:.75rem}.elo-badge-sm .elo-number{font-size:.8rem}.elo-badge-sm .elo-tier,.elo-badge-sm .elo-label{font-size:.65rem}.elo-badge-md{font-size:.8rem}.elo-badge-md .elo-number{font-size:.9rem}.elo-badge-md .elo-tier,.elo-badge-md .elo-label{font-size:.7rem}.elo-badge-lg{padding:.4rem .75rem;font-size:.9rem}.elo-badge-lg .elo-number{font-size:1rem}.elo-badge-lg .elo-tier,.elo-badge-lg .elo-label{font-size:.75rem}.user-section-with-elo{display:flex;align-items:center;gap:1rem}.elo-badge[style*=MYTHIC] .elo-number{text-shadow:0 0 10px rgba(253,227,82,.665)}.elo-badge[style*=DIAMOND] .elo-number{text-shadow:0 0 8px rgba(132,232,255,.616)}.elo-badge[style*=PLATINUM] .elo-number{text-shadow:0 0 6px rgba(255,255,255,.583)}.notification-bell-wrapper{position:relative;display:flex;align-items:center}.notification-bell-btn{position:relative;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:1px solid rgba(255,255,255,.15);border-radius:50%;cursor:pointer;transition:all .15s;color:#94a3b8}.notification-bell-btn:hover{background:#ffffff14;border-color:#ffffff4d;color:#e2e8f0}.notification-bell-btn.has-unread{border-color:#17a7c780;color:#17a7c7;animation:bell-pulse 2s ease-in-out infinite}@keyframes bell-pulse{0%,to{box-shadow:0 0 #17a7c700}50%{box-shadow:0 0 0 4px #17a7c726}}.bell-icon{font-size:1rem;line-height:1}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 3px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;line-height:1;border:2px solid var(--header-bg, #0f1923)}.notification-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:320px;background:#1a2332;border:1px solid rgba(255,255,255,.1);border-radius:.75rem;box-shadow:0 8px 32px #0006;z-index:1000;overflow:hidden}.notification-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.08)}.notification-dropdown-title{font-size:.85rem;font-weight:700;color:#e2e8f0;letter-spacing:.04em;text-transform:uppercase}.notification-clear-btn{font-size:.72rem;color:#64748b;background:none;border:none;cursor:pointer;padding:0;transition:color .15s}.notification-clear-btn:hover{color:#94a3b8}.notification-list{max-height:360px;overflow-y:auto}.notification-empty{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:2rem 1rem;color:#475569;font-size:.85rem}.notification-empty-sub{font-size:.75rem;color:#334155}.notification-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;transition:background .15s;position:relative}.notification-item:hover{background:#ffffff0a}.notification-item.unread{background:#17a7c70d}.notification-item:last-child{border-bottom:none}.notification-item-icon{font-size:1rem;flex-shrink:0;margin-top:.1rem;color:#64748b}.type-game_result_win .notification-item-icon{color:#34d399}.type-game_result_loss .notification-item-icon{color:#f87171}.type-game_result_draw .notification-item-icon{color:#94a3b8}.type-opponent_found .notification-item-icon{color:#17a7c7}.type-your_turn .notification-item-icon{color:#fbbf24}.type-opponent_disconnected .notification-item-icon{color:#f87171}.type-game_cancelled .notification-item-icon{color:#64748b}.notification-item-body{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.notification-item-title{font-size:.82rem;font-weight:600;color:#e2e8f0}.notification-item-message{font-size:.75rem;color:#64748b;line-height:1.4}.notification-item-time{font-size:.68rem;color:#334155;margin-top:.1rem}.notification-unread-dot{width:7px;height:7px;border-radius:50%;background:#17a7c7;flex-shrink:0;margin-top:.35rem}.teach-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000009e;z-index:200;display:flex;align-items:center;justify-content:center}.teach-modal{background:#1a1a1e;border:1px solid rgba(200,160,40,.3);border-radius:.75rem;padding:1.75rem 1.5rem 1.25rem;max-width:340px;width:90%;display:flex;flex-direction:column;gap:1rem;box-shadow:0 8px 40px #0000008c}.teach-modal-title{font-size:1rem;font-weight:700;color:#c8a028;letter-spacing:.04em;margin:0}.teach-modal-desc{font-size:.8rem;color:#c8c8c8a6;margin:0;line-height:1.45}.teach-modal-options{display:flex;flex-direction:column;gap:.5rem}.teach-modal-option{display:grid;grid-template-columns:1.6rem 1fr;grid-template-rows:auto auto;column-gap:.6rem;padding:.75rem .9rem;background:#ffffff08;border:1px solid rgba(200,160,40,.18);border-radius:.5rem;cursor:pointer;text-align:left;transition:background .14s,border-color .14s}.teach-modal-option:hover{background:#c8a0281a;border-color:#c8a02866}.teach-modal-option-icon{grid-row:1 / 3;display:flex;align-items:center;font-size:1.1rem;color:#c8a0288c;align-self:center}.teach-modal-option-label{font-size:.85rem;font-weight:700;color:#e2e8f0;line-height:1.2}.teach-modal-option-hint{font-size:.72rem;color:#c8c8c880;line-height:1.35;margin-top:.1rem}.teach-modal-cancel{align-self:flex-end;font-size:.75rem;color:#b4b4b473;background:none;border:none;cursor:pointer;padding:.2rem .1rem;transition:color .12s}.teach-modal-cancel:hover{color:#c8c8c8bf}.page-container{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg, #0f1923);color:var(--color-text, #e2e8f0)}.page-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;z-index:10}.page-back-btn{background:none;border:1px solid rgba(255,255,255,.2);color:#e2e8f0;padding:.4rem .9rem;border-radius:.375rem;font-size:.875rem;cursor:pointer;transition:all .15s;white-space:nowrap}.page-back-btn:hover{background:#ffffff1a;border-color:#fff6}.page-title{font-size:1.25rem;font-weight:700;color:#f1f5f9;margin:0}.page-content{flex:1;padding:1.5rem;max-width:680px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}.page-loading{text-align:center;padding:3rem;color:#94a3b8;font-style:italic}.profile-section{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:.75rem;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin:0}.profile-card{display:flex;align-items:center;gap:1.25rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:.75rem;padding:1.25rem}.profile-avatar-circle{width:64px;height:64px;border-radius:50%;border:3px solid;background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;color:#fff;flex-shrink:0}.profile-displayname{font-size:1.25rem;font-weight:700;color:#f1f5f9;margin:0 0 .25rem}.profile-username{font-size:.85rem;color:#64748b;margin:0 0 .5rem}.profile-account-type{font-size:.72rem;font-weight:600;padding:.2rem .5rem;border-radius:.25rem;text-transform:uppercase;letter-spacing:.05em}.profile-account-type.registered{background:#05966933;color:#34d399;border:1px solid rgba(52,211,153,.3)}.profile-account-type.guest{background:#64748b33;color:#94a3b8;border:1px solid rgba(148,163,184,.3)}.profile-elo-card{background:#ffffff08;border-radius:.5rem;border:1px solid rgba(255,255,255,.06);padding:1rem;display:flex;flex-direction:column;gap:.75rem}.profile-elo-main{display:flex;align-items:baseline;gap:1rem}.profile-elo-number{font-size:2.5rem;font-weight:800;color:#f1f5f9;font-family:PGF Monona,monospace;line-height:1}.profile-tier-badge{font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.profile-elo-progress{display:flex;flex-direction:column;gap:.35rem}.progress-track{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .4s ease}.progress-label{font-size:.72rem;color:#64748b}.profile-record-grid{display:flex;gap:.75rem;flex-wrap:wrap}.record-card{flex:1;min-width:70px;display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;border-radius:.5rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.07)}.record-number{font-size:1.5rem;font-weight:800;font-family:PGF Monona,monospace}.record-label{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-top:.2rem}.record-card.wins .record-number{color:#34d399}.record-card.losses .record-number{color:#f87171}.record-card.draws .record-number{color:#94a3b8}.record-card.total .record-number{color:#e2e8f0}.record-card.winrate .record-number{color:#60a5fa}.guest-upgrade-card{background:#0ea5e914;border:1px solid rgba(14,165,233,.25);border-radius:.5rem;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.guest-upgrade-card h3{margin:0;font-size:.95rem;font-weight:700;color:#7dd3fc}.guest-upgrade-card p{margin:0;font-size:.82rem;color:#94a3b8}.upgrade-btn{align-self:flex-start;margin-top:.5rem;padding:.5rem 1rem;background:#0ea5e9;color:#fff;border:none;border-radius:.375rem;font-weight:700;font-size:.85rem;cursor:pointer;transition:background .2s}.upgrade-btn:hover{background:#0284c7}.stats-summary-row{display:flex;gap:.75rem}.stats-summary-card{flex:1;display:flex;flex-direction:column;align-items:center;padding:1rem .5rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:.75rem}.stats-summary-number{font-size:1.75rem;font-weight:800;color:#f1f5f9;font-family:PGF Monona,monospace;line-height:1}.stats-summary-label{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-top:.3rem}.stats-summary-sub{font-size:.72rem;font-weight:600;margin-top:.15rem}.stats-wld-bar{height:12px;border-radius:6px;overflow:hidden;display:flex;background:#ffffff0f}.wld-segment.wins{background:#34d399}.wld-segment.draws{background:#64748b}.wld-segment.losses{background:#f87171}.wld-empty{flex:1;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#64748b}.wld-legend{display:flex;gap:1.5rem;font-size:.8rem}.wld-legend-item{font-weight:600}.wld-legend-item.wins{color:#34d399}.wld-legend-item.draws{color:#94a3b8}.wld-legend-item.losses{color:#f87171}.stats-coming-soon{padding:1.5rem;text-align:center;color:#475569}.stats-coming-soon p{margin:0 0 .4rem;font-size:.875rem}.stats-coming-soon-sub{font-size:.78rem!important;color:#334155!important}.history-empty{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem 1rem;text-align:center}.history-empty-icon{font-size:3rem;opacity:.3}.history-empty h3{margin:0;font-size:1.1rem;color:#94a3b8}.history-empty p{margin:0;font-size:.85rem;color:#475569;max-width:320px}.history-play-btn{margin-top:.5rem;padding:.6rem 1.5rem;background:#17a7c7;color:#fff;border:none;border-radius:.375rem;font-weight:700;cursor:pointer;transition:background .2s}.history-play-btn:hover{background:#0f8faa}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-item{display:flex;align-items:center;gap:1rem;padding:.875rem 1rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:.5rem;border-width:1px}.history-item.win{border-color:#34d39940;background:#34d3990d}.history-item.loss{border-color:#f8717140;background:#f871710d}.history-item.draw{border-color:#64748b33;background:#64748b0d}.result-badge{font-size:.72rem;font-weight:700;padding:.2rem .5rem;border-radius:.25rem;text-transform:uppercase;white-space:nowrap}.result-badge.win{background:#34d39926;color:#34d399}.result-badge.loss{background:#f8717126;color:#f87171}.result-badge.draw{background:#64748b26;color:#94a3b8}.history-details{flex:1}.history-opponent{font-size:.875rem;font-weight:600;color:#e2e8f0}.history-meta{font-size:.75rem;color:#64748b;display:flex;gap:.75rem;margin-top:.2rem}.history-elo{text-align:right}.elo-delta{font-size:.9rem;font-weight:700;font-family:PGF Monona,monospace}.elo-delta.positive{color:#34d399}.elo-delta.negative{color:#f87171}.history-date{display:block;font-size:.7rem;color:#475569;margin-top:.2rem}.pref-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.06)}.pref-row:last-child{border-bottom:none}.pref-label{display:flex;flex-direction:column;gap:.2rem;flex:1}.pref-name{font-size:.875rem;font-weight:600;color:#e2e8f0}.pref-desc{font-size:.75rem;color:#64748b}.pref-select{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#e2e8f0;padding:.4rem .75rem;border-radius:.375rem;font-size:.85rem;cursor:pointer;min-width:160px}.pref-select:focus{outline:none;border-color:#17a7c7}.pref-action-btn{padding:.4rem .9rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#94a3b8;border-radius:.375rem;font-size:.82rem;cursor:not-allowed;white-space:nowrap}.pref-toggle{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.pref-toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:#ffffff26;border-radius:24px;transition:.2s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.pref-toggle input:checked+.toggle-slider{background:#17a7c7}.pref-toggle input:checked+.toggle-slider:before{transform:translate(20px)}.pref-save-row{display:flex;justify-content:flex-end;padding-top:.5rem}.pref-save-btn{padding:.65rem 2rem;background:#17a7c7;color:#fff;border:none;border-radius:.375rem;font-weight:700;font-size:.9rem;cursor:pointer;transition:background .2s}.pref-save-btn:hover{background:#0f8faa}.pref-save-btn.saved{background:#059669}.dropdown-item--disabled{opacity:.45;cursor:not-allowed!important;pointer-events:none;position:relative}.dropdown-item-locked{margin-left:auto;font-size:.65rem;font-weight:600;color:#94a3b8;background:#94a3b81f;border:1px solid rgba(148,163,184,.2);border-radius:.25rem;padding:.1rem .35rem;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}.pref-error{padding:.65rem 1rem;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:.375rem;color:#f87171;font-size:.82rem;text-align:center}.pref-notif-status{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.pref-notif-badge{font-size:.72rem;font-weight:700;padding:.2rem .6rem;border-radius:.25rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.pref-notif-badge.granted{background:#34d39926;color:#34d399;border:1px solid rgba(52,211,153,.3)}.pref-notif-badge.denied{background:#f8717126;color:#f87171;border:1px solid rgba(248,113,113,.3)}.pref-notif-badge.unsupported{background:#64748b26;color:#64748b;border:1px solid rgba(100,116,139,.3)}.pref-notif-denied{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}.pref-notif-hint{font-size:.65rem;color:#475569;white-space:nowrap}.pref-notif-enable-btn{padding:.35rem .9rem!important;background:#17a7c726!important;border:1px solid rgba(23,167,199,.4)!important;color:#17a7c7!important;cursor:pointer!important;border-radius:.375rem;font-size:.8rem;font-weight:600;transition:all .15s}.pref-notif-enable-btn:hover{background:#17a7c740!important}.htp-page{flex:1;min-height:0;overflow-y:auto;position:relative;padding-bottom:6rem;background:var(--color-bg, #0f1923);color:var(--color-text, #e2e8f0);display:flex;flex-direction:column}.htp-nav{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:.75rem;padding:.6rem 1.5rem;background:#0f1923f5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0}.htp-nav__back{background:none;border:1px solid rgba(255,255,255,.18);color:#94a3b8;font-size:.85rem;padding:.32rem .75rem;border-radius:4px;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s;flex-shrink:0}.htp-nav__back:hover{color:#e2e8f0;border-color:#ffffff61}.htp-nav__anchors{list-style:none;margin:0;padding:0;display:flex;gap:.2rem;flex-wrap:wrap}.htp-nav__anchor{background:none;border:none;color:#64748b;font-size:.82rem;padding:.3rem .55rem;cursor:pointer;border-radius:4px;transition:color .15s,background .15s;white-space:nowrap;letter-spacing:.02em}.htp-nav__anchor:hover{color:#cbd5e1;background:#ffffff0f}.htp-header{padding:2.25rem 1.5rem 1.5rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.htp-header__title{font-size:2.1rem;font-weight:700;margin:0 0 .4rem;color:#f1f5f9;letter-spacing:-.02em}.htp-header__brand{color:#c9a84c;font-style:italic}.htp-content{max-width:980px;width:100%;margin:0 auto;padding:0 1.5rem;display:flex;flex-direction:column;gap:3.5rem;flex:1}.htp-section{display:flex;flex-direction:column;gap:1.25rem;padding-top:2.25rem}.htp-section__title{font-size:.9rem;font-weight:700;color:#c9a84c;margin:0;text-transform:uppercase;letter-spacing:.14em;padding-bottom:.5rem;border-bottom:1px solid rgba(201,168,76,.22)}.htp-section__intro{font-size:.98rem;color:#94a3b8;line-height:1.7;margin:0;max-width:680px}.htp-grid{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-start}.htp-card{background:#ffffff07;border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:.7rem;transition:border-color .2s;min-width:180px;flex:1 1 auto;max-width:360px;overflow:visible}.htp-card:hover{border-color:#c9a84c40}.htp-card__title{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:#cbd5e1;margin:0}.htp-card__board-wrap{display:flex;justify-content:flex-start;align-items:flex-start;overflow:visible;padding:4px 8px 4px 4px}.htp-card__caption{font-size:.92rem;color:#b0bec5;margin:0;line-height:1.55}.htp-card__detail{font-size:.84rem;color:#64748b;margin:0;line-height:1.6;border-top:1px solid rgba(255,255,255,.05);padding-top:.5rem}.htp-board{display:grid;gap:2px;background:#181c24;border:2px solid rgba(255,255,255,.1);border-radius:5px;padding:3px;width:calc(var(--htp-cols, 3) * 28px + (var(--htp-cols, 3) - 1) * 2px + 6px);flex-shrink:0;overflow:visible}.htp-cell{position:relative;display:flex;align-items:center;justify-content:center;border-radius:2px;width:28px;height:28px;background-size:cover;background-position:center;background-repeat:no-repeat;overflow:visible;flex-shrink:0}.htp-cell--move:after{content:"";position:absolute;width:10px;height:10px;border-radius:50%;background:#66bb6abf;z-index:2;pointer-events:none}.htp-cell--capture{box-shadow:inset 0 0 0 2px #c00}.htp-cell--from{box-shadow:inset 0 0 0 2px #ffd93d}.htp-cell--to{box-shadow:inset 0 0 0 2px #6bcf7f}.htp-cell--danger{box-shadow:inset 0 0 0 2px #cc00008c}.htp-flow-arrow{position:absolute;right:1px;bottom:0;font-size:.48rem;color:#64aae680;z-index:1;pointer-events:none;line-height:1}.htp-piece{width:20px;height:20px;object-fit:contain;display:block;flex-shrink:0;z-index:3}.htp-piece--n{filter:brightness(0) saturate(100%) invert(16%) sepia(96%) saturate(3749%) hue-rotate(352deg) brightness(78%) contrast(117%)}.htp-piece--s{filter:brightness(0) saturate(100%) invert(78%) sepia(0%) saturate(546%) hue-rotate(195deg) brightness(96%) contrast(100%)}.htp-anim-move-n{animation:htp-kf-move-n 4s linear infinite}@keyframes htp-kf-move-n{0%{transform:translate(0);opacity:1}32%{transform:translateY(-30px);opacity:1}52%{transform:translateY(-30px);opacity:0}54%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-move-ne{animation:htp-kf-move-ne 3s linear infinite}@keyframes htp-kf-move-ne{0%{transform:translate(0);opacity:1}32%{transform:translate(30px,-30px);opacity:1}52%{transform:translate(30px,-30px);opacity:0}54%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-push{animation:htp-kf-push 3s linear infinite}@keyframes htp-kf-push{0%{transform:translate(0);opacity:1}32%{transform:translate(30px);opacity:1}52%{transform:translate(30px);opacity:0}54%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-chain{animation:htp-kf-push 3s linear .4s infinite}.htp-anim-threat-n1{animation:htp-kf-threat 3s linear infinite}@keyframes htp-kf-threat{0%{transform:translate(0);opacity:1}32%{transform:translate(-30px,-30px);opacity:1}52%{transform:translate(-30px,-30px);opacity:0}54%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-win{animation:htp-kf-win 3.5s linear infinite}@keyframes htp-kf-win{0%{transform:translate(0);opacity:1}32%{transform:translateY(-30px);opacity:1}52%{transform:translateY(-30px);opacity:0}54%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-captured{animation:htp-kf-captured 3.5s linear infinite}@keyframes htp-kf-captured{0%{transform:scale(1)}45%{transform:scale(.1)}50%{transform:scale(.1)}51%{transform:scale(1)}to{transform:scale(1)}}.htp-anim-drown{animation:htp-kf-drown 4s linear infinite}@keyframes htp-kf-drown{0%{transform:translate(0);opacity:1}32%{transform:translateY(20px);opacity:.5}52%{transform:translateY(30px);opacity:0}68%{transform:translate(0);opacity:0}78%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-back-top{position:fixed;bottom:1.5rem;right:1.5rem;z-index:50;background:#c9a84c1a;border:1px solid rgba(201,168,76,.32);color:#c9a84c;font-size:.82rem;padding:.45rem .85rem;border-radius:5px;cursor:pointer;letter-spacing:.05em;transition:background .2s,border-color .2s}.htp-back-top:hover{background:#c9a84c33;border-color:#c9a84c8c}@media (max-width: 640px){.htp-header__title{font-size:1.6rem}.htp-section__intro{font-size:.9rem}.htp-card__caption{font-size:.86rem}.htp-card__detail{font-size:.78rem}.htp-nav__anchors{display:none}.htp-grid{gap:.75rem}}.htp-anim-ortho{animation:htp-kf-ortho 5s linear infinite}@keyframes htp-kf-ortho{0%{transform:translate(0);opacity:1}10%{transform:translateY(-30px);opacity:1}18%{transform:translateY(-30px);opacity:0}20%{transform:translate(0);opacity:0}25%{transform:translate(0);opacity:1}35%{transform:translate(30px);opacity:1}43%{transform:translate(30px);opacity:0}45%{transform:translate(0);opacity:0}50%{transform:translate(0);opacity:1}60%{transform:translateY(30px);opacity:1}68%{transform:translateY(30px);opacity:0}70%{transform:translate(0);opacity:0}75%{transform:translate(0);opacity:1}85%{transform:translate(-30px);opacity:1}93%{transform:translate(-30px);opacity:0}95%{transform:translate(0);opacity:0}to{transform:translate(0);opacity:1}}.htp-anim-archer{animation:htp-kf-archer 3.2s linear infinite}@keyframes htp-kf-archer{0%{transform:translate(0);opacity:1}10%{transform:translate(-30px,-30px);opacity:1}18%{transform:translate(-30px,-30px);opacity:0}20%{transform:translate(0);opacity:0}25%{transform:translate(0);opacity:1}35%{transform:translate(30px,-30px);opacity:1}43%{transform:translate(30px,-30px);opacity:0}45%{transform:translate(0);opacity:0}50%{transform:translate(0);opacity:1}63%{transform:translateY(30px);opacity:1}73%{transform:translateY(30px);opacity:0}75%{transform:translate(0);opacity:0}82%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-lancer{animation:htp-kf-lancer 4s linear infinite}@keyframes htp-kf-lancer{0%{transform:translate(0);opacity:1}10%{transform:translate(-30px,-30px);opacity:1}17%{transform:translate(-30px,-30px);opacity:0}19%{transform:translate(0);opacity:0}24%{transform:translate(0);opacity:1}34%{transform:translate(30px,-30px);opacity:1}41%{transform:translate(30px,-30px);opacity:0}43%{transform:translate(0);opacity:0}48%{transform:translate(0);opacity:1}58%{transform:translate(30px,30px);opacity:1}65%{transform:translate(30px,30px);opacity:0}67%{transform:translate(0);opacity:0}72%{transform:translate(0);opacity:1}82%{transform:translate(-30px,30px);opacity:1}89%{transform:translate(-30px,30px);opacity:0}91%{transform:translate(0);opacity:0}96%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-king{animation:htp-kf-king 6s linear infinite}@keyframes htp-kf-king{0%{transform:translate(0);opacity:1}6%{transform:translateY(-30px);opacity:1}10%{transform:translateY(-30px);opacity:0}11%{transform:translate(0);opacity:0}13%{transform:translate(0);opacity:1}19%{transform:translate(30px,-30px);opacity:1}23%{transform:translate(30px,-30px);opacity:0}24%{transform:translate(0);opacity:0}26%{transform:translate(0);opacity:1}32%{transform:translate(30px);opacity:1}36%{transform:translate(30px);opacity:0}37%{transform:translate(0);opacity:0}39%{transform:translate(0);opacity:1}45%{transform:translate(30px,30px);opacity:1}49%{transform:translate(30px,30px);opacity:0}50%{transform:translate(0);opacity:0}52%{transform:translate(0);opacity:1}58%{transform:translateY(30px);opacity:1}62%{transform:translateY(30px);opacity:0}63%{transform:translate(0);opacity:0}65%{transform:translate(0);opacity:1}71%{transform:translate(-30px,30px);opacity:1}75%{transform:translate(-30px,30px);opacity:0}76%{transform:translate(0);opacity:0}78%{transform:translate(0);opacity:1}84%{transform:translate(-30px);opacity:1}88%{transform:translate(-30px);opacity:0}89%{transform:translate(0);opacity:0}91%{transform:translate(0);opacity:1}97%{transform:translate(-30px,-30px);opacity:1}to{transform:translate(-30px,-30px);opacity:0}}.htp-anim-archer{animation:htp-kf-archer 5s linear infinite}@keyframes htp-kf-archer{0%{transform:translate(0);opacity:1}10%{transform:translate(-30px,-30px);opacity:1}18%{transform:translate(-30px,-30px);opacity:0}20%{transform:translate(0);opacity:0}26%{transform:translate(0);opacity:1}36%{transform:translate(30px,-30px);opacity:1}44%{transform:translate(30px,-30px);opacity:0}46%{transform:translate(0);opacity:0}52%{transform:translate(0);opacity:1}62%{transform:translateY(30px);opacity:1}70%{transform:translateY(30px);opacity:0}72%{transform:translate(0);opacity:0}78%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-lancer{animation:htp-kf-lancer 6s linear infinite}@keyframes htp-kf-lancer{0%{transform:translate(0);opacity:1}10%{transform:translate(-30px,-30px);opacity:1}18%{transform:translate(-30px,-30px);opacity:0}20%{transform:translate(0);opacity:0}25%{transform:translate(0);opacity:1}35%{transform:translate(30px,-30px);opacity:1}43%{transform:translate(30px,-30px);opacity:0}45%{transform:translate(0);opacity:0}50%{transform:translate(0);opacity:1}60%{transform:translate(30px,30px);opacity:1}68%{transform:translate(30px,30px);opacity:0}70%{transform:translate(0);opacity:0}75%{transform:translate(0);opacity:1}85%{transform:translate(-30px,30px);opacity:1}93%{transform:translate(-30px,30px);opacity:0}95%{transform:translate(0);opacity:0}to{transform:translate(0);opacity:1}}.htp-anim-king{animation:htp-kf-king 8s linear infinite}@keyframes htp-kf-king{0%{transform:translate(0);opacity:1}5%{transform:translate(-30px,-30px);opacity:1}9%{transform:translate(-30px,-30px);opacity:0}11%{transform:translate(0);opacity:0}13%{transform:translate(0);opacity:1}18%{transform:translateY(-30px);opacity:1}22%{transform:translateY(-30px);opacity:0}24%{transform:translate(0);opacity:0}26%{transform:translate(0);opacity:1}31%{transform:translate(30px,-30px);opacity:1}35%{transform:translate(30px,-30px);opacity:0}37%{transform:translate(0);opacity:0}39%{transform:translate(0);opacity:1}44%{transform:translate(30px);opacity:1}48%{transform:translate(30px);opacity:0}50%{transform:translate(0);opacity:0}52%{transform:translate(0);opacity:1}57%{transform:translate(30px,30px);opacity:1}61%{transform:translate(30px,30px);opacity:0}63%{transform:translate(0);opacity:0}65%{transform:translate(0);opacity:1}70%{transform:translateY(30px);opacity:1}74%{transform:translateY(30px);opacity:0}76%{transform:translate(0);opacity:0}78%{transform:translate(0);opacity:1}83%{transform:translate(-30px,30px);opacity:1}87%{transform:translate(-30px,30px);opacity:0}89%{transform:translate(0);opacity:0}91%{transform:translate(0);opacity:1}96%{transform:translate(-30px);opacity:1}99%{transform:translate(-30px);opacity:0}to{transform:translate(0);opacity:1}}.htp-anim-entry-push{animation:htp-kf-entry-push 4s linear infinite}@keyframes htp-kf-entry-push{0%{transform:translate(0);opacity:1}28%{transform:translate(0);opacity:1}42%{transform:translateY(30px);opacity:1}50%{transform:translateY(30px);opacity:1}64%{transform:translate(30px,30px);opacity:1}76%{transform:translate(30px,30px);opacity:0}78%{transform:translate(0);opacity:0}88%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-entry-blocked{animation:htp-kf-entry-blocked 4s linear infinite}@keyframes htp-kf-entry-blocked{0%{transform:translate(0);opacity:1}28%{transform:translate(0);opacity:1}42%{transform:translateY(30px);opacity:1}70%{transform:translateY(30px);opacity:1}80%{transform:translateY(30px);opacity:0}82%{transform:translate(0);opacity:0}90%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-entry-diag-push{animation:htp-kf-entry-diag-push 4s linear infinite}@keyframes htp-kf-entry-diag-push{0%{transform:translate(0);opacity:1}28%{transform:translate(0);opacity:1}42%{transform:translate(30px,30px);opacity:1}50%{transform:translate(30px,30px);opacity:1}64%{transform:translate(60px,30px);opacity:1}76%{transform:translate(60px,30px);opacity:0}78%{transform:translate(0);opacity:0}88%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-entry-diag-blocked{animation:htp-kf-entry-diag-blocked 4s linear infinite}@keyframes htp-kf-entry-diag-blocked{0%{transform:translate(0);opacity:1}28%{transform:translate(0);opacity:1}42%{transform:translate(30px,30px);opacity:1}70%{transform:translate(30px,30px);opacity:1}80%{transform:translate(30px,30px);opacity:0}82%{transform:translate(0);opacity:0}90%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-before-after{display:flex;align-items:center;gap:.5rem}.htp-ba-col{display:flex;flex-direction:column;align-items:center;gap:.3rem}.htp-ba-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.htp-ba-arrow{font-size:1rem;color:#c9a84c;flex-shrink:0;margin-top:1rem}.htp-anim-move-s{animation:htp-kf-move-s 4s linear infinite}@keyframes htp-kf-move-s{0%{transform:translate(0)}30%{transform:translate(0)}45%{transform:translateY(30px)}50%{transform:translateY(30px)}51%{transform:translate(0)}to{transform:translate(0)}}.htp-crossfade{position:relative;width:158px;height:98px}.htp-cf-a,.htp-cf-b{position:absolute;top:0;left:0}.htp-cf-a{animation:htp-kf-cf-a 6s linear infinite}@keyframes htp-kf-cf-a{0%{opacity:1}38%{opacity:1}45%{opacity:0}to{opacity:0}}.htp-cf-b{animation:htp-kf-cf-b 6s linear infinite}@keyframes htp-kf-cf-b{0%{opacity:0}38%{opacity:0}45%{opacity:1}90%{opacity:1}97%{opacity:0}to{opacity:0}}.htp-crossfade--sm{width:102px;height:102px}.htp-crossfade--river{width:158px;height:98px}.htp-anim-piece-fade-n{animation:htp-kf-pf-n 4s linear infinite}@keyframes htp-kf-pf-n{0%{transform:translate(0);opacity:1}25%{transform:translate(0);opacity:1}40%{transform:translateY(-30px);opacity:1}60%{transform:translateY(-30px);opacity:1}72%{transform:translateY(-30px);opacity:0}73%{transform:translate(0);opacity:0}85%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-piece-fade-ne{animation:htp-kf-pf-ne 4s linear infinite}@keyframes htp-kf-pf-ne{0%{transform:translate(0);opacity:1}25%{transform:translate(0);opacity:1}40%{transform:translate(30px,-30px);opacity:1}60%{transform:translate(30px,-30px);opacity:1}72%{transform:translate(30px,-30px);opacity:0}73%{transform:translate(0);opacity:0}85%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-piece-fade-nw{animation:htp-kf-pf-nw 4s linear infinite}@keyframes htp-kf-pf-nw{0%{transform:translate(0);opacity:1}25%{transform:translate(0);opacity:1}40%{transform:translate(-30px,-30px);opacity:1}60%{transform:translate(-30px,-30px);opacity:1}72%{transform:translate(-30px,-30px);opacity:0}73%{transform:translate(0);opacity:0}85%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-rep-n{animation:htp-kf-rep-n 8s linear infinite}@keyframes htp-kf-rep-n{0%{transform:translate(0);opacity:1}5%{transform:translate(30px);opacity:1}25%{transform:translate(30px);opacity:1}26%{transform:translate(0);opacity:1}50%{transform:translate(0);opacity:1}55%{transform:translate(0);opacity:1}75%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-rep-s{animation:htp-kf-rep-s 8s linear infinite}@keyframes htp-kf-rep-s{0%{transform:translate(0);opacity:1}25%{transform:translate(0);opacity:1}30%{transform:translate(-30px);opacity:1}50%{transform:translate(-30px);opacity:1}51%{transform:translate(0);opacity:1}75%{transform:translate(0);opacity:1}80%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-iso-n{animation:htp-kf-iso-n 4s linear infinite}@keyframes htp-kf-iso-n{0%{transform:translate(0);opacity:1}20%{transform:translate(0);opacity:1}40%{transform:translate(30px);opacity:1}60%{transform:translate(30px);opacity:1}80%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-iso-s{animation:htp-kf-iso-s 4s linear 2s infinite}@keyframes htp-kf-iso-s{0%{transform:translate(0);opacity:1}20%{transform:translate(0);opacity:1}40%{transform:translate(-30px);opacity:1}60%{transform:translate(-30px);opacity:1}80%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-piece-fade-s{animation:htp-kf-pf-s 4s linear infinite}@keyframes htp-kf-pf-s{0%{transform:translate(0);opacity:1}25%{transform:translate(0);opacity:1}40%{transform:translateY(30px);opacity:1}60%{transform:translateY(30px);opacity:1}72%{transform:translateY(30px);opacity:0}73%{transform:translate(0);opacity:0}85%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-seq5{position:relative;width:158px;height:158px}.htp-s5-1,.htp-s5-2,.htp-s5-3,.htp-s5-4,.htp-s5-5{position:absolute;top:0;left:0}.htp-s5-1{animation:htp-kf-s5-1 10s linear infinite}.htp-s5-2{animation:htp-kf-s5-2 10s linear infinite}.htp-s5-3{animation:htp-kf-s5-3 10s linear infinite}.htp-s5-4{animation:htp-kf-s5-4 10s linear infinite}.htp-s5-5{animation:htp-kf-s5-5 10s linear infinite}@keyframes htp-kf-s5-1{0%{opacity:1}18%{opacity:1}20%{opacity:0}90%{opacity:0}95%{opacity:1}to{opacity:1}}@keyframes htp-kf-s5-2{0%{opacity:0}18%{opacity:0}20%{opacity:1}38%{opacity:1}40%{opacity:0}to{opacity:0}}@keyframes htp-kf-s5-3{0%{opacity:0}38%{opacity:0}40%{opacity:1}58%{opacity:1}60%{opacity:0}to{opacity:0}}@keyframes htp-kf-s5-4{0%{opacity:0}58%{opacity:0}60%{opacity:1}78%{opacity:1}80%{opacity:0}to{opacity:0}}@keyframes htp-kf-s5-5{0%{opacity:0}78%{opacity:0}80%{opacity:1}93%{opacity:1}95%{opacity:0}to{opacity:0}}.htp-section__badge{display:inline-block;font-size:.62rem;font-weight:700;letter-spacing:.08em;color:#c9a84c;background:#c9a84c1f;border:1px solid rgba(201,168,76,.3);border-radius:3px;padding:.1rem .4rem;vertical-align:middle;margin-left:.5rem;text-transform:uppercase}.htp-anim-queen{animation:htp-kf-queen 16s linear infinite}@keyframes htp-kf-queen{0%{transform:translate(0);opacity:1}3%{transform:translateY(-30px);opacity:1}6%{transform:translateY(-30px);opacity:0}7%{transform:translate(0);opacity:0}8%{transform:translate(0);opacity:1}11%{transform:translateY(-60px);opacity:1}14%{transform:translateY(-60px);opacity:0}15%{transform:translate(0);opacity:0}16%{transform:translate(0);opacity:1}19%{transform:translateY(-90px);opacity:1}22%{transform:translateY(-90px);opacity:0}23%{transform:translate(0);opacity:0}24%{transform:translate(0);opacity:1}27%{transform:translate(90px,-90px);opacity:1}30%{transform:translate(90px,-90px);opacity:0}31%{transform:translate(0);opacity:0}32%{transform:translate(0);opacity:1}35%{transform:translate(90px);opacity:1}38%{transform:translate(90px);opacity:0}39%{transform:translate(0);opacity:0}40%{transform:translate(0);opacity:1}43%{transform:translate(90px,90px);opacity:1}46%{transform:translate(90px,90px);opacity:0}47%{transform:translate(0);opacity:0}48%{transform:translate(0);opacity:1}51%{transform:translateY(90px);opacity:1}54%{transform:translateY(90px);opacity:0}55%{transform:translate(0);opacity:0}56%{transform:translate(0);opacity:1}59%{transform:translate(-90px,90px);opacity:1}62%{transform:translate(-90px,90px);opacity:0}63%{transform:translate(0);opacity:0}64%{transform:translate(0);opacity:1}67%{transform:translate(-90px);opacity:1}70%{transform:translate(-90px);opacity:0}71%{transform:translate(0);opacity:0}72%{transform:translate(0);opacity:1}75%{transform:translate(-90px,-90px);opacity:1}78%{transform:translate(-90px,-90px);opacity:0}79%{transform:translate(0);opacity:0}81%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-queen-wall{animation:htp-kf-queen-wall 4s linear infinite}@keyframes htp-kf-queen-wall{0%{transform:translate(0);opacity:1}20%{transform:translate(0);opacity:1}38%{transform:translateY(-30px);opacity:1}55%{transform:translateY(-30px);opacity:1}68%{transform:translateY(-30px);opacity:0}70%{transform:translate(0);opacity:0}80%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-queen-capture{animation:htp-kf-queen-capture 4s linear infinite}@keyframes htp-kf-queen-capture{0%{transform:translate(0);opacity:1}22%{transform:translate(0);opacity:1}38%{transform:translate(60px,-60px);opacity:1}55%{transform:translate(60px,-60px);opacity:0}57%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-queen-capture-r{animation:htp-kf-queen-capture-r 4s linear infinite}@keyframes htp-kf-queen-capture-r{0%{transform:translate(0);opacity:1}20%{transform:translate(0);opacity:1}38%{transform:translate(90px,-90px);opacity:1}55%{transform:translate(90px,-90px);opacity:0}57%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-move-se{animation:htp-kf-move-se 3s linear infinite}@keyframes htp-kf-move-se{0%{transform:translate(0);opacity:1}32%{transform:translate(30px,30px);opacity:1}52%{transform:translate(30px,30px);opacity:0}54%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-move-nw{animation:htp-kf-move-nw 3s linear infinite}@keyframes htp-kf-move-nw{0%{transform:translate(0);opacity:1}32%{transform:translate(-30px,-30px);opacity:1}52%{transform:translate(-30px,-30px);opacity:0}54%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-wolf{animation:htp-kf-wolf 10s linear infinite}@keyframes htp-kf-wolf{0%{transform:translate(0);opacity:1}4%{transform:translateY(-30px);opacity:1}7%{transform:translateY(-30px);opacity:0}8%{transform:translate(0);opacity:0}9%{transform:translate(0);opacity:1}13%{transform:translateY(-60px);opacity:1}16%{transform:translateY(-60px);opacity:0}17%{transform:translate(0);opacity:0}18%{transform:translate(0);opacity:1}22%{transform:translate(60px,-60px);opacity:1}25%{transform:translate(60px,-60px);opacity:0}26%{transform:translate(0);opacity:0}27%{transform:translate(0);opacity:1}31%{transform:translate(60px);opacity:1}34%{transform:translate(60px);opacity:0}35%{transform:translate(0);opacity:0}36%{transform:translate(0);opacity:1}40%{transform:translate(60px,60px);opacity:1}43%{transform:translate(60px,60px);opacity:0}44%{transform:translate(0);opacity:0}45%{transform:translate(0);opacity:1}49%{transform:translateY(60px);opacity:1}52%{transform:translateY(60px);opacity:0}53%{transform:translate(0);opacity:0}54%{transform:translate(0);opacity:1}58%{transform:translate(-60px,60px);opacity:1}61%{transform:translate(-60px,60px);opacity:0}62%{transform:translate(0);opacity:0}63%{transform:translate(0);opacity:1}67%{transform:translate(-60px);opacity:1}70%{transform:translate(-60px);opacity:0}71%{transform:translate(0);opacity:0}72%{transform:translate(0);opacity:1}76%{transform:translate(-60px,-60px);opacity:1}79%{transform:translate(-60px,-60px);opacity:0}80%{transform:translate(0);opacity:0}82%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-wolf-jump-e2{animation:htp-kf-wolf-jump-e2 4s linear infinite}@keyframes htp-kf-wolf-jump-e2{0%{transform:translate(0);opacity:1}22%{transform:translate(0);opacity:1}40%{transform:translate(60px);opacity:1}58%{transform:translate(60px);opacity:0}60%{transform:translate(0);opacity:0}72%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-wolf-jump-n2{animation:htp-kf-wolf-jump-n2 4s linear infinite}@keyframes htp-kf-wolf-jump-n2{0%{transform:translate(0);opacity:1}22%{transform:translate(0);opacity:1}40%{transform:translateY(-60px);opacity:1}58%{transform:translateY(-60px);opacity:0}60%{transform:translate(0);opacity:0}72%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-anim-wolf-capture-ne{animation:htp-kf-wolf-capture-ne 6s linear infinite}@keyframes htp-kf-wolf-capture-ne{0%{transform:translate(0);opacity:1}25%{transform:translate(0);opacity:1}45%{transform:translate(60px,-60px);opacity:1}62%{transform:translate(60px,-60px);opacity:0}64%{transform:translate(0);opacity:0}75%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.htp-crossfade3{position:relative}.htp-crossfade3--sm{width:102px;height:102px}.htp-cf3-a,.htp-cf3-b,.htp-cf3-c{position:absolute;top:0;left:0}.htp-cf3-a{animation:htp-kf-cf3-a 9s linear infinite}.htp-cf3-b{animation:htp-kf-cf3-b 9s linear infinite}.htp-cf3-c{animation:htp-kf-cf3-c 9s linear infinite}@keyframes htp-kf-cf3-a{0%{opacity:1}28%{opacity:1}33%{opacity:0}95%{opacity:0}to{opacity:1}}@keyframes htp-kf-cf3-b{0%{opacity:0}28%{opacity:0}33%{opacity:1}61%{opacity:1}66%{opacity:0}to{opacity:0}}@keyframes htp-kf-cf3-c{0%{opacity:0}61%{opacity:0}66%{opacity:1}94%{opacity:1}99%{opacity:0}to{opacity:0}}.htp-anim-move-w{animation:htp-kf-move-w 3s linear infinite}@keyframes htp-kf-move-w{0%{transform:translate(0);opacity:1}32%{transform:translate(-30px);opacity:1}52%{transform:translate(-30px);opacity:0}54%{transform:translate(0);opacity:0}68%{transform:translate(0);opacity:1}to{transform:translate(0);opacity:1}}.notation-legend-page{width:100%;max-width:760px;margin:0 auto;padding:1.5rem 1.25rem 3rem;color:var(--text-primary, #e8e8e8);font-family:inherit}.nlp-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:1rem}.nlp-back-btn{background:transparent;border:1px solid rgba(255,255,255,.15);color:var(--text-secondary, #a0a0b0);padding:.35rem .85rem;border-radius:.4rem;font-size:.85rem;cursor:pointer;transition:border-color .15s,color .15s}.nlp-back-btn:hover{border-color:#ffffff59;color:#e8e8e8}.nlp-title{font-size:1.4rem;font-weight:600;margin:0;color:#e8e8e8}.nlp-body{display:flex;flex-direction:column;gap:2rem}.nlp-section{border:1px solid rgba(255,255,255,.07);border-radius:.6rem;padding:1.1rem 1.25rem;background:#ffffff05}.nlp-section-title{font-size:.95rem;font-weight:600;color:#c8c8d8;margin:0 0 .85rem;display:flex;align-items:center;gap:.6rem}.nlp-mode-tag{font-size:.7rem;font-weight:500;background:#ffffff14;color:#a0a0b8;padding:.15rem .5rem;border-radius:.3rem}.nlp-subsection-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#22a0bc;margin:.85rem 0 .5rem}.nlp-subsection-label:first-of-type{margin-top:0}.nlp-section-note{font-size:.78rem;color:#22a0bc;margin:.5rem 0 0}.nlp-example-code{font-family:PGF Monona Regular,Courier New,monospace;font-size:.88rem;background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:.4rem;padding:.65rem .9rem;color:#d4d4e8;word-break:break-all}.nlp-grid{display:flex;flex-direction:column;gap:.45rem}.nlp-row{display:flex;align-items:baseline;gap:.75rem;font-size:.85rem}.nlp-symbol{font-family:PGF Monona Regular,Courier New,monospace;font-size:.88rem;font-weight:600;color:#e8e8e8;min-width:2.8rem;flex-shrink:0}.nlp-symbol--north{color:#e05050}.nlp-symbol--south{color:#a0a0a0}.nlp-symbol--wolf{color:#1ee5ce}.nlp-desc{color:#9898b0;line-height:1.4}.nlp-badge{display:inline-block;font-size:.72rem;font-weight:600;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:.3rem;padding:.15rem .5rem;color:#c8c8d8;min-width:9rem;flex-shrink:0;white-space:nowrap}.nlp-example-list{display:flex;flex-direction:column;gap:.5rem}.nlp-example-row{display:flex;align-items:baseline;gap:.75rem;font-size:.85rem}.nlp-example-notation{font-family:PGF Monona Regular,Courier New,monospace;font-size:.82rem;color:#d4d4e8;min-width:13rem;flex-shrink:0}.nlp-example-explain{color:#9898b0}@media (max-width: 540px){.nlp-example-notation{min-width:unset}.nlp-example-row,.nlp-row{flex-direction:column;gap:.2rem}.nlp-badge{min-width:unset}}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-Hairline-D2u1-QMU.woff2) format("woff2");font-weight:100;font-style:normal;font-display:swap}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-Light-JKUWODvt.woff2) format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-Regular-BzDeZD4H.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-Medium-CDGkfo4N.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-Bold-XrSAxMhq.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-Black-BWRDEwWZ.woff2) format("woff2");font-weight:900;font-style:normal;font-display:swap}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-LightItalic-DDpPKz4M.woff2) format("woff2");font-weight:300;font-style:italic;font-display:swap}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-Italic-BL9KTjLc.woff2) format("woff2");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:PGF Webfont;src:url(/assets/PGF-Webfont-ExtraBoldItalic-CFPmETzg.woff2) format("woff2");font-weight:800;font-style:italic;font-display:swap}@font-face{font-family:PGF Monona;src:url(/assets/PGF-Monona-Regular-Dd0R8GUu.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}body{font-family:PGF Webfont,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:PGF Webfont,system-ui,-apple-system,sans-serif;font-weight:700;line-height:1.2}h1{font-weight:800}.osf{font-variant-numeric:oldstyle-nums}.light{font-weight:300}.sm{font-size:.7rem}.move-item,.notation-item,.cell__coordinate,.font-mono{font-family:PGF Monona,Courier New,monospace}.tip-section h3{font-weight:600}.tip-section p{font-style:italic;font-weight:400}.instruction-content{font-style:italic}.instruction-content ol{list-style:none;counter-reset:number;font-size:.9rem;margin-left:-20px}.instruction-content li{counter-increment:number;margin-left:-10px;margin-bottom:5px;line-height:1.4rem;color:#026a71}.instruction-content li:before{content:counter(number);font-feature-settings:"ss01" 1;font-variant-numeric:lining-nums;font-weight:100;font-size:1.3rem;margin-left:-1rem;margin-right:.5rem;color:#0cb6a8;width:2em;text-align:center;font-family:inherit;font-style:normal}.app-container{height:100vh;max-height:100vh;overflow-y:auto;background:linear-gradient(135deg,#373b3b,#1c2022);display:flex;flex-direction:column}.main-wrapper{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.main-layout{display:grid;grid-template-columns:1fr;gap:.5rem;padding:.25rem 0 .15rem;margin:0 36px;flex:1;min-height:0;width:auto;box-sizing:border-box;align-items:start}@media (min-width: 900px) and (orientation: landscape),(min-width: 1100px){.main-layout{grid-template-columns:70fr 30fr;gap:.75rem;align-items:stretch}}@media (max-width: 1099px) and (orientation: portrait){.main-layout{grid-template-columns:1fr;align-items:start;overflow-y:auto}.board-column{height:auto;overflow:visible}}@media (max-width: 600px){.main-layout{margin:0 12px}}.board-column{display:flex;justify-content:center;align-items:flex-start;padding:0;min-height:0;box-sizing:border-box;overflow:visible}.gameui-column{background:#0f302bf2;border-radius:10px;padding:.6rem;box-shadow:0 10px 30px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden}@media (max-width: 1099px) and (orientation: portrait){.gameui-column{max-height:none;overflow-y:visible}.main-layout{overflow-y:auto}}.header-center{display:flex;align-items:flex-end;text-align:left;gap:1rem}.game-title{font-size:3.6rem;margin:0;font-weight:400!important}.game-subtitle{font-size:1.6rem;font-family:PGF Webfont,system-ui,-apple-system,sans-serif;color:#81d8e2;margin:0;font-style:italic;font-weight:300;white-space:nowrap}.app-footer{background:none;color:#fff;text-align:center;padding:.3rem 0 .4rem;margin-top:0;flex-shrink:0;transform:translate(-15%)}.rlk-dev-note{color:#0f778e;padding-left:2rem}.container{max-width:1400px;margin:0 auto;padding:0 .5rem}.container p{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.instruction-content{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:#4a5568;line-height:1.1}.instruction-content p{margin:.2rem}.notation-grid{display:grid;grid-template-columns:1fr 1fr;gap:.25rem;font-size:.75rem}.notation-item{padding:.25rem .5rem;border-radius:.2rem;font-weight:700;font-size:.75rem}.notation-item.northern{color:#c00;background-color:#fee}.notation-item.southern{color:#666;background-color:#f3f3f3}.tip-section{background:linear-gradient(135deg,#c7fedf,#8afde0);border:1px solid #01938f;border-radius:.4rem;padding:0 .75rem 1.25rem}.tip-section h3{font-weight:700;color:#026a71;margin-bottom:.1rem;font-size:.9rem}.tip-section p{color:#01938f;font-size:.8rem;line-height:1.2;margin:0}.header-content{display:flex;align-items:baseline;justify-content:left;gap:1rem;flex-wrap:wrap}.header-content h1{font-size:2rem;font-weight:500;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.subtitle{color:#68d391;font-size:1rem;font-weight:500;margin:0;font-style:italic}.tab-navigation{display:flex;border-bottom:2px solid #e5e7eb;margin-bottom:1rem}.tab-button{flex:1;padding:.75rem 1rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-weight:600;color:#6b7280;transition:all .2s}.tab-button:hover{color:#374151;background-color:#f9fafb}.tab-button.active{color:#dc2626;border-bottom-color:#dc2626;background-color:#fef2f2}.online-lobby{space-y-4:1rem}.connection-status{padding:.75rem;border-radius:.5rem;font-weight:600;margin-bottom:1rem}.connection-status.connected{background-color:#dcfce7;color:#166534;border:1px solid #bbf7d0}.connection-status.disconnected{background-color:#fee2e2;color:#dc2626;border:1px solid #fecaca}.lobby-actions{display:flex;flex-direction:column;gap:.75rem}.create-room-btn,.join-room-btn{padding:.75rem 1rem;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.create-room-btn{background-color:#17a7c7;color:#fff}.create-room-btn:hover{background-color:#0f778e}.join-room-btn{background-color:#4b5563;color:#fff}.join-room-btn:hover{background-color:#374151}.room-form{space-y-4:1rem}.form-group{space-y-2:1rem;margin-bottom:1rem}.form-group label{display:block;font-weight:600;color:#374151;margin-bottom:.25rem}.form-group input{width:100%;padding:.75rem 0;border:1px solid #e2e8f0;border-radius:4px;font-size:1rem}.form-group input:focus{outline:none;border-color:#42c4e1;box-shadow:0 0 0 3px #4299e11a}.room-code-input{font-family:monospace;font-weight:600;letter-spacing:.05em}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.submit-btn,.cancel-btn{flex:1;padding:.5rem 1rem;border:none;border-radius:.375rem;font-weight:600;cursor:pointer;transition:all .2s}.submit-btn{background-color:#16a8ab;color:#fff}.submit-btn:hover{background-color:#0e7a8d}.cancel-btn{background-color:#6b7280;color:#fff}.cancel-btn:hover{background-color:#4b5563}.players-grid{display:grid;gap:.75rem;margin:1rem 0}.player-card{padding:1rem;border-radius:.5rem;border:2px solid}.player-card.northern{border-color:#dc2626;background-color:#fef2f2}.player-card.southern{border-color:#6b7280;background-color:#f9fafb}.player-faction{font-weight:600;font-size:.875rem}.player-card.northern .player-faction{color:#dc2626}.player-card.southern .player-faction{color:#4b5563}.player-name{font-size:1.125rem;font-weight:700;margin:.25rem 0}.player-color{font-size:.75rem;color:#6b7280}.room-status{padding:.75rem;border-radius:.5rem;font-weight:600;margin:1rem 0;text-align:center}.room-status.waiting{background-color:#fef3c7;color:#92400e;border:1px solid #fcd34d}.room-status.playing{background-color:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.leave-room-btn{width:100%;padding:.75rem 1rem;background-color:#dc2626;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:background-color .2s}.leave-room-btn:hover{background-color:#b91c1c}.game-info{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;padding:1rem;margin:1rem 0}.info-item{display:flex;justify-content:space-between;padding:.25rem 0;border-bottom:1px solid #f1f5f9}.info-item:last-child{border-bottom:none}.info-item strong{color:#374151}.player-card.waiting{border-color:#d1d5db;background-color:#f9fafb;color:#6b7280}.player-card.waiting .player-faction{color:#6b7280}.header-container{display:grid;grid-template-columns:2fr 6fr 4fr;gap:1rem;align-items:center;max-width:1400px;margin:0 auto;padding:0 1rem}.app-header{background:linear-gradient(135deg,#1a202c,#2d3748);color:#fff;padding:.2rem 0;box-shadow:0 4px 6px #0000001a;border-bottom:2px solid #4a5568;flex-shrink:0}.app-header h1{font-weight:800}.header-left{display:flex;align-items:center}.logo-section{display:flex;align-items:right;margin-left:auto;gap:1rem}.main-logo{height:54px;width:auto}.icon-grid{display:flex;gap:.25rem;align-items:center}.size-icon{height:20px;width:20px;transition:transform .2s}.size-icon:hover{transform:scale(1.1)}.header-right{display:flex;justify-content:flex-end}.user-section{display:flex;align-items:center;gap:.75rem;position:relative;gap:.5rem}.user-profile-btn{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:.3rem 1rem;color:#fafafa;cursor:pointer;transition:all .2s}.user-profile-btn:hover{background:#fff3;transform:translateY(-1px)}.user-avatar{height:32px;width:32px;border-radius:0}.user-name{font-weight:600}.dropdown-arrow{font-size:.8rem;transition:transform .2s}.user-profile-btn:hover .dropdown-arrow{transform:rotate(180deg)}.user-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;min-width:250px;z-index:1000}.dropdown-content{padding:1rem}.user-info{display:flex;align-items:flex-end;gap:.75rem;padding-bottom:.75rem}.user-details .user-name{color:#2d3748;font-weight:700}.user-details .user-status{color:#718096;font-size:.8rem}.dropdown-divider{height:1px;background:#e2e8f0;margin:.5rem 0}.dropdown-menu{display:flex;flex-direction:column;gap:.25rem}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:none;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s;text-align:left;width:100%;color:#4a5568}.dropdown-item:hover{background:#f7fafc}.dropdown-item.logout{color:#e53e3e}.dropdown-item.logout:hover{background:#fed7d7}.item-icon{font-size:1.1rem;width:20px;text-align:center}.auth-section .login-btn,.login-btn{background:linear-gradient(45deg,#178a9b,#134c60);padding:.5rem 1.25rem;color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s;border-radius:4px;border:none;white-space:nowrap}.auth-section .login-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #e53e3e4d;background:#1fa2b9}.login-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;color:#0acece;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000}.login-form{width:90%;position:relative;background:#051618;padding:2rem;border-radius:8px;border:1px solid rgb(1,147,143,.7);box-shadow:0 10px 25px #0003;width:100%;max-width:400px;animation:slideDown .2s ease-out}.login-form h3{margin:0 2.5rem 1.5rem 0;text-align:center;color:#2d3748;padding-right:1rem}.auth-options{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.switch-auth,.guest-btn{background:none;border:none;color:#23a5bf;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s;text-decoration:none}.switch-auth:hover,.guest-btn:hover{color:#18739d}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:#0acece;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;padding:0;z-index:100}.modal-close-btn:hover{background:#f7fafc;color:#2d3748}.modal-close-btn:active{transform:scale(.95)}.new-game-dropdown-wrapper{position:relative;width:100%;margin:.75rem 0}.new-game-dropdown-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:#17a7c7;color:#fff;border:none;border-radius:.5rem;font-weight:700;font-size:.95rem;cursor:pointer;transition:background-color .2s}.new-game-dropdown-trigger:hover:not(:disabled){background-color:#0f8faa}.new-game-dropdown-trigger:disabled{background-color:#9ca3af;cursor:not-allowed}.dropdown-arrow{font-size:.65rem;opacity:.8}.new-game-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 4px 16px #0000001f;z-index:200;overflow:hidden;animation:slideDown .12s ease-out}.new-game-dropdown-menu .dropdown-item{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:.65rem 1rem;background:none;border:none;border-bottom:1px solid #f1f5f9;text-align:left;cursor:pointer;transition:background-color .15s}.new-game-dropdown-menu .dropdown-item:last-child{border-bottom:none}.new-game-dropdown-menu .dropdown-item:hover:not(:disabled){background-color:#f0fdff}.new-game-dropdown-menu .dropdown-item:disabled,.new-game-dropdown-menu .dropdown-item.disabled{cursor:not-allowed;opacity:.5}.dropdown-item-label{font-weight:600;font-size:.9rem;color:#1a202c}.dropdown-item-desc{font-size:.75rem;color:#6b7280;margin-top:.1rem}.dropdown-item-desc.coming-soon{color:#9ca3af;font-style:italic}.pairing-search-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1rem;text-align:center}.pairing-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#17a7c7;border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pairing-searching-label{font-weight:700;font-size:1rem;color:#1a202c;margin:0}.pairing-hint{font-size:.82rem;color:#6b7280;margin:0}.pairing-cancel-btn{padding:.5rem 1.5rem;background-color:#6b7280;color:#fff;border:none;border-radius:.375rem;font-weight:600;font-size:.875rem;cursor:pointer;transition:background-color .2s;margin-top:.25rem}.pairing-cancel-btn:hover{background-color:#4b5563}.pairing-inline-status{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:#f0fdff;border:1px solid #bae6fd;border-radius:.375rem;font-size:.82rem;color:#0369a1;font-weight:600}.pairing-inline-spinner{display:inline-block;width:14px;height:14px;border:2px solid #bae6fd;border-top-color:#17a7c7;border-radius:50%;animation:spin .9s linear infinite;flex-shrink:0}.pairing-inline-cancel{margin-left:auto;padding:.2rem .6rem;background:none;border:1px solid #0369a1;border-radius:.25rem;color:#0369a1;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.pairing-inline-cancel:hover{background-color:#0369a1;color:#fff}.session-status.spectating{background:#8b5cf626;color:#a78bfa;border:1px solid rgba(139,92,246,.3);border-radius:.25rem;padding:.2rem .5rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.spectator-label{text-align:center;font-size:.78rem;color:#a78bfa;background:#8b5cf614;border:1px solid rgba(139,92,246,.2);border-radius:.375rem;padding:.4rem .75rem;margin:.25rem 0}.spectate-btn{font-size:.72rem;font-weight:600;padding:.2rem .6rem;background:#8b5cf61f;color:#a78bfa;border:1px solid rgba(139,92,246,.3);border-radius:.25rem;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.spectate-btn:hover:not(:disabled){background:#8b5cf640;border-color:#8b5cf680}.spectate-btn:disabled{opacity:.4;cursor:not-allowed}.lobby-live-games{display:flex;flex-direction:column;gap:.5rem}.lobby-live-game-card{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem .75rem;background:#8b5cf60f;border:1px solid rgba(139,92,246,.18);border-radius:.5rem}.live-game-players{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}.live-game-player{font-size:.8rem;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.live-game-player.north{color:#f87171}.live-game-player.south{color:#94a3b8}.live-game-vs{font-size:.7rem;color:#475569;flex-shrink:0}.board-spectator-mode{cursor:default!important}.board-spectator-mode .cell{cursor:default!important;pointer-events:none}.practice-mode-bar{display:flex;flex-direction:row;align-items:stretch;justify-content:space-between;width:94%;height:26px;min-height:26px;margin-bottom:.25rem;gap:.4rem;flex-shrink:0}.practice-mode-bar:not(:has(.practice-mode-banner)){height:0;min-height:0;margin-bottom:0;overflow:hidden}.practice-mode-bar .practice-mode-banner{flex:1;margin-bottom:0;width:auto;justify-content:flex-start}.practice-mode-bar .practice-mode-exit-btn{margin:0}.practice-mode-banner{display:flex;align-items:center;justify-content:space-between;width:94%;padding:.2rem .7rem;margin-bottom:.5rem;background:#facc1512;border:1px solid rgba(250,204,21,.4);border-radius:.3rem;box-shadow:0 0 14px #facc1526}.practice-mode-banner-text{font-size:.65rem;font-weight:700;color:#fbbf24;letter-spacing:.06em;text-transform:uppercase}.practice-mode-exit-btn{padding:.2rem .7rem;background:none;border:1px solid rgba(250,204,21,.5);border-radius:.2rem;color:#fbbf24;font-size:.65rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.practice-mode-exit-btn:hover{background:#facc151f;border-color:#facc15cc}.board-center-stack{display:flex;flex-direction:column;align-items:center;width:100%}.logo-btn{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;opacity:1;transition:opacity .15s}.logo-btn:hover{opacity:.8}.golem-mode-banner{background:#4ade8012!important;border-color:#4ade8066!important;box-shadow:0 0 14px #4ade8026!important}.golem-mode-banner.thinking{animation:golem-banner-pulse 1.4s ease-in-out infinite}@keyframes golem-banner-pulse{0%,to{box-shadow:0 0 14px #4ade8026}50%{box-shadow:0 0 22px #4ade8059}}.golem-mode-banner .practice-mode-banner-text{color:#4ade80!important}.golem-mode-banner .practice-mode-exit-btn,.practice-mode-bar:has(.golem-mode-banner) .practice-mode-exit-btn{border-color:#4ade8080!important;color:#4ade80!important}.golem-mode-banner .practice-mode-exit-btn:hover,.practice-mode-bar:has(.golem-mode-banner) .practice-mode-exit-btn:hover{background:#4ade801f!important}.golem-banner-thinking{font-weight:400;opacity:.75;font-style:italic;animation:golem-banner-pulse 1.4s ease-in-out infinite}.standalone-page{flex:1;max-width:900px;margin:0 auto;width:100%;padding:1.5rem 1rem 2rem;box-sizing:border-box;overflow-y:auto}.standalone-page-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.standalone-page-header h1{font-size:1.8rem;font-weight:600;color:#e2e8f0;margin:0}.back-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .85rem;background:#ffffff12;border:1px solid rgba(255,255,255,.15);border-radius:.375rem;color:#cbd5e0;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.back-btn:hover{background:#ffffff24;color:#e2e8f0}.standalone-page-content{background:#0f302bf2;border-radius:10px;padding:1.25rem;box-shadow:0 10px 30px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);color:#e2e8f0}.online-play-page-content{max-width:640px;margin:0 auto}.piece-notation h3{margin-bottom:.5rem;font-size:.9rem}.notation-grid-container{max-height:150px;overflow-y:auto}.tip-section{margin-top:auto;flex-shrink:0}.gameui-page-links{display:flex;gap:.5rem;margin-top:auto;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.gameui-page-link-btn{flex:1;padding:.4rem .5rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.12);border-radius:.375rem;color:#94a3b8;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}.gameui-page-link-btn:hover{background:#ffffff17;color:#cbd5e0;border-color:#ffffff38}.instructions-panel-container{display:flex;flex-direction:column;height:100%}.instructions-content-wrapper{display:flex;flex-direction:column;flex:1;gap:1rem;min-height:0}.instruction-slider{flex:1;display:flex;flex-direction:column;overflow:auto}.slider-content-area{min-height:200px;display:flex;flex:1;align-items:flex-start;justify-content:flex-start;padding:0 .25rem}.instruction-section{width:100%;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start}.slider-navigation-wrapper{display:grid;flex:1;grid-template-columns:20px 1fr 20px;gap:1rem;align-items:start;margin-left:-.1rem;margin-right:-.1rem;margin-bottom:.75rem;padding:.2rem;z-index:1000;min-height:0}.slider-arrow-minimal{position:relative;background:none;border:none;color:#a9a9a9;cursor:pointer;font-size:2rem;font-weight:100;font-family:PGF Webfont;padding:0;display:flex;align-items:center;justify-content:center;height:100%;transition:all .2s ease;opacity:.6;align-self:center}.slider-arrow-minimal:hover{opacity:1;color:#056877;transform:scale(1.2)}.slider-arrow-minimal:after{position:absolute;content:"";width:800%;height:100%;mix-blend-mode:multiply;display:hidden}.slider-arrow-minimal:active{transform:scale(1)}.slide-content{width:100%;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.slider-dots{display:flex;justify-content:center;gap:.75rem;padding-top:.5rem;border-top:1px solid rgba(8,145,178,.2);margin-top:.75rem;flex-shrink:0}.slider-dot{background:none;border:none;color:#b6c6c6;font-size:1.8rem;cursor:pointer;padding:0;line-height:1;transition:all .2s ease}.slider-dot:hover{color:#115463;transform:scale(1.8)}.slider-dot.active{color:#058f9c;transform:scale(1.5)}.strategy-tips-fixed{margin-top:auto;flex-shrink:0}.slider-title{font-size:1.1rem;font-weight:700;color:#0c4a6e;text-align:center;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.05em}@media (max-width: 768px){.slider-title{font-size:.95rem}.slider-navigation-wrapper{grid-template-columns:30px 1fr 30px}.slider-arrow-minimal{font-size:1.5rem}.slider-content-area{min-height:180px}}.piece-movements ul{list-style:none;padding-left:0}.piece-movements li{margin-bottom:.75rem;line-height:1.5;color:#2d3748}.instruction-content{width:100%}.instruction-content ol,.instruction-content ul{width:100%;margin:0;padding-left:.5rem;vertical-align:middle}.instructions-content{flex:1;display:flex;flex-direction:column;min-height:0}.piece-movements ul li{font-size:.9rem;color:#01938f;margin-left:-1.2rem}.mini{width:1rem;aspect-ratio:1/1;filter:brightness(0) saturate(100%) invert(34%) sepia(55%) saturate(526%) hue-rotate(133deg) brightness(93%) contrast(97%)}.piece-movements .mini{vertical-align:middle;margin-right:.25rem}.piece-notation{margin-bottom:1rem;font-size:.9rem}.instructions-column{display:flex;flex-direction:column;background:#fffffff2;border-radius:8px;padding:1rem;box-shadow:0 4px 12px #00000026;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);height:auto}.piece-movements p{font-size:.9rem;font-weight:300;margin-bottom:-.2rem;margin-left:-2rem;color:#859197;font-style:italic}.instruction-section{margin-bottom:1rem}.instruction-section h2{flex-shrink:0;font-size:1rem;color:#2d3748;font-weight:700;min-height:max-content;margin-left:-2rem;text-transform:uppercase;letter-spacing:1px;font-weight:500}.instruction-section h3{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:-2px}.app-container{height:100dvh;max-height:100dvh}@media (min-width: 900px) and (orientation: landscape),(min-width: 1100px){.main-layout{grid-template-columns:72fr 28fr}.board-column{align-self:stretch;align-items:flex-start;justify-content:center}.gameui-column{max-height:calc(100dvh - 100px - .5rem);overflow-y:auto;overflow-x:hidden}.hamburger-btn{display:none!important}.header-user-controls{display:flex!important}}@media (min-width: 900px) and (max-width: 1400px) and (orientation: landscape){:root{--footer-h: 16px;--board-v-padding: .35rem;--modebar-reserve: calc(26px + .25rem) }.app-container{overflow:hidden;height:100dvh;max-height:100dvh}.main-wrapper{overflow:hidden;flex:1;min-height:0;max-height:calc(100dvh - var(--header-h) - var(--footer-h))}.main-layout{overflow:hidden;height:100%;min-height:0;max-height:100%}.board-column{overflow:hidden;min-height:0;align-self:stretch;align-items:flex-start;justify-content:center}.app-footer{padding:0;font-size:.6rem;line-height:1;flex-shrink:0}.main-layout{grid-template-columns:68fr 32fr;padding:.1rem 0 .05rem;margin:0 16px;align-items:stretch}.gameui-column{max-height:calc(100dvh - var(--header-h) - var(--footer-h) - var(--board-v-padding));overflow-y:auto;overflow-x:hidden}}@media (max-width: 899px) and (orientation: landscape){:root{--header-h: 44px;--footer-h: 14px;--board-v-padding: .2rem}.app-header{padding:.1rem 0}.header-container{display:flex!important;flex-direction:row!important;align-items:center;gap:.5rem;padding:0 .6rem}.main-logo{height:32px}.game-subtitle{font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-user-controls{display:none!important}.hamburger-btn{display:flex!important}.app-container{overflow:hidden;height:100dvh;max-height:100dvh}.main-wrapper{overflow:hidden;flex:1;min-height:0}.main-layout{grid-template-columns:60fr 40fr!important;gap:.4rem;margin:0 6px;padding:.1rem 0;height:100%;min-height:0;align-items:stretch;overflow:hidden}.board-column{overflow:hidden;min-height:0;align-self:stretch;align-items:flex-start;justify-content:center}.gameui-column{position:static!important;transform:none!important;transition:none!important;max-height:calc(100dvh - var(--header-h) - var(--footer-h));overflow-y:auto;overflow-x:hidden;border-radius:8px!important}.app-footer{padding:0;font-size:.55rem;line-height:1;flex-shrink:0}.portrait-panel-toggle,.portrait-panel-handle,.portrait-panel-backdrop{display:none!important}}@media (max-width: 1099px) and (orientation: portrait){:root{--header-h: 50px}.app-header{padding:.15rem 0}.header-container{display:flex!important;flex-direction:row!important;align-items:center;gap:.5rem;padding:0 .75rem}.header-left{flex-shrink:0}.header-center{flex:1;min-width:0;justify-content:flex-start}.header-right{flex-shrink:0;justify-content:flex-end}.main-logo{height:36px}.game-subtitle{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.header-user-controls{display:none!important}.hamburger-btn{display:flex!important}.app-footer{padding:.2rem 0;font-size:.65rem}.app-container{overflow:hidden}.main-wrapper{padding-bottom:48px;box-sizing:border-box;overflow:hidden}.main-layout{grid-template-columns:1fr!important;margin:0 8px;gap:.25rem;overflow:hidden;align-items:start}.board-column{width:100%;justify-content:center}.board-center-stack{width:100%;align-items:center}.gameui-column{position:fixed!important;left:0;right:0;bottom:0;z-index:200;border-radius:16px 16px 0 0!important;border-bottom:none!important;max-height:72dvh;overflow-y:auto;overflow-x:hidden;transform:translateY(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);background:#0c2824fa!important;box-shadow:0 -8px 32px #00000080!important;padding:0 .75rem 1rem!important;box-sizing:border-box}.gameui-column.portrait-panel-open{transform:translateY(0)}.portrait-panel-handle{display:flex;align-items:center;cursor:pointer;position:sticky;top:0;background:#0c2824fa;z-index:1;border-radius:16px 16px 0 0;margin:0 -.75rem;padding:.65rem .75rem .5rem}.portrait-panel-pill{width:36px;height:4px;background:#ffffff40;border-radius:2px;flex-shrink:0}.portrait-panel-title{flex:1;text-align:center;font-size:.78rem;font-weight:600;color:#cbd5e1b3;letter-spacing:.06em;text-transform:uppercase;margin:0 .5rem}.portrait-panel-close{background:none;border:none;color:#cbd5e180;font-size:1.1rem;cursor:pointer;padding:.2rem .3rem;line-height:1;transition:color .15s;flex-shrink:0}.portrait-panel-close:hover{color:#e2e8f0}.portrait-panel-toggle{position:fixed;bottom:0;right:5%;z-index:201;display:flex;align-items:center;gap:.5rem;padding:0 1.75rem;background:#0a5046f7;border:1px solid rgba(255,255,255,.15);border-bottom:none;border-radius:12px 12px 0 0;color:#a7f3d0;font-size:.8rem;font-weight:700;letter-spacing:.05em;cursor:pointer;box-shadow:0 -4px 16px #00000059;transition:background .15s,color .15s;white-space:nowrap;height:48px;box-sizing:border-box}.portrait-panel-toggle:hover{background:#0a6458fa;color:#d1fae5}.portrait-panel-toggle-arrow{font-size:.65rem;opacity:.75}.portrait-panel-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199}.portrait-panel-backdrop.visible{display:block}}@media (min-width: 1100px),(min-width: 900px) and (orientation: landscape){.portrait-panel-toggle,.portrait-panel-handle,.portrait-panel-backdrop{display:none!important}}@media (max-width: 480px) and (orientation: portrait){.main-layout{margin:0 4px}.gameui-column{max-height:80dvh}.portrait-panel-toggle{padding:0 1.25rem;font-size:.75rem}.main-logo{height:32px}.game-subtitle{font-size:.78rem}}.hamburger-btn{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;background:#ffffff14;border:1px solid rgba(255,255,255,.18);border-radius:6px;cursor:pointer;flex-shrink:0;padding:0;transition:background .15s}.hamburger-btn:hover{background:#ffffff2e}.hamburger-line{display:block;width:18px;height:2px;background:#e2e8f0;border-radius:2px;transition:opacity .15s}.header-user-controls{display:flex;align-items:center}.hamburger-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:299}.hamburger-menu{position:fixed;top:var(--header-h, 50px);right:.5rem;z-index:300;min-width:200px;background:#0c201cfa;border:1px solid rgba(255,255,255,.15);border-radius:10px;box-shadow:0 8px 32px #00000080;padding:.5rem 0;display:flex;flex-direction:column}.hamburger-user-row{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem .4rem}.hamburger-user-icon{width:24px;height:24px;border-radius:50%;opacity:.9}.hamburger-username{flex:1;font-size:.85rem;font-weight:700;color:#e2e8f0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hamburger-divider{height:1px;background:#ffffff1a;margin:.3rem 0}.hamburger-item{width:100%;padding:.6rem 1rem;background:none;border:none;color:#cbd5e0;font-size:.9rem;font-weight:500;text-align:left;cursor:pointer;transition:background .12s,color .12s}.hamburger-item:hover{background:#ffffff14;color:#f1f5f9}.hamburger-item--primary{color:#67e8f9;font-weight:700}.hamburger-item--logout{color:#f87171}.hamburger-item--logout:hover{background:#f871711a;color:#fca5a5}@tailwind base;@tailwind components;@tailwind utilities;@layer base{html,body{margin:0;padding:0;height:100%;font-family:PGF Webfont,system-ui,sans-serif}code,kbd,samp,pre{font-family:PGF Monona,ui-monospace,monospace}#root{height:100%}}
