@media screen and (max-width: 768px),screen and (pointer: coarse) and (hover: none){#app-container{display:flex;flex-direction:column}#main-content-area{order:2;display:flex;flex-direction:column;flex-grow:1;min-height:0;overflow:hidden;position:relative}canvas#hexGridCanvas{display:block;width:100%;height:100%;flex-grow:1;min-width:0;touch-action:none;position:relative}#top-info-bar{order:1}#bottom-tab-bar{display:flex;order:3;width:100%;height:var(--bottom-tab-bar-height);background-color:#2a2a2a;border-top:1px solid #444;flex-shrink:0;padding-bottom:env(safe-area-inset-bottom)}.tab-bar-button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:none;border:none;color:#aaa;font-size:.7em;gap:2px;cursor:pointer;-webkit-tap-highlight-color:transparent}.tab-bar-button .icon{font-size:1.8em}.tab-bar-button.active{color:#f0c674}.draggable-panel-base{position:fixed;display:none;top:0!important;left:0!important;width:100%!important;height:100%!important;max-width:100vw;max-height:100vh;border-radius:0;border:none;transform:none!important;z-index:5000;background-color:#1e1e1e}.draggable-panel-base.is-mobile-view{display:flex}.draggable-panel-base h3{cursor:default}#worldSetupGrid{grid-template-columns:1fr}.popout-panel{display:none!important}#interaction-mode-toggle{width:60px;height:60px;border-radius:50%;background-color:#282828e6;border:1px solid #666;box-shadow:0 2px 8px #0006;color:#fff;font-size:1em;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center}#interaction-mode-toggle .icon{font-size:1.8em;line-height:1}#interaction-mode-toggle .label{font-size:.7em;margin-top:2px}.mobile-fab-container{position:absolute;bottom:calc(env(safe-area-inset-bottom,0px) + 10px);z-index:4500;display:flex;flex-direction:column-reverse;align-items:center;gap:15px}#mobile-fab-container-right{right:20px}#mobile-fab-container-left{left:20px}.mobile-fab{width:60px;height:60px;border-radius:50%;border:none;box-shadow:0 4px 12px #0006;color:#fff;font-size:1.8em;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .15s ease-out,background-color .15s ease-out,box-shadow .15s ease-out}.mobile-fab:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 7px 18px #00000080}.secondary-fab:hover{background-color:#5a5a5a}.primary-fab:hover{background-color:#ffda83}.mobile-fab:active{transform:translateY(1px) scale(.95);transition-duration:.05s;box-shadow:0 2px 8px #0006}.secondary-fab:active{background-color:#3f3f3f}.primary-fab:active{background-color:#d8b05b}.mobile-fab:focus-visible{outline:3px solid #009dff;outline-offset:3px}.primary-fab{background-color:#f0c674;color:#1e1e1e;width:70px;height:70px;font-size:2.2em}.secondary-fab{background-color:#4a4a4a;border:1px solid #666}}:root{--bottom-tab-bar-height: 60px}*,*:before,*:after{box-sizing:border-box}body{margin:0;background-color:#1e1e1e;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#e0e0e0;display:flex;height:100dvh;overflow:hidden;padding-bottom:env(safe-area-inset-bottom,10px);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}*{-webkit-overflow-scrolling:touch}.hidden{display:none!important}.button{padding:6px 12px;cursor:pointer;background-color:#4a4a4a;border:1px solid #666;color:#fff;border-radius:4px;font-size:.9em;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.button:hover{background-color:#5a5a5a}.checkbox-input{display:none}.checkbox-label{cursor:pointer;padding:5px 8px;border-radius:3px;transition:background-color .2s ease;border:1px solid #555;display:inline-block;line-height:normal;background-color:#4a4a4a;color:#ddd;font-size:.9em;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}.checkbox-label:hover{background-color:#5a5a5a}.checkbox-input:checked+.checkbox-label{background-color:#0078d4;border-color:#005a9e;color:#fff}#fileInput{display:none}::-webkit-scrollbar{width:3px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#fff5;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#f0f0f0}@media screen and (min-width: 769px){#app-container{display:flex;flex-direction:column;flex-grow:1;width:100%;height:100%;overflow:hidden;padding-bottom:env(safe-area-inset-bottom,0px)}#main-content-area{display:flex;flex-grow:1;overflow:hidden;min-height:0;position:relative}canvas#hexGridCanvas{display:block;flex-grow:1;background-color:#181818;min-width:0;touch-action:none}canvas#hexGridCanvas.placing-pattern-cursor{cursor:crosshair}canvas#hexGridCanvas.selecting-region-cursor{cursor:crosshair}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 500px)),(max-width: 480px){#main-content-area{flex-direction:column;padding-bottom:10px}canvas#hexGridCanvas{margin-bottom:10px}}}.placing-exit-hint{position:absolute;top:0;left:0;z-index:20;display:flex;align-items:center;gap:5px;padding:3px 8px;font-size:11px;line-height:1;color:#e8e8e8;background:#181818d9;border:1px solid rgba(255,255,255,.18);border-radius:5px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .12s ease}.placing-exit-hint.visible{opacity:1}.placing-exit-hint kbd{display:inline-block;padding:1px 5px;font-family:inherit;font-size:10px;color:#fff;background:#ffffff1f;border:1px solid rgba(255,255,255,.3);border-radius:3px}.world-status-badge{position:absolute;min-width:18px;height:18px;padding:0 5px;box-sizing:border-box;border-radius:9px;border:1px solid rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;line-height:1;color:#fff;background-color:#0009;pointer-events:none;transition:opacity .3s;z-index:51}.world-status-badge.hidden{display:none;opacity:0}.world-status-badge.extinct{background-color:#3c3c46d9;color:#c8c8d0}.world-status-badge.saturated{background-color:#e6aa1ee6;color:#1a1a1a;border-color:#ffe696cc}.world-status-badge.cycling{background-color:#1482a0e6;color:#e8fbff;border-color:#8cdcf0cc}.world-status-badge.mini{height:15px;min-width:15px;padding:0 3px;font-size:9px;border-radius:7.5px}.world-explore-score{position:absolute;min-width:22px;height:16px;padding:0 4px;box-sizing:border-box;border-radius:8px;border:1px solid rgba(255,255,255,.45);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;color:#fff;background-color:#000000a6;pointer-events:none;z-index:52}.world-explore-score.hidden{display:none}.world-explore-score.high{background-color:#6ebe5aeb;color:#0e1a0c;border-color:#b4f0a0d9}.world-explore-score.mid{background-color:#e6be46eb;color:#1a1505;border-color:#ffe18cd9}.world-explore-score.low{background-color:#464650d9;color:#d2d2da}.world-explore-score.killed{background-color:#963c41e6;color:#ffe3e3;border-color:#e69696cc}.world-explore-score.mini{height:13px;min-width:18px;padding:0 2px;font-size:8px;border-radius:6.5px}.world-lock-badge{position:absolute;height:18px;min-width:18px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1;pointer-events:none;text-shadow:0 0 3px rgba(0,0,0,.9);z-index:53}.world-lock-badge.hidden{display:none}.world-lock-badge.mini{height:15px;min-width:15px;font-size:10px}.world-parent-ring{position:absolute;box-sizing:border-box;border-radius:4px;border:2px solid #5ad17a;box-shadow:0 0 8px #5ad17ab3,inset 0 0 6px #5ad17a59;pointer-events:none;z-index:50}.world-parent-ring.hidden{display:none}.world-parent-badge{position:absolute;height:18px;min-width:18px;box-sizing:border-box;display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1;pointer-events:none;text-shadow:0 0 3px rgba(0,0,0,.9);z-index:53}.world-parent-badge.hidden{display:none}.world-parent-badge.mini{height:15px;min-width:15px;font-size:10px}#loading-indicator{position:fixed;top:0;left:0;width:100%;height:100%;background:#1e1e1e;display:flex;align-items:center;justify-content:center;z-index:10000;color:#e0e0e0;font-size:1.2em;flex-direction:column}#loading-indicator .loading-content{text-align:center}#loading-title{margin-top:20px;font-size:1.2em;color:#f0f0f0}#loading-status{font-size:.9em;color:#aaa;margin-top:10px;min-height:20px;transition:color .3s}.loader-grid{display:block;position:relative;width:100%;height:100%}.loader-hex{width:50px;height:57.73px;position:absolute;background-color:#333;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);transition:background-color .5s ease-in-out,transform .3s ease;transform:scale(.95) rotate(90deg) translate(-50%,-50%)}.loader-hex.active{background-color:#f0c674;transform:scale(1) rotate(90deg) translate(-50%,-50%)}#loader-hex-0{left:0%;top:40%}#loader-hex-1{left:16%;top:70%}#loader-hex-2{left:16%;top:12%}#loader-hex-3{left:32%;top:-18%}#loader-hex-4{left:32%;top:40%}#loader-hex-5{left:32%;top:98%}#loader-hex-6{left:48%;top:70%}#loader-hex-7{left:48%;top:12%}#loader-hex-8{left:64%;top:40%}#top-info-bar{display:flex;align-items:center;justify-content:space-between;background-color:#2a2a2a;border-bottom:1px solid #444;padding:0 10px;gap:15px;flex-shrink:0;font-size:.85em;box-sizing:border-box;height:2.5rem;padding-top:env(safe-area-inset-top)}#appMenuButton{display:flex;align-items:center;gap:8px;font-weight:700;color:#f0f0f0;cursor:pointer;padding:5px 10px;border-radius:4px;transition:background-color .2s}#appMenuButton:hover{background-color:#3f3f3f}#appLogo{font-size:1.5rem;color:#ff0}#appTitle{font-size:1em;color:#f0f0f0;white-space:nowrap}#rulesetDisplayContainer{display:flex;align-items:center;background-color:#3c3c3c;border-radius:4px;padding:2px 5px;border:1px solid #555;font-family:monospace;font-size:.9rem;min-width:0}@media screen and (min-width: 769px){#rulesetDisplayContainer{flex-grow:1;justify-content:center}}.ruleset-display-toggle{position:relative;display:grid;place-items:center;text-align:center;min-width:250px}#rulesetDisplayName,#rulesetDisplayCode{grid-area:1 / 1;transition:opacity .2s ease-in-out}#rulesetDisplayName{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-weight:700;font-size:1.1em;color:#f0f0f0;cursor:pointer}.ruleset-display-toggle.is-derived #rulesetDisplayName{font-weight:500;font-style:italic;color:#c8c8d0}#rulesetDisplayCode{font-family:monospace;font-size:.9rem;padding:4px 5px;background-color:transparent;border:none;font-weight:700}.ruleset-display-toggle.has-name #rulesetDisplayName{opacity:1}.ruleset-display-toggle.has-name #rulesetDisplayCode,.ruleset-display-toggle.has-name:hover #rulesetDisplayName{opacity:0;pointer-events:none}.ruleset-display-toggle.has-name:hover #rulesetDisplayCode{opacity:1}.ruleset-display-toggle:not(.has-name) #rulesetDisplayName{opacity:0;pointer-events:none}.ruleset-display-toggle:not(.has-name) #rulesetDisplayCode{opacity:1}#statsDisplayContainer{display:flex;gap:15px;align-items:center;justify-content:flex-end}#statsDisplayContainer>span{min-width:35px;display:inline-block;text-align:left}#statsDisplayContainer span span{font-weight:700;color:#f0f0f0;display:inline-block;text-align:right;font-variant-numeric:tabular-nums}#statsDisplayContainer>span:first-child{min-width:60px}#stat-tick{min-width:6ch}#stat-ratio{min-width:3ch}#stat-brush-size{min-width:2ch}#stat-fps{min-width:3ch}#stat-actual-tps,#stat-target-tps{min-width:4ch}#appMenuPopout{z-index:1100}@media screen and (max-width: 768px),screen and (pointer: coarse) and (hover: none){#top-info-bar{flex-direction:column;height:auto;padding:8px;gap:8px}#appMenuButton{display:none}#rulesetDisplayContainer{order:1;width:100%;justify-content:center}#statsDisplayContainer{order:2;width:100%;justify-content:space-around;flex-wrap:wrap;gap:10px}.ruleset-display-toggle{min-width:200px}@media (max-width: 360px){#statsDisplayContainer>span:nth-child(3){display:none}#statsDisplayContainer>span:nth-child(4){display:none}}}.history-item{padding:5px 10px;cursor:pointer;border-radius:3px;border-bottom:1px solid #4a4a4a;transition:background-color .2s;display:flex;align-items:center;gap:10px}.history-item .viz-placeholder,.history-item .ruleset-viz-svg{width:24px;height:48px;flex-shrink:0;background-color:#111;border:1px solid #555}.history-item-label{flex-grow:1;display:flex;flex-direction:column;gap:1px;min-width:0}.history-item-name{font-weight:600;font-size:.95em;color:#e8e8ee}.history-item-name.is-derived{font-weight:500;font-style:italic;color:#c0c4d0}.history-item-hex{font-family:monospace;font-size:.8em;color:#9a9aa4}.ruleset-history-controls{display:flex;align-items:center;flex-direction:row}.ruleset-history-controls .button-icon,.save-ruleset-button{width:32px;height:32px;padding:0;background-color:#4a4a4a;border:1px solid #555;color:#fff;border-radius:4px;font-size:1.2em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease,transform .1s ease;-webkit-user-select:none;user-select:none;margin:0 4px}.ruleset-history-controls .button-icon:hover:not(:disabled),.save-ruleset-button:hover:not([style*="cursor: not-allowed"]){background-color:#5a5a5a;transform:scale(1.05)}.ruleset-history-controls .button-icon:active:not(:disabled),.save-ruleset-button:active:not([style*="cursor: not-allowed"]){background-color:#3f3f3f;transform:scale(.98)}.ruleset-history-controls .button-icon:disabled{color:#666;background-color:#404040;cursor:not-allowed}.save-ruleset-button{font-size:1.4em;transition:filter .2s ease,opacity .2s ease,color .2s ease,text-shadow .2s ease,transform .1s ease}.save-ruleset-button.not-saved{background-color:#4a4a4a;color:#999}.save-ruleset-button.not-saved:hover{color:gold;background-color:#5a5a5a}.save-ruleset-button.is-public{background-color:#4a4a4a;color:#87ceeb;text-shadow:0 0 4px #87CEEB;cursor:not-allowed}.save-ruleset-button.is-public:hover{background-color:#4a4a4a;transform:none}.save-ruleset-button.is-personal{background-color:#4a4a4a;color:gold;text-shadow:0 0 5px #FFD700}@media screen and (min-width: 769px){#vertical-toolbar{width:50px;background-color:#2f2f2f;border-right:1px solid #444;display:flex;flex-direction:column;align-items:center;padding:10px 0;gap:5px;flex-shrink:0;overflow-y:auto;touch-action:pan-x}.toolbar-button{width:40px;height:40px;padding:0;background-color:#4a4a4a;border:1px solid #555;color:#fff;border-radius:4px;font-size:1.2em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.toolbar-button:hover{background-color:#5a5a5a}.toolbar-button:active,.toolbar-button.active{background-color:#0078d4;border-color:#005a9e}.toolbar-button.is-recording{color:#ff4d4d;border-color:#ff4d4d;animation:toolbar-recording-pulse 1.2s ease-in-out infinite}@keyframes toolbar-recording-pulse{0%,to{background-color:#ff4d4d1f}50%{background-color:#ff4d4d52}}.toolbar-separator{height:1px;width:80%;background-color:#444;margin:8px 0}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 900px)),(max-width: 768px){#vertical-toolbar{width:45px}.toolbar-button{width:35px;height:35px;font-size:1em}}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 500px)),(max-width: 480px){#vertical-toolbar{width:100%;height:50px;flex-direction:row;justify-content:space-around;border-right:none;border-bottom:1px solid #444;border-top:none;padding:0 5px;overflow-x:auto;overflow-y:hidden;order:-1;touch-action:pan-x}.toolbar-button{margin:5px 2px}.toolbar-separator{display:none}}}.scrub-bar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:6px;max-width:min(560px,calc(100% - 24px));padding:6px 10px;background-color:#1d1d20eb;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-popout);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-secondary);font-variant-numeric:tabular-nums;-webkit-user-select:none;user-select:none}.scrub-bar.hidden{display:none}.scrub-bar.is-scrubbing{border-color:var(--accent-border)}.scrub-btn{display:inline-flex;align-items:center;justify-content:center;height:30px;min-width:30px;padding:0 6px;background-color:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:background-color .15s ease,color .15s ease}.scrub-btn:hover{background-color:var(--surface-4);color:var(--text-primary)}.scrub-btn:active{background-color:var(--surface-5)}.scrub-btn svg{width:18px;height:18px;display:block}.scrub-btn.scrub-live{font-size:.78em;letter-spacing:.04em;text-transform:uppercase;font-weight:600}.scrub-bar.is-scrubbing .scrub-live{background-color:var(--accent-soft);border-color:var(--accent-border);color:var(--accent)}.scrub-slider{flex:1 1 160px;min-width:90px;accent-color:var(--accent);cursor:pointer}.scrub-label{flex-shrink:0;min-width:78px;text-align:right;font-size:.8em;color:var(--text-primary)}@media screen and (max-width: 768px),screen and (pointer: coarse) and (hover: none){.scrub-bar{bottom:84px;gap:4px;padding:5px 8px}.scrub-bar [data-action=back10],.scrub-bar [data-action=fwd10]{display:none}.scrub-label{min-width:64px}}@keyframes pulse-highlight{0%{box-shadow:0 0 8px #ffffffb3}50%{box-shadow:0 0 16px 4px #ffffffe6}to{box-shadow:0 0 8px #ffffffb3}}#onboarding-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000000b3;z-index:2000;pointer-events:none;transition:all .3s ease-in-out;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}#onboarding-overlay.interactive{pointer-events:auto}.onboarding-highlight{z-index:5001!important;box-shadow:0 0 8px #ffffffb3;animation:pulse-highlight 2s infinite;pointer-events:auto!important;border-radius:4px;transition:all .3s ease-in-out}.onboarding-highlight.onboarding-highlight-no-filter{animation:none;box-shadow:0 0 10px 3px #fff096d9;border:1px solid rgba(255,240,150,.9)}.onboarding-canvas-highlight{display:block!important;box-shadow:0 0 0 500vmax #000000b3;border:2px solid #f0c674;z-index:2000;animation:pulse-highlight 2s infinite}#onboarding-tooltip{position:fixed;background:linear-gradient(145deg,#4a4a4a,#383838);border:1px solid #777;border-radius:8px;padding:0;z-index:6001;width:320px;max-width:90vw;box-shadow:0 8px 25px #00000080;transition:opacity .3s ease-in-out;overflow:hidden}#onboarding-progress-container{width:100%;height:4px;background-color:#0000004d}#onboarding-progress-bar{width:0%;height:100%;background-color:#f0c674;transition:width .5s ease}#onboarding-tooltip-title{font-size:1.1em;color:#f0c674;margin:15px 15px 10px;padding-bottom:10px;border-bottom:1px solid #555}#onboarding-tooltip-content{color:#e0e0e0;line-height:1.5;margin:0 15px 15px}.onboarding-highlight-text{font-weight:700;color:#f0c674}#onboarding-tooltip-actions{display:flex;justify-content:space-between;align-items:center;background-color:#0003;padding:10px 15px}#onboarding-tooltip .button{background-color:#f0c674;color:#1e1e1e;border:none;font-weight:700}#onboarding-tooltip .button:hover{background-color:#fff2a8}.button-link{background:none;border:none;color:#ccc;cursor:pointer;text-decoration:underline;font-size:.9em}.button-link:hover{color:#fff}.button-help-trigger{background:#555;color:#fff;border:1px solid #777;border-radius:50%;width:20px;height:20px;font-size:13px;font-weight:700;cursor:pointer;margin-left:8px;vertical-align:middle;line-height:18px;padding:0;transition:background-color .2s,transform .2s}.button-help-trigger:hover{background:#0078d4;transform:scale(1.1)}.slider-component-container{display:flex;align-items:center;gap:5px}.slider-component-container label{margin-right:3px;-webkit-user-select:none;user-select:none;font-size:.9em}.slider-wrapper{position:relative;display:inline-flex;align-items:center;width:100%}.slider-component-container input[type=range]{vertical-align:middle;min-width:100px;width:100%;color:#2b2d42;--track-color: rgba(0, 0, 0, .4);--brightness-hover: 180%;--brightness-down: 80%;--thumb-height: 2.1rem;--thumb-width: 1px;--clip-edges: .0125em;position:relative;background:#fff0;overflow:hidden}.slider-wrapper span.value-display{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:#fff;font-size:.8rem;font-family:Arial,sans-serif;pointer-events:none;z-index:2;text-shadow:0px 0px 3px rgba(0,0,0,.9);padding:1px 3px;white-space:nowrap}.slider-component-container span.unit-display{font-size:.9em;color:#ccc;margin-left:2px;-webkit-user-select:none;user-select:none}.slider-component-container input[type=range]:active{cursor:grabbing}.slider-component-container input[type=range]:disabled{filter:grayscale(1);opacity:.3;cursor:not-allowed}.slider-component-container input[type=range],.slider-component-container input[type=range]::-webkit-slider-runnable-track,.slider-component-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;transition:all ease .1s;height:var(--thumb-height)}.slider-component-container input[type=range]::-webkit-slider-runnable-track,.slider-component-container input[type=range]::-webkit-slider-thumb{position:relative}.slider-component-container input[type=range]::-webkit-slider-thumb{--thumb-radius: calc((var(--thumb-height) * .5) - 1px);--clip-top: calc((var(--thumb-height) - var(--track-height, .5rem)) * .5 - .5px);--clip-bottom: calc(var(--thumb-height) - var(--clip-top));--clip-further: calc(100% + 1px) ;--box-fill: calc(-100vmax - var(--thumb-width, var(--thumb-height))) 0 0 100vmax currentColor;width:var(--thumb-width, var(--thumb-height));background:linear-gradient(currentColor 0 0) scroll no-repeat left center / 50% calc(var(--track-height, .5rem) + 1px);background-color:currentColor;box-shadow:var(--box-fill);border-radius:var(--thumb-width, var(--thumb-height));filter:brightness(100%);clip-path:polygon(100% -1px,var(--clip-edges) -1px,0 var(--clip-top),-100vmax var(--clip-top),-100vmax var(--clip-bottom),0 var(--clip-bottom),var(--clip-edges) 100%,var(--clip-further) var(--clip-further))}.slider-component-container input[type=range]:hover::-webkit-slider-thumb{filter:brightness(var(--brightness-hover));cursor:grab}.slider-component-container input[type=range]:active::-webkit-slider-thumb{filter:brightness(var(--brightness-down));cursor:grabbing}.slider-component-container input[type=range]::-webkit-slider-runnable-track{background:linear-gradient(var(--track-color) 0 0) scroll no-repeat center / 100% calc(var(--track-height, .5rem) + 1px)}.slider-component-container input[type=range]:disabled::-webkit-slider-thumb{cursor:not-allowed}@supports (-webkit-overflow-scrolling: touch){input[type=range]{font-size:16px!important}}.slider-tooltip{position:fixed;background-color:#2a2a2a;color:#f0c674;padding:8px 12px;border-radius:6px;border:1px solid #777;box-shadow:0 4px 12px #0006;font-size:1.2em;font-weight:700;pointer-events:none;z-index:9999;opacity:0;transform:translate(-50%,-10px) scale(.8);transition:opacity .15s ease-out,transform .15s ease-out;white-space:nowrap}.slider-tooltip.visible{opacity:1;transform:translate(-50%,-15px) scale(1)}.slider-tooltip:not(.hidden){opacity:1;transform:translate(-50%,-15px) scale(1)}.slider-tooltip.hidden{opacity:0;transform:translate(-50%,-10px) scale(.8)}.slider-tooltip-granularity{display:block;font-size:.7em;color:#ccc;text-align:center;margin-top:2px;font-weight:400}.slider-component-container.is-scrubbing input[type=range]::-webkit-slider-thumb{transform:scale(1.2);box-shadow:0 0 10px #f0c674b3}.slider-component-container.is-scrubbing input[type=range]::-moz-range-thumb{transform:scale(1.2);box-shadow:0 0 10px #f0c674b3}.switch-component-container{display:flex;flex-direction:column;gap:0px}.switch-component-label{font-size:.9em;color:#ccc;margin-bottom:2px}.switch-group{display:inline-flex;border-radius:4px;overflow:hidden;border:1px solid #555}.switch-item{display:contents}.switch-input{display:none}.switch-label{padding:6px 12px;cursor:pointer;background-color:#4a4a4a;color:#ccc;font-size:.9em;-webkit-user-select:none;user-select:none;transition:background-color .2s,color .2s;border-right:1px solid #555;text-align:center;flex-grow:1}.switch-group .switch-item:last-child .switch-label{border-right:none}.switch-label:hover{background-color:#5a5a5a}.switch-input:checked+.switch-label{background-color:#0078d4;color:#fff;font-weight:400}.switch-input:checked+.switch-label:hover{background-color:#006ac1}.type-checkbox .switch-group{border:none}.type-checkbox .switch-label{border:1px solid #555;border-radius:4px}.controls-component-content,.controls-component-content .tool-group{display:flex;flex-direction:column}.controls-component-content .tool-group h5{margin:0;font-size:1em;color:#f0c674;border-bottom:1px solid #444}.controls-component-content .slider-component-container{padding:0 4px}.pattern-buttons{display:flex;gap:6px;margin-top:6px}.pattern-buttons .button{flex:1;display:flex;align-items:center;justify-content:center;gap:6px}#patterns-capture-button{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:6px}.pattern-hotkey-hint{margin:6px 0 0;font-size:.75em;color:#999;text-align:center}.pattern-hotkey-hint kbd{background-color:#333;border:1px solid #555;border-radius:3px;padding:0 4px;font-size:.9em;color:#ddd}.patterns-list{display:flex;flex-direction:column;gap:4px;margin-top:6px;max-height:160px;overflow-y:auto}.patterns-list .empty-state-text{margin:4px 0 0;font-size:.8em;color:#999;line-height:1.3}.pattern-list-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 8px;background-color:#2a2a2a;border:1px solid #444;border-radius:4px}.pattern-list-thumb{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background-color:#1e1e1e;border:1px solid #444;border-radius:3px;padding:2px}.pattern-thumb-svg{max-width:100%;max-height:100%}.pattern-thumb-svg polygon{fill:#3cb44b}.pattern-list-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9em}.pattern-list-actions{display:flex;gap:2px;flex-shrink:0}.pattern-list-actions .button-icon{display:inline-flex;align-items:center;justify-content:center;padding:2px}@media screen and (min-width: 769px){.draggable-panel-base{position:fixed;max-width:90vw;max-height:90vh;min-width:35vw;background-color:#1e1e1ef7;border:1px solid #555;border-radius:8px;padding:15px;box-sizing:border-box;z-index:1000;color:#eee;display:flex;flex-direction:column;overflow:hidden}.draggable-panel-base.hidden{display:none!important}.draggable-panel-base h3{margin-top:0;margin-bottom:10px;text-align:center;border-bottom:1px solid #444;padding-bottom:8px;-webkit-user-select:none;user-select:none;font-size:1.1em;cursor:move}.close-panel-button{position:absolute;top:8px;right:12px;background:none;border:none;color:#aaa;font-size:1.8em;font-weight:700;cursor:pointer;padding:0 5px;line-height:1}.close-panel-button:hover{color:#fff}.panel-content-area{flex-grow:1;overflow-y:auto;padding-right:5px}.panel-actions{border-top:1px solid #444;display:flex;justify-content:center;gap:10px}.panel-actions .button{-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.panel-actions .button:hover{background-color:#5a5a5a}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 900px)),(max-width: 768px){.draggable-panel-base{max-width:95vw;min-width:35vw;max-height:85vh}}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 500px)),(max-width: 480px){.draggable-panel-base{left:0!important;top:0!important;width:100%!important;height:100%!important;max-width:100vw;min-width:35vw;max-height:100vh;border-radius:0;transform:none!important}}}@media screen and (min-width: 769px){.popout-panel{position:absolute;background-color:#383838cc;border:1px solid #555;border-radius:6px;box-shadow:0 4px 12px #0000004d;padding:15px;min-width:200px;color:#e0e0e0;z-index:1010}.popout-panel.hidden{display:none!important}.popout-panel h4{margin-top:0;margin-bottom:0;font-size:1em;border-bottom:1px solid #4f4f4f;padding-bottom:5px;color:#f0f0f0}.popout-panel .form-group{margin-bottom:2px;display:flex;flex-direction:column;gap:0px}.popout-panel .form-group label:not(.checkbox-label):not(.radio-switch-label){font-size:.9em;color:#ccc;margin-bottom:0}.popout-panel .form-group-buttons{display:flex;gap:10px;margin-top:15px;justify-content:flex-end}.popout-panel .hex-input{padding:6px 8px;border:1px solid #555;background-color:#2c2c2c;color:#fff;border-radius:3px;font-size:.9em;font-family:monospace;width:100%;box-sizing:border-box}.popout-panel .popout-separator{height:1px;background-color:#4f4f4f;margin:12px 0}.radio-switch-input{display:none}.three-way-switch{display:inline-flex;border-radius:4px}.radio-switch-label{padding:6px 10px;cursor:pointer;color:#ccc;background-color:#4a4a4a;font-size:.85em;transition:background-color .2s ease,color .2s ease;border-right:1px solid #555;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}.three-way-switch .radio-switch-label:last-of-type{border-right:none}.radio-switch-input:checked+.radio-switch-label{background-color:#0078d4;color:#fff;font-weight:700}.radio-switch-label:hover{background-color:#5a5a5a}#historyPopout .history-list-container{max-height:300px;overflow-y:auto;font-family:monospace}.history-item{padding:8px 10px;cursor:pointer;border-radius:3px;border-bottom:1px solid #4a4a4a;transition:background-color .2s;display:flex;justify-content:space-between;align-items:center}.history-item:last-child{border-bottom:none}.history-item:hover{background-color:#0078d4}.history-item.is-current{font-weight:700;color:#f0c674;background-color:#28282880;cursor:default}.history-item .tag{font-size:.8em;color:#999;margin-left:10px}.popout-tabs{display:flex;border-bottom:1px solid #555;margin:-15px -15px 10px}.tab-button{flex:1;padding:10px;cursor:pointer;background-color:transparent;border:none;color:#aaa;font-size:.9em;border-bottom:2px solid transparent;transition:all .2s ease}.tab-button:hover{background-color:#ffffff0d}.tab-button.active{color:#fff;font-weight:700;border-bottom-color:#0078d4}.tab-content{max-height:40vh;overflow-y:auto}.library-item{display:flex;align-items:center;padding:8px 5px;border-bottom:1px solid #4f4f4f}.library-item:last-child{border-bottom:none}.library-item-info{flex-grow:1}.library-item-name{font-weight:700;color:#e0e0e0}.library-item-desc{font-size:.85em;color:#b0b0b0;margin-top:2px}.library-item .button{flex-shrink:0;margin-left:10px}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 900px)),(max-width: 768px){.popout-panel{min-width:200px;padding:10px}}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 500px)),(max-width: 480px){.popout-panel{left:5%!important;width:90%!important;max-width:90vw;box-sizing:border-box}}.popout-panel.popout-menu{padding:5px;min-width:180px}.popout-link-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.popout-link-list li a{display:flex;align-items:center;gap:10px;padding:10px 15px;color:#e0e0e0;text-decoration:none;border-radius:4px;transition:background-color .2s,color .2s;font-size:.95em}.popout-link-list li a:hover{background-color:#0078d4;color:#fff}.popout-link-list li a .icon{display:inline-flex;align-items:center;justify-content:center}.popout-link-list li a .icon svg{width:16px;height:16px;fill:currentColor}}.bottom-sheet-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:6000;display:flex;justify-content:center;align-items:flex-end;opacity:1;transition:opacity .3s ease;padding-bottom:var(--bottom-tab-bar-height)}.bottom-sheet-overlay.hidden{display:none;opacity:0}.bottom-sheet-panel{width:100%;max-width:600px;background-color:#2c2c2c;border-top-left-radius:12px;border-top-right-radius:12px;box-shadow:0 -4px 15px #0000004d;transform:translateY(100%);transition:transform .3s ease-out;display:flex;flex-direction:column;max-height:80vh}.bottom-sheet-panel.visible{transform:translateY(0)}.bottom-sheet-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #444;flex-shrink:0}.bottom-sheet-title{margin:0;font-size:1.1em;font-weight:700;color:#eee}.bottom-sheet-close-button{background:none;border:none;color:#aaa;font-size:2em;font-weight:400;cursor:pointer;line-height:1;padding:0}.bottom-sheet-content{padding:16px;overflow-y:auto}.learning-component-content{height:100%;display:flex;flex-direction:column}.learning-component-content .info-text{margin-bottom:10px;flex-shrink:0}.learning-center-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:5px;overflow-y:auto;flex-grow:1}.learning-center-item{display:flex;align-items:center;background-color:#0003;padding:10px 12px;border-radius:4px;border:1px solid #333;transition:background-color .2s}.learning-center-item:hover{background-color:#ffffff0d}.learning-center-item .status-icon{font-size:1.2em;margin-right:12px;flex-shrink:0;display:inline-flex;align-items:center;color:var(--accent, #f0c674)}.learning-center-item .status-icon svg{width:20px;height:20px}.learning-center-item .tour-name{flex-grow:1;font-size:.9em;color:#ddd}.learning-center-item .tour-start-button{flex-shrink:0;padding:6px 12px;font-size:.9em}.ruleset-actions-container{display:flex;flex-direction:column;height:100%}.ruleset-actions-header{display:flex;justify-content:stretch;background-color:#2a2a2a;flex-shrink:0}.ruleset-actions-segment{flex-grow:1;padding:12px 5px;font-size:.9em;text-align:center;background-color:#3a3a3a;color:#ccc;border:none;border-right:1px solid #555;cursor:pointer;transition:background-color .2s}.ruleset-actions-segment:last-child{border-right:none}.ruleset-actions-segment.active{background-color:#f0c674;color:#1e1e1e;font-weight:700}.ruleset-actions-segment:hover:not(.active){background-color:#4a4a4a}.ruleset-actions-content{flex-grow:1;overflow-y:auto}.ruleset-pane{display:flex;flex-direction:column}.ruleset-pane.hidden{display:none}.ruleset-pane .form-group{display:flex;flex-direction:column;gap:10px}.ruleset-pane .form-group label:not(.switch-label):not(.checkbox-label){font-weight:700;color:#ccc}.ruleset-pane .bias-controls{display:flex;flex-direction:row;gap:3px}.ruleset-pane .checkbox-input{margin-right:8px}.ruleset-pane .checkbox-label{display:flex;align-items:center;color:#ccc;font-weight:700}.ruleset-pane .hex-input{padding:6px 8px;border:1px solid #555;background-color:#2c2c2c;color:#fff;border-radius:3px;font-size:.9em;font-family:monospace;width:100%;box-sizing:border-box}.ruleset-pane .action-button,.ruleset-pane .form-group-buttons{display:flex;gap:10px;margin-top:10px}.ruleset-pane .action-button,.ruleset-pane .form-group-buttons .button{flex:1;padding:15px;font-size:1.1em;font-weight:700;background-color:#f0c674;color:#1e1e1e;border:none;border-radius:5px;cursor:pointer;transition:background-color .2s}.ruleset-pane .action-button:hover,.ruleset-pane .form-group-buttons .button:hover{background-color:#f4d03f}.ruleset-pane .breed-hint{margin:0 0 4px;color:#aaa;font-size:.85em;line-height:1.4}.ruleset-pane .breed-hint kbd{background-color:#2c2c2c;border:1px solid #555;border-radius:3px;padding:0 4px;font-family:monospace;color:#f0f0f0}.ruleset-pane .breed-parent-grid{display:grid;grid-template-columns:repeat(3,40px);gap:5px}.ruleset-pane .breed-parent-cell{width:40px;height:40px;border:1px solid #555;background-color:#2c2c2c;color:#ccc;border-radius:4px;font-size:.85em;font-weight:700;cursor:pointer;transition:background-color .15s,border-color .15s}.ruleset-pane .breed-parent-cell:hover:not(:disabled):not(.active){background-color:#3a3a3a}.ruleset-pane .breed-parent-cell.active{background-color:#5ad17a;border-color:#8df0a8;color:#0e1a0c}.ruleset-pane .breed-parent-cell:disabled,.ruleset-pane .breed-parent-cell.disabled{opacity:.35;cursor:not-allowed}.ruleset-pane .breed-parent-readout{color:#aaa;font-size:.85em;font-style:italic}.library-filter-tabs{display:flex;justify-content:stretch;border-radius:4px;overflow:hidden;border:1px solid #555;margin-bottom:15px;flex-shrink:0}.library-filter-tabs .sub-tab-button{flex-grow:1;padding:8px;background-color:#4a4a4a;color:#ccc;border:none;cursor:pointer;border-right:1px solid #555;transition:background-color .2s}.library-filter-tabs .sub-tab-button:last-child{border-right:none}.library-filter-tabs .sub-tab-button.active{background-color:#0078d4;color:#fff}.library-filter-tabs .sub-tab-button:hover:not(.active){background-color:#5a5a5a}.library-list{display:flex;flex-direction:column;gap:2px;max-height:70vh;overflow-y:auto}.library-item{background-color:#2a2a2a;padding:8px 10px;border-radius:5px;border:1px solid #444;display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.library-item .viz-placeholder,.library-item .ruleset-viz-svg{width:24px;height:48px;flex-shrink:0;margin-right:10px;background-color:#111;border:1px solid #555;border-radius:2px}.library-item-info{flex-grow:1;margin-right:10px}.library-item .name{font-size:1em;font-weight:700;color:#f0f0f0}.library-item .description{font-size:.9em;color:#aaa;line-height:1.4}.library-item-actions{display:flex;gap:5px;flex-shrink:0}.library-item .button-icon{background:none;border:1px solid #666;color:#ccc;font-size:1.2em;font-weight:700;cursor:pointer;padding:5px 10px;border-radius:4px}.library-item .button-icon:hover{background-color:#555}.empty-state-text{color:#aaa;font-style:italic;text-align:center;padding:20px;line-height:1.5}@media screen and (min-width: 769px){#rulesetActionsPanel{width:440px;min-width:320px}}@media (max-width: 768px){.ruleset-actions-segment{padding:10px 4px;font-size:.8em}.library-list{max-height:70vh}}.chroma-lab-component-content{display:flex;flex-direction:column;height:100%;gap:5px}.chroma-lab-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.chroma-mode-section{display:flex;align-items:center;gap:10px;padding-bottom:10px;border-bottom:1px solid #444;flex-shrink:0}.chroma-mode-section h4{margin:0;color:#ccc}#chroma-mode-select{flex-grow:1;padding:8px;background-color:#333;color:#fff;border:1px solid #555;border-radius:4px;font-size:.9em}.chroma-section{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.chroma-section h4{margin:0 0 5px;color:#f0c674;border-bottom:1px solid #444;padding-bottom:5px}.preset-visualizations{display:grid;grid-template-columns:repeat(4,150px);gap:12px}.preset-vis-container{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;border:2px solid #555;background-color:#3a3a3a;border-radius:4px;cursor:pointer;transition:all .2s ease}.preset-vis-container:hover{border-color:#f0c674;transform:translateY(-2px)}.preset-vis-container.active{border-color:#f0c674;background-color:#4a4a4a;font-weight:700;box-shadow:0 0 8px #f0c67466}.preset-vis-container img{width:100%;height:40px;object-fit:fill;image-rendering:pixelated;border:1px solid #777}.preset-vis-container span{font-size:.85em;color:#eee}.preset-controls{display:flex;justify-content:center;align-items:center;padding:10px 0;border-bottom:1px solid #444}.preset-controls label{display:flex;align-items:center;gap:8px;color:#ccc;font-size:.9em}.preset-controls input[type=checkbox]{width:16px;height:16px}.preset-warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404;padding:10px;border-radius:4px;text-align:center;font-size:.85em;margin-bottom:10px}.color-group-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;overflow-y:auto;flex-grow:1;padding-right:5px}.color-group-column{display:flex;flex-direction:column}.color-group-column h5{text-align:center;margin:0 0 5px;color:#ddd;display:flex;flex-direction:column;align-items:center;gap:4px}.column-actions{display:flex;align-items:center;justify-content:center;gap:4px;font-size:.8em;font-weight:400}.select-all-swatches{font-size:.75em;padding:2px 6px;border:1px solid #555;background-color:#3a3a3a;color:#87ceeb;border-radius:3px;cursor:pointer;transition:all .2s ease}.select-all-swatches:hover{background-color:#4a4a4a;border-color:#f0c674}.color-group{border:1px solid #444;border-radius:4px;background-color:#2c2c2c;display:flex;flex-direction:column}.color-group.selected{box-shadow:0 0 0 2px #f0c674}.group-label-container{display:flex;align-items:center;justify-content:center;color:#ccc;font-size:.9em;min-height:40px}.group-label-container .r-sym-rule-viz{transform:scale(.6)!important;margin:-15px -20px}.color-swatch-pair{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid #444}.color-swatch-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:4px;border-radius:3px;border:1px solid transparent}.color-swatch-wrapper.selected{border-color:#f0c674;background-color:#f0c67433}.color-swatch-wrapper .swatch-label{font-size:.75em;font-weight:700;color:#aaa}.color-swatch-wrapper .color-swatch{width:100%;height:20px;border:1px solid #777;border-radius:3px}#color-palette-modal{position:fixed;z-index:9999;left:0;top:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center}.color-palette-content{background:#2c2c2c;padding:20px;border-radius:8px;border:1px solid #666;display:grid;grid-template-columns:repeat(7,1fr);gap:10px;max-width:400px}.palette-color{width:35px;height:35px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .2s ease}.palette-color:hover{transform:scale(1.15);border-color:#fff}#chroma-batch-action-bar{display:flex;justify-content:space-between;align-items:center;padding:10px;background-color:#2a2a2a;border:1px solid #555;border-radius:4px;margin-bottom:10px;flex-shrink:0}#chroma-batch-action-bar span{font-weight:700;color:#f0c674}.batch-swatch{padding:5px 10px;width:auto;text-align:center;white-space:nowrap;background-color:#555;border:2px dashed #f0c674;cursor:pointer}.button-link{color:#87ceeb;text-decoration:underline;cursor:pointer;background:none;border:none}.selection-order-marker{position:absolute;top:2px;left:2px;width:16px;height:16px;background-color:#f0c674e6;color:#1e1e1e;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;box-shadow:0 0 4px #000;pointer-events:none}#gradient-creator-modal{position:fixed;z-index:9999;left:0;top:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center}#gradient-preview-strip{height:30px;border:1px solid #555;border-radius:4px;margin-bottom:15px;background-color:#222;transition:background .3s ease}.reset-column-defaults{font-size:.75em;padding:2px 6px;border:1px solid #7c3a3a;background-color:#4a3a3a;color:#fca5a5;border-radius:3px;cursor:pointer;transition:all .2s ease;margin-left:8px}.reset-column-defaults:hover{background-color:#5a4a4a;border-color:#ef4444;color:#fecaca}.flicker-warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404;padding:12px;border-radius:4px;display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.9em}.flicker-warning .deflicker-btn{background-color:#28a745;color:#fff;border:none;padding:6px 12px;border-radius:3px;cursor:pointer;font-size:.85em}.flicker-warning .deflicker-btn:hover{background-color:#218838}.explore-component-content{display:flex;flex-direction:column;gap:14px;min-width:280px}.explore-component-content .tool-group{display:flex;flex-direction:column;gap:8px}.explore-component-content .tool-group h5{margin:0;font-size:1em;color:var(--accent, #f0c674);border-bottom:1px solid var(--border-subtle, #444);padding-bottom:4px}.explore-blurb{margin:0;font-size:.8em;color:var(--text-muted, #999);line-height:1.4}.explore-status{display:flex;align-items:baseline;gap:8px;font-size:.85em}.explore-status-state{font-weight:600;color:var(--text-secondary, #b9b9c2)}.explore-status-state.state-running{color:var(--accent, #f0c674)}.explore-status-state.state-paused{color:#d8b05b}.explore-status-detail{color:var(--text-muted, #87878f);font-variant-numeric:tabular-nums}.explore-run-buttons{display:flex;gap:6px;flex-wrap:wrap}.explore-run-buttons .button{flex:1;min-width:72px;display:inline-flex;align-items:center;justify-content:center;gap:6px}.explore-run-buttons .action-button{background-color:var(--accent-soft, rgba(240, 198, 116, .14));border-color:var(--accent-border, rgba(240, 198, 116, .5));color:var(--accent, #f0c674)}.explore-run-buttons .button:disabled{opacity:.4;cursor:not-allowed}.explore-settings.disabled{opacity:.45;pointer-events:none}.explore-field-label{font-size:.85em;color:var(--text-secondary, #b9b9c2)}.explore-field-hint{font-size:.85em;color:var(--text-muted, #87878f);font-weight:400}.explore-budget-field{display:flex;align-items:center;justify-content:space-between;gap:8px}.explore-budget-input{width:5.5em;padding:3px 6px;background-color:var(--surface-1, #1d1d20);border:1px solid var(--border, #444);border-radius:var(--radius-sm, 6px);color:var(--text-primary, #e6e6ea);font-variant-numeric:tabular-nums}.explore-embedding-field{display:flex;flex-direction:column;gap:4px}.explore-embedding-toggle{display:inline-flex;align-items:center;gap:6px;font-size:.9em;color:var(--text-secondary, #b9b9c2);cursor:pointer}.explore-embedding-status{font-size:.8em;color:var(--text-muted, #87878f);min-height:1em;line-height:1.3}.explore-embedding-status[data-status=loading]{color:var(--accent, #5a9bd4)}.explore-embedding-status[data-status=ready]{color:var(--success, #4caf50)}.explore-embedding-status[data-status=error]{color:var(--text-muted, #87878f)}.explore-component-content.is-running .explore-find-actions [data-action=retest]{opacity:.4;pointer-events:none}.explore-ic-checkboxes{display:flex;gap:8px;flex-wrap:wrap}.explore-ic-checkbox{display:inline-flex;align-items:center;gap:5px;font-size:.85em;text-transform:capitalize;color:var(--text-secondary, #b9b9c2);cursor:pointer}.explore-gallery-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-subtle, #444);padding-bottom:4px}.explore-gallery-header h5{margin:0;border:none;padding:0;font-size:1em;color:var(--accent, #f0c674)}.explore-gallery-count{color:var(--text-muted, #87878f);font-weight:400;font-size:.85em}.explore-gallery-list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto}.explore-gallery-list .empty-state-text{margin:4px 0 0;font-size:.8em;color:var(--text-muted, #999);line-height:1.4}.explore-find{background-color:var(--surface-3, #2a2a2a);border:1px solid var(--border, #444);border-radius:var(--radius-sm, 6px);padding:6px 8px;display:flex;flex-direction:column;gap:6px}.explore-find-row{display:flex;gap:8px;align-items:stretch}.explore-find-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.explore-find-thumb{flex:0 0 auto;width:48px;height:48px;border-radius:var(--radius-sm, 6px);border:1px solid var(--border, #444);background-color:var(--surface-1, #1d1d20);object-fit:cover;image-rendering:pixelated}.explore-find-thumb--empty{display:flex;align-items:center;justify-content:center;color:var(--text-muted, #87878f);font-size:1.4em}.explore-find-head{display:flex;align-items:center;gap:8px}.explore-find-score{font-weight:700;font-variant-numeric:tabular-nums;color:var(--accent, #f0c674);min-width:2.4em}.explore-find-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9em}.explore-find-ic{font-size:.72em;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #87878f);background-color:var(--surface-1, #1d1d20);border-radius:4px;padding:2px 5px;flex-shrink:0}.explore-find-cyclic{font-size:.72em;font-weight:600;color:var(--warning-text, #d8a23a);background-color:var(--warning-surface, rgba(216, 162, 58, .15));border-radius:4px;padding:2px 5px;flex-shrink:0}.explore-find-bars{display:flex;flex-direction:column;gap:2px}.explore-bar-row{display:flex;align-items:center;gap:6px;font-size:.72em;color:var(--text-muted, #87878f)}.explore-bar-label{min-width:4.5em;text-align:right}.explore-bar-track{flex:1;height:6px;border-radius:3px;background-color:var(--surface-1, #1d1d20);overflow:hidden}.explore-bar-fill{display:block;height:100%;background-color:var(--accent-dim, #d8b05b);border-radius:3px}.explore-bar-val{min-width:2.4em;text-align:right;font-variant-numeric:tabular-nums}.explore-find-actions{display:flex;gap:4px;justify-content:flex-end}.explore-find-actions .button-icon{display:inline-flex;align-items:center;justify-content:center;padding:3px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:9999;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-content{background-color:#2c2c2c;padding:20px;border-radius:8px;border:1px solid #555;box-shadow:0 5px 25px #00000080;width:90%;max-width:450px;position:relative}.modal-close-button{position:absolute;top:10px;right:15px;background:none;border:none;font-size:1.8em;color:#aaa;cursor:pointer}.modal-content h3{margin-top:0;color:#f0c674}.modal-content .form-group{margin-bottom:15px}.modal-content label{display:block;margin-bottom:5px;font-size:.9em;color:#ccc}.modal-content input[type=text],.modal-content textarea{width:100%;padding:8px;background-color:#1e1e1e;border:1px solid #555;border-radius:4px;color:#eee;font-size:1em;box-sizing:border-box}.modal-content code{display:block;padding:8px;background-color:#1e1e1e;border:1px solid #555;border-radius:4px;font-family:monospace;word-break:break-all}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-actions .button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:.9em}.modal-actions .button:disabled{opacity:.5;cursor:not-allowed}.modal-content h4{margin:0 0 10px;color:#f0c674}.modal-content p{margin:0 0 15px;color:#ccc;font-size:.9em}.pattern-preview{display:flex;justify-content:center;align-items:center;min-height:80px;max-height:160px;padding:10px;background-color:#1e1e1e;border:1px solid #555;border-radius:4px}.pattern-preview-svg{max-height:140px}.pattern-preview-svg polygon{fill:#3cb44b;stroke:#1e1e1e;stroke-width:.5}.pattern-cell-count{margin:6px 0 0!important;text-align:center;font-size:.85em!important;color:#aaa!important}#initial-state-config-modal .modal-content{max-width:500px;z-index:9999}#initial-state-config-modal .params-container{display:flex;flex-direction:column;gap:5px;margin-top:15px;border-top:1px solid #444;padding-top:15px}#initial-state-config-modal .slider-component-container{display:grid;grid-template-columns:120px 1fr 50px;align-items:center}.actions-popover{position:fixed;background-color:#3a3a3a;border:1px solid #666;border-radius:4px;box-shadow:0 3px 10px #0006;z-index:2100;opacity:0;transform:translateY(-10px);transition:opacity .15s ease-out,transform .15s ease-out;pointer-events:none}.actions-popover.visible{opacity:1;transform:translateY(0);pointer-events:auto}.actions-popover ul{list-style:none;margin:0;padding:5px}.actions-popover li{padding:8px 15px;cursor:pointer;border-radius:3px;color:#eee;font-size:.9em}.actions-popover li:hover{background-color:#0078d4;color:#fff}#toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column-reverse;gap:10px;pointer-events:none}.toast-notification{background-color:#282828e6;color:#f0f0f0;padding:12px 20px;border-radius:6px;border:1px solid #666;box-shadow:0 4px 12px #0006;font-size:.9em;opacity:0;transform:translate(100%);transition:opacity .3s ease-out,transform .3s ease-out;pointer-events:all}.toast-notification.show{opacity:1;transform:translate(0)}.toast-notification.fade-out{opacity:0}.toast-notification.info{border-left:4px solid #3498db}.toast-notification.success{border-left:4px solid #2ecc71}.toast-notification.error{border-left:4px solid #e74c3c}@media screen and (max-width: 768px),screen and (pointer: coarse) and (hover: none){#toast-container{bottom:calc(var(--bottom-tab-bar-height) + 15px);left:50%;right:auto;transform:translate(-50%);width:90%;align-items:center}}.editor-controls{display:flex;justify-content:space-around;align-items:center;gap:10px;flex-wrap:wrap;border-bottom:1px solid #333}.editor-controls .editor-hex-input{font-family:monospace;font-size:1.2em;background-color:#222;color:#eee;border:1px solid #444;border-radius:4px;padding:6px 8px;width:280px;text-align:center;flex-grow:1;min-width:200px}.editor-controls .editor-hex-input::placeholder{color:#666}.editor-controls #rulesetEditorMode{padding:7px;background-color:#333;color:#fff;border:1px solid #555;border-radius:4px;font-size:.85em}.editor-controls #clearRulesButton.button{min-width:80px;height:auto}.editor-apply-scope-controls{display:flex;align-items:flex-end;justify-content:flex-start;gap:10px;padding-bottom:15px;border-bottom:1px solid #333}.editor-apply-scope-controls label{font-size:.9em;color:#ccc}.editor-apply-scope-controls .radio-group{display:inline-flex;border-radius:4px;overflow:hidden;border:1px solid #555;margin-right:auto}.editor-apply-scope-controls .radio-group .radio-switch-label{padding:6px 12px;background-color:#4a4a4a;color:#ccc;border-right:1px solid #555;font-size:.9em}.editor-apply-scope-controls .radio-group .radio-switch-label:last-of-type{border-right:none}.editor-apply-scope-controls .radio-group .radio-switch-input:checked+.radio-switch-label{background-color:#0078d4;color:#fff;font-weight:400}.editor-apply-scope-controls .radio-group .radio-switch-label:hover{background-color:#5a5a5a}.editor-apply-scope-controls .radio-group .radio-switch-input:checked+.radio-switch-label:hover{background-color:#006ac1}.editor-auto-reset-control{display:inline-flex;align-items:center;gap:5px}.editor-auto-reset-control .checkbox-label{padding:6px 10px;font-size:.9em}#rulesetEditorGrid,#neighborCountRulesetEditorGrid,#rotationalSymmetryRulesetEditorGrid{display:grid;margin:0 auto 10px;gap:2px;padding:5px;border:1px solid #333;background-color:#1a1a1a;border-radius:4px}#rulesetEditorGrid{grid-template-columns:repeat(16,5.9%);grid-template-rows:repeat(8,55px);max-width:712px}#neighborCountRulesetEditorGrid{grid-template-columns:repeat(7,13.6%);width:98%;gap:5px}#rotationalSymmetryRulesetEditorGrid{grid-template-columns:repeat(7,14.3%);max-width:900px;gap:0px;padding:10px;background-color:#1c1c1c}.editor-text{font-size:.85em;color:#ccc;margin:0 auto 10px;text-align:left;line-height:1.3;padding:0 5px}.editor-text.info-text{text-align:center;margin-bottom:15px;font-style:italic;color:#aaa}.editor-text-rules{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:5px;margin-top:5px}.editor-text-rules>p,.editor-text>p{margin:0}.rule-viz{position:relative;width:100px;height:110px;margin:auto;transform:scale(.4) translate(-70px,-65px);cursor:pointer}.rule-viz:hover .inner-hex{border-color:#fff}.hexagon{position:absolute;width:40px;height:46.18804px;clip-path:polygon(0% 50%,25% 0%,75% 0%,100% 50%,75% 100%,25% 100%);background-color:#555;box-sizing:border-box}.hexagon:not([style*=background-color]).state-0{background-color:#404040}.hexagon:not([style*=background-color]).state-1{background-color:#fff}.hexagon:not([style*=background-color]).state-2{background:linear-gradient(45deg,#633030,#306330)}.center-hex{top:50%;left:50%;transform:translate(-50%,-50%) scale(1);z-index:1}.inner-hex{width:60%;height:69.28206%;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);border:1px solid #CCCCCC;z-index:2;transition:background-color .2s ease,border-color .2s ease}.inner-hex:not([style*=background-color]).state-0{background-color:#900!important}.inner-hex:not([style*=background-color]).state-1{background-color:#0b0!important}.inner-hex:not([style*=background-color]).state-2{background:linear-gradient(45deg,#700000,#005000)!important;border-color:#888!important}.neighbor-hex{transform-origin:center center;transform:translate(-50%,-50%) scale(.9)}.neighbor-0{top:70%;left:23%}.neighbor-1{top:31%;left:23%}.neighbor-2{top:12%;left:50%}.neighbor-3{top:31%;left:78%}.neighbor-4{top:70%;left:78%}.neighbor-5{top:88%;left:50%}.neighbor-count-rule-viz{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 5px;border:1px solid #444;border-radius:4px;cursor:pointer;background-color:#282828;transition:background-color .2s ease;min-height:80px;box-sizing:border-box}.neighbor-count-rule-viz:hover{background-color:#3a3a3a}.neighbor-count-rule-viz .hexagon.center-hex{position:relative;transform:scale(.8) translate(-46px,-53px);margin-bottom:5px;width:40px;height:46.18804px}.neighbor-count-label{font-size:.75em;text-align:center;color:#ccc;margin-top:3px;line-height:1.2}.r-sym-rule-viz{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5px;border:1px solid #444;border-radius:4px;background-color:#282828;cursor:pointer;transition:background-color .2s ease;min-height:100px}.r-sym-rule-viz:hover{background-color:#3a3a3a}.r-sym-rule-viz .rule-viz-hex-display{position:relative;width:100px;height:110px;transform:scale(.45) translateY(-45px);margin-bottom:-25px}.r-sym-rule-viz .orbit-size-display{font-size:.7em;color:#b0b0b0;margin-top:2px;background-color:#0000004d;padding:1px 4px;border-radius:2px;text-align:center;position:absolute;bottom:3px;left:50%;transform:translate(-50%);white-space:nowrap}.r-sym-rule-viz .rule-label{font-size:.7em;color:#ccc;text-align:center;margin-bottom:0;width:100%}.inline-hex{display:inline-block;width:1em;height:calc(1em * 1.154701);clip-path:polygon(0% 50%,25% 0%,75% 0%,100% 50%,75% 100%,25% 100%);vertical-align:middle;margin:0 2px;position:relative;box-sizing:border-box}.inline-hex-inner{position:absolute;display:inline-block;width:60%;height:69.28206%;clip-path:polygon(0% 50%,25% 0%,75% 0%,100% 50%,75% 100%,25% 100%);top:50%;left:50%;transform:translate(-50%,-50%);border:1px solid #CCCCCC;box-sizing:border-box}.inline-hex.state-0{background-color:#404040}.inline-hex.state-1{background-color:#ff0}.inline-hex-inner.state-0{background-color:#900!important}.inline-hex-inner.state-1{background-color:#0b0!important}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 900px)),(max-width: 768px){.neighbor-count-rule-viz .hexagon.center-hex{transform:scale(.8) translate(-23px,-53px)}#rulesetEditorGrid{grid-template-columns:repeat(8,42px);grid-template-rows:repeat(16,56px)}.editor-controls .editor-hex-input{font-size:1.2em;width:250px}#neighborCountRulesetEditorGrid{grid-template-columns:repeat(7,13.6%)}}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 700px)),(max-width: 600px){#rotationalSymmetryRulesetEditorGrid{grid-template-columns:repeat(4,1fr);gap:0px}.r-sym-rule-viz .rule-viz-hex-display{transform:scale(.45) translateY(-35px);margin-bottom:-30px}}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 600px)),(max-width: 500px){#rotationalSymmetryRulesetEditorGrid{grid-template-columns:repeat(3,1fr);gap:0px}.r-sym-rule-viz .rule-viz-hex-display{transform:scale(.45) translateY(-40px);margin-bottom:-35px}.r-sym-rule-viz{min-height:85px}}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 500px)),(max-width: 480px){.editor-controls{flex-direction:row;align-items:stretch}#rotationalSymmetryRulesetEditorGrid{grid-template-columns:repeat(2,1fr)}}.ruleset-editor-component-content.mobile-context{padding-right:0}.world-setup-component-content{display:flex;flex-direction:column;gap:10px;height:100%}.panel-header-controls{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid #444;margin-bottom:10px}.panel-header-controls .info-text{margin:0;flex-grow:1}.state-control{grid-column:span 2;display:flex;justify-content:space-between;align-items:center;background-color:#0003;padding:5px 8px;border-radius:4px}.state-mode-label{font-size:.9em}.state-mode-value{color:#f0c674}.world-config-grid{display:grid;gap:10px;padding:10px 0;grid-template-columns:repeat(3,1fr);overflow-y:auto;flex-grow:1}.world-config-cell .state-control{grid-column:span 2}.world-ruleset-name{grid-column:span 2;font-size:.8em;font-style:italic;color:#9fa8c0;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.world-config-cell{border:1px solid #333;border-radius:6px;padding:5px;background-color:#ffffff08;display:grid;grid-template-columns:.5fr .5fr;align-items:center}.world-label{font-weight:700;font-size:.9em;color:#bbb}.world-config-cell .ruleset-viz-container{display:flex;justify-content:center;align-items:center}.world-config-cell .ruleset-hex{font-family:monospace;font-size:.9em;background-color:#3a3a3a;padding:3px 6px;border-radius:4px}.setting-control{width:100%;display:flex;flex-direction:column;align-items:stretch;gap:5px}.setting-control label{font-size:.8em;color:#aaa;text-align:center}.density-control .slider-component-container{width:100%}.density-control .slider-component-container input[type=range]{width:100%;min-width:0}.enable-control label.checkbox-label{padding:6px 12px;font-size:.85em;text-align:center;width:100%;box-sizing:border-box}.world-config-cell .button.set-ruleset-button{height:auto;padding:6px 10px;font-size:.8em;min-width:0;width:100%;margin-top:5px}.panel-actions{border-top:1px solid #444;padding-top:10px;display:flex;flex-direction:row;gap:10px;flex-shrink:0}.panel-actions .button{width:100%;padding:12px;font-size:1em}@media (max-width: 768px){.world-config-grid{grid-template-columns:repeat(2,1fr);gap:8px}.world-config-cell{padding:8px;gap:6px}.world-label{font-size:.85em}.panel-actions{flex-direction:column;gap:8px}.panel-actions .button{padding:10px;font-size:.9em}}@media (max-width: 480px){.world-config-grid{grid-template-columns:1fr}}.analysis-component-content{display:flex;flex-direction:column;gap:15px;height:100%}.plugins-mount-area{display:flex;flex-direction:column;gap:15px}.analysis-plugin-container{border:1px solid #383838;border-radius:4px;padding:10px;background-color:#0000001a}.analysis-plugin-container .plugin-canvas{display:block;width:100%;height:100px;background-color:#2a2a2a;border-radius:2px}.analyze-view-header{display:flex;justify-content:stretch;background-color:#2a2a2a;padding:10px;flex-shrink:0}.analyze-view-segment{flex-grow:1;padding:12px 5px;font-size:.9em;text-align:center;background-color:#3a3a3a;color:#ccc;border:none;border-right:1px solid #555}.analyze-view-segment:last-child{border-right:none}.analyze-view-segment.active{background-color:#f0c674;color:#1e1e1e;font-weight:700}.analyze-pane{display:flex;flex-direction:column;gap:20px}.analyze-pane .plugin-canvas{width:100%;height:auto;max-height:150px}.mobile-rank-list{display:flex;flex-direction:column;gap:8px}.mobile-rank-item{display:grid;grid-template-columns:20px 50px 1fr 60px;align-items:center;gap:10px;background-color:#2a2a2a;padding:8px;border-radius:4px}.mobile-rank-item .rank{font-weight:700;color:#888}.mobile-rank-item .viz{transform:scale(.3) translate(-80px,-85px);height:35px}.mobile-rank-item .usage{text-align:right;font-family:monospace;font-size:.9em}.entropy-plugin-container{display:flex;flex-direction:column;gap:10px}.entropy-controls-section{display:flex;flex-direction:column;gap:8px;padding:8px;background-color:#0000001a;border-radius:4px;border:1px solid #333}.entropy-display-section{display:flex;align-items:center;justify-content:space-between;font-size:.9em}.entropy-display-section label{color:#ccc}.entropy-value-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.entropy-value-row:last-child{margin-bottom:0}.entropy-value{font-weight:700;padding:2px 6px;background-color:#0000004d;border-radius:3px;color:#fff;min-width:60px;text-align:right}.entropy-sampling-controls{display:flex;flex-direction:column;gap:6px}.sampling-enable-control{display:flex;align-items:center;gap:6px}.sampling-enable-control .checkbox-label{font-size:.85em;color:#bbb}#ranks-pane>h4{margin:0}.analysis-component-content.mobile-context{padding:0}.interestingness-metrics-plugin{display:flex;flex-direction:column;gap:10px}.interestingness-metrics-plugin .im-blurb{margin:0;font-size:.78em;color:#aaa;line-height:1.4}.interestingness-metrics-plugin .im-controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.interestingness-metrics-plugin .im-ticks-field,.interestingness-metrics-plugin .im-probe-field{display:inline-flex;align-items:center;gap:5px;font-size:.82em;color:#ccc}.interestingness-metrics-plugin .im-ticks-field input{width:5em;background-color:var(--surface-1, #1d1d20);border:1px solid #444;border-radius:3px;color:#eee;padding:2px 4px}.interestingness-metrics-plugin .im-measure-btn{padding:5px 12px;border:1px solid var(--accent-dim, #d8b05b);border-radius:4px;background-color:#d8b05b1f;color:var(--accent, #f0c674);cursor:pointer;font-size:.85em}.interestingness-metrics-plugin .im-measure-btn:hover:not(:disabled){background-color:#d8b05b40}.interestingness-metrics-plugin .im-measure-btn:disabled{opacity:.5;cursor:default}.interestingness-metrics-plugin .im-status{font-size:.85em;color:#ddd;display:flex;align-items:center;gap:8px}.interestingness-metrics-plugin .im-kill{color:#e07a7a;font-weight:700}.interestingness-metrics-plugin .im-score-bar{display:inline-block;flex:1;max-width:120px;height:6px;border-radius:3px;background-color:var(--surface-1, #1d1d20);overflow:hidden}.interestingness-metrics-plugin .im-score-fill{display:block;height:100%;background-color:var(--accent, #f0c674);border-radius:3px}#ruleRankPanel{width:600px;max-height:70vh}#ruleRankPanel .panel-content-area{padding:0}#ruleRankContent .empty-state-text{text-align:center;color:#888;padding-top:20px;font-style:italic}.dual-rank-container{display:flex;justify-content:space-between;gap:10px;padding:10px;height:100%}.rank-column{flex:1;min-width:0;background-color:#0003;border:1px solid #333;border-radius:4px;display:flex;flex-direction:column;overflow:hidden}.rank-column-header{font-weight:700;text-align:center;padding:8px;background-color:#ffffff14;border-bottom:1px solid #444;font-size:.9em;color:#ddd;flex-shrink:0}.rank-list-content{overflow-y:auto;flex-grow:1}.rank-list-header,.rank-list-item{display:grid;grid-template-columns:50px 1fr 120px;align-items:center;padding:8px 10px;border-bottom:1px solid #333;font-size:.9em;position:relative}.rank-list-header{font-weight:700;color:#ccc;background-color:#282828f2;position:sticky;top:0;z-index:10}.rank-list-item:hover{background-color:#ffffff0d}.rank-list-item .rank-list-rank{font-weight:700;font-size:1.1em;color:#aaa;text-align:center;z-index:1}.rank-list-item .rank-list-viz-container{z-index:1}.rank-list-item .rank-list-viz{transform:scale(.45) translate(-10px);margin:-30px 0}.rank-list-item .rank-list-usage{font-family:monospace;text-align:right;font-weight:700;font-size:.9em;z-index:1}.rank-list-item .usage-percent{font-size:1.1em;color:#fff}.rank-list-item .usage-count{font-size:.8em;color:#aaa;margin-top:2px}.usage-background-bar{position:absolute;left:0;top:0;height:100%;z-index:0;pointer-events:none;transition:width .3s ease-out}#activation-rank .usage-background-bar{background-color:#3b82f640}#deactivation-rank .usage-background-bar{background-color:#ef444440}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 900px)),(max-width: 768px){#ruleRankPanel{width:clamp(300px,85vw,400px);max-height:80vh}.rank-list-header,.rank-list-item{grid-template-columns:40px 1fr 100px;padding:6px 8px;font-size:.85em}}@media screen and ((hover: none) and (pointer: coarse) and (orientation: portrait) and (max-height: 500px)),(max-width: 480px){#ruleRankPanel{width:100%;max-height:100vh}.rank-list-header,.rank-list-item{grid-template-columns:35px 1fr 90px;padding:5px 6px;font-size:.8em}}#settingsPopout .form-group{display:flex;flex-direction:column;gap:8px}#settingsPopout .radio-group{display:flex;flex-direction:column;gap:5px}.ruleset-viz-container{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle}.ruleset-viz-svg{border:1px solid #555;border-radius:2px;width:24px;height:48px;background-color:#111}#minimap-overlays-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:50}.minimap-ruleset-overlay{position:absolute;width:32px;height:64px;opacity:.85;box-sizing:border-box;transition:opacity .2s ease;transform-origin:top left}.minimap-ruleset-overlay.mini{transform:scale(.5);opacity:.9}.minimap-ruleset-overlay svg{width:100%;height:100%}#rulesetDisplayContainer .ruleset-viz-container{width:24px;height:24px;margin-right:8px}.world-card .ruleset-viz-container{width:24px;height:48px;margin-left:10px}.world-card-header{display:flex;justify-content:space-between;align-items:center}.tools-bottom-sheet-content{display:flex;flex-direction:column;gap:10px;padding:10px}.tool-group{display:flex;flex-direction:column}.tool-group h5{margin:0;font-size:1em;color:#f0c674;border-bottom:1px solid #444;padding-bottom:0}.tool-group .slider-component-container{padding:0 4px}.reset-clear-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px}.bottom-sheet-tabs{display:flex;justify-content:stretch;background-color:#2a2a2a;padding:0;flex-shrink:0}.bottom-sheet-tabs .tab-button{flex-grow:1;padding:12px 5px;font-size:.9em;text-align:center;background-color:#3a3a3a;color:#ccc;border:none;border-right:1px solid #555;transition:background-color .2s}.bottom-sheet-tabs .tab-button:last-child{border-right:none}.bottom-sheet-tabs .tab-button.active{background-color:#f0c674;color:#1e1e1e;font-weight:700}.bottom-sheet-panes .pane.hidden{display:none}.fab-custom-toggle{display:flex;justify-content:space-between;align-items:center;background-color:#0000001a;padding:10px;border-radius:4px}.fab-action-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}.fab-action-list li{display:flex;align-items:center;background-color:#0003;padding:8px 12px;border-radius:4px;border:1px solid #333}.fab-action-list li .icon{font-size:1.5em}.fab-action-list li .text{flex-grow:1;color:#ddd}.keyboard-shortcuts-component-content{display:flex;flex-direction:column;gap:14px;height:100%}.kb-board-view{display:flex;flex-direction:column;gap:12px;width:520px;max-width:100%}.kb-controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.kb-search{flex:1 1 180px;min-width:150px;background-color:#2a2a2a;border:1px solid #555;border-radius:6px;color:#eee;padding:7px 10px;font-size:.9em}.kb-search:focus{outline:none;border-color:#f0c674}.kb-layers{display:flex;gap:6px}.kb-layer{background-color:#333;border:1px solid #555;border-radius:6px;color:#ccc;padding:6px 11px;font-size:.85em;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.kb-layer:hover{background-color:#444}.kb-layer.kb-on{background-color:#4a4a4a;border-color:#888;color:#fff;font-weight:600}.kb-keys{display:flex;flex-direction:column;gap:6px}.kb-row{display:flex;gap:6px}.kb-key{position:relative;flex:1 1 0;min-width:44px;height:54px;border:1px solid #555;border-bottom:3px solid #555;border-radius:7px;background-color:#2c2c2c;color:#777;font-family:monospace;padding:0;cursor:default;text-align:left;box-sizing:border-box;transition:transform .06s ease,opacity .12s ease}.kb-key .kb-cap{position:absolute;top:4px;left:7px;font-size:11px;font-weight:600;line-height:1}.kb-key .kb-act{position:absolute;left:7px;right:7px;top:19px;bottom:4px;font-family:inherit;font-size:9.5px;line-height:1.12;color:#cfcfcf;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.kb-key.kb-bound{color:#f0f0f0}.kb-key.kb-active{transform:translateY(-1px)}.kb-key.kb-dim{opacity:.34}.kb-key.kb-search-miss{opacity:.12}.kb-key.kb-mod-on{border-bottom-color:#f0c674;color:#f0f0f0}.kb-lower{display:flex;gap:16px;align-items:stretch}.kb-numpad{display:flex;flex-direction:column;gap:4px}.kb-numpad-label{font-size:10px;color:#999;max-width:118px;line-height:1.2}.kb-numpad-label kbd{padding:1px 4px;font-size:.85em}.kb-numpad-grid{display:grid;grid-template-columns:repeat(3,34px);gap:4px}.kb-key.kb-np{flex:none;height:34px;min-width:34px;display:flex;align-items:center;justify-content:center;padding:0;color:#f0f0f0}.kb-key.kb-np .kb-cap{position:static;font-size:.85em}.kb-detail{flex:1;min-width:0;min-height:86px;background-color:#262626;border:1px solid #3a3a3a;border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;justify-content:center;gap:4px}.kb-detail-hint{font-size:.85em;color:#999}.kb-detail-hint kbd{padding:1px 5px}.kb-detail-row{display:flex;align-items:center;gap:9px;font-size:.85em}.kb-detail-dot{flex:none;width:10px;height:10px;border-radius:3px}.kb-detail-combo{flex:none;min-width:58px;font-family:monospace;color:#bbb}.kb-detail-desc{color:#eee;min-width:0;overflow-wrap:anywhere}.kb-detail-row.kb-ctx .kb-detail-desc{font-style:italic;color:#c7c7c7}.kb-legend{display:flex;flex-wrap:wrap;gap:14px;font-size:12px;color:#bbb}.kb-legend span{display:inline-flex;align-items:center;gap:6px}.kb-legend i{width:11px;height:11px;border-radius:3px;display:inline-block}.kb-list-view{display:none;flex-direction:column;gap:15px}.shortcut-category h4{margin:0 0 10px;color:#f0c674;border-bottom:1px solid #444;padding-bottom:5px}.shortcut-category ul{list-style:none;padding:0;margin:0}.shortcut-category li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #333}.shortcut-category li:last-child{border-bottom:none}.keys{display:flex;gap:4px;align-items:center}kbd{background-color:#4a4a4a;border:1px solid #666;border-radius:3px;padding:4px 8px;font-family:monospace;font-size:.9em;color:#eee;white-space:nowrap}.description{color:#ccc;font-size:.9em;text-align:right}@media screen and (max-width: 768px){.kb-board-view{display:none}.kb-list-view{display:flex}}.mobile-view{position:fixed;top:0;left:0;right:0;bottom:var(--bottom-tab-bar-height);background-color:#1e1e1e;z-index:4501;display:flex;flex-direction:column;overflow:hidden}.mobile-view.hidden{display:none}.mobile-view-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid #444;background-color:#2a2a2a;flex-shrink:0}.mobile-view-title{font-size:1.5em;color:#f0c674;margin:0}.mobile-view-close-button{background:none;border:none;color:#ccc;font-size:2em;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:4px}.mobile-view-close-button:hover{background-color:#444;color:#fff}.mobile-view-content{flex:1;overflow-y:auto;padding:15px}.mobile-view-content .world-setup-component-content{height:100%}#rules-view .mobile-view-content-area,#worlds-view .worlds-list,#analyze-view .analyze-view-content,#more-view #more-view-content{overflow-y:auto;flex-grow:1}#editor-view .ruleset-editor-component-content{height:100%;overflow-y:auto}#more-view{background-color:#1e1e1e;padding:20px;display:flex;flex-direction:column;gap:15px}#more-view .more-view-title{font-size:1.5em;color:#f0c674;text-align:center;margin-bottom:20px}#more-view .button,#more-view .file-input-label{display:block;width:100%;text-align:center;padding:15px;font-size:1.1em;background-color:#3a3a3a;border:1px solid #555;box-sizing:border-box}#more-view .file-input-label{cursor:pointer}:root{--bg-app: #161618;--surface-1: #1d1d20;--surface-2: #242428;--surface-3: #2e2e34;--surface-4: #3a3a42;--surface-5: #45454e;--border-subtle: #2e2e33;--border: #3c3c44;--border-strong: #54545e;--text-primary: #f2f2f4;--text-secondary: #b9b9c2;--text-muted: #87878f;--accent: #f0c674;--accent-bright: #ffd98e;--accent-dim: #d8b05b;--on-accent: #1c1505;--accent-soft: rgba(240, 198, 116, .14);--accent-soft-hover: rgba(240, 198, 116, .22);--accent-border: rgba(240, 198, 116, .5);--danger: #e06c75;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-popout: 0 10px 28px rgba(0, 0, 0, .5), 0 2px 6px rgba(0, 0, 0, .35);--shadow-panel: 0 18px 48px rgba(0, 0, 0, .55), 0 4px 12px rgba(0, 0, 0, .4)}body{background-color:var(--bg-app);color:var(--text-primary)}canvas#hexGridCanvas{background-color:var(--bg-app)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:var(--surface-5);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.button{background-color:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:7px 14px;transition:background-color .15s ease,border-color .15s ease}.button:hover{background-color:var(--surface-4);border-color:var(--border-strong)}.button:active{background-color:var(--surface-5)}.checkbox-label{background-color:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary)}.checkbox-label:hover{background-color:var(--surface-4)}.checkbox-input:checked+.checkbox-label{background-color:var(--accent-soft);border-color:var(--accent-border);color:var(--accent)}.switch-group{border:1px solid var(--border);border-radius:var(--radius-sm);background-color:var(--surface-2)}.switch-label,.radio-switch-label{background-color:transparent;color:var(--text-secondary);border-right:1px solid var(--border)}.switch-label:hover,.radio-switch-label:hover{background-color:var(--surface-4)}.switch-input:checked+.switch-label,.radio-switch-input:checked+.radio-switch-label,.editor-apply-scope-controls .radio-group .radio-switch-input:checked+.radio-switch-label{background-color:var(--accent-soft);color:var(--accent);font-weight:600}.switch-input:checked+.switch-label:hover{background-color:var(--accent-soft-hover)}.three-way-switch{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background-color:var(--surface-2)}.type-checkbox .switch-label{border:1px solid var(--border);border-radius:var(--radius-sm)}.slider-component-container input[type=range]{color:var(--accent-dim);--track-color: rgba(255, 255, 255, .12)}.slider-component-container label,.switch-component-label{color:var(--text-secondary)}.slider-tooltip{background-color:var(--surface-2);border:1px solid var(--border-strong);color:var(--accent)}.popout-panel .hex-input,input[type=text],input[type=number],textarea,select{background-color:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary)}input[type=text]:focus,input[type=number]:focus,textarea:focus,select:focus{border-color:var(--accent-border);outline:none}#top-info-bar{background-color:var(--surface-1);border-bottom:1px solid var(--border-subtle);gap:12px}#appLogo{color:var(--accent)}#appMenuButton:hover{background-color:var(--surface-3)}#rulesetDisplayContainer{background-color:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}#rulesetDisplayCode{color:var(--accent)}#statsDisplayContainer{font-variant-numeric:tabular-nums;color:var(--text-muted)}#statsDisplayContainer span span{color:var(--text-primary)}.ruleset-history-controls .button-icon,.save-ruleset-button{background-color:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary)}.ruleset-history-controls .button-icon:hover:not(:disabled),.save-ruleset-button:hover:not([style*="cursor: not-allowed"]){background-color:var(--surface-3);transform:none}.ruleset-history-controls .button-icon:disabled{background-color:transparent;color:var(--surface-5)}.save-ruleset-button.not-saved,.save-ruleset-button.is-public,.save-ruleset-button.is-personal{background-color:transparent}.inline-icon{display:inline-flex;vertical-align:-.15em}.inline-icon svg{width:1.1em;height:1.1em}#vertical-toolbar{background-color:var(--surface-1);border-right:1px solid var(--border-subtle);gap:3px;padding:8px 0}@media screen and (min-width: 769px){.toolbar-button{width:38px;height:38px}}.toolbar-button{background-color:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);transition:background-color .15s ease,color .15s ease}.toolbar-button svg{width:20px;height:20px;display:block}.toolbar-button:hover{background-color:var(--surface-3);color:var(--text-primary)}.toolbar-button:active,.toolbar-button.active{background-color:var(--accent-soft);border-color:transparent;color:var(--accent)}#playPauseButton{background-color:var(--accent);color:var(--on-accent)}#playPauseButton:hover{background-color:var(--accent-bright);color:var(--on-accent)}.toolbar-separator{background-color:var(--border-subtle);margin:4px 0;flex-shrink:0}.popout-panel{background-color:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-popout)}.popout-panel h4{border-bottom:1px solid var(--border-subtle);color:var(--text-primary);font-size:.8em;text-transform:uppercase;letter-spacing:.08em;padding-bottom:8px;margin-bottom:10px}.popout-panel .popout-separator{background-color:var(--border-subtle)}.popout-panel .form-group label:not(.checkbox-label):not(.radio-switch-label){color:var(--text-secondary)}.history-item{border-bottom:1px solid var(--border-subtle)}.history-item:hover{background-color:var(--surface-4)}.history-item.is-current{color:var(--accent);background-color:var(--accent-soft)}.popout-link-list li a:hover{background-color:var(--surface-4);color:var(--text-primary)}.actions-popover li:hover{background-color:var(--surface-4)}.tab-button{color:var(--text-muted)}.tab-button:hover{background-color:var(--surface-3)}.tab-button.active{color:var(--accent);border-bottom-color:var(--accent)}.library-filter-tabs .sub-tab-button.active{background-color:var(--accent-soft);color:var(--accent)}@media screen and (min-width: 769px){.draggable-panel-base{background-color:#202024f5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-panel)}.draggable-panel-base h3{border-bottom:1px solid var(--border-subtle);color:var(--text-primary);font-size:.85em;text-transform:uppercase;letter-spacing:.1em}}.close-panel-button{color:var(--text-muted);border-radius:var(--radius-sm)}.close-panel-button:hover{color:var(--text-primary)}.button-help-trigger:hover{background:var(--accent-soft);color:var(--accent)}.learning-section-header{list-style:none;font-size:.72em;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:12px 4px 4px;border-bottom:1px solid var(--border-subtle);margin-bottom:4px}@media screen and (max-width: 768px),screen and (pointer: coarse) and (hover: none){#app-container{min-width:0;max-width:100vw}#rulesetDisplayContainer{max-width:100%;min-width:0}.ruleset-display-toggle{min-width:0;flex:1;overflow:hidden}#rulesetDisplayName,#rulesetDisplayCode{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}#top-info-bar{padding:6px 8px;gap:6px}#statsDisplayContainer{justify-content:space-between;gap:4px;font-size:.9em;overflow:hidden}#statsDisplayContainer>span,#statsDisplayContainer>span:first-child{min-width:0;white-space:nowrap}#bottom-tab-bar{background-color:var(--surface-1);border-top:1px solid var(--border-subtle)}.tab-bar-button{color:var(--text-muted);font-size:.62em;gap:3px;min-width:0;padding:0 2px;overflow:hidden}.tab-bar-button .icon{font-size:1.6em;display:flex;align-items:center;justify-content:center}.tab-bar-button .icon svg{width:22px;height:22px}.tab-bar-button .label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.tab-bar-button.active{color:var(--accent)}.mobile-fab{background-color:#28282eeb;border:1px solid var(--border-strong);color:var(--text-primary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mobile-fab .icon svg{width:24px;height:24px;display:block}.secondary-fab{background-color:#28282eeb;border:1px solid var(--border-strong)}.secondary-fab:hover{background-color:var(--surface-4)}.primary-fab{background-color:var(--accent);border:none;color:var(--on-accent)}.primary-fab svg{width:30px;height:30px;display:block}.primary-fab:hover{background-color:var(--accent-bright)}.primary-fab:active{background-color:var(--accent-dim)}.draggable-panel-base{background-color:var(--bg-app)}}
