:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.btn{font-family:var(--font-family-base);font-size:var(--font-size-sm);line-height:var(--line-height-base);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-accent);color:var(--color-text-inverse);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-2);font-weight:500;transition:background var(--transition-base),transform var(--transition-fast),filter var(--transition-fast),box-shadow var(--transition-fast);text-decoration:none;-webkit-user-select:none;user-select:none}.btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.btn:disabled{opacity:.55;cursor:not-allowed}.btn:hover:not(:disabled){filter:brightness(1.05)}.btn--primary{background:var(--color-accent);border-color:var(--color-accent)}.btn--primary:hover{filter:brightness(1.1)}.btn--danger{background:var(--color-danger);border-color:var(--color-danger)}.btn--danger:hover{background:var(--color-danger-hover)}.btn--ghost{background:transparent;color:var(--color-accent);border-color:transparent}.btn--ghost:hover{background:#0000000d}.btn--outline{background:transparent;color:var(--color-text)}.btn--outline:hover{background:var(--color-surface-accent)}.btn--sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.btn--lg{padding:var(--space-3) var(--space-5);font-size:var(--font-size-md)}.btn--full{width:100%;justify-content:center}.btn--purple{background:#96f;border-color:#8a59f0;box-shadow:0 2px 8px #0000004d}.btn--purple:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 4px 12px #0006}.btn--red{background:#ff6b6b;border-color:#ff5a5a;box-shadow:0 2px 8px #0000004d}.btn--red:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 4px 12px #0006}.btn--green{background:#4caf50;border-color:#469c4a;box-shadow:0 2px 8px #0000004d}.btn--green:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 4px 12px #0006}.btn--gold{background:#ffc107;border-color:#e0ab00;color:#000;box-shadow:0 2px 6px #00000040}.btn--gold:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 4px 10px #00000059}.btn--orange{background:#ff8c00;border-color:#e67d00;box-shadow:0 4px 12px #ff8c004d}.btn--orange:hover{background:#f70;transform:translateY(-2px)}.btn--danger-alt{background:#dc3545;border-color:#c12d3b}.btn--danger-alt:hover{filter:brightness(1.05)}.btn--outline-alt{background:transparent;border:1px solid #888;color:var(--subtitle-color, #666)}.btn--outline-alt:hover{background:#646cff1a;color:var(--color-accent, #646cff)}.btn--lg2{padding:16px 32px;font-size:1.3rem;font-weight:700;border-radius:8px}.btn--icon{padding:4px 6px;min-width:28px;height:28px;font-size:14px;background:transparent;border:1px solid #ddd;color:#666}.btn--icon:hover{background:#f5f5f5;border-color:#999;color:#333}.btn--icon:active{background:#e5e5e5;transform:scale(.95)}@media (prefers-reduced-motion: reduce){.btn,.btn:hover{transition:none;transform:none!important}}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);position:relative}.panel--accent{background:var(--color-surface-accent)}.panel--danger{border-color:var(--color-danger)}.panel__header{margin:0 0 var(--space-3) 0;font-size:var(--font-size-md);font-weight:600;color:var(--color-text)}.panel__section+.panel__section{margin-top:var(--space-4)}.panel__footer{margin-top:var(--space-4);display:flex;gap:var(--space-3);justify-content:flex-end}.text-muted{color:var(--color-text-secondary)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-col{display:flex;flex-direction:column}.gap-xs{gap:var(--space-1)}.gap-sm{gap:var(--space-2)}.gap-md{gap:var(--space-3)}.gap-lg{gap:var(--space-4)}@media (prefers-color-scheme: dark){.panel{box-shadow:var(--shadow-sm)}}.overlay{position:fixed;inset:0;background:var(--color-overlay, rgba(0, 0, 0, .55));z-index:var(--z-overlay, 1000)}.overlay--center{display:flex;align-items:center;justify-content:center}.overlay--scroll{overflow:auto}.overlay[data-layer=top]{z-index:calc(var(--z-overlay, 1000) + 10)}.modal{background:var(--color-surface, #fff);color:var(--color-text, #222);border:1px solid var(--color-border, #d0d5da);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg);position:relative;padding:var(--space-4);max-width:600px;width:100%}.modal--narrow{max-width:420px}.modal--wide{max-width:900px}.modal--fill{max-width:90vw;max-height:90vh;display:flex;flex-direction:column}.modal--no-pad{padding:0}.modal__header{display:flex;align-items:center;justify-content:space-between;margin:0 0 var(--space-3) 0}.modal__title{font-size:var(--font-size-lg);font-weight:600;margin:0}.modal__body{flex:1;overflow:auto}.modal__footer{margin-top:var(--space-4);display:flex;justify-content:flex-end;gap:var(--space-3)}.modal__close{position:absolute;top:var(--space-3);right:var(--space-3)}.modal__body::-webkit-scrollbar{width:8px}.modal__body::-webkit-scrollbar-track{background:var(--color-bg-alt)}.modal__body::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:4px}@media (prefers-color-scheme: dark){.modal{border-color:var(--color-border, #3d444c)}}@media (prefers-reduced-motion: reduce){.modal{transition:none}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.app{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem}.app h1{color:#646cff;font-size:3.2em;line-height:1.1;margin-bottom:1rem}.app h2{color:#61dafb;font-size:2em;margin:0}.input-section{display:flex;flex-direction:column;gap:.5rem;align-items:center}.input-section label{font-size:1.1em;color:#888}.input-section input{padding:.5rem;font-size:1rem;border:2px solid #646cff;border-radius:8px;background:transparent;color:inherit;text-align:center;min-width:200px}@keyframes highlight-pulse{0%{background-color:#7f7f004d}50%{background-color:#ffff00e6}to{background-color:#7f7f004d}}.highlight-circle{animation:highlight-pulse 1.5s ease-in-out infinite}@keyframes selected-pulse{0%{background-color:#00ff00b3}50%{background-color:#00ff00e6}to{background-color:#00ff00b3}}.selected-circle{animation:selected-pulse 1.5s ease-in-out infinite}.input-section input:focus{outline:none;border-color:#61dafb;box-shadow:0 0 0 2px #61dafb4d}.info{color:#888;font-size:1em;line-height:1.6;max-width:600px;margin-top:2rem}:root{--title-color: #333;--text-color: #333;--modal-bg: #fff;--button-bg: #f0f0f0;--info-box-bg: #f0f8ff;--temple-box-bg: #f5f0ff;--dark-mode-filter: none;--border-color: #ddd;--input-bg: #fff;--subtitle-color: #666;--text-secondary: #666;--highlight-bg: #e9f4ff;--title-shadow: 4px 4px 6px rgba(0, 0, 0, .9);--color-bg: #f6f7f9;--color-bg-alt: #eef0f3;--color-surface: #ffffff;--color-surface-accent: #f0f6ff;--color-border: #d0d5da;--color-border-strong: #8b949e;--color-text: #1f2328;--color-text-secondary: #5c636a;--color-text-inverse: #ffffff;--color-accent: #646cff;--color-accent-hover: #5158ff;--color-accent-gradient: #646cff;--color-accent-gradient-end: #8892ff;--color-danger: #d92d20;--color-danger-hover: #b42318;--color-warning: #b54708;--color-success: #067647;--color-focus-ring: #1a7efb;--color-overlay: rgba(0, 0, 0, .55);--font-family-base: system-ui, Avenir, Helvetica, Arial, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--line-height-base: 1.4;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .12);--shadow-md: 0 2px 6px rgba(0, 0, 0, .18);--shadow-lg: 0 4px 10px rgba(0, 0, 0, .25);--transition-fast: .12s ease;--transition-base: .2s ease;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--z-base: 0;--z-overlay: 1000;--z-tooltip: 1100;--z-toast: 1200}@media (prefers-color-scheme: dark){:root{--title-color: #f0f0f0;--text-color: #e0e0e0;--modal-bg: #2a2a2a;--button-bg: #444;--info-box-bg: #3a4a5a;--temple-box-bg: #2a1f32;--dark-mode-filter: brightness(1.2);--border-color: #555;--input-bg: #3a3a3a;--subtitle-color: #bbb;--text-secondary: #aaa;--highlight-bg: #2a4a2a;--title-shadow: 0 0 20px rgba(100, 150, 255, .9), 0 0 20px rgba(100, 150, 255, .9), 0 0 30px rgba(100, 150, 255, .7);--color-bg: #1d2125;--color-bg-alt: #252b31;--color-surface: #2c333a;--color-surface-accent: #22303f;--color-border: #3d444c;--color-border-strong: #6b737c;--color-text: #e6eaf0;--color-text-secondary: #9aa4af;--color-text-inverse: #ffffff;--color-accent: #8892ff;--color-accent-hover: #9fa6ff;--color-accent-gradient: #5468ff;--color-accent-gradient-end: #8892ff;--color-danger: #f97066;--color-danger-hover: #f04438;--color-warning: #f79009;--color-success: #32d583;--color-focus-ring: #2e90fa;--color-overlay: rgba(0, 0, 0, .65);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 2px 6px rgba(0, 0, 0, .5);--shadow-lg: 0 4px 14px rgba(0, 0, 0, .55)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.desync-dialog-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.desync-dialog{background:#fff;padding:2rem;border-radius:8px;text-align:center;max-width:400px;box-shadow:0 4px 6px #0000001a}.desync-dialog h2{color:#dc3545;margin-bottom:1rem}.desync-dialog p{margin-bottom:1rem;color:#333}.desync-dialog button{background:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem}.desync-dialog button:hover{background:#0056b3}.movable-window{background:var(--background-color, var(--modal-bg, white));border:2px solid var(--border-color, #ccc);border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;min-width:200px;min-height:150px;overflow:hidden}.movable-window-header{background:var(--header-background, var(--button-bg, #007acc));color:var(--header-text-color, var(--text-color, white));padding:8px 12px;display:flex;justify-content:space-between;align-items:center;cursor:move;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border-color, #ddd);min-height:32px}.movable-window-header:hover{background:var(--header-background-hover, var(--highlight-bg, #0056a3))}.movable-window-title{font-weight:700;font-size:14px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.movable-window-header-actions{display:flex;align-items:center;gap:4px}.movable-window-close{background:none;border:none;color:inherit;cursor:pointer;font-size:18px;font-weight:700;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.movable-window-close:hover{background:var(--highlight-bg, rgba(255, 255, 255, .2))}.movable-window-close:active{background:var(--highlight-bg, rgba(255, 255, 255, .3))}.movable-window-content{flex:1 1 auto;display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden;color:var(--text-color, #333)}.movable-window-resize-handle{position:absolute;bottom:0;right:0;width:16px;height:16px;cursor:nw-resize;background:linear-gradient(-45deg,transparent 0%,transparent 40%,var(--border-color) 40%,var(--border-color) 50%,transparent 50%,transparent 60%,var(--border-color) 60%,var(--border-color) 70%,transparent 70%)}.movable-window-resize-handle:hover{background:linear-gradient(-45deg,transparent 0%,transparent 40%,var(--button-bg, #007acc) 40%,var(--button-bg, #007acc) 50%,transparent 50%,transparent 60%,var(--button-bg, #007acc) 60%,var(--button-bg, #007acc) 70%,transparent 70%)}.movable-window.dragging,.movable-window.resizing{-webkit-user-select:none;user-select:none}@media (max-width: 768px){.movable-window{max-width:calc(100vw - 40px);max-height:calc(100vh - 40px)}.movable-window-header{padding:6px 10px;min-height:28px}.movable-window-title{font-size:13px}.movable-window-close{width:20px;height:20px;font-size:16px}}.rules-component{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:14px;line-height:1.4}.dice-examples{margin:16px 0;padding:12px;background:#f9f9f9;border-radius:6px;border-left:4px solid #8B4513}.dice-examples h4{margin:0 0 8px;font-size:14px;color:#8b4513}.dice-example-row{display:flex;gap:16px}.dice-set{display:flex;align-items:center;gap:8px;padding:8px;background:#fff;border-radius:4px;border:1px solid #ddd}.die-image{width:24px;height:24px}.dice-total{font-weight:600;color:#8b4513;margin-left:8px}.special-squares-grid{display:grid;gap:16px}.special-square-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.square-icon{width:24px;height:24px;border:1px solid blue;padding:0}.capture-example{margin:16px 0;padding:12px;background:#fff8dc;border-radius:6px;border-left:4px solid #DAA520}.capture-example h4{margin:0 0 8px;font-size:14px;color:#daa520}.piece-interaction{display:grid;gap:8px}.before-capture,.capture-action,.after-capture{display:flex;align-items:center;gap:4px;font-size:13px}.piece-icon{width:20px;height:20px}.winning-visual{margin:16px 0;padding:12px;background:#f0f8ff;border-radius:6px;border-left:4px solid #4682B4}.winning-visual h4{margin:0 0 8px;font-size:14px;color:#4682b4}.pieces-in-treasury{display:flex;align-items:center;gap:8px;font-size:14px}.treasury-icon{width:28px;height:28px;border:1px solid blue;padding:0}.piece-count{font-weight:600;color:#8b4513}.victory-text{font-weight:600;color:#4682b4;font-size:16px}.board-overview-items{display:grid;gap:8px;margin-top:12px}.board-overview-item{padding:8px;background:#f9f9f9;border-radius:4px;border-left:3px solid #8B4513;font-size:13px}.edge-cases-list{display:grid;gap:16px}.edge-case-item{padding:12px;background:#fff8dc;border-radius:6px;border-left:4px solid #DAA520}.edge-case-situation{margin:0 0 6px;font-size:14px;font-weight:600;color:#daa520}.edge-case-resolution{margin:0;color:#333;font-size:13px}.rules-image-container{display:flex;justify-content:center;margin:12px 0}.rules-image{max-width:100%;height:auto;border-radius:4px}@media (max-width: 640px){.dice-set,.pieces-in-treasury,.special-square-header{flex-wrap:wrap}}.inline-square-icon{width:16px;height:16px;vertical-align:middle;margin:0 2px;border:1px solid blue;padding:0}.inline-piece-icon{width:16px;height:16px;vertical-align:middle;margin:0 2px;padding:0}.path-visualization{display:flex;justify-content:center;margin:16px 0}.board-container{position:relative;display:inline-block;max-width:100%}.board-image{width:100%;height:auto;max-width:600px;border:1px solid #ddd;border-radius:4px}.path-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.path-overlay.black-path{transform:scaleY(-1)}.rules-component ul,.rules-component li{text-align:left}.rules-window{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:14px;line-height:1.4;height:100%;display:flex;flex-direction:column}.rules-window{--background-primary: #ffffff !important;--background-secondary: #ffffff !important;--background-tertiary: #ffffff !important;--header-background: #ffffff !important;--header-background-hover: #f5f5f5 !important;--text-primary: #000000 !important;--text-secondary: #333333 !important;--primary-color: #000000 !important;--border-color: #cccccc !important;--hover-background: #f5f5f5 !important;--warning-background: #fff8dc;--warning-color: #000000 !important}.rules-window.movable-window{background:#fff!important;color:#000!important;box-shadow:0 2px 6px #00000026}.rules-window .movable-window-header{background:#fff!important;color:#000!important}.rules-window .movable-window-close:hover{background:#00000014!important}.rules-window .rules-section-title,.rules-window .rules-ruleset-name,.rules-window .quick-reference-label,.rules-window .board-overview-label,.rules-window .rules-subsection-title,.rules-window .special-square-name,.rules-window .edge-case-situation,.rules-window .rules-example-title{color:#000!important;border-color:#000!important}.rules-window .rules-section-separator{background:linear-gradient(to right,transparent,#000000,transparent)!important}.rules-window .rules-example,.rules-window .special-square-item,.rules-window .edge-case-item{border-color:#999!important;border-left-color:#000!important}.rules-window a.rules-more-info-link{color:#000!important;text-decoration:underline}.rules-window a.rules-more-info-link:hover{text-decoration:none}.rules-header-content{display:flex;align-items:center;gap:12px}.rules-subheader{background:var(--background-secondary, #f8f8f8);border-bottom:1px solid var(--border-color, #e0e0e0);padding:12px 16px;margin:-16px -16px 20px}.rules-ruleset-display{display:flex;align-items:center}.rules-ruleset-selector{display:flex;align-items:center;gap:12px}.rules-ruleset-label{font-weight:600;color:var(--text-primary, #333);white-space:nowrap}.rules-ruleset-dropdown{padding:6px 12px;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--background-primary, white);font-size:14px;color:var(--text-primary, #333);cursor:pointer;min-width:200px;transition:border-color .2s ease}.rules-ruleset-dropdown:hover{border-color:var(--primary-color, #8B4513)}.rules-ruleset-dropdown:focus{outline:none;border-color:var(--primary-color, #8B4513);box-shadow:0 0 0 2px #8b451333}.rules-window-content{padding:16px;flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--primary-color, #8B4513) var(--background-secondary, #f0f0f0);min-height:0;background:var(--background-primary, white);color:var(--text-primary, #333)}.rules-window-content::-webkit-scrollbar{width:8px}.rules-window-content::-webkit-scrollbar-track{background:var(--background-secondary, #f0f0f0)}.rules-window-content::-webkit-scrollbar-thumb{background:var(--primary-color, #8B4513);border-radius:4px}.rules-section-title{margin:0 0 12px;font-size:18px;font-weight:600;color:var(--primary-color, #8B4513);border-bottom:2px solid var(--primary-color, #8B4513);padding-bottom:4px}.rules-ruleset-name{margin:0;font-size:16px;font-weight:600;color:var(--primary-color, #8B4513)}.rules-section-separator{height:1px;background:linear-gradient(to right,transparent,var(--primary-color, #8B4513),transparent);margin:20px 0}.rules-quick-reference{margin-bottom:20px}.quick-reference-grid{display:grid;gap:8px;margin-bottom:16px}.quick-reference-item{display:grid;grid-template-columns:80px 1fr;gap:8px;align-items:start}.quick-reference-label{font-weight:600;color:var(--primary-color, #8B4513);text-align:right}.quick-reference-value{color:var(--text-primary, #333);text-align:left}.board-overview-title{margin:16px 0 8px;font-size:14px;font-weight:600;color:var(--primary-color, #8B4513)}.board-overview{display:grid;gap:6px}.board-overview-item{display:grid;grid-template-columns:80px 1fr;gap:8px;align-items:start}.board-overview-label{font-weight:600;color:var(--primary-color, #8B4513);text-align:right;font-size:12px}.board-overview-description{color:var(--text-secondary, #555);font-size:12px}.rules-detailed-section{margin-top:20px}.rules-subsection{margin-bottom:12px;border:1px solid var(--border-color, #e0e0e0);border-radius:6px;overflow:hidden}.rules-subsection-header{width:100%;background:var(--background-secondary, #f8f8f8);border:none;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;text-align:left;transition:background-color .2s;color:var(--text-primary, #333)}.rules-subsection-header:hover{background:var(--hover-background, #f0f0f0)}.rules-subsection-header:focus{outline:2px solid var(--primary-color, #8B4513);outline-offset:-2px}.rules-subsection-title{font-weight:600;color:var(--primary-color, #8B4513);font-size:14px}.rules-expand-icon{color:var(--primary-color, #8B4513);font-size:12px;transition:transform .2s}.rules-subsection-content{padding:16px;background:var(--background-primary, white)}.rules-description{margin:0 0 12px;color:var(--text-primary, #333)}.rules-list{margin:0;padding-left:20px;color:var(--text-primary, #333)}.rules-list-item{margin-bottom:6px}.special-square-item{margin-bottom:16px;padding:12px;background:var(--background-tertiary, #f9f9f9);border-radius:6px;border-left:4px solid var(--primary-color, #8B4513)}.special-square-item:last-child{margin-bottom:0}.special-square-name{margin:0 0 6px;font-size:14px;font-weight:600;color:var(--primary-color, #8B4513)}.special-square-description{margin:0 0 6px;color:var(--text-secondary, #555);font-size:13px}.special-square-effect{margin:0;color:var(--text-primary, #333);font-size:13px}.edge-case-item{margin-bottom:16px;padding:12px;background:var(--warning-background, #fff8dc);border-radius:6px;border-left:4px solid var(--warning-color, #DAA520)}.edge-case-item:last-child{margin-bottom:0}.edge-case-situation{margin:0 0 6px;font-size:14px;font-weight:600;color:var(--warning-color, #DAA520)}.edge-case-resolution{margin:0;color:var(--text-primary, #333);font-size:13px}.rules-example{margin-bottom:20px;padding:16px;background:var(--info-background, #f0f8ff);border-radius:8px;border:1px solid #4682B4}.rules-example:last-child{margin-bottom:0}.rules-example-title{margin:0 0 8px;font-size:14px;font-weight:600;color:#4682b4}.rules-example-description{margin:0 0 12px;color:#333;font-size:13px}.rules-example-states{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;margin-bottom:12px}.rules-example-state{padding:8px;background:#fff;border-radius:4px;border:1px solid #4682B4}.rules-example-state-label{margin:0 0 4px;font-size:12px;font-weight:600;color:#4682b4}.rules-example-state-description{margin:0;font-size:12px;color:#333}.rules-example-arrow{font-size:18px;color:#4682b4;font-weight:700;text-align:center}.rules-example-explanation{font-size:13px;color:#333;padding:8px;background:#4682b41a;border-radius:4px}@media (max-width: 640px){.rules-window{width:calc(100vw - 40px);max-width:none;left:20px!important;right:20px}.quick-reference-item,.board-overview-item{grid-template-columns:1fr;gap:4px}.quick-reference-label,.board-overview-label{text-align:left;font-size:12px}.rules-example-states{grid-template-columns:1fr;gap:8px}.rules-example-arrow{transform:rotate(90deg)}}@media (prefers-reduced-motion: reduce){.rules-expand-icon,.rules-window-close{transition:none}}@media (prefers-contrast: high){.rules-window{border-color:#000}.rules-window-header{background:#000}.rules-section-title,.rules-subsection-title,.special-square-name,.edge-case-situation,.rules-example-title{color:#000}}.path-diagrams{margin-top:16px;display:grid;gap:16px}.path-diagram{background:#f9f9f9;border-radius:8px;padding:12px;border:1px solid #e0e0e0}.path-diagram-title{margin:0 0 8px;font-size:14px;font-weight:600;color:#8b4513;text-align:center}.path-diagram-container{display:flex;justify-content:center}.path-diagram-board{position:relative;max-width:400px;width:100%}.path-diagram-board-image{width:100%;height:auto;display:block;border-radius:4px}.path-diagram-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.path-diagram-overlay.flipped-y{transform:scaleY(-1)}.rules-more-info{margin-top:16px;padding:12px 16px;border-top:1px solid var(--border-color, #e0e0e0);text-align:center;background:var(--background-secondary, #f9f9f9)}.rules-more-info-link{color:var(--primary-color, #8B4513);text-decoration:none;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--primary-color, #8B4513);border-radius:6px;background:var(--background-primary, white);transition:all .2s ease}.rules-more-info-link:hover{background:var(--primary-color, #8B4513);color:var(--background-primary, white);text-decoration:none;transform:translateY(-1px);box-shadow:0 2px 8px #8b45134d}.rules-more-info-link:active{transform:translateY(0);box-shadow:0 1px 4px #8b45134d}@media (max-width: 640px){.path-diagram-board{max-width:300px}.path-diagram-title{font-size:13px}.rules-more-info-link{font-size:13px;padding:6px 12px}}.piece-editor{background:var(--modal-bg, #f8f9fa);color:var(--text-color, #333);border-radius:12px;padding:24px;max-width:600px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.piece-editor-header{text-align:center;margin-bottom:24px}.piece-editor-header h3{margin:0 0 8px;color:var(--title-color, #2c3e50);font-size:1.5rem}.piece-editor-header p{margin:0;color:var(--text-secondary, #6c757d);font-size:.95rem}.theme-selector{margin-bottom:32px;text-align:center}.theme-selector label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-color, #495057);font-size:1rem}.theme-selector-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.theme-dropdown{padding:12px 16px;border:2px solid var(--border-color, #dee2e6);border-radius:8px;font-size:1rem;background:var(--input-bg, white);color:var(--text-color, #333);cursor:pointer;transition:border-color .2s;min-width:200px}.theme-dropdown:disabled{opacity:.6;cursor:not-allowed}.save-status{font-size:.9rem;font-weight:500;padding:4px 8px;border-radius:4px;white-space:nowrap}.save-status.saving{color:#007bff;background:#007bff1a}.guest-notice{font-size:.85rem;color:var(--text-secondary, #6c757d);font-style:italic;margin:0}.theme-dropdown:hover{border-color:#007bff}.theme-dropdown:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.piece-preview-section h4{text-align:center;margin:0 0 20px;color:var(--text-color, #495057);font-size:1.2rem;font-weight:600}.piece-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}.player-section h5{text-align:center;margin:0 0 16px;color:var(--text-secondary, #6c757d);font-size:1rem;font-weight:500}.piece-pair{display:flex;justify-content:center;gap:20px}.piece-preview{display:flex;flex-direction:column;align-items:center;gap:8px}.piece-preview img{width:64px;height:64px;border:3px solid var(--border-color, #ffffff);border-radius:8px;box-shadow:0 2px 8px #0000001a;background:var(--input-bg, white);transition:transform .2s}.piece-preview img:hover{transform:scale(1.05)}.piece-label{font-size:.85rem;color:var(--text-secondary, #6c757d);font-weight:500;text-align:center}@media (max-width: 768px){.piece-editor{padding:16px;margin:0 16px}.piece-grid{grid-template-columns:1fr;gap:24px}.piece-pair{gap:16px}.piece-preview img{width:56px;height:56px}}.piece-editor-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color, #dee2e6)}.save-button,.cancel-button{padding:10px 20px;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:80px}.save-button{background:#28a745;color:#fff}.save-button:hover:not(:disabled){background:#218838}.save-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.7}.cancel-button{background:#6c757d;color:#fff}.cancel-button:hover:not(:disabled){background:#5a6268}.cancel-button:disabled{cursor:not-allowed;opacity:.7}.piece-editor-window{--_piece-editor-window: 1}.piece-editor-window .movable-window-header{background:var(--panel-header-bg, var(--color-surface-alt));color:var(--panel-header-fg, var(--color-text))}.piece-editor-window-content{padding:0 0 4px;background:var(--modal-bg, var(--color-surface))}.piece-editor-window-content .piece-editor{max-width:100%;box-shadow:none;margin:0}.achievement-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.achievement-modal-content{background:var(--modal-bg);border-radius:12px;width:100%;max-width:900px;max-height:80vh;overflow:hidden;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column}.achievement-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color);background:var(--button-bg)}.achievement-modal-header h2{margin:0;color:var(--text-color);font-size:24px;font-weight:600}.achievement-modal-close{background:none;border:none;font-size:28px;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.achievement-modal-close:hover{background-color:var(--border-color);color:var(--text-color)}.achievement-stats-summary{display:flex;gap:24px;padding:16px 20px;background:var(--button-bg);border-bottom:1px solid var(--border-color)}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:12px;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:18px;font-weight:600;color:var(--text-color)}.achievement-modal-body{flex:1;overflow-y:auto;padding:20px}.achievement-loading{text-align:center;padding:40px;color:var(--text-secondary);font-size:16px}.achievement-not-signed-in{text-align:center;padding:40px;color:var(--text-secondary)}.achievement-not-signed-in p{font-size:16px;margin:0}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.achievement-card{background:var(--modal-bg);border:2px solid var(--border-color);border-radius:8px;padding:16px;transition:all .2s ease;display:flex;gap:12px;position:relative}.achievement-card:hover{border-color:var(--border-color);box-shadow:0 4px 12px #0000001a}.achievement-card.completed{border-color:#28a745;background:var(--info-box-bg)}.achievement-card.incomplete{border-color:var(--border-color);background:var(--modal-bg)}.achievement-card.new-achievement{border-color:#ffc107;background:linear-gradient(135deg,#fff9c4,#fff3cd);animation:newAchievementGlow 2s ease-in-out infinite alternate;box-shadow:0 0 20px #ffc1074d}.achievement-card.new-achievement:hover{border-color:#ffc107;box-shadow:0 4px 20px #ffc10766}.new-achievement-badge{position:absolute;top:-8px;right:-8px;background:linear-gradient(45deg,#ff6b6b,#ffd93d);color:#fff;font-size:10px;font-weight:700;padding:4px 8px;border-radius:12px;box-shadow:0 2px 8px #0003;z-index:10;animation:newBadgePulse 1.5s ease-in-out infinite}@keyframes newAchievementGlow{0%{box-shadow:0 0 15px #ffc1074d}to{box-shadow:0 0 25px #ffc10780}}@keyframes newBadgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.unlock-date{font-size:11px;color:#856404;font-weight:500;background:#ffc10733;padding:2px 6px;border-radius:4px;margin-left:8px}.new-achievements-count{background:linear-gradient(45deg,#ff6b6b,#ffd93d);border-radius:8px;padding:4px 8px!important}.new-achievements-count .stat-label,.new-achievements-count .stat-value{color:#fff!important;font-weight:700}.achievement-icon{font-size:32px;display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--button-bg);border-radius:8px;flex-shrink:0}.achievement-card.completed .achievement-icon{background:#d4edda}.achievement-info{flex:1;display:flex;flex-direction:column;gap:8px}.achievement-name{margin:0;font-size:16px;font-weight:600;color:var(--text-color);line-height:1.2}.achievement-description{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.4}.achievement-meta{display:flex;justify-content:space-between;align-items:center;gap:8px}.achievement-points{font-size:12px;font-weight:600;color:var(--text-color);background:var(--button-bg);padding:2px 6px;border-radius:4px}.achievement-progress{display:flex;flex-direction:column;gap:4px}.progress-text{font-size:12px;color:var(--text-secondary);font-weight:500}.progress-bar{height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:#007bff;border-radius:2px;transition:width .3s ease}.achievement-card.completed .progress-fill{background:#28a745}@media (max-width: 768px){.achievement-modal-overlay{padding:10px}.achievement-modal-content{max-height:90vh}.achievements-grid{grid-template-columns:1fr;gap:12px}.achievement-card{padding:12px}.achievement-stats-summary{flex-direction:column;gap:12px}.stat-item{flex-direction:row;justify-content:space-between;align-items:center}}.achievement-modal-footer{padding:20px;border-top:1px solid var(--border-color);background:var(--button-bg);display:flex;justify-content:center}.reset-achievements-btn{background:#dc3545;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.reset-achievements-btn:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 4px 8px #dc35454d}.reset-achievements-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.refresh-achievements-btn{background:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.refresh-achievements-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-1px);box-shadow:0 3px 6px #007bff4d}.refresh-achievements-btn:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.achievement-status{text-align:center;padding:8px 20px;background:var(--button-bg);border-bottom:1px solid var(--border-color)}.achievement-status small{color:var(--text-secondary);font-size:12px}.turn-log-window{font-family:Courier New,monospace;width:260px!important;max-width:260px!important;min-width:260px!important}.turn-log-window.dragging,.turn-log-window.resizing{-webkit-user-select:none;user-select:none}.turn-log-window .movable-window-content{overflow:hidden!important}.turn-log-content-wrapper{overflow:hidden!important;display:flex;flex-direction:column;height:100%;min-height:0}.export-button{background:none;border:none;color:var(--text-color, #ccc);cursor:pointer;padding:4px 8px;border-radius:4px;font-size:12px;transition:all .2s ease}.export-button:hover{background:var(--highlight-bg, #4a4a4a);color:#4caf50}.turn-log-content{flex:1;overflow:hidden;padding:12px;font-size:11px;line-height:1.3;display:flex;flex-direction:column;min-height:0}.log-info{background:var(--info-box-bg, #333);color:var(--text-color, white);padding:8px;border-radius:4px;margin-bottom:12px;font-size:10px;border-left:3px solid #4caf50}.log-info div{margin:2px 0}.log-turns{border:1px solid var(--border-color, #444);border-radius:4px;background:var(--input-bg, #1e1e1e);flex:1;overflow:auto;min-height:0;position:relative;scrollbar-gutter:stable;overscroll-behavior:contain}.turns-table{width:100%;font-size:11px;border-collapse:separate;border-spacing:0;table-layout:fixed}.turns-table thead{position:sticky;top:0;z-index:1}.turns-table thead tr,.turns-table tbody tr{display:table-row}.turns-table th{background:var(--button-bg, #333);color:var(--text-color, #ccc);padding:8px;text-align:left;border-bottom:2px solid var(--border-color, #555);font-weight:700;flex-shrink:0;overflow:hidden;min-width:0}.turns-table th:first-child,.turns-table td:first-child{width:25%}.turns-table th:nth-child(2),.turns-table td:nth-child(2){width:20%}.turns-table th:last-child,.turns-table td:last-child{width:55%}.turns-table td{padding:6px 8px;border-bottom:1px solid var(--border-color, #333);color:var(--text-color, white);vertical-align:top;text-align:left;flex-shrink:0;overflow:hidden;word-wrap:break-word;min-width:0}.turns-table tr:last-child td{border-bottom:none}.turns-table tr:hover{background:var(--highlight-bg, rgba(255, 255, 255, .05))}.turns-table tr.completed{opacity:1}.turns-table tr.dice-rolled{background:#ffc1071a}.turns-table tr.new{background:#2196f31a}.turns-table tr.white{border-left:3px solid #f5f5f5}.turns-table tr.black{border-left:3px solid #424242}.turn-cell{font-weight:500}.roll-cell{font-family:Courier New,monospace;color:#4caf50}.move-cell{color:#81c784}.turn-row{padding:2px 8px;border-bottom:1px solid var(--border-color, #333);transition:background-color .1s ease}.turn-row:last-child{border-bottom:none}.turn-row:hover{background:var(--highlight-bg, rgba(255, 255, 255, .05))}.turn-row.completed{opacity:1}.turn-row.dice-rolled{background:#ffc1071a}.turn-row.new{background:#2196f31a}.turn-row.white{border-left:3px solid #f5f5f5}.turn-row.black{border-left:3px solid #424242}.turn-row code{font-family:inherit;background:none;color:inherit;font-size:inherit;white-space:nowrap}.turn-notes{font-size:10px;color:var(--text-secondary, #aaa);font-style:italic;margin-top:2px;padding-left:12px}.no-turns,.no-log{text-align:center;color:var(--text-secondary, #666);padding:20px;font-style:italic}.log-turns::-webkit-scrollbar{width:10px}.log-turns::-webkit-scrollbar-track{background:var(--input-bg, #1a1a1a)}.log-turns::-webkit-scrollbar-thumb{background:var(--border-color, #555);border-radius:6px}.log-turns::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #777)}.log-turns{scrollbar-width:thin;scrollbar-color:var(--border-color, #555) var(--input-bg, #1a1a1a)}.turn-log-content::-webkit-scrollbar{display:none}
