*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}:root,[data-theme=midnight]{--bg-primary:#0a0a0f;--bg-secondary:#12121c;--bg-tertiary:#1a1a2e;--bg-gradient:linear-gradient(165deg, var(--bg-primary) 0%, var(--bg-secondary) 40%, var(--bg-tertiary) 100%);--surface:#ffffff0a;--surface-hover:#ffffff1a;--border:#ffffff14;--border-hover:#818cf859;--text-primary:#f8fafc;--text-secondary:#e2e8f0;--text-muted:#94a3b8f2;--text-subtle:#94a3b8bf;--accent:#6366f1;--accent-light:#a5b4fc;--accent-lighter:#818cf8;--accent-bg:#6366f140;--accent-bg-hover:#6366f159;--accent-border:#818cf873;--accent-gradient:linear-gradient(135deg, #6366f1, #7c3aed);--accent-shadow:#6366f159;--header-bg:#0a0a0fb8;--panel-bg:#0a0a0f;--shadow:#00000059;--shadow-heavy:#0006;--pricing-featured-bg:linear-gradient(160deg, #6366f11f, #1a1a2e80)}[data-theme=light]{--bg-primary:#f8f9fb;--bg-secondary:#fff;--bg-tertiary:#f0f2f5;--bg-gradient:linear-gradient(165deg, var(--bg-primary) 0%, var(--bg-secondary) 40%, var(--bg-tertiary) 100%);--surface:#00000008;--surface-hover:#0000000f;--border:#00000014;--border-hover:#6366f166;--text-primary:#1e293b;--text-secondary:#334155;--text-muted:#475569e6;--text-subtle:#64748bbf;--accent:#6366f1;--accent-light:#6366f1;--accent-lighter:#818cf8;--accent-bg:#6366f11a;--accent-bg-hover:#6366f12e;--accent-border:#6366f14d;--accent-gradient:linear-gradient(135deg, #6366f1, #7c3aed);--accent-shadow:#6366f133;--header-bg:#ffffffd9;--panel-bg:#fff;--shadow:#00000014;--shadow-heavy:#0000001f;--pricing-featured-bg:linear-gradient(160deg, #6366f114, #f1f5f9cc)}[data-theme=grey]{--bg-primary:#1a1a1a;--bg-secondary:#2a2a2a;--bg-tertiary:#333;--bg-gradient:linear-gradient(165deg, var(--bg-primary) 0%, var(--bg-secondary) 40%, var(--bg-tertiary) 100%);--surface:#ffffff0d;--surface-hover:#ffffff1a;--border:#ffffff1a;--border-hover:#9ca3af66;--text-primary:#f3f4f6;--text-secondary:#d1d5db;--text-muted:#9ca3aff2;--text-subtle:#9ca3afb3;--accent:#9ca3af;--accent-light:#d1d5db;--accent-lighter:#9ca3af;--accent-bg:#9ca3af26;--accent-bg-hover:#9ca3af40;--accent-border:#9ca3af59;--accent-gradient:linear-gradient(135deg, #6b7280, #4b5563);--accent-shadow:#6b72804d;--header-bg:#1a1a1ad9;--panel-bg:#1a1a1a;--shadow:#0000004d;--shadow-heavy:#0006;--pricing-featured-bg:linear-gradient(160deg, #6b728026, #2a2a2a99)}body{-webkit-font-smoothing:antialiased;min-height:100vh;color:var(--text-secondary);background:var(--bg-gradient);background-attachment:fixed;margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5}#root{min-height:100vh}h1,h2,h3,p,ul{margin:0}button{font-family:inherit}.demo-root{--content-max-width:50rem;min-height:100vh;padding-bottom:11rem;position:relative}.state-badge{z-index:50;letter-spacing:.06em;text-transform:uppercase;color:var(--text-primary);background:var(--accent-bg);border:1px solid var(--accent-border);-webkit-backdrop-filter:blur(12px);box-shadow:0 4px 24px var(--shadow);border-radius:999px;padding:.35rem .85rem;font-size:.7rem;font-weight:600;position:fixed;top:1rem;right:1rem}.site-header{z-index:40;border-bottom:1px solid var(--border);background:var(--header-bg);-webkit-backdrop-filter:blur(16px);position:sticky;top:0}.nav-inner{max-width:var(--content-max-width);align-items:center;gap:2rem;margin:0 auto;padding:1rem 1.5rem;display:flex}.logo-mark{background:var(--accent-gradient);color:#0000;-webkit-background-clip:text;background-clip:text;margin-right:auto;font-size:1.1rem;font-weight:700}.nav-link{color:var(--text-muted);font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-link:hover{color:var(--accent-light)}.nav-theme{border:1px solid var(--border);border-radius:.4rem;flex-shrink:0;display:flex;overflow:hidden}.nav-theme-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:.3rem .6rem;font-family:inherit;font-size:.72rem;font-weight:600;transition:background .15s,color .15s}.nav-theme-btn:not(:last-child){border-right:1px solid var(--border)}.nav-theme-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.nav-theme-btn-active{background:var(--accent-bg-hover);color:var(--text-primary)}main{max-width:var(--content-max-width);margin:0 auto;padding:0 1.5rem}.hero{justify-content:center;align-items:center;min-height:min(92vh,52rem);padding:4rem 0 8rem;display:flex;position:relative}.hero-glow{background:radial-gradient(ellipse at 50% 40%, var(--accent-bg), transparent 65%);pointer-events:none;height:50%;position:absolute;inset:10% 15% auto}.hero-inner{text-align:center;max-width:44rem;padding:0 .5rem clamp(4rem,18vh,10rem);position:relative}.hero-eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--accent-lighter);margin-bottom:1rem;font-size:.8rem;font-weight:600}.hero-title{letter-spacing:-.03em;color:var(--text-primary);margin-bottom:1.25rem;font-size:clamp(2.25rem,5vw,3.35rem);font-weight:700;line-height:1.08}.hero-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:1.05rem;line-height:1.65}.hero-cta{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:1.75rem;display:flex}.btn{cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;padding:.75rem 1.35rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 8px 32px var(--accent-shadow)}.btn-primary:hover{box-shadow:0 12px 40px var(--accent-shadow);transform:translateY(-2px)}.btn-ghost{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-hover);border-color:var(--border-hover)}.hero-hint{color:var(--accent-light);font-size:.9rem;font-weight:500}.hero-name-picker{vertical-align:baseline;display:inline-flex;position:relative}.hero-name-btn{all:unset;cursor:pointer;border-bottom:2.5px dotted var(--accent-lighter);background:var(--accent-gradient);color:#0000;-webkit-background-clip:text;background-clip:text;align-items:baseline;gap:.15em;padding-bottom:.06em;transition:border-color .2s,color .2s;display:inline-flex}.hero-name-btn:hover,.hero-name-btn[aria-expanded=true]{border-bottom-color:var(--accent)}.hero-name-chevron{color:var(--accent-lighter);vertical-align:middle;flex-shrink:0;transition:transform .2s;display:inline-block;position:relative;top:-.08em}.hero-name-btn[aria-expanded=true] .hero-name-chevron{transform:rotate(180deg)}.hero-name-dropdown{background:var(--bg-secondary);border:1px solid var(--border-hover);min-width:10rem;box-shadow:0 12px 48px var(--shadow-heavy);z-index:60;border-radius:.65rem;flex-direction:column;gap:.15rem;margin:0;padding:.35rem;list-style:none;animation:.15s ease-out hero-dropdown-in;display:flex;position:absolute;top:calc(100% + .4rem);left:50%;transform:translate(-50%)}@keyframes hero-dropdown-in{0%{opacity:0;transform:translate(-50%)translateY(-4px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.hero-name-option{all:unset;width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;box-sizing:border-box;border-radius:.4rem;padding:.45rem .75rem;font-size:.95rem;font-weight:600;transition:background .15s,color .15s;display:block}.hero-name-option:hover{background:var(--surface-hover);color:var(--text-primary)}.hero-name-option-active{background:var(--accent-bg);color:var(--accent-lighter)}.hero-name-option-active:hover{background:var(--accent-bg-hover)}.section{padding:5rem 0;scroll-margin-top:5rem}.container{max-width:var(--content-max-width);margin:0 auto}.section-title{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:.75rem;font-size:clamp(1.75rem,3.5vw,2.25rem);font-weight:700}.section-lead{color:var(--text-muted);max-width:36rem;margin-bottom:2.5rem;font-size:1.05rem;line-height:1.6}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(15.5rem,1fr));gap:1.25rem;display:grid}.feature-card{background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);border-radius:1rem;padding:1.5rem 1.35rem;transition:border-color .25s,box-shadow .25s,transform .25s}.feature-card:hover{border-color:var(--border-hover);box-shadow:0 12px 40px var(--shadow);transform:translateY(-3px)}.feature-icon{color:var(--accent-light);margin-bottom:.85rem;font-size:1.25rem;display:block}.feature-name{color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.feature-desc{color:var(--text-muted);font-size:.9rem;line-height:1.55}.pricing{padding-bottom:6rem}.pricing-grid{grid-template-columns:repeat(auto-fit,minmax(16rem,1fr));align-items:stretch;gap:1.25rem;display:grid}.pricing-card{background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);border-radius:1rem;padding:1.75rem 1.5rem;position:relative}.pricing-card-featured{border-color:var(--accent-border);background:var(--pricing-featured-bg);box-shadow:0 16px 48px var(--accent-shadow)}.pricing-badge{letter-spacing:.08em;text-transform:uppercase;background:var(--accent);color:#fff;border-radius:.35rem;padding:.25rem .5rem;font-size:.65rem;font-weight:700;position:absolute;top:1rem;right:1rem}.pricing-name{color:var(--text-secondary);margin-bottom:.75rem;font-size:1.05rem;font-weight:600}.pricing-price{margin-bottom:1.25rem}.price-amount{color:var(--text-primary);font-size:2.25rem;font-weight:700}.price-unit{color:var(--text-muted);margin-left:.25rem;font-size:.95rem}.pricing-list{margin:0;padding:0;list-style:none}.pricing-list li{color:var(--text-muted);border-bottom:1px solid var(--border);padding:.4rem 0;font-size:.9rem}.pricing-list li:last-child{border-bottom:none}.pricing-list a{color:var(--accent);word-break:break-all;font-size:.8rem;font-weight:500;text-decoration:none}.pricing-list a:hover{text-decoration:underline}.pricing-cta{color:var(--text-muted);text-align:center;max-width:36rem;margin-top:2.5rem;margin-left:auto;margin-right:auto;font-size:.95rem;line-height:1.6}.pricing-cta a{color:var(--accent);font-weight:600;text-decoration:none}.pricing-cta a:hover{text-decoration:underline}.controls-spacer{min-height:2rem;padding:0}.site-footer{border-top:1px solid var(--border);padding:2rem 1.5rem 10rem}.footer-inner{text-align:center}.site-footer p{color:var(--text-subtle);font-size:.85rem}.site-footer a{color:var(--text-muted);font-weight:500;text-decoration:none}.site-footer a:hover{color:var(--accent)}.control-panel{z-index:45;background:var(--panel-bg);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(20px)saturate(1.2);box-shadow:0 -8px 40px var(--shadow-heavy);padding:.75rem 1rem 1rem;position:fixed;bottom:0;left:0;right:0}.control-panel-inner{max-width:var(--content-max-width);margin:0 auto}.control-panel-header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.control-panel-label{letter-spacing:.1em;text-transform:uppercase;color:var(--accent-light);font-size:.7rem;font-weight:600}.quick-actions{align-items:center;gap:.3rem;display:flex}.quick-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:999px;padding:.3rem .6rem;font-family:inherit;font-size:.68rem;font-weight:600;transition:background .15s,border-color .15s,color .15s,box-shadow .3s}.quick-btn:hover{background:var(--surface-hover);border-color:var(--border-hover);color:var(--text-primary)}.quick-btn-primary{background:var(--accent-light);border-color:var(--accent-light);color:#fff;box-shadow:0 0 8px var(--accent-shadow)}.quick-btn-primary:hover{filter:brightness(1.15)}.quick-btn-danger{color:#ef4444;background:#ef444426;border-color:#ef444466}.quick-btn-danger:hover{background:#ef444440;border-color:#ef4444}.quick-btn-active{border-color:var(--accent-light);box-shadow:0 0 10px var(--accent-shadow);animation:1.5s ease-in-out infinite ctrl-pulse}.panel-character-select{align-items:center;gap:.4rem;margin-left:auto;display:flex}.download-glb-btn{border:1px solid var(--border);background:var(--surface);width:1.6rem;height:1.6rem;color:var(--text-muted);cursor:pointer;border-radius:.375rem;justify-content:center;align-items:center;padding:0;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.download-glb-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--surface-hover,var(--surface))}.panel-character-label{color:var(--text-muted);white-space:nowrap;opacity:.7;font-size:.65rem;font-weight:500;line-height:1}.selector-dropdown{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:.4rem;padding:.3rem .5rem;font-family:inherit;font-size:.7rem;font-weight:600}.selector-dropdown option{background:var(--bg-secondary);color:var(--text-primary)}.selector-dropdown:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.control-tabs{border:1px solid var(--border);border-radius:.4rem;display:flex;overflow:hidden}.control-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.3rem .7rem;font-family:inherit;font-size:.7rem;font-weight:600;transition:background .15s,color .15s}.control-tab:not(:last-child){border-right:1px solid var(--border)}.control-tab:hover{background:var(--surface-hover);color:var(--text-primary)}.control-tab-active{background:var(--accent-bg-hover);color:var(--text-primary)}.desktop-collapse-trigger{border:1px solid var(--border);background:var(--surface);width:1.5rem;height:1.5rem;color:var(--text-muted);cursor:pointer;border-radius:.35rem;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:0;transition:background .15s,color .15s;display:flex}.desktop-collapse-trigger:hover{background:var(--surface-hover);color:var(--text-primary)}.control-panel-desktop-collapsed .control-panel-body,.mobile-expand-trigger{display:none}.mobile-backdrop{z-index:44;-webkit-backdrop-filter:blur(4px);background:#00000080;position:fixed;inset:0}.control-panel-body{margin-top:.65rem}.actions-grouped{flex-direction:column;gap:.5rem;display:flex}.action-group{flex-direction:column;gap:.25rem;display:flex}.action-group-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding-left:.1rem;font-size:.55rem;font-weight:700}.action-group-btns{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.target-select{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:.5rem;min-width:7rem;padding:.45rem .55rem;font-family:inherit;font-size:.75rem;font-weight:600}.target-select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.ctrl-btn{border:1px solid var(--accent-border);background:linear-gradient(180deg, var(--accent-bg-hover), var(--accent-bg));color:var(--text-primary);cursor:pointer;border-radius:.5rem;padding:.45rem .65rem;font-size:.75rem;font-weight:600;transition:background .2s,border-color .2s,transform .15s,box-shadow .3s}.ctrl-btn:hover{border-color:var(--accent-light);transform:translateY(-1px)}.ctrl-btn:active{transform:translateY(0)}.ctrl-btn-featured{border-color:var(--accent-light);box-shadow:0 2px 8px var(--accent-shadow);padding:.5rem .85rem;font-size:.8rem}.ctrl-btn-featured:hover{box-shadow:0 4px 16px var(--accent-shadow)}.ctrl-btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text-secondary);padding:.4rem .55rem;font-size:.7rem}.ctrl-btn-secondary:hover{background:var(--surface-hover);border-color:var(--border-hover);color:var(--text-primary)}.ctrl-btn-active{border-color:var(--accent-light);box-shadow:0 0 12px var(--accent-shadow);animation:1.5s ease-in-out infinite ctrl-pulse}@keyframes ctrl-pulse{0%,to{box-shadow:0 0 8px var(--accent-shadow)}50%{box-shadow:0 0 18px var(--accent-shadow)}}.ctrl-btn-primary{background:var(--accent-light);border-color:var(--accent-light);color:#fff;box-shadow:0 0 10px var(--accent-shadow)}.ctrl-btn-primary:hover{filter:brightness(1.15)}.ctrl-btn-muted{border-color:var(--accent-border);color:var(--text-secondary);background:0 0;font-weight:400}.ctrl-btn-muted:hover{border-color:var(--accent-light);color:var(--text-primary);background:#ffffff0a;transform:none}.ctrl-btn-danger{color:#ef4444;background:#ef444426;border-color:#ef444466}.ctrl-btn-danger:hover{background:#ef444440;border-color:#ef4444;transform:translateY(-1px)}.toggle-switch{cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;white-space:nowrap;align-items:center;gap:.35rem;padding:.45rem .65rem;font-size:.65rem;display:flex}.toggle-track{background:var(--accent-border);border-radius:.6rem;flex-shrink:0;width:2.2rem;height:1.2rem;transition:background .2s;position:relative}.toggle-track:after{content:"";background:var(--text-secondary);border-radius:50%;width:.9rem;height:.9rem;transition:transform .2s,background .2s;position:absolute;top:.15rem;left:.15rem}.toggle-switch-on .toggle-track{background:var(--accent-light)}.toggle-switch-on .toggle-track:after{background:#fff;transform:translate(1rem)}.toggle-switch:hover .toggle-track{filter:brightness(1.2)}.tour-panel{flex-direction:column;gap:.35rem;display:flex}.tour-panel-top{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.tour-controls{align-items:center;gap:.5rem;display:flex}.tour-step-badge{color:var(--accent-light);background:var(--accent-bg);border:1px solid var(--accent-border);white-space:nowrap;border-radius:999px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.voice-disclosure-trigger{all:unset;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);cursor:pointer;align-self:flex-start;align-items:center;gap:.25rem;padding:.2rem 0;font-size:.6rem;font-weight:600;transition:color .15s;display:inline-flex}.voice-disclosure-trigger:hover{color:var(--text-primary)}.voice-disclosure-trigger:disabled{opacity:.45;cursor:default}.voice-disclosure-chevron{transition:transform .2s}.voice-disclosure-trigger-open .voice-disclosure-chevron{transform:rotate(90deg)}.tour-voice-selector{flex-direction:column;gap:.3rem;display:flex}.tour-voice-visual-compact{border-top:1px solid var(--border,#e2e2e2);padding:.25rem .4rem}.tour-voice-visual-compact .voice-disclosure-trigger{font-size:.68rem}.tour-voice-selector-inline{flex-flow:wrap;align-items:center;gap:.35rem;margin-top:.25rem}.tour-voice-selector-inline .voice-mode-toggle{align-self:center}.tour-voice-selector-inline .voice-pref-row{flex:1;min-width:0}.tour-voice-selector-inline .voice-pref-select{padding:.18rem .25rem;font-size:.65rem}.tour-voice-selector-inline>select.selector-dropdown{flex:1;min-width:0;padding:.18rem .25rem;font-size:.65rem}.voice-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding-bottom:.1rem;font-size:.68rem;font-weight:600}.tour-voice-header-row{align-items:center;gap:.5rem;display:flex}.tour-voice-header-row .tour-global-toggles{margin-left:auto}.tour-voice-fieldset,.tour-toggles-fieldset{border:none;margin:0;padding:0}.tour-voice-fieldset:disabled,.tour-toggles-fieldset:disabled{opacity:.45;pointer-events:none}.voice-mode-toggle{border:1px solid var(--border);border-radius:4px;align-self:flex-start;gap:0;display:flex;overflow:hidden}.voice-mode-btn{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.2rem .5rem;font-size:.6rem;font-weight:600;transition:background .15s,color .15s}.voice-mode-btn-active{background:var(--accent,#6366f1);color:#fff}.voice-pref-row{gap:.3rem;display:flex}.voice-pref-select{flex:1;min-width:0;padding:.2rem .3rem;font-size:.7rem}.tour-json-error{color:#ef4444;background:#ef44441a;border:1px solid #ef44444d;border-radius:.4rem;padding:.35rem .65rem;font-size:.72rem}.tour-json-editor{border:1px solid var(--border);background:var(--bg-secondary);width:100%;min-height:60px;max-height:100px;color:var(--text-primary);resize:vertical;box-sizing:border-box;tab-size:2;border-radius:.5rem;outline:none;padding:.4rem .6rem;font-family:IBM Plex Mono,SF Mono,Consolas,monospace;font-size:.68rem;line-height:1.5}.tour-json-editor:focus{border-color:var(--accent-border);box-shadow:0 0 0 2px var(--accent-bg)}.tour-editor-toolbar{align-items:center;gap:.4rem;display:flex}.tour-toolbar-right{flex-shrink:0;align-items:center;gap:.4rem;margin-left:auto;display:flex}.tour-json-section{flex-direction:column;gap:.35rem;display:flex}.tour-json-toolbar{align-items:center;gap:.4rem;display:flex}.tour-expand-btn{border:1px solid var(--border);background:var(--bg-secondary);width:1.5rem;height:1.5rem;color:var(--text-muted);cursor:pointer;border-radius:.3rem;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:color .15s,border-color .15s;display:flex}.tour-expand-btn:hover{color:var(--text-primary);border-color:var(--accent-border)}.tour-popup-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;justify-content:center;align-items:center;animation:.15s tour-popup-fade-in;display:flex;position:fixed;inset:0}@keyframes tour-popup-fade-in{0%{opacity:0}to{opacity:1}}.tour-popup{border:1px solid var(--border);background:var(--panel-bg);-webkit-backdrop-filter:blur(20px)saturate(1.2);backdrop-filter:blur(20px)saturate(1.2);border-radius:.75rem;flex-direction:column;width:min(90vw,720px);max-height:80vh;animation:.2s tour-popup-slide-in;display:flex;box-shadow:0 20px 60px #0006}@keyframes tour-popup-slide-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.tour-popup-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.65rem .85rem;display:flex}.tour-popup-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-primary);font-size:.75rem;font-weight:700}.tour-popup-close{width:1.75rem;height:1.75rem;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.3rem;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:flex}.tour-popup-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.tour-popup-body{flex:1;padding:.75rem .85rem;overflow-y:auto}.tour-json-editor-popup{resize:none;height:55vh;min-height:300px;max-height:none}.tour-visual-editor-popup{flex-direction:column;gap:.5rem;height:55vh;display:flex}.tour-visual-editor-popup .tour-steps-list.tour-steps-list-popup{flex:1;max-height:none;overflow-y:auto}.tour-view-tabs{border:1px solid var(--border);border-radius:.35rem;display:flex;overflow:hidden}.tour-view-tab{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.2rem .55rem;font-family:inherit;font-size:.62rem;font-weight:600;transition:background .15s,color .15s}.tour-view-tab:not(:last-child){border-right:1px solid var(--border)}.tour-view-tab:hover{background:var(--surface-hover);color:var(--text-primary)}.tour-view-tab-active{background:var(--accent-bg-hover);color:var(--text-primary)}.tour-visual-editor{flex-direction:column;gap:.35rem;display:flex}.tour-global-toggles{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.tour-toggle{cursor:pointer;color:var(--text-muted);-webkit-user-select:none;user-select:none;white-space:nowrap;align-items:center;gap:.3rem;font-size:.65rem;font-weight:600;display:flex}.tour-toggle .toggle-track{border-radius:.5rem;width:1.8rem;height:1rem}.tour-toggle .toggle-track:after{width:.7rem;height:.7rem;top:.15rem;left:.15rem}.tour-toggle-on .toggle-track{background:var(--accent-light)}.tour-toggle-on .toggle-track:after{background:#fff;transform:translate(.8rem)}.tour-toggle-inline{align-self:flex-end;padding-bottom:.15rem}.tour-steps-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-direction:column;gap:.35rem;min-height:60px;max-height:100px;padding-right:.25rem;display:flex;overflow-y:auto}.tour-step-card{border:1px solid var(--border);background:var(--bg-secondary);border-radius:.4rem;flex-direction:column;gap:.25rem;padding:.35rem .5rem;transition:border-color .2s;display:flex}.tour-step-card:hover{border-color:var(--border-hover)}.tour-step-header{align-items:center;gap:.4rem;display:flex}.tour-step-number{background:var(--accent-bg);border:1px solid var(--accent-border);width:1.4rem;height:1.4rem;color:var(--accent-light);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:flex}.tour-step-action-select{border:1px solid var(--border);background:var(--surface);color:var(--accent-light);cursor:pointer;border-radius:.35rem;padding:.2rem .4rem;font-family:IBM Plex Mono,SF Mono,Consolas,monospace;font-size:.7rem;font-weight:600}.tour-step-actions{align-items:center;gap:.15rem;margin-left:auto;display:flex}.tour-step-move,.tour-step-delete{all:unset;width:1.2rem;height:1.2rem;color:var(--text-muted);cursor:pointer;border-radius:.25rem;justify-content:center;align-items:center;font-size:.55rem;transition:background .15s,color .15s;display:flex}.tour-step-move:hover{background:var(--surface-hover);color:var(--text-primary)}.tour-step-move:disabled{opacity:.3;cursor:default}.tour-step-delete{font-size:.6rem}.tour-step-delete:hover{color:#ef4444;background:#ef444426}.tour-step-delete:disabled{opacity:.3;cursor:default}.tour-step-fields{flex-wrap:wrap;align-items:flex-end;gap:.3rem;display:flex}.tour-step-field{flex-direction:column;flex:7rem;gap:.1rem;min-width:0;display:flex}.tour-step-field-wide{flex:2 14rem}.tour-step-field-narrow{flex:0 5rem;min-width:4.5rem}.tour-field-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.55rem;font-weight:600}.tour-field-input{border:1px solid var(--border);background:var(--surface);color:var(--text-primary);border-radius:.3rem;outline:none;min-width:0;padding:.25rem .4rem;font-family:inherit;font-size:.72rem;transition:border-color .15s}.tour-field-input:focus{border-color:var(--accent-border);box-shadow:0 0 0 2px var(--accent-bg)}.tour-field-input:disabled{opacity:.5;cursor:default}.tour-field-input::placeholder{color:var(--text-subtle,var(--text-muted));opacity:.6}.tour-add-step{align-self:flex-start;padding:.4rem .8rem;font-size:.72rem}@media (width<=768px){.desktop-collapse-trigger{display:none}.nav-inner{gap:1rem;padding:.75rem 1rem}.nav-link-collapse{display:none}.state-badge{top:3.25rem;left:50%;right:auto;transform:translate(-50%)}.demo-root{padding-bottom:5rem}.hero{min-height:min(75vh,36rem);padding:2.5rem 0 5rem}.site-footer{padding-bottom:5rem}.control-panel{padding:.5rem .75rem .65rem;transition:border-radius .2s}.control-panel-expanded{border-top-left-radius:1rem;border-top-right-radius:1rem}.control-panel-header{flex-wrap:nowrap}.panel-character-select,.control-tabs{display:none}.control-panel-expanded .panel-character-select,.control-panel-expanded .control-tabs{display:flex}.control-panel-expanded .control-panel-header{border-bottom:1px solid var(--border);flex-wrap:wrap;margin-bottom:.5rem;padding-bottom:.5rem;padding-right:2rem;position:relative}.control-panel-expanded .control-tabs{order:3}.control-panel-expanded .mobile-expand-trigger{position:absolute;top:0;right:0}.control-panel-expanded .panel-character-select{flex-basis:100%;order:5;margin-left:0}.mobile-expand-trigger{border:1px solid var(--border);background:var(--surface);width:1.5rem;height:1.5rem;color:var(--text-muted);cursor:pointer;border-radius:.35rem;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:0;transition:background .15s,color .15s;display:flex}.mobile-expand-trigger:hover{background:var(--surface-hover);color:var(--text-primary)}.control-panel-body{display:none}.control-panel-expanded .control-panel-body{-webkit-overflow-scrolling:touch;max-height:55vh;display:block;overflow-y:auto}.ctrl-btn{padding:.45rem .4rem;font-size:.7rem}.ctrl-btn-featured{padding:.45rem .65rem;font-size:.72rem}.ctrl-btn-secondary{padding:.35rem .45rem;font-size:.65rem}.toggle-switch{padding:.4rem .5rem;font-size:.6rem}.action-group-btns{gap:.3rem}.target-select{min-width:5.5rem;padding:.35rem .45rem;font-size:.7rem}}
