: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}}.ccp-slider{width:100%;-webkit-appearance:none;appearance:none;height:10px;border-radius:6px;background:var(--gradient, #ccc);outline:none;cursor:pointer;position:relative}.ccp-slider::-webkit-slider-runnable-track{height:10px;border-radius:6px;background:var(--gradient, #ccc);border:1px solid #bbb}.ccp-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #333;box-shadow:0 0 2px #0006;margin-top:-4px}.ccp-slider:focus::-webkit-slider-thumb{outline:2px solid #0078d4}.ccp-slider::-moz-range-track{height:10px;border-radius:6px;background:var(--gradient, #ccc);border:1px solid #bbb}.ccp-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #333;box-shadow:0 0 2px #0006}.ccp-slider::-moz-range-progress{background:transparent}.ccp-slider::-ms-track{height:10px;border-radius:6px;background:transparent;border-color:transparent;color:transparent}.ccp-slider::-ms-fill-lower,.ccp-slider::-ms-fill-upper{background:var(--gradient, #ccc);border:1px solid #bbb;border-radius:6px}.ccp-slider::-ms-thumb{width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #333}._editorShell_1ngax_1{display:flex;gap:20px;align-items:flex-start}._panels_1ngax_13{flex:1 1 auto;min-height:320px}._previewPane_1ngax_23{width:200px;flex:0 0 200px;border-left:1px solid #e2e2e2;padding-left:12px}._tabBar_1ngax_37{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap}._tabButton_1ngax_51{background:var(--pe-bg-alt);border:1px solid var(--pe-border);padding:6px 12px;border-radius:var(--pe-button-radius, 6px);font-size:.75rem;font-weight:600;cursor:pointer;position:relative;color:var(--pe-text);transition:background .15s,border-color .15s,color .15s}._tabButton_1ngax_51:hover:not([aria-disabled=true]){background:var(--pe-bg-alt-hover)}._tabActive_1ngax_85{background:var(--pe-accent);color:var(--pe-accent-text, #fff);border-color:var(--pe-accent-hover)}._pieceTile_1ngax_99{text-align:center;font-size:.6rem}@media (max-width: 900px){._editorShell_1ngax_1{flex-direction:column}._previewPane_1ngax_23{width:100%;border-left:none;border-top:1px solid #e2e2e2;padding-left:0;padding-top:12px}}:root{--pe-bg: #ffffff;--pe-bg-alt: #f5f7fa;--pe-bg-alt-hover: #eef2f7;--pe-border: #cfd4dc;--pe-border-strong: #a8b0bb;--pe-border-soft: #e2e6eb;--pe-text: #1e2329;--pe-text-soft: #555e68;--pe-accent: #2d79ff;--pe-accent-hover: #1e5fcc;--pe-accent-text: #ffffff;--pe-danger: #d33;--pe-focus-ring: 2px solid #2d79ff66;--pe-tile-bg: #ffffff;--pe-button-radius: 6px;--pe-shadow: 0 6px 18px rgba(0, 0, 0, .18)}@media (prefers-color-scheme: dark){:root{--pe-bg: #1e1f22;--pe-bg-alt: #272a30;--pe-bg-alt-hover: #31363d;--pe-border: #3a4048;--pe-border-strong: #4c5560;--pe-border-soft: #30353b;--pe-text: #f2f4f6;--pe-text-soft: #a9b2bd;--pe-accent: #5590ff;--pe-accent-hover: #3479ef;--pe-accent-text: #ffffff;--pe-danger: #ff6b6b;--pe-focus-ring: 2px solid #5590ff66;--pe-tile-bg: #202328;--pe-shadow: 0 6px 18px rgba(0, 0, 0, .6)}}.pe-surface{background:var(--pe-bg);color:var(--pe-text)}.pe-surface-alt{background:var(--pe-bg-alt)}.pe-border{border:1px solid var(--pe-border)}.pe-btn-base{border:1px solid var(--pe-border);background:var(--pe-bg-alt);color:var(--pe-text);border-radius:var(--pe-button-radius);cursor:pointer;font-size:.75rem;font-weight:600;line-height:1.1;padding:6px 12px;transition:background .15s,border-color .15s,color .15s,box-shadow .15s}.pe-btn-base:hover:not([aria-disabled=true]){background:var(--pe-bg-alt-hover)}.pe-btn-base:focus-visible{outline:var(--pe-focus-ring);outline-offset:2px}.pe-btn-accent{background:var(--pe-accent);border-color:var(--pe-accent);color:var(--pe-accent-text)}.pe-btn-accent:hover{background:var(--pe-accent-hover);border-color:var(--pe-accent-hover)}.pe-tab-btn{position:relative;border:1px solid var(--pe-border);background:var(--pe-bg-alt);color:var(--pe-text);border-radius:var(--pe-button-radius);cursor:pointer;font-size:.75rem;font-weight:600;line-height:1.1;padding:6px 12px;transition:background .15s,border-color .15s,color .15s,box-shadow .15s}.pe-tab-btn:hover:not([aria-disabled=true]){background:var(--pe-bg-alt-hover)}.pe-tab-btn:focus-visible{outline:var(--pe-focus-ring);outline-offset:2px}.pe-tab-btn[aria-selected=true]{background:var(--pe-accent);color:var(--pe-accent-text);border-color:var(--pe-accent-hover)}.pe-tab-btn.locked{opacity:.55;cursor:not-allowed}.pe-theme-btn{border:1px solid var(--pe-border);background:var(--pe-tile-bg);padding:6px 6px 7px;border-radius:var(--pe-button-radius);cursor:pointer;text-align:left;line-height:1.1;font-size:.72rem;transition:background .15s,border-color .15s}.pe-theme-btn:hover{background:var(--pe-bg-alt-hover)}.pe-theme-btn.active{border:2px solid var(--pe-accent)}.pe-shape-btn{padding:6px 10px;border-radius:4px;border:1px solid var(--pe-border);background:var(--pe-tile-bg);cursor:pointer;font-size:.7rem;display:flex;align-items:center;gap:4px;transition:background .15s,border-color .15s,color .15s}.pe-shape-btn.active{border:2px solid var(--pe-accent)}.pe-shape-btn:hover{background:var(--pe-bg-alt-hover)}.pe-emoji-btn{padding:4px 0;border-radius:6px;border:1px solid var(--pe-border-strong);background:var(--pe-tile-bg);cursor:pointer;font-size:1.1rem;line-height:1.1;text-align:center;transition:background .15s,border-color .15s,transform .08s}.pe-emoji-btn:hover{background:var(--pe-bg-alt-hover)}.pe-emoji-btn.active{border:2px solid var(--pe-accent)}.pe-emoji-btn:active{transform:scale(.92)}:root{--ccp-panel-bg: var(--pe-bg);--ccp-panel-border: var(--pe-border);--ccp-panel-shadow: var(--pe-shadow);--ccp-panel-divider: var(--pe-border-soft);--ccp-panel-text: var(--pe-text);--ccp-panel-subtext: var(--pe-text-soft);--ccp-slider-track: var(--pe-bg-alt)}.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}.achievement-card.new-achievement:hover{border-color:#fd5}.new-achievement-badge{position:absolute;top:-10px;right:-10px;background:linear-gradient(135deg,#ff6b6b,#ffb347 40%,#ffd93d);color:#fff;font-size:13px;font-weight:700;padding:8px 14px;border-radius:18px;box-shadow:0 4px 14px #0000004d;z-index:10;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.4);animation:newBadgeSwing 2.2s ease-in-out infinite;transform-origin:50% 60%;will-change:transform;pointer-events:none}@keyframes newBadgeSwing{0%{transform:rotate(-10deg) scale(1)}25%{transform:rotate(0) scale(1.06)}50%{transform:rotate(10deg) scale(1.12)}75%{transform:rotate(0) scale(1.06)}to{transform:rotate(-10deg) scale(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}
