:root{--bg-deep:#020812;--bg-mid:#081625c7;--bg-soft:#0c21359e;--border-soft:#a7c5df29;--text-main:#ecf4fb;--text-muted:#9bb3c7;--accent:#7ad4ff;--accent-strong:#f7b955;--success:#4fe3b2;--shadow:0 24px 80px #00000059}*{box-sizing:border-box}#root,body,html{margin:0;min-height:100%}body{background:radial-gradient(circle at 15% 15%,#205d8c4d,#0000 35%),radial-gradient(circle at 80% 20%,#f4af4c24,#0000 28%),linear-gradient(180deg,#030913,#02060d);color:#ecf4fb;color:var(--text-main);font-family:Avenir Next,Segoe UI Variable,Segoe UI,sans-serif;overflow:hidden}button,input{font:inherit}.app-shell{min-height:100vh;position:relative}.scene-layer{inset:0;position:absolute}.app-overlay{align-items:stretch;display:flex;flex-direction:column;gap:18px;height:100vh;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;padding:24px 14px 24px 24px;pointer-events:auto;position:relative;scrollbar-gutter:stable;width:min(420px,calc(100vw - 8px));z-index:2}.app-menu-toggle,.app-overlay-backdrop{display:none}.app-brandmark{bottom:20px;display:block;pointer-events:auto;position:fixed;right:24px;width:clamp(88px,12vw,156px);z-index:2}.app-brandmark__image{display:block;filter:drop-shadow(0 10px 28px rgba(0,0,0,.42));height:auto;opacity:.92;transition:transform .14s ease,opacity .14s ease;width:100%}.app-brandmark:hover .app-brandmark__image{opacity:1;transform:translateY(-1px)}.panel{-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);background:linear-gradient(180deg,#0a1b2bc7,#040c14e0);border:1px solid #a7c5df29;border:1px solid var(--border-soft);border-radius:22px;box-shadow:0 24px 80px #00000059;box-shadow:var(--shadow);width:100%}.controls-panel,.hero-panel,.sample-panel{padding:22px 22px 20px}.controls-panel,.hero-panel,.legend-panel,.sample-panel{align-self:stretch}.legend-panel{padding:18px 18px 16px}.eyebrow{color:#7ad4ff;color:var(--accent);font-size:.72rem;font-weight:700;letter-spacing:.18em;margin:0 0 10px;text-transform:uppercase}.hero-panel h1{font-size:clamp(2rem,4vw,3.2rem);letter-spacing:-.04em;line-height:.98;margin:0}.lead{color:#9bb3c7;color:var(--text-muted);font-size:.98rem;line-height:1.55}.hero-credit,.hero-note,.lead{margin:14px 0 0;max-width:34ch}.hero-credit,.hero-note{line-height:1.5}.hero-note{color:#ecf4fb;color:var(--text-main);font-size:.92rem}.hero-credit{color:#9bb3c7;color:var(--text-muted);font-size:.88rem}.status-row{align-items:center;background:#ffffff0f;border-radius:999px;color:#ecf4fb;color:var(--text-main);display:inline-flex;font-size:.88rem;gap:10px;margin-top:18px;padding:10px 14px}.status-dot{background:#4fe3b2;background:var(--success);border-radius:50%;box-shadow:0 0 16px #4fe3b299;height:10px;width:10px}.status-dot--busy{background:#f7b955;background:var(--accent-strong);box-shadow:0 0 16px #f7b955a6}.panel-heading{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.panel-label{color:#9bb3c7;color:var(--text-muted);font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.panel-chip{background:#ffffff14;border-radius:999px;color:#ecf4fb;color:var(--text-main);font-size:.74rem;padding:6px 10px}.mode-toggle{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:14px}.mode-toggle__button{background:#ffffff0f;border:0;border-radius:14px;color:#ecf4fb;color:var(--text-main);cursor:pointer;padding:12px 14px;transition:transform .14s ease,background-color .14s ease,box-shadow .14s ease}.mode-toggle__button:hover{background:#ffffff1a;transform:translateY(-1px)}.mode-toggle__button.is-active{background:linear-gradient(135deg,#7ad4ff38,#f7b9552e);box-shadow:inset 0 0 0 1px #7ad4ff2e}.control-group+.control-group{border-top:1px solid #ffffff14;margin-top:18px;padding-top:18px}.slider-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.slider-label{font-size:1rem;font-weight:600}.slider-note{color:#9bb3c7;color:var(--text-muted);font-size:.88rem;line-height:1.45;margin-top:6px;max-width:30ch}.slider-value{color:#f7b955;color:var(--accent-strong);font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:1.3rem}.layer-slider{accent-color:#f7b955;accent-color:var(--accent-strong);margin-top:16px;width:100%}.layer-slider:disabled{cursor:not-allowed;opacity:.45}.metric-row{align-items:baseline;display:flex;gap:10px}.metric-label{color:#9bb3c7;color:var(--text-muted);font-size:.94rem}.metric-value{font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:clamp(1.4rem,3vw,2.2rem);font-weight:600;letter-spacing:-.05em}.metric-unit{color:#7ad4ff;color:var(--accent);font-size:.92rem}.sample-caption{align-items:center;color:#9bb3c7;color:var(--text-muted);display:flex;font-size:.9rem;gap:12px;line-height:1.45;margin-top:16px}.sample-swatch{border:1px solid #ffffff3d;border-radius:50%;box-shadow:0 0 18px #7ad4ff2e;flex:0 0 auto;height:18px;width:18px}.legend-stack{display:flex;flex-direction:column;gap:20px}.empty-state{color:#9bb3c7;color:var(--text-muted);font-size:.92rem;line-height:1.5}.app-overlay::-webkit-scrollbar{width:10px}.app-overlay::-webkit-scrollbar-thumb{background:#9bb3c759;border-radius:999px}.app-overlay::-webkit-scrollbar-track{background:#0000}.legend-card{width:100%}.legend-header{align-items:baseline;display:flex;gap:12px;justify-content:space-between;margin-bottom:18px}.legend-subtitle{color:#7ad4ff;color:var(--accent);font-size:.84rem}.legend-body{align-items:stretch;display:flex;gap:18px}.legend-body--horizontal{display:block}.legend-scale{height:220px;position:relative;width:28px}.legend-scale--horizontal{height:24px;width:100%}.legend-track{border:1px solid #ffffff1f;border-radius:999px;box-shadow:inset 0 0 24px #ffffff14;height:100%;width:100%}.legend-labels{height:220px;position:relative;width:68px}.legend-labels--horizontal{height:28px;margin-top:12px;width:100%}.legend-label{color:#ecf4fb;color:var(--text-main);font-size:.82rem;left:0;position:absolute;transform:translateY(-50%)}.legend-label--horizontal{top:0;white-space:nowrap}@media (max-width:1080px){.app-overlay{width:min(400px,calc(100vw - 8px))}}@media (max-width:720px){.app-menu-toggle{align-items:center;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#07121ec7;border:1px solid #a7c5df3d;border-radius:999px;box-shadow:0 18px 40px #00000047;color:#ecf4fb;color:var(--text-main);display:inline-flex;gap:10px;padding:10px 14px;position:fixed;right:14px;top:14px;z-index:4}.app-menu-toggle__icon{display:inline-flex;flex-direction:column;gap:4px}.app-menu-toggle__icon span{background:currentColor;border-radius:999px;display:block;height:2px;transition:transform .16s ease,opacity .16s ease;width:16px}.app-menu-toggle__label{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.app-menu-toggle.is-open .app-menu-toggle__icon span:first-child{transform:translateY(6px) rotate(45deg)}.app-menu-toggle.is-open .app-menu-toggle__icon span:nth-child(2){opacity:0}.app-menu-toggle.is-open .app-menu-toggle__icon span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.app-overlay-backdrop{background:#01060c7a;border:0;display:block;inset:0;opacity:0;padding:0;pointer-events:none;position:fixed;transition:opacity .18s ease;z-index:2}.app-overlay-backdrop.is-visible{opacity:1;pointer-events:auto}.app-overlay{bottom:0;height:100vh;left:0;max-width:100%;opacity:0;padding:72px 10px 16px 16px;pointer-events:none;position:fixed;top:0;transform:translateX(calc(-100% - 16px));transition:transform .22s ease,opacity .18s ease;width:min(360px,calc(100vw - 56px));z-index:3}.app-overlay--open{opacity:1;pointer-events:auto;transform:translateX(0)}.app-brandmark{bottom:12px;right:12px;width:clamp(72px,20vw,104px)}.controls-panel,.hero-panel,.legend-panel,.sample-panel{align-self:start;justify-self:stretch}}
/*# sourceMappingURL=main.75dec202.css.map*/