:root{--stone-50: #fafaf9;--stone-100: #f5f5f4;--stone-200: #e7e5e4;--stone-300: #d6d3d1;--stone-400: #a8a29e;--stone-500: #78716c;--stone-600: #57534e;--stone-700: #44403c;--stone-800: #292524;--stone-900: #1c1917;--stone-950: #0c0a09;--highlight-pink-bg: #f6d5dc;--highlight-pink-border: #be5f78;--highlight-pink-ring: rgb(190 95 120 / 42%);color:var(--stone-900);background:var(--stone-100);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}.app-shell{width:min(1240px,calc(100vw - 20px));margin:0 auto;padding:10px 0 24px}.sim-shell{width:100vw;min-height:100vh;overflow:hidden;background:#131614}.eyebrow{margin:0 0 4px;color:var(--stone-600);font-size:.68rem;font-weight:700;letter-spacing:0;text-transform:uppercase}h1,h2,h3,p{margin-top:0}h1{margin-bottom:0;font-size:1.25rem;line-height:.95;letter-spacing:0}h2{margin-bottom:0;font-size:1rem;line-height:1.15;letter-spacing:0}h3{margin-bottom:5px;color:var(--stone-600);font-size:.68rem;letter-spacing:0;text-transform:uppercase}.primary-button,.secondary-button,.step-controls button,.view-toggle button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:30px;border:1px solid var(--stone-300);border-radius:6px;background:var(--stone-50);color:var(--stone-900);font-size:.78rem;font-weight:700}.primary-button,.secondary-button{padding:0 10px}.primary-button{background:var(--stone-800);border-color:var(--stone-800);color:var(--stone-50)}.controls-band{display:grid;grid-template-columns:minmax(150px,230px) auto auto auto minmax(190px,1fr);align-items:end;gap:8px;padding:0 0 10px;border-bottom:1px solid var(--stone-300)}.seed-field,.timeline{display:grid;gap:4px;color:var(--stone-600);font-size:.68rem;font-weight:700;text-transform:uppercase}.seed-field input{width:100%;min-height:30px;padding:0 8px;border:1px solid var(--stone-300);border-radius:6px;background:var(--stone-50);color:var(--stone-900);font-size:.78rem;text-transform:none}.step-controls{display:flex;gap:5px}.step-controls button{width:32px;padding:0}.view-toggle{display:inline-flex;align-self:end;overflow:hidden;min-inline-size:0;min-height:30px;margin:0;padding:0;border:1px solid var(--stone-300);border-radius:6px;background:var(--stone-50)}.view-toggle button{min-height:28px;padding:0 9px;border:0;border-radius:0;background:transparent}.view-toggle button+button{border-left:1px solid var(--stone-300)}.view-toggle button.active{background:var(--stone-800);color:var(--stone-50)}.timeline input{width:100%;accent-color:var(--stone-800)}.timeline span{display:block;width:100%;padding-inline:2px}.generation-pill{position:fixed;top:8px;left:50%;z-index:20;max-width:min(520px,calc(100vw - 32px));padding:6px 10px;transform:translate(-50%);border:1px solid var(--stone-300);border-radius:999px;background:var(--stone-50);box-shadow:0 8px 24px #1c19171f;color:var(--stone-600);font-size:.76rem;font-weight:700;line-height:1.2;text-align:center}.generation-pill.error{border-color:var(--stone-500);background:var(--stone-200);color:var(--stone-800)}.perf-panel{position:fixed;right:12px;bottom:12px;z-index:30;display:grid;gap:8px;width:min(280px,calc(100vw - 24px));padding:10px;border:1px solid rgb(245 245 244 / 18%);border-radius:6px;background:#131614d6;box-shadow:0 10px 30px #00000047;color:var(--stone-100);font-size:.72rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.perf-panel header{display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--stone-50);font-weight:800;text-transform:uppercase}.perf-panel header span,.perf-panel dd{font-variant-numeric:tabular-nums}.perf-panel dl{display:grid;grid-template-columns:1fr 1fr;gap:5px 10px;margin:0}.perf-panel dl div{display:grid;min-width:0;gap:2px}.perf-panel dt{overflow:hidden;color:var(--stone-400);font-size:.64rem;font-weight:800;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.perf-panel dd{min-width:0;margin:0;overflow:hidden;color:var(--stone-50);font-size:.76rem;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.perf-panel-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.perf-panel button{min-height:26px;padding:0 7px;border:1px solid rgb(255 255 255 / 22%);border-radius:4px;background:#ffffff14;color:var(--stone-100);font-size:.68rem;font-weight:800}.perf-panel button:hover,.perf-panel button:focus-visible{background:#ffffff29}.viewer-shell{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:12px;padding:12px 0}.three-viewer{position:relative;height:min(760px,calc(100vh - 96px));min-height:520px;margin-top:10px;overflow:hidden;border-radius:6px;background:#131614}.sim-shell .three-viewer{width:100vw;height:100vh;min-height:100vh;margin:0;border-radius:0}.three-viewer canvas{display:block}.three-r3f-canvas{width:100%;height:100%;background:#101514}.three-loading-overlay{position:absolute;inset:0;z-index:4;display:grid;place-items:center;background:#131614;color:var(--stone-300);font-size:.82rem;font-weight:800;letter-spacing:.02em;text-transform:uppercase}.screensaver-shell .three-loading-overlay{color:#131614}.table-flip-controls{position:absolute;top:14px;left:14px;z-index:5;display:flex;gap:8px;align-items:center;padding:8px;border:1px solid rgb(245 245 244 / 14%);border-radius:8px;background:#131614c7;box-shadow:0 8px 22px #0000003d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);margin:0}.table-flip-controls button{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border:1px solid rgb(245 245 244 / 18%);border-radius:6px;background:#f5f5f41a;color:#f5f5f4e0;font-size:.78rem;font-weight:800}.table-flip-controls .primary-button{border-color:#f5f5f414;background:#f5f5f4eb;color:#131614f0}.table-flip-controls button:hover:not(:disabled),.table-flip-controls button:focus-visible:not(:disabled){background:#f5f5f42e}.table-flip-controls .primary-button:hover:not(:disabled),.table-flip-controls .primary-button:focus-visible:not(:disabled){background:#fffffffa}.three-debug-panel.table-flip-debug-panel{top:10px;right:44px;width:250px}.round-transition-overlay{position:absolute;inset:0;z-index:3;pointer-events:none;background:#0f1112;opacity:0;transition:opacity .62s ease-in-out}.round-transition-overlay.active{opacity:1}.three-debug-panel{position:absolute;right:10px;top:48px;z-index:5;display:grid;gap:7px;width:230px;max-height:calc(100% - 58px);overflow-y:auto;padding:9px;border:1px solid rgb(255 255 255 / 18%);border-radius:6px;background:#131614c7;box-shadow:0 10px 30px #00000042;color:var(--stone-100);font-size:.72rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.three-debug-panel header,.three-debug-panel label span{display:flex;align-items:center;justify-content:space-between;gap:8px}.three-debug-panel header{color:var(--stone-100);font-weight:800;letter-spacing:.02em;text-transform:uppercase}.three-debug-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px}.three-debug-panel button{min-height:22px;padding:0 7px;border:1px solid rgb(255 255 255 / 22%);border-radius:4px;background:#ffffff14;color:var(--stone-100);font-size:.68rem;font-weight:700}.three-debug-tabs button.active{background:var(--stone-100);color:var(--stone-900)}.three-debug-panel label{display:grid;gap:3px;color:var(--stone-200);font-weight:700}.three-debug-panel strong{color:var(--stone-50);font-variant-numeric:tabular-nums}.three-debug-panel input{width:100%;accent-color:#d2b16f}.three-debug-toggle{grid-template-columns:1fr auto;align-items:center}.three-debug-toggle input{width:auto}.three-viewer.loading{display:grid;place-items:center;color:var(--stone-300);font-size:.82rem;font-weight:700}.screensaver-shell .three-viewer.loading{color:#131614}.round-loading{display:grid;min-height:420px;margin-top:12px;place-items:center;border:1px solid var(--stone-300);border-radius:6px;background:var(--stone-50);color:var(--stone-600);font-size:.82rem;font-weight:700;text-transform:uppercase}.event-rail{display:grid;align-content:start;gap:8px;min-width:0}.event-panel{min-width:0}.event-panel header{display:flex;align-items:baseline;min-height:18px;margin-bottom:5px}.event-title{display:flex;align-items:center;flex-wrap:wrap;gap:4px;min-height:24px;color:var(--stone-900);font-size:.88rem;font-weight:700;line-height:1.25}.event-panel p{max-width:64ch;color:var(--stone-700);font-size:.82rem;line-height:1.35}.event-panel>p:not(.eyebrow){min-height:32px;margin-bottom:0}.event-list{display:grid;align-content:start;max-height:238px;overflow:auto;border:1px solid var(--stone-300);border-radius:6px;background:var(--stone-50)}.rules-error{padding:10px;border:1px solid var(--stone-500);border-radius:6px;background:var(--stone-200)}.rules-error p:last-child{margin-bottom:0}.event-group{display:grid}.event-group-header{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:30px;padding:6px 8px;border:0;border-bottom:1px solid var(--stone-300);background:var(--stone-200);color:var(--stone-900);font-size:.78rem;text-align:left}.event-group-header span{color:var(--stone-600);font-size:.7rem;font-weight:700}.event-group-header strong{color:var(--stone-600);font-size:.72rem;font-weight:700}.event-group-header.active{background:var(--stone-300)}.event-row{display:grid;grid-template-columns:34px 1fr;gap:6px;align-items:center;width:100%;min-height:30px;padding:5px 8px;border:0;border-bottom:1px solid var(--stone-200);background:transparent;color:var(--stone-900);font-size:.76rem;text-align:left}.event-row strong{display:inline-flex;align-items:center;flex-wrap:wrap;gap:4px}.event-panel p:not(.eyebrow){display:flex;align-items:center;flex-wrap:wrap;gap:4px}.event-row:last-child{border-bottom:0}.event-row span{color:var(--stone-500);font-variant-numeric:tabular-nums}.event-row.active{background:var(--stone-200)}.table-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.player-panel,.wall-panel{min-width:0;padding:10px;border-radius:6px;background:var(--stone-50)}.wall-panel header{display:flex;align-items:baseline;justify-content:space-between;gap:10px;min-height:18px;margin-bottom:5px}.wall-panel header span{color:var(--stone-600);font-size:.78rem;font-weight:700}.player-panel header{display:flex;align-items:baseline;margin-bottom:6px}.player-tile-rows{display:grid;gap:8px}.player-tile-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(86px,max-content);gap:10px;align-items:start}.tile-group{min-width:0}.dead-wall-group{margin-top:8px}.flowers-group{grid-column:2}.player-tile-row>.tile-group:only-child:not(.flowers-group){grid-column:1 / -1}.tiles{display:flex;flex-wrap:wrap;gap:4px;min-height:24px}.tile{display:inline-flex;align-items:center;justify-content:center;position:relative;width:28px;height:38px;padding:0;border:1px solid var(--stone-900);border-radius:5px;background:var(--stone-50);font-size:.72rem;font-weight:800}.muted-tile-group .tile{opacity:.4}.tile img{display:block;width:100%;height:100%;object-fit:contain}.tile.highlighted{border-color:var(--highlight-pink-border);background:var(--highlight-pink-bg);box-shadow:0 0 0 2px var(--highlight-pink-ring)}.muted-tile-group .tile.highlighted{opacity:1}.inline-tile{display:inline-flex;align-items:center;justify-content:center;width:17px;height:23px;border:1px solid var(--stone-900);border-radius:3px;background:var(--stone-50);vertical-align:middle}.inline-tile img{display:block;width:100%;height:100%;object-fit:contain}.empty{color:var(--stone-500);font-size:.78rem;line-height:24px}.info-button{position:fixed;right:10px;top:10px;z-index:30;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border:0;border-radius:999px;background:var(--stone-50);box-shadow:0 6px 18px #1c19171f;color:var(--stone-600);outline:0}.info-popover-controls{opacity:1;transition:opacity .22s ease}.info-popover-controls.is-hidden{opacity:0;pointer-events:none}.auto-orbit-button{right:44px}.mac-download-callout{position:fixed;top:10px;left:10px;z-index:30;display:inline-flex;align-items:center;max-width:calc(100vw - 64px);min-height:26px;padding:3px 4px 3px 0;color:#f5f5f4b8;font-size:.72rem;font-weight:700;line-height:1;opacity:1;transition:color .16s ease,opacity .22s ease}.mac-download-callout.is-hidden{opacity:0;pointer-events:none}.mac-download-callout:hover,.mac-download-callout:focus-within{color:#f5f5f4e5}.mac-download-callout a{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-height:20px;padding:0 7px;border:0;border-radius:999px;background:transparent;color:inherit;font-size:.68rem;font-weight:800;text-decoration:none;transition:background .16s ease}.mac-download-callout a:hover,.mac-download-callout a:focus-visible{background:#f5f5f42e;outline:0}.info-modal{position:fixed;right:10px;top:44px;z-index:31;width:min(260px,calc(100vw - 20px));padding:8px 10px;border:1px solid var(--stone-300);border-radius:6px;background:var(--stone-50);box-shadow:0 10px 28px #1c191729;color:var(--stone-700);font-size:.76rem;line-height:1.3}.info-modal header{margin-bottom:8px}.info-modal h2{margin:0;font-size:.86rem;font-weight:800;line-height:1.15}.info-modal-subtitle{margin-top:1px;color:inherit;font-weight:400}.info-modal-meta{font-size:.68rem;line-height:1.22}.info-modal p{margin-bottom:3px}.info-modal p:last-child{margin-bottom:0}.info-modal a{color:inherit;text-underline-offset:2px}.sim-shell .info-button{background:transparent;box-shadow:none;color:#f5f5f4b8;transition:background .16s ease,color .16s ease}.sim-shell .info-button:hover,.sim-shell .info-button:focus-visible{background:#f5f5f42e;color:#f5f5f4e5}.sim-shell .info-modal{border-color:#f5f5f429;background:#131614e0;box-shadow:0 12px 34px #0000005c;color:#f5f5f4bd;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sim-shell .info-modal h2,.sim-shell .info-modal a{color:#f5f5f4e0}@media(max-width:860px){.viewer-shell,.table-grid,.controls-band{display:grid;grid-template-columns:1fr}.three-viewer{height:calc(100vh - 210px);min-height:420px}}
