.landing{min-height:100dvh;display:flex;flex-direction:column;color:var(--text);overflow-x:clip}.landing a{color:inherit}.landing-nav{position:sticky;top:0;z-index:200;background:#0c0f14eb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding-top:env(safe-area-inset-top,0px)}.landing-nav__inner{max-width:1120px;margin:0 auto;padding:.75rem max(1rem,env(safe-area-inset-left,0px)) .75rem max(1rem,env(safe-area-inset-right,0px));display:flex;align-items:center;gap:.75rem}.landing-nav__brand{display:flex;align-items:center;gap:.55rem;text-decoration:none;font-weight:600;font-size:1rem;flex-shrink:0;min-height:44px}.landing-nav__logo{display:grid;place-items:center;width:2rem;height:2rem;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-dim));color:var(--bg);font-size:1rem;font-weight:700;flex-shrink:0}.landing-nav__links{display:none;align-items:center;gap:1.5rem;margin-left:auto;margin-right:.5rem}.landing-nav__links a{text-decoration:none;color:var(--muted);font-size:.92rem;padding:.35rem 0;transition:color .2s}.landing-nav__links a:hover{color:var(--text)}.landing-nav__cta{margin-left:auto;flex-shrink:0;white-space:nowrap}.landing-nav__cta-short{display:none}.landing-nav__toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;margin:0 -6px 0 0;border:none;border-radius:var(--radius-sm);background:transparent;cursor:pointer;flex-shrink:0}.landing-nav__toggle:hover{background:#ffffff0f}.landing-nav__toggle-bar{display:block;width:100%;height:2px;background:var(--text);border-radius:1px;transition:transform .2s,opacity .2s}.landing-nav__toggle[aria-expanded=true] .landing-nav__toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}.landing-nav__toggle[aria-expanded=true] .landing-nav__toggle-bar:nth-child(2){opacity:0}.landing-nav__toggle[aria-expanded=true] .landing-nav__toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.landing-mobile-menu__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;border:none;background:#0000008c;cursor:pointer}.landing-mobile-menu{position:fixed;top:0;right:0;z-index:160;width:min(300px,88vw);height:100dvh;padding:calc(4.5rem + env(safe-area-inset-top,0px)) 1.25rem 1.5rem;padding-right:max(1.25rem,env(safe-area-inset-right,0px));background:var(--surface);border-left:1px solid var(--border);transform:translate(100%);transition:transform .25s ease;pointer-events:none}.landing-mobile-menu--open{transform:translate(0);pointer-events:auto}.landing-mobile-menu__nav{display:flex;flex-direction:column;gap:.25rem}.landing-mobile-menu__nav a{display:flex;align-items:center;min-height:48px;padding:.75rem .5rem;text-decoration:none;font-size:1.05rem;font-weight:500;color:var(--text);border-radius:var(--radius-sm)}.landing-mobile-menu__nav a:hover{background:#ffffff0d}.landing-mobile-menu__nav .landing-btn{margin-top:1rem;width:100%;min-height:48px}@media(min-width:768px){.landing-nav__inner{padding-top:.85rem;padding-bottom:.85rem;padding-left:max(1.25rem,env(safe-area-inset-left,0px));padding-right:max(1.25rem,env(safe-area-inset-right,0px));gap:1rem}.landing-nav__brand{font-size:1.05rem}.landing-nav__links{display:flex}.landing-nav__cta{margin-left:0}.landing-nav__toggle,.landing-mobile-menu,.landing-mobile-menu__backdrop{display:none}}@media(max-width:380px){.landing-nav__cta-full{display:none}.landing-nav__cta-short{display:inline}}.landing-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:44px;padding:.65rem 1.25rem;border-radius:var(--radius-sm);font-family:var(--font);font-size:.95rem;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s;-webkit-tap-highlight-color:transparent}.landing-btn:hover{transform:translateY(-1px)}.landing-btn:active{transform:translateY(0)}.landing-btn--primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 20px #3b82f659}.landing-btn--primary:hover{box-shadow:0 6px 28px #3b82f673}.landing-btn--ghost{background:#ffffff0f;color:var(--text);border:1px solid var(--border)}.landing-btn--ghost:hover{background:#ffffff1a}.landing-btn--lg{padding:.85rem 1.75rem;font-size:1.05rem;min-height:48px}.landing-btn--sm{padding:.5rem 1rem;font-size:.88rem}.landing-hero{position:relative;overflow:hidden;padding:2.5rem max(1rem,env(safe-area-inset-left,0px)) 3.5rem max(1rem,env(safe-area-inset-right,0px));text-align:center}@media(min-width:768px){.landing-hero{padding:4rem 1.25rem 5rem}}@media(min-width:1024px){.landing-hero{padding:5rem 1.5rem 6rem}}.landing-hero__glow{position:absolute;inset:-20% -10% auto;height:70%;background:radial-gradient(ellipse 60% 50% at 30% 40%,rgba(59,130,246,.25) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 70% 30%,rgba(61,214,198,.2) 0%,transparent 65%),radial-gradient(ellipse 40% 30% at 50% 80%,rgba(139,92,246,.15) 0%,transparent 60%);animation:landingGlowShift 8s ease-in-out infinite alternate;pointer-events:none}@keyframes landingGlowShift{0%{transform:translate(0) scale(1)}to{transform:translate(2%,-3%) scale(1.05)}}.landing-hero__content{position:relative;max-width:720px;margin:0 auto}.landing-hero__eyebrow{margin:0 0 .85rem;font-size:clamp(.72rem,2.5vw,.85rem);font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.landing-hero__title{margin:0 0 1rem;font-size:clamp(2rem,9vw,4rem);font-weight:700;line-height:1.1;letter-spacing:-.02em}.landing-hero__subtitle{display:block;margin-top:.35rem;font-size:clamp(1rem,3.8vw,1.5rem);font-weight:500;color:var(--muted);letter-spacing:0;line-height:1.25}.landing-hero__desc{margin:0 auto 1.75rem;max-width:540px;font-size:clamp(.95rem,2.8vw,1.05rem);line-height:1.65;color:var(--muted)}.landing-hero__actions{display:flex;flex-direction:column;gap:.75rem;align-items:stretch;max-width:320px;margin:0 auto}@media(min-width:480px){.landing-hero__actions{flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center;max-width:none}.landing-hero__actions .landing-btn{width:auto}}.landing-hero__actions .landing-btn{width:100%}.landing-section{padding:2.75rem max(1rem,env(safe-area-inset-left,0px)) 2.75rem max(1rem,env(safe-area-inset-right,0px));scroll-margin-top:4.5rem}@media(min-width:768px){.landing-section{padding:4rem 1.25rem;scroll-margin-top:5rem}}@media(min-width:1024px){.landing-section{padding:5rem 1.5rem}}.landing-section--alt{background:#ffffff05;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.landing-section__inner{max-width:1120px;margin:0 auto}.landing-section__header{text-align:center;max-width:640px;margin:0 auto 2rem}@media(min-width:768px){.landing-section__header{margin-bottom:2.5rem}}.landing-section__eyebrow{margin:0 0 .5rem;font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#3b82f6}.landing-section__header h2{margin:0 0 .75rem;font-size:clamp(1.5rem,5vw,2.25rem);font-weight:700;letter-spacing:-.02em;line-height:1.2}.landing-section__lead{margin:0;font-size:clamp(.95rem,2.5vw,1rem);line-height:1.65;color:var(--muted)}.landing-features{display:grid;grid-template-columns:1fr;gap:.85rem}@media(min-width:600px){.landing-features{grid-template-columns:repeat(2,1fr);gap:1rem}}@media(min-width:900px){.landing-features{grid-template-columns:repeat(3,1fr);gap:1.25rem}}.landing-feature-card{padding:1.25rem;border-radius:var(--radius);background:#ffffff0a;border:1px solid var(--border);transition:border-color .2s,transform .2s}@media(min-width:768px){.landing-feature-card{padding:1.5rem}}@media(hover:hover){.landing-feature-card:hover{border-color:#3b82f666;transform:translateY(-2px)}}.landing-feature-card__icon{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;margin-bottom:.85rem;border-radius:10px;background:#3b82f626;color:#60a5fa;font-size:1.1rem;font-weight:600}.landing-feature-card h3{margin:0 0 .5rem;font-size:clamp(1rem,2.5vw,1.05rem);font-weight:600}.landing-feature-card p{margin:0;font-size:.92rem;line-height:1.55;color:var(--muted)}.landing-gallery{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:600px){.landing-gallery{grid-template-columns:repeat(2,1fr);gap:1.25rem}}@media(min-width:900px){.landing-gallery{grid-template-columns:repeat(3,1fr)}}.landing-gallery__card{margin:0;border-radius:var(--radius);overflow:hidden;background:#ffffff0a;border:1px solid var(--border);transition:transform .2s}@media(hover:hover){.landing-gallery__card:hover{transform:translateY(-3px)}}.landing-gallery__image{aspect-ratio:16 / 10;width:100%}.landing-gallery__card figcaption{padding:.9rem 1rem;display:flex;flex-direction:column;gap:.2rem}@media(min-width:768px){.landing-gallery__card figcaption{padding:1rem 1.1rem}}.landing-gallery__card strong{font-size:.95rem}.landing-gallery__card span{font-size:.85rem;color:var(--muted)}.landing-about{display:grid;gap:2rem;align-items:center}@media(min-width:768px){.landing-about{grid-template-columns:1.2fr 1fr;gap:2.5rem}}.landing-about__content{text-align:center}@media(min-width:768px){.landing-about__content{text-align:left}}.landing-about__content h2{margin:0 0 .5rem;font-size:clamp(1.5rem,5vw,2.25rem);font-weight:700;line-height:1.2}.landing-about__tagline{margin:0 0 1rem;font-size:clamp(1rem,2.8vw,1.1rem);color:var(--accent);font-weight:500}.landing-about__content p{margin:0 0 1rem;font-size:clamp(.95rem,2.5vw,1rem);line-height:1.65;color:var(--muted)}.landing-about__versions{font-size:.82rem!important;font-family:var(--font-mono, "JetBrains Mono", monospace);color:var(--muted)!important;opacity:.85;margin-bottom:1.25rem!important}.landing-about__contact{margin-bottom:1.25rem!important;word-break:break-word}.landing-about__contact a{color:#60a5fa;text-decoration:none}.landing-about__contact a:hover{text-decoration:underline}.landing-about__content .landing-btn{width:100%}@media(min-width:480px){.landing-about__content .landing-btn{width:auto}}.landing-about__stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.65rem}@media(min-width:768px){.landing-about__stats{grid-template-columns:repeat(2,1fr);gap:1rem}}.landing-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1rem .5rem;min-height:88px;border-radius:var(--radius);background:#ffffff0a;border:1px solid var(--border)}@media(min-width:768px){.landing-stat{padding:1.5rem .75rem;min-height:auto}}.landing-stat__value{font-size:clamp(1.35rem,4vw,1.75rem);font-weight:700;color:#3b82f6;line-height:1.2}.landing-stat__label{margin-top:.35rem;font-size:clamp(.68rem,2vw,.78rem);color:var(--muted);line-height:1.3}.landing-footer{margin-top:auto;border-top:1px solid var(--border);background:#00000059}.landing-footer__inner{max-width:1120px;margin:0 auto;padding:2.5rem max(1rem,env(safe-area-inset-left,0px)) calc(1.25rem + env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-right,0px))}@media(min-width:768px){.landing-footer__inner{padding:3rem max(1.25rem,env(safe-area-inset-left,0px)) calc(1.5rem + env(safe-area-inset-bottom,0px)) max(1.25rem,env(safe-area-inset-right,0px))}}.landing-footer__grid{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:600px){.landing-footer__grid{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}.landing-footer__brand{grid-column:1 / -1}}@media(min-width:900px){.landing-footer__grid{grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem}.landing-footer__brand{grid-column:auto}}.landing-footer__brand{max-width:320px}.landing-footer__logo-link{display:inline-flex;align-items:center;gap:.55rem;margin-bottom:.85rem;text-decoration:none;color:var(--text);font-weight:600;font-size:1.05rem}.landing-footer__logo{display:grid;place-items:center;width:2rem;height:2rem;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-dim));color:var(--bg);font-size:1rem;font-weight:700;flex-shrink:0}.landing-footer__tagline{margin:0;font-size:.92rem;line-height:1.6;color:var(--muted)}.landing-footer__heading{margin:0 0 .85rem;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text)}.landing-footer__links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}.landing-footer__links a{display:inline-flex;align-items:center;min-height:36px;font-size:.92rem;color:var(--muted);text-decoration:none;transition:color .2s}.landing-footer__links a:hover{color:#60a5fa}.landing-footer__muted{font-size:.88rem;color:var(--muted);opacity:.85}.landing-footer__cta-col{display:flex;flex-direction:column;align-items:flex-start}.landing-footer__cta-text{margin:0 0 1rem;font-size:.9rem;line-height:1.55;color:var(--muted)}.landing-footer__cta-col .landing-btn{width:100%}@media(min-width:480px){.landing-footer__cta-col .landing-btn{width:auto}}.landing-footer__bar{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border);text-align:center}@media(min-width:768px){.landing-footer__bar{flex-direction:row;justify-content:space-between;align-items:center;text-align:left}}.landing-footer__copy,.landing-footer__note{margin:0;font-size:.82rem;color:var(--muted)}.landing-footer__note{opacity:.8}.landing-fade-in{animation:landingFadeIn .7s ease-out both}@keyframes landingFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.landing-fade-in,.landing-hero__glow{animation:none}.landing-btn:hover,.landing-feature-card:hover,.landing-gallery__card:hover{transform:none}html{scroll-behavior:auto}}html{scroll-behavior:smooth}.topbar__home-link{display:grid;place-items:center;text-decoration:none;color:inherit;border-radius:8px;transition:opacity .2s}.topbar__home-link:hover{opacity:.85}:root{--bg: #0c0f14;--surface: #141a24;--surface-2: #1b2433;--border: #2a3548;--text: #e8edf5;--muted: #8b9bb5;--accent: #3dd6c6;--accent-dim:#2a9d90;--danger: #f07178;--success: #3dd6c6;--radius: 14px;--radius-sm: 8px;--font: "Outfit", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace;--safe-b: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box}html{-webkit-tap-highlight-color:transparent}body{margin:0;min-height:100dvh;font-family:var(--font);color:var(--text);background:radial-gradient(ellipse 100% 40% at 50% 0%,rgba(61,214,198,.1) 0%,transparent 70%),var(--bg);overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100dvh;max-width:480px;margin:0 auto}.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.1rem;background:#0c0f14d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.topbar__brand{display:flex;align-items:center;gap:.55rem}.topbar__logo{display:grid;place-items:center;width:2rem;height:2rem;border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-dim));color:var(--bg);font-size:1rem;font-weight:700;flex-shrink:0}.topbar__name{font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.topbar__actions{display:flex;align-items:center;gap:.5rem}.topbar__bt-btn{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border:1px solid var(--border);border-radius:999px;background:var(--surface-2);color:var(--text);font-size:.78rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s}.topbar__bt-btn:hover{border-color:var(--accent);background:#3dd6c614}.bt-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.bt-dot--on{background:var(--accent);box-shadow:0 0 6px var(--accent)}.bt-dot--off{background:var(--muted)}.bt-label{line-height:1}.topbar__settings-btn{display:grid;place-items:center;width:2.25rem;height:2.25rem;border:none;border-radius:50%;background:transparent;color:var(--muted);cursor:pointer;transition:color .15s,background .15s}.topbar__settings-btn:hover{color:var(--text);background:var(--surface-2)}.main-page{flex:1;padding:1.25rem 1.1rem 0;display:flex;flex-direction:column;gap:1.5rem}.save-bar{position:sticky;bottom:0;margin-top:auto;margin-left:-1.1rem;margin-right:-1.1rem;padding:.9rem 1.1rem calc(.9rem + var(--safe-b));background:#0c0f14f0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.55rem}.save-bar__hint{margin:0;font-size:.8rem;color:var(--muted);line-height:1.4}.save-bar__error{margin:0;font-size:.78rem}.save-bar__actions{display:flex;gap:.55rem}.btn--save-action{flex:1;min-height:48px;font-size:1rem}.btn--save{width:100%;min-height:48px;font-size:1rem}.save-detail--muted{font-size:.78rem;opacity:.75}.banner{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.85rem;line-height:1.5}.banner--warn{background:#ffa0001a;border:1px solid rgba(255,160,0,.3);color:#ffd080}.banner--ok{background:#3dd6c614;border:1px solid rgba(61,214,198,.25);color:var(--accent)}.sync-badge{font-size:.72rem;font-weight:500;padding:.2rem .55rem;border-radius:999px;white-space:nowrap}.sync-badge--saved{background:#3dd6c61f;color:var(--accent)}.sync-badge--dirty{background:#ffa0001f;color:#ffd080}.timing-controls{padding:.75rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border)}.timing-controls__label{margin:0 0 .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.timing-controls__busy{font-weight:500;text-transform:none;letter-spacing:0;color:var(--accent)}.timing-controls__hint{margin:0 0 .65rem;font-size:.78rem;color:var(--muted);line-height:1.35}.timing-controls__grid{display:flex;flex-direction:column;gap:.65rem}.timing-controls__field{display:grid;grid-template-columns:1fr auto;gap:.25rem .5rem;font-size:.82rem}.timing-controls__field span:first-child{color:var(--text)}.timing-controls__val{font-family:var(--mono);font-size:.75rem;color:var(--muted)}.timing-controls__field input[type=range]{grid-column:1 / -1;width:100%}.group-assign__limit{margin:0;font-size:.82rem;color:#ffd080}.group-assign__running-hint{margin:0 0 .5rem;font-size:.8rem;color:var(--muted);line-height:1.4}.letter-row__test{display:flex;gap:.25rem}.btn--test{min-width:1.6rem;padding:.2rem .35rem;font-size:.72rem;font-weight:700}.btn--test-red{color:#ff6a6a}.btn--test-green{color:#6aff9a}.btn--test-blue{color:#6ab4ff}.hint--borderless{margin-top:.5rem;font-size:.8rem;color:var(--muted)}.advanced-panel{margin-top:.5rem;padding-left:.5rem;border-left:2px solid var(--border)}.log-toggle--nested{font-size:.85rem}.sign-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.sign-row__titles{display:flex;flex-direction:column;gap:.15rem;min-width:0}.sign-row__subtitle{margin:0;font-size:.8rem;color:var(--muted);font-weight:500}.sign-name{margin:0;font-size:1.4rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.section{display:flex;flex-direction:column;gap:.75rem}.section__title{margin:0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}.brightness-bar{display:flex;flex-direction:column;gap:.6rem;transition:opacity .2s}.brightness-bar--disabled{opacity:.38;pointer-events:none}.brightness-bar__row{display:flex;align-items:center;gap:.5rem}.brightness-bar__icon{color:var(--muted);flex-shrink:0}.brightness-bar__label{font-size:.85rem;color:var(--muted)}.brightness-bar__slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:linear-gradient(90deg,var(--accent) var(--val, 100%),var(--surface-2) var(--val, 100%));outline:none;cursor:pointer}.brightness-bar__slider::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px #3dd6c666;cursor:pointer;transition:transform .1s}.brightness-bar__slider::-webkit-slider-thumb:active{transform:scale(1.15)}.brightness-bar__slider::-moz-range-thumb{width:26px;height:26px;border:none;border-radius:50%;background:var(--accent);cursor:pointer}.preset-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;transition:opacity .2s}.preset-grid--disabled{opacity:.38;pointer-events:none}.preset-card{display:flex;flex-direction:column;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden;cursor:pointer;transition:border-color .15s,transform .12s,box-shadow .15s;padding:0}.preset-card:active{transform:scale(.97)}.preset-card:not(:disabled):hover{border-color:var(--muted)}.preset-card--active{border-color:var(--accent);box-shadow:0 0 0 3px #3dd6c62e}.preset-card:disabled{opacity:.5;cursor:not-allowed}.preset-card__swatch{height:64px;width:100%}.preset-card__name{display:block;padding:.55rem .75rem;font-size:.85rem;font-weight:600;color:var(--text);text-align:left}.effect-card__swatch{position:relative;height:72px}.effect-card__label-top{position:absolute;bottom:6px;left:8px;right:8px;font-size:.65rem;font-weight:500;color:#ffffffbf;text-shadow:0 1px 3px rgba(0,0,0,.7);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-builder{display:flex;flex-direction:column;gap:.55rem}.group-builder__label{margin:0;font-size:.78rem;color:var(--muted)}.group-builder__label--spaced{margin-top:.75rem}.group-assign__hint{margin:0 0 .65rem;font-size:.78rem;color:var(--muted)}.group-assign__whole{display:flex;flex-direction:column;align-items:stretch;gap:.5rem;margin-bottom:.75rem}.group-assign__whole-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.solid-color-picker{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;border:1px solid var(--border);border-radius:var(--radius, 12px);background:var(--surface)}.solid-color-picker__sv{position:relative;height:9.5rem;border-radius:8px;cursor:crosshair;touch-action:none;border:1px solid rgba(255,255,255,.08);background:linear-gradient(to top,#000,transparent),linear-gradient(to right,#fff,transparent),hsl(calc(var(--sv-hue) * 1deg) 100% 50%)}.solid-color-picker__sv-thumb{position:absolute;width:1.1rem;height:1.1rem;margin:-.55rem 0 0 -.55rem;border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 1px #00000059,0 2px 6px #00000059;pointer-events:none}.solid-color-picker__hue-row{display:flex;align-items:center;gap:.65rem}.solid-color-picker__preview{width:2rem;height:2rem;border-radius:50%;border:2px solid rgba(255,255,255,.15);flex-shrink:0}.solid-color-picker__hue{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;height:1rem;border-radius:999px;background:transparent;cursor:pointer}.solid-color-picker__hue:disabled{opacity:.45;cursor:not-allowed}.solid-color-picker__hue::-webkit-slider-runnable-track{height:.75rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red)}.solid-color-picker__hue::-webkit-slider-thumb{-webkit-appearance:none;width:1.25rem;height:1.25rem;margin-top:-.28rem;border-radius:50%;border:3px solid #fff;background:hsl(calc(var(--sv-hue, 180) * 1deg) 100% 50%);box-shadow:0 1px 4px #00000059}.solid-color-picker__hue::-moz-range-track{height:.75rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red)}.solid-color-picker__hue::-moz-range-thumb{width:1.25rem;height:1.25rem;border-radius:50%;border:3px solid #fff;background:#0ff;box-shadow:0 1px 4px #00000059}.solid-color-picker__rgb{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.solid-color-picker__channel{display:flex;flex-direction:column;gap:.25rem;font-size:.72rem;font-weight:600;color:var(--muted)}.solid-color-picker__channel input{width:100%;padding:.45rem .5rem;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text);font-size:.88rem;font-variant-numeric:tabular-nums}.solid-color-picker__channel input:focus{outline:none;border-color:var(--accent)}.solid-color-picker__off{width:100%;min-height:2.75rem;padding:.55rem .9rem;border:1px solid var(--border);border-radius:10px;background:var(--surface-2);color:var(--muted);font-size:.82rem;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}.solid-color-picker__off:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.solid-color-picker__off--active{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 2px #4a9eff33}.group-assign__modes{display:flex;gap:.35rem;margin-bottom:.65rem}.group-assign__mode{flex:1;padding:.45rem .5rem;font-size:.8rem;font-weight:600;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--muted);cursor:pointer}.group-assign__mode--active{border-color:var(--accent, #4a9eff);color:var(--text);background:#4a9eff1f}.letter-chase-controls{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.85rem;padding:.75rem;border:1px solid var(--border);border-radius:10px;background:var(--surface-2)}.letter-chase-controls__label{margin:0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.letter-chase-controls__field{display:flex;flex-direction:column;gap:.25rem;font-size:.85rem}.letter-chase-controls__field span:first-child{font-weight:600;color:var(--text)}.letter-chase-controls__val{font-size:.8rem;color:var(--accent, #4a9eff);font-weight:600}.letter-chase-controls__hint{font-size:.75rem;color:var(--muted)}.letter-chase-controls__direction{display:flex;flex-direction:column;gap:.35rem}.letter-chase-controls__direction-label{font-size:.85rem;font-weight:600;color:var(--text)}.letter-chase-controls__modes{display:flex;gap:.35rem}.letter-chase-controls__mode{flex:1;padding:.45rem .35rem;font-size:.78rem;font-weight:600;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted);cursor:pointer}.letter-chase-controls__mode--active{border-color:var(--accent, #4a9eff);color:var(--text);background:#4a9eff1f}.letter-chase-controls__mode:disabled{opacity:.5;cursor:not-allowed}.group-assign__picker{margin-bottom:.65rem}.group-assign__border{margin-top:.75rem}.group-assign__border-label{margin:0 0 .4rem;font-size:.72rem;color:var(--muted)}.group-assign__border-modes{display:flex;gap:.4rem;margin-bottom:.55rem}.group-assign__border-mode{border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text);padding:.35rem .65rem;font-size:.78rem;cursor:pointer}.group-assign__border-mode--active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 18%,var(--surface-2))}.group-builder__chips{display:flex;flex-wrap:wrap;gap:.4rem}.group-builder__input{width:100%;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text);padding:.58rem .7rem;font-size:.9rem}.group-builder__input:focus{outline:2px solid var(--accent);outline-offset:1px}.group-builder__actions{margin-top:.2rem}.chip--active{border-color:var(--accent);color:var(--accent)}.btn--ghost{background:transparent;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:6px;color:var(--muted);font-size:.8rem;line-height:1;transition:color .15s,background .15s}.btn--ghost:hover:not(:disabled){color:var(--text);background:var(--border)}.btn--ghost:disabled{opacity:.4;cursor:not-allowed}.btn--icon{flex-shrink:0}.custom-colors{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.custom-colors__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.9rem 1rem;background:none;border:none;color:var(--text);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.custom-colors__toggle:hover{background:var(--surface-2)}.custom-colors__body{padding:0 1rem 1rem;display:flex;flex-direction:column;gap:.9rem;border-top:1px solid var(--border)}.custom-colors__pickers{display:flex;flex-wrap:wrap;gap:.6rem;padding-top:.9rem}.custom-colors__empty{margin:.9rem 0 0;font-size:.82rem;color:var(--muted);line-height:1.5}.color-pill{display:flex;align-items:center;gap:.4rem;padding:.4rem .7rem .4rem .6rem;border:1px solid var(--border);border-radius:999px;background:var(--surface-2);cursor:pointer;transition:border-color .15s}.color-pill:hover{border-color:var(--accent)}.color-pill__label{font-size:.82rem;font-weight:600;color:var(--text);min-width:1ch}.color-pill__swatch{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.15);flex-shrink:0}.color-pill input[type=color]{position:absolute;opacity:0;width:0;height:0}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000008c;opacity:0;pointer-events:none;transition:opacity .28s ease;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.sheet-backdrop--visible{opacity:1;pointer-events:auto}.sheet{position:fixed;bottom:0;top:auto;z-index:201;max-height:92dvh;background:var(--surface);border-top-left-radius:20px;border-top-right-radius:20px;border-top:1px solid var(--border);display:flex;flex-direction:column;transform:translateY(100%);transition:transform .32s cubic-bezier(.32,1,.4,1);max-width:480px;margin:0 auto;left:0;right:0}.sheet--open{transform:translateY(0)}.sheet__header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem .7rem;flex-shrink:0;border-bottom:1px solid var(--border);gap:1rem}.sheet__handle{position:absolute;left:50%;transform:translate(-50%);top:.55rem;width:36px;height:4px;border-radius:2px;background:var(--border)}.sheet__title{flex:1;text-align:center;font-size:1rem;font-weight:600;letter-spacing:-.01em}.sheet__close{display:grid;place-items:center;width:2rem;height:2rem;border:none;border-radius:50%;background:var(--surface-2);color:var(--muted);cursor:pointer;transition:color .15s,background .15s;flex-shrink:0}.sheet__close:hover{color:var(--text);background:var(--border)}.sheet__body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 0 calc(1.5rem + var(--safe-b))}.sheet__section{padding:.75rem 1rem 0}.sheet__section+.sheet__section{border-top:1px solid var(--border)}.log-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.7rem 0;background:none;border:none;color:var(--muted);font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:color .15s}.log-toggle:hover{color:var(--text)}.card{background:transparent;padding:.5rem 0 .75rem}.card h2{margin:0 0 .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1.25rem;border-radius:var(--radius-sm);font-family:var(--font);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,opacity .15s,transform .1s;border:1px solid transparent;text-decoration:none;min-height:44px}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn--primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn--primary:not(:disabled):hover{background:var(--accent-dim);border-color:var(--accent-dim)}.btn--ghost{background:transparent;color:var(--text);border-color:var(--border)}.btn--ghost:not(:disabled):hover{border-color:var(--accent);color:var(--accent)}.btn--danger{background:transparent;color:var(--danger);border-color:var(--danger)}.btn--danger:not(:disabled):hover{background:#f071781a}.btn--sm{padding:.4rem .85rem;font-size:.8rem;min-height:36px}.btn--full{width:100%}.hint{margin:0 0 .75rem;font-size:.82rem;color:var(--muted);line-height:1.5}.hint--error{color:var(--danger)}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem;font-size:.85rem;color:var(--muted)}.field input{padding:.6rem .8rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text);font-family:var(--font);font-size:.9rem;outline:none;transition:border-color .15s}.field input:focus{border-color:var(--accent)}.check{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted);margin-bottom:.75rem;cursor:pointer}.actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:.5rem}.device-label{margin:.5rem 0 0;font-size:.8rem;color:var(--muted)}.map-string-input{width:100%;padding:.55rem .65rem;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text);font-family:var(--mono);font-size:.88rem;line-height:1.35;resize:vertical;min-height:3.4rem}.map-string-input:focus{outline:none;border-color:var(--accent)}.map-string-input--error{border-color:#d85f5f}.map-errors,.map-warnings{margin:0 0 .7rem;padding:.5rem .65rem;border-radius:8px;font-size:.78rem}.map-errors{background:#d85f5f24;border:1px solid rgba(216,95,95,.45);color:#ffc4c4}.map-warnings{background:#e2b74921;border:1px solid rgba(226,183,73,.45);color:#ffdd9a}.map-errors p,.map-warnings p{margin:0}.map-errors p+p,.map-warnings p+p{margin-top:.25rem}.map-active{margin-bottom:.75rem}.map-active__title{margin:0 0 .4rem;font-size:.8rem;color:var(--muted)}.map-active__chips{display:flex;flex-wrap:wrap;gap:.35rem}.map-load-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.btn--load{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:600;background:var(--surface2);color:var(--text);border:1.5px solid var(--border);cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.btn--load:hover:not(:disabled){background:var(--surface3, #2a2a3a);border-color:var(--accent)}.btn--load:disabled{opacity:.45;cursor:not-allowed}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.load-status{font-size:.8rem;font-weight:500;padding:.25rem .6rem;border-radius:.4rem;flex-shrink:0}.load-status--ok{color:#4ade80;background:#4ade801f}.load-status--unconfigured{color:#94a3b8;background:#94a3b81a}.load-status--error{color:#f87171;background:#f871711f}.map-generate{margin-bottom:.65rem}.btn--secondary{background:var(--surface-2);border:1px solid var(--border);color:var(--text)}.btn--secondary:not(:disabled):hover{border-color:var(--accent)}.letter-rows{border:1px solid var(--border);border-radius:10px;padding:.6rem;background:#1b243359;margin-bottom:.7rem;display:grid;grid-template-columns:2.3rem 2.3rem minmax(3.25rem,1fr) minmax(3.25rem,1fr) 5.5rem;column-gap:.45rem;row-gap:.45rem;align-items:center}.letter-row{display:grid;grid-template-columns:subgrid;grid-column:1 / -1;align-items:center}.letter-row--header{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.letter-row__col-label{text-align:center;white-space:nowrap}.letter-rows>.map-errors,.letter-rows>.map-warnings{grid-column:1 / -1}.letter-row__tag,.letter-row__char{font-size:.8rem;color:var(--muted);text-align:center;border:1px solid var(--border);border-radius:6px;padding:.25rem .1rem;background:var(--surface-2)}.letter-row__led{width:100%;padding:.35rem .5rem;border:1px solid var(--border);border-radius:6px;background:var(--surface-2);color:var(--text)}.chip{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .55rem;border:1px solid var(--border);border-radius:6px;background:var(--surface-2);color:var(--muted);font-size:.75rem;font-weight:600;cursor:pointer;transition:border-color .12s,color .12s}.chip:not(:disabled):hover{border-color:var(--accent);color:var(--accent)}.chip:disabled{opacity:.35;cursor:not-allowed}.chip--sm{padding:.2rem .45rem;font-size:.7rem}.chip+.chip{margin-left:.3rem}.log-panel{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);overflow:hidden}.log-panel__header{display:flex;align-items:center;justify-content:space-between;padding:.4rem .7rem;border-bottom:1px solid var(--border);background:var(--surface-2)}.log-panel__title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.log-panel__body{max-height:200px;overflow-y:auto;padding:.5rem .7rem;font-family:var(--mono);font-size:.72rem;line-height:1.6;color:var(--muted)}.log-panel__line{white-space:pre-wrap;word-break:break-all}@keyframes fadeIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.save-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;background:#0c0f14c7;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.save-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;min-width:240px;max-width:320px;padding:2rem 2.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;animation:fadeIn .18s ease}.save-card--saving{border-color:var(--border)}.save-card--saved{border-color:var(--accent)}.save-card--error{border-color:var(--danger)}.save-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;font-size:1.5rem;font-weight:700}.save-card--saving .save-icon{background:var(--surface-2)}.save-card--saved .save-icon{background:#3dd6c626;color:var(--accent)}.save-card--error .save-icon{background:#f0717826;color:var(--danger)}.save-spinner{display:block;width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.save-title{margin:0;font-size:1.05rem;font-weight:600}.save-card--saved .save-title{color:var(--accent)}.save-card--error .save-title{color:var(--danger)}.save-detail{margin:0;font-size:.82rem;color:var(--muted);line-height:1.5}.browser-warn-card{max-width:360px;width:calc(100% - 2rem);align-items:stretch;text-align:left}.browser-warn-detail{color:var(--text)}.browser-warn-note{font-size:.78rem}.browser-warn-btn{width:100%;margin-top:.25rem;text-align:center;text-decoration:none;box-sizing:border-box}.pin-card{max-width:22rem;width:calc(100% - 2rem);padding:1.25rem 1.35rem}.pin-input{width:100%;margin-top:.35rem;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text);padding:.65rem .75rem;font-size:1.1rem;letter-spacing:.15em;text-align:center}.pin-input:focus{outline:none;border-color:var(--accent)}.pin-submit{width:100%;margin-top:.85rem}.pin-error{margin:.5rem 0 0;text-align:center}.pin-settings__label{display:block;margin-bottom:.65rem;font-size:.78rem;color:var(--muted)}.advanced-panel .pin-settings{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.sheet__section-title{margin:0 0 .35rem;font-size:.9rem;font-weight:600}.hint--ok{color:var(--accent);margin:.35rem 0;font-size:.82rem}.install-prompt{margin-top:.85rem;padding:.75rem;border-radius:var(--radius);background:#3b82f614;border:1px solid rgba(59,130,246,.22)}.install-prompt__text{margin:0 0 .65rem;font-size:.85rem;line-height:1.45;color:var(--muted)}.install-prompt__btn{width:100%}.install-prompt__hint{margin-top:.85rem}.page-tabs{display:flex;gap:.35rem;margin:.75rem 0 .5rem}.page-tabs__tab{flex:1;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--muted);padding:.55rem .75rem;font-size:.88rem;font-weight:600;cursor:pointer}.page-tabs__tab--active{color:var(--text);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--surface-2))}.schedule-panel{display:flex;flex-direction:column;gap:.75rem}.schedule-panel__steps{margin:0;padding-left:1.15rem;font-size:.82rem;color:var(--muted);line-height:1.55}.schedule-panel__add{width:100%}.schedule-panel__empty{margin:0;font-size:.85rem;color:var(--muted);text-align:center;padding:.75rem 0}.schedule-panel__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.schedule-panel__row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:.5rem;padding:.55rem .65rem;border:1px solid var(--border);border-radius:8px;background:var(--surface-2)}.schedule-panel__name{font-size:.88rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.schedule-panel__duration{display:flex;align-items:center;gap:.35rem}.schedule-panel__btn{border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:1.1rem;font-weight:500;line-height:1;padding:.25rem .5rem;cursor:pointer;min-width:28px;text-align:center}.schedule-panel__btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--accent)}.schedule-panel__btn:disabled{opacity:.4;cursor:not-allowed}.schedule-panel__value{font-size:.82rem;font-weight:500;color:var(--text);min-width:50px;text-align:center}.schedule-panel__remove{border:none;background:transparent;color:var(--muted);font-size:1.25rem;line-height:1;padding:0 .25rem;cursor:pointer}.schedule-panel__remove:disabled{opacity:.4;cursor:not-allowed}.schedule-panel__live{margin:0;font-size:.82rem;color:var(--accent)}.schedule-panel__save{width:100%}.section--flat{padding-top:.25rem}@media(min-width:481px){.app,.sheet{border-left:1px solid var(--border);border-right:1px solid var(--border)}}
