@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/archivo-vietnamese-300-normal-DlA9Skee.woff2) format("woff2"),url(/assets/archivo-vietnamese-300-normal-D1FN3R2n.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/archivo-latin-ext-300-normal-0WwdIqab.woff2) format("woff2"),url(/assets/archivo-latin-ext-300-normal-D3llZCfd.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/archivo-latin-300-normal-AMs-pvbP.woff2) format("woff2"),url(/assets/archivo-latin-300-normal-BRswihEa.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/archivo-vietnamese-400-normal-BF4g3tCF.woff2) format("woff2"),url(/assets/archivo-vietnamese-400-normal-FGOLYM1a.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/archivo-latin-ext-400-normal-B5tPZzqW.woff2) format("woff2"),url(/assets/archivo-latin-ext-400-normal-DrmqtLj6.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/archivo-latin-400-normal-C81ewxNO.woff2) format("woff2"),url(/assets/archivo-latin-400-normal-Bl602Mgc.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/archivo-vietnamese-500-normal-k0drYPZA.woff2) format("woff2"),url(/assets/archivo-vietnamese-500-normal-7W3lD2kQ.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/archivo-latin-ext-500-normal-RFhg4CpD.woff2) format("woff2"),url(/assets/archivo-latin-ext-500-normal-D7mXw3Kz.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/archivo-latin-500-normal-CGugC8dq.woff2) format("woff2"),url(/assets/archivo-latin-500-normal-pkzA7jw9.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/archivo-vietnamese-600-normal-anCjMumA.woff2) format("woff2"),url(/assets/archivo-vietnamese-600-normal-C8xBVdfP.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/archivo-latin-ext-600-normal-Dm61iqcg.woff2) format("woff2"),url(/assets/archivo-latin-ext-600-normal-D7uErJuz.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/archivo-latin-600-normal-3BBy0ZsW.woff2) format("woff2"),url(/assets/archivo-latin-600-normal-DwYieO8P.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/archivo-vietnamese-700-normal-nuAQAQa7.woff2) format("woff2"),url(/assets/archivo-vietnamese-700-normal-Bz2vkKqq.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/archivo-latin-ext-700-normal-DD_nkw6b.woff2) format("woff2"),url(/assets/archivo-latin-ext-700-normal-CgyfnKjw.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Archivo;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/archivo-latin-700-normal-D9cHMWGj.woff2) format("woff2"),url(/assets/archivo-latin-700-normal-lT5TFe7H.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--c-bg-dark: #041829;--c-bg-light: #fafafa;--c-primary-intense: #050e18;--c-primary-dark: #0a2e45;--c-primary-light: #1e3a52;--c-surface-page: #f5f4f8;--c-surface-subtle: #eeedf3;--c-surface-card: #ffffff;--c-secondary: #2e3070;--c-secondary-medium: #9090c0;--c-secondary-light: #8888b8;--c-tertiary: #ee486f;--c-accent: #4e8fad;--c-accent-light: #7aafc8;--c-accent-dark: #34738e;--c-accent-2: #f4ae10;--c-accent-2-dark: #d4900a;--c-success: #3a8020;--c-error: #ba1a1a;--c-border: #ddd8d0;--c-border-strong: #c8c4bc;--c-neutral: #565c61;--c-neutral-light: #87909b;--c-neutral-dark: #42474e;--font-body: "Archivo", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--r-pill: 999px;--s-soft: 0 1px 3px rgba(10, 46, 69, .08), 0 1px 2px rgba(10, 46, 69, .06);--s-panel: 0 4px 24px rgba(10, 46, 69, .08);--s-elevated: 0 10px 24px rgba(10, 46, 69, .18);--t-default: all .18s cubic-bezier(.25, .8, .25, 1);--t-button: all .1s ease-in-out;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-body);font-size:14px;line-height:1.5;color:var(--c-primary-dark);background:var(--c-surface-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overscroll-behavior:none}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px}::selection{background:#4e8fad4d}.app-shell{display:grid;grid-template-rows:auto 1fr;height:100vh;height:100dvh;overflow:hidden}.app-shell.is-mobile{grid-template-rows:auto 1fr auto}.app-shell.is-mobile.is-play{grid-template-rows:auto 1fr}.app-body{display:grid;grid-template-columns:240px 1fr 300px;min-height:0;background:var(--c-surface-page)}.app-shell.is-mobile .app-body{grid-template-columns:1fr}@media(max-width:1100px){.app-shell:not(.is-mobile) .app-body{grid-template-columns:200px 1fr 260px}}.topbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:linear-gradient(180deg,var(--c-primary-dark) 0%,var(--c-primary-intense) 100%);color:var(--c-bg-light);border-bottom:1px solid rgba(0,0,0,.4);flex-wrap:wrap;min-width:0}.topbar>*{min-width:0}.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:.2px;white-space:nowrap;flex-shrink:0}.topbar .brand .brand-text{overflow:hidden;text-overflow:ellipsis}@media(max-width:1280px){.topbar .brand .brand-text{display:none}}@media(max-width:1180px){.topbar-actions .btn-label-md{display:none}}@media(max-width:1024px){.topbar{gap:8px;padding:10px 12px}}.topbar .brand .mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--c-accent) 0%,var(--c-secondary) 100%);display:grid;place-items:center;color:#fff}.topbar .spacer{flex:1}.topbar .topbar-actions{display:flex;align-items:center;gap:8px}@media(max-width:1024px){.topbar{padding:8px 10px;gap:6px;overflow:hidden}.topbar .brand .brand-text{display:none}.topbar .topbar-desktop-only{display:none!important}.topbar .spacer{flex:0 1 8px}.layout-pill{min-width:0;flex:1 1 0;max-width:none}.layout-pill .ui-select{min-width:0}.topbar [role=tablist]{flex-shrink:0}.topbar [role=tablist] .btn{padding:6px 10px;font-size:12px}.topbar [role=tablist] .btn span,.topbar [role=tablist] .btn-label{display:none}}.panel{background:var(--c-surface-card);border-right:1px solid var(--c-surface-subtle);overflow-y:auto;display:flex;flex-direction:column}.panel-left{composes:panel}.panel-right{background:var(--c-surface-card);border-left:1px solid var(--c-surface-subtle);overflow-y:auto;display:flex;flex-direction:column}.panel-section{padding:14px 16px;border-bottom:1px solid var(--c-surface-subtle)}.panel-section h3{margin:0 0 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--c-neutral)}.panel-section .hint{font-size:12px;color:var(--c-neutral-light);margin-top:6px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:var(--r-md);font-weight:500;font-size:13px;transition:var(--t-button);cursor:pointer;background:var(--c-surface-card);color:var(--c-primary-dark);border:1px solid var(--c-surface-subtle)}.btn:hover{background:var(--c-surface-subtle)}.btn.btn-primary{background:var(--c-accent);color:#fff;border-color:transparent}.btn.btn-primary:hover{background:var(--c-accent-dark)}.btn.btn-ghost{background:transparent;border-color:transparent;color:var(--c-bg-light)}.btn.btn-ghost:hover{background:#ffffff14}.btn.btn-danger{color:var(--c-error);border-color:transparent}.btn.btn-danger:hover{background:#ba1a1a14}.btn.btn-icon{padding:8px;width:34px;height:34px}.btn.is-active{background:var(--c-accent);color:#fff;border-color:transparent}.btn:disabled,.btn[disabled]{opacity:.4;cursor:not-allowed}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-md);color:var(--c-bg-light);background:transparent;transition:var(--t-button)}.icon-btn:hover{background:#ffffff14}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.field label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--c-neutral)}.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--c-surface-subtle);border-radius:var(--r-md);padding:8px 10px;background:var(--c-surface-card);color:var(--c-primary-dark);transition:var(--t-default);width:100%}@media(max-width:1024px){.input,input[type=number],input[type=text],input[type=range],.ui-select{font-size:16px}}.input:hover{border-color:var(--c-border-strong)}.input:focus{border-color:var(--c-accent);outline:none;box-shadow:0 0 0 3px #4e8fad26}.ui-select{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--c-surface-subtle);border-radius:var(--r-md);padding:8px 10px 8px 12px;background:var(--c-surface-card);color:var(--c-primary-dark);transition:var(--t-default);font:inherit;font-size:13px;width:100%;cursor:pointer;text-align:left;line-height:1.2}.ui-select[data-placeholder]{color:var(--c-neutral-light)}.ui-select:hover{border-color:var(--c-border-strong)}.ui-select:focus,.ui-select[data-state=open]{border-color:var(--c-accent);outline:none;box-shadow:0 0 0 3px #4e8fad26}.ui-select>[data-radix-select-value]{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ui-select__icon{display:inline-flex;align-items:center;color:var(--c-neutral);transition:transform .15s ease}.ui-select[data-state=open] .ui-select__icon{transform:rotate(180deg);color:var(--c-accent)}.ui-select--ghost{background:#ffffff0f;border-color:#ffffff1f;color:var(--c-bg-light);font-weight:500;border-radius:var(--r-pill);padding-left:14px;padding-right:12px}.ui-select--ghost:hover{background:#ffffff1a;border-color:#fff3}.ui-select--ghost:focus,.ui-select--ghost[data-state=open]{background:#ffffff1f;border-color:var(--c-accent-light);box-shadow:0 0 0 3px #7aafc82e}.ui-select--ghost .ui-select__icon{color:#ffffffb3}.ui-select--ghost[data-state=open] .ui-select__icon{color:var(--c-accent-light)}.ui-select__content{z-index:80;min-width:var(--radix-select-trigger-width);max-height:var(--radix-select-content-available-height);background:var(--c-surface-card);color:var(--c-primary-dark);border:1px solid var(--c-surface-subtle);border-radius:var(--r-md);box-shadow:var(--s-panel);overflow:hidden;padding:4px;animation:ui-select-pop .12s ease;transform-origin:var(--radix-select-content-transform-origin)}@keyframes ui-select-pop{0%{opacity:0;transform:scale(.97) translateY(-2px)}to{opacity:1;transform:scale(1) translateY(0)}}.ui-select__viewport{display:flex;flex-direction:column;gap:1px}.ui-select__item{position:relative;display:flex;align-items:center;gap:8px;padding:8px 28px 8px 10px;border-radius:var(--r-sm);font-size:13px;color:var(--c-primary-dark);cursor:pointer;-webkit-user-select:none;user-select:none;outline:none}.ui-select__item[data-highlighted]{background:var(--c-surface-subtle)}.ui-select__item[data-state=checked]{color:var(--c-accent-dark);font-weight:500}.ui-select__item[data-disabled]{color:var(--c-neutral-light);pointer-events:none}.ui-select__indicator{position:absolute;right:8px;display:inline-flex;align-items:center;color:var(--c-accent)}.ui-select__item--clear{color:var(--c-neutral);border-bottom:1px solid var(--c-surface-subtle);margin-bottom:2px;padding-bottom:8px;border-radius:0}.ui-select__icon-slot{display:inline-flex;align-items:center;color:var(--c-neutral)}.row{display:flex;gap:8px;align-items:center}.row>.input{flex:1}.tool-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.tool-tile{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 8px;background:var(--c-surface-page);border:1px solid var(--c-surface-subtle);border-radius:var(--r-md);color:var(--c-primary-dark);cursor:grab;transition:var(--t-default);font-size:11px;font-weight:500;text-align:center}.tool-tile:active{cursor:grabbing}.tool-tile:hover{background:var(--c-surface-card);border-color:var(--c-accent-light);transform:translateY(-1px);box-shadow:var(--s-soft)}.tool-tile .preview{width:28px;height:28px;background:var(--c-accent);display:grid;place-items:center;color:#fff}.tool-tile .preview.rect{border-radius:4px}.tool-tile .preview.rounded{border-radius:10px}.tool-tile .preview.circle{border-radius:50%}.tool-tile .preview.trackpad{background:radial-gradient(circle at center,rgba(255,255,255,.7),transparent 60%),var(--c-secondary);border-radius:4px}.tool-tile .preview.trackpad-c{background:radial-gradient(circle at center,rgba(255,255,255,.7),transparent 60%),var(--c-secondary);border-radius:50%}.tool-tile .preview.triangle{background:var(--c-accent);clip-path:polygon(50% 0%,100% 100%,0% 100%)}.tool-tile .preview.arch{background:var(--c-accent);border-top-left-radius:100%;border-top-right-radius:100%}.canvas-wrap{position:relative;display:flex;align-items:center;justify-content:center;padding:24px;min-height:0;overflow:auto;touch-action:pan-y}@media(max-width:1024px){.canvas-wrap{padding:12px;padding-bottom:max(12px,env(safe-area-inset-bottom))}}.app-shell.is-mobile.is-play .canvas-wrap{padding:0;background:var(--c-bg-dark)}.app-shell.is-play .canvas-wrap,.app-shell.is-play .canvas-frame{touch-action:manipulation}.app-shell.is-mobile.is-play .canvas-frame{border-radius:0;max-width:100%;max-height:100%;width:100%;aspect-ratio:16 / 9;margin:auto}.canvas-frame{position:relative;background:var(--canvas-bg, var(--c-bg-dark));background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px;border-radius:var(--r-lg);box-shadow:var(--s-elevated);width:min(100%,1280px);aspect-ratio:16 / 9;overflow:hidden;touch-action:none}.canvas-frame.is-play{cursor:default;background-image:none}.canvas-frame.is-drag-over{outline:2px dashed var(--c-accent-2);outline-offset:-8px;background-color:#f4ae100a}.element{position:absolute;display:grid;place-items:center;color:#fff;font-weight:600;user-select:none;-webkit-user-select:none;border:0;outline:none;text-align:center;word-break:break-word;padding:6px;cursor:grab;transition:filter .1s ease;touch-action:none;-webkit-tap-highlight-color:transparent}.element.is-rect{border-radius:4px}.element.is-rounded{border-radius:14px}.element.is-circle{border-radius:50%}.element.is-triangle{clip-path:polygon(50% 0%,100% 100%,0% 100%);background-clip:padding-box}.element.is-arch{border-radius:100% 100% 0 0}.element.is-trackpad{background-image:radial-gradient(circle at center,rgba(255,255,255,.2),transparent 70%);border:1px dashed rgba(255,255,255,.35)}.element .label{font-size:inherit;line-height:1.1;pointer-events:none;text-shadow:0 1px 0 rgba(0,0,0,.2)}.element.is-selected{outline:2px solid var(--c-accent-2);outline-offset:2px}.element:focus{outline:none}.element:focus-visible{outline:2px solid var(--c-accent-2);outline-offset:2px;box-shadow:0 0 0 4px #f4ae1040}.element.is-play:active{filter:brightness(1.2)}.element.is-trackpad .crosshair{position:absolute;width:14px;height:14px;border:2px solid var(--c-accent-2);border-radius:50%;background:#f4ae1033;transform:translate(-50%,-50%);pointer-events:none}.element.is-trackpad .crosshair:before,.element.is-trackpad .crosshair:after{content:"";position:absolute;background:var(--c-accent-2)}.element.is-trackpad .crosshair:before{top:50%;left:-8px;right:-8px;height:2px;transform:translateY(-50%)}.element.is-trackpad .crosshair:after{left:50%;top:-8px;bottom:-8px;width:2px;transform:translate(-50%)}.handle{position:absolute;width:12px;height:12px;background:var(--c-accent-2);border:2px solid white;border-radius:50%;box-shadow:0 1px 2px #0006;z-index:2;touch-action:none}@media(pointer:coarse){.handle{width:18px;height:18px}.handle:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px}.handle-rotate{width:20px;height:20px;top:-36px}}.handle.h-nw{top:-6px;left:-6px;cursor:nwse-resize}.handle.h-ne{top:-6px;right:-6px;cursor:nesw-resize}.handle.h-sw{bottom:-6px;left:-6px;cursor:nesw-resize}.handle.h-se{bottom:-6px;right:-6px;cursor:nwse-resize}.handle.h-n{top:-6px;left:50%;transform:translate(-50%);cursor:ns-resize}.handle.h-s{bottom:-6px;left:50%;transform:translate(-50%);cursor:ns-resize}.handle.h-w{top:50%;left:-6px;transform:translateY(-50%);cursor:ew-resize}.handle.h-e{top:50%;right:-6px;transform:translateY(-50%);cursor:ew-resize}.handle-rotate{position:absolute;top:-28px;left:50%;width:14px;height:14px;border-radius:50%;background:var(--c-accent-2);border:2px solid white;transform:translate(-50%);box-shadow:0 1px 3px #0006;cursor:grab;z-index:3;touch-action:none}.handle-rotate:before{content:"";position:absolute;top:100%;left:50%;width:2px;height:18px;background:var(--c-accent-2);transform:translate(-50%)}.handle-rotate:active{cursor:grabbing}.swatch-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.swatch{width:100%;aspect-ratio:1;border-radius:var(--r-md);border:2px solid transparent;cursor:pointer;transition:var(--t-default)}.swatch:hover{transform:scale(1.05)}.swatch.is-active{border-color:var(--c-primary-dark);box-shadow:0 0 0 2px #fff inset}.fullscreen-toggle{position:absolute;top:12px;right:12px;width:36px;height:36px;display:grid;place-items:center;background:#0a2e45b3;color:var(--c-bg-light);border:1px solid rgba(255,255,255,.18);border-radius:var(--r-md);cursor:pointer;z-index:4;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:var(--t-default)}.fullscreen-toggle:hover{background:#0a2e45e6;border-color:var(--c-accent-light)}html:fullscreen .topbar,html:fullscreen .app-body>.panel,html:fullscreen .app-body>.panel-right,html:fullscreen .mobile-bar,html:fullscreen .drawer,html:fullscreen .drawer-backdrop,html:-webkit-full-screen .topbar,html:-webkit-full-screen .app-body>.panel,html:-webkit-full-screen .app-body>.panel-right,html:-webkit-full-screen .mobile-bar,html:-webkit-full-screen .drawer,html:-webkit-full-screen .drawer-backdrop,html.is-soft-fullscreen .topbar,html.is-soft-fullscreen .app-body>.panel,html.is-soft-fullscreen .app-body>.panel-right,html.is-soft-fullscreen .mobile-bar,html.is-soft-fullscreen .drawer,html.is-soft-fullscreen .drawer-backdrop{display:none!important}html:fullscreen .app-shell,html:-webkit-full-screen .app-shell,html.is-soft-fullscreen .app-shell{grid-template-rows:1fr}html:fullscreen .app-body,html:-webkit-full-screen .app-body,html.is-soft-fullscreen .app-body{grid-template-columns:1fr;grid-template-rows:1fr}html:fullscreen .canvas-wrap,html:-webkit-full-screen .canvas-wrap,html.is-soft-fullscreen .canvas-wrap{padding:0;background:var(--c-bg-dark)}html:fullscreen .canvas-frame,html:-webkit-full-screen .canvas-frame,html.is-soft-fullscreen .canvas-frame{border-radius:0;max-width:100%;max-height:100%;width:100%;aspect-ratio:16 / 9;margin:auto}html.is-soft-fullscreen,html.is-soft-fullscreen body,html.is-soft-fullscreen #root{width:100%;height:100vh;height:100dvh}html.is-soft-fullscreen .app-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--c-bg-dark)}.settings-section{margin-top:4px}.settings-section h3{margin:14px 0 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--c-neutral)}.settings-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--c-surface-subtle);border-radius:var(--r-md);cursor:pointer;transition:var(--t-default)}.settings-row:hover{background:var(--c-surface-page);border-color:var(--c-border)}.settings-row input[type=checkbox]{margin-top:2px;width:16px;height:16px;accent-color:var(--c-accent);flex-shrink:0}.settings-row__body strong{display:block;font-size:13px;font-weight:600;color:var(--c-primary-dark);margin-bottom:2px}.settings-row__body p{margin:0;font-size:12px;line-height:1.5;color:var(--c-neutral)}.play-status{position:absolute;top:16px;left:16px;right:16px;display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:var(--r-md);background:var(--c-surface-card);color:var(--c-primary-dark);box-shadow:var(--s-elevated);font-size:13px;max-width:560px;margin-inline:auto;z-index:5}.play-status--warn{background:#f4ae10f5;color:#2a1a00}.play-status--warn .play-status__icon{color:#2a1a00}.play-status--error{background:#ba1a1af5;color:#fff}.play-status--info{background:#0a2e45f0;color:var(--c-bg-light);justify-content:center;font-size:12px}.play-status__icon{display:inline-flex;align-items:center;flex-shrink:0;margin-top:1px}.play-status__body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.play-status__body strong{font-size:13px;font-weight:600}.play-status__body p{margin:0;font-size:12.5px;line-height:1.45;opacity:.92}.play-status .btn{flex-shrink:0}.play-status--error .btn,.play-status--warn .btn{background:#ffffff2e;color:inherit;border-color:#ffffff52}.play-status--error .btn:hover,.play-status--warn .btn:hover{background:#ffffff47}.play-status__spinner{animation:ccc-spin 1s linear infinite}@keyframes ccc-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#050e1880;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:50}.modal{background:var(--c-surface-card);border-radius:var(--r-lg);padding:20px 22px;width:min(500px,92vw);box-shadow:var(--s-elevated);color:var(--c-primary-dark)}.modal h2{margin:0 0 8px;font-size:18px}.modal .modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.modal.modal--wide{width:min(720px,92vw);max-height:86vh;display:flex;flex-direction:column}.modal--wide .preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;overflow-y:auto;margin-right:-6px;padding-right:6px}@media(max-width:600px){.modal--wide .preset-grid{grid-template-columns:1fr 1fr}}.preset-card{display:flex;flex-direction:column;gap:8px;padding:10px;background:var(--c-surface-page);border:1px solid var(--c-surface-subtle);border-radius:var(--r-md);cursor:pointer;text-align:left;transition:var(--t-default);color:var(--c-primary-dark)}.preset-card:hover{border-color:var(--c-accent-light);background:var(--c-surface-card)}.preset-card.is-active{border-color:var(--c-accent);background:var(--c-surface-card);box-shadow:0 0 0 3px #4e8fad2e}.preset-card__thumb{border-radius:var(--r-sm);overflow:hidden}.preset-card__body strong{display:block;font-size:13px;font-weight:600;margin-bottom:2px}.preset-card__body p{margin:0;font-size:11.5px;line-height:1.4;color:var(--c-neutral)}.layout-thumb{position:relative;width:100%;aspect-ratio:16 / 9;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:12px 12px;overflow:hidden}.layout-thumb__empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#ffffff73;font-size:11px;font-style:italic}.layout-thumb__el{position:absolute;pointer-events:none}.layout-thumb__el.is-rect{border-radius:1px}.layout-thumb__el.is-rounded{border-radius:3px}.layout-thumb__el.is-circle{border-radius:50%}.layout-thumb__el.is-triangle{clip-path:polygon(50% 0%,100% 100%,0% 100%)}.layout-thumb__el.is-arch{border-top-left-radius:100%;border-top-right-radius:100%}.layout-thumb__el.is-trackpad{border:1px dashed rgba(255,255,255,.35);background-image:radial-gradient(circle at center,rgba(255,255,255,.2),transparent 70%)}.layout-pill{display:flex;align-items:center;gap:6px;min-width:220px;max-width:320px}.empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#fff9;pointer-events:none;text-align:center;padding:24px}.empty-state .title{font-size:16px;margin-bottom:6px;color:#ffffffd9}.empty-state .body{font-size:13px;max-width:420px}.device-card{width:min(440px,100%);background:var(--c-surface-card);border-radius:var(--r-lg);padding:22px;box-shadow:var(--s-elevated);color:var(--c-primary-dark)}.device-card__head{display:flex;align-items:center;gap:8px;color:var(--c-accent);margin-bottom:6px}.device-card__head h2{margin:0;font-size:16px;color:var(--c-primary-dark)}.device-card__hint{font-size:13px;color:var(--c-neutral);margin:0 0 14px;line-height:1.5}.device-card__select{margin-bottom:14px}.device-card__state{padding:12px;border-radius:var(--r-md);background:var(--c-surface-subtle);color:var(--c-neutral);font-size:13px;margin-bottom:14px}.device-card__error{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#ba1a1a14;border:1px solid rgba(186,26,26,.25);border-radius:var(--r-md);color:var(--c-error);font-size:13px;margin-bottom:14px}.device-card__actions{display:flex;gap:8px;justify-content:flex-end}.device-pill{display:flex;align-items:center;gap:6px;color:var(--c-bg-light);min-width:180px}.device-pill .ui-select{min-width:160px}.device-pill__placeholder{padding:6px 10px;border-radius:var(--r-pill);background:#ffffff0f;border:1px dashed rgba(255,255,255,.18);font-size:12px;color:#ffffffb3}.device-onboarding{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#050e1899;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:30}.key-picker{position:relative;display:flex;flex-direction:column;gap:6px}.key-picker__trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:8px 10px;border:1px solid var(--c-surface-subtle);border-radius:var(--r-md);background:var(--c-surface-card);color:var(--c-primary-dark);font-size:13px;cursor:pointer;text-align:left;transition:var(--t-default)}.key-picker__trigger:hover{border-color:var(--c-border-strong)}.key-picker__trigger[aria-expanded=true]{border-color:var(--c-accent);box-shadow:0 0 0 3px #4e8fad26}.key-picker__label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.key-picker__chevron{color:var(--c-neutral);transition:transform .15s ease;flex-shrink:0}.key-picker__trigger[aria-expanded=true] .key-picker__chevron{transform:rotate(180deg)}.key-picker__chips{display:flex;flex-wrap:wrap;gap:4px}.key-picker__chip{display:inline-flex;align-items:center;gap:4px;padding:2px 4px 2px 6px;background:var(--c-surface-subtle);border:1px solid var(--c-border);border-radius:var(--r-pill);font-size:11px;color:var(--c-primary-dark);max-width:100%}.key-picker__chip-glyph{font-family:var(--font-mono);font-size:10.5px;font-weight:600;background:var(--c-surface-card);border-radius:3px;padding:1px 4px}.key-picker__chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:14ch}.key-picker__chip-remove{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;color:var(--c-neutral);background:transparent;border:0;cursor:pointer}.key-picker__chip-remove:hover{background:var(--c-border);color:var(--c-error)}.key-picker__panel{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:var(--c-surface-card);border:1px solid var(--c-surface-subtle);border-radius:var(--r-md);box-shadow:var(--s-panel);display:flex;flex-direction:column;max-height:min(420px,60vh);overflow:hidden}.key-picker__search{padding:8px;border-bottom:1px solid var(--c-surface-subtle)}.key-picker__search .input{font-size:13px}.key-picker__list{overflow-y:auto;overflow-x:hidden;padding:6px}.key-picker__group{margin-bottom:6px}.key-picker__group-head{font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--c-neutral);font-weight:600;padding:6px 6px 4px;position:sticky;top:0;background:var(--c-surface-card);z-index:1}.key-picker__group-keys{display:flex;flex-direction:column;gap:2px}.key-picker__key{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:var(--r-sm);background:transparent;border:0;font-size:12.5px;color:var(--c-primary-dark);text-align:left;cursor:pointer;min-height:30px}.key-picker__key:hover{background:var(--c-surface-subtle)}.key-picker__key.is-on{background:#4e8fad1f;color:var(--c-accent-dark);font-weight:500}.key-picker__key-glyph{font-family:var(--font-mono);font-size:10.5px;font-weight:600;background:var(--c-surface-subtle);border-radius:3px;padding:2px 5px;min-width:28px;text-align:center;flex-shrink:0}.key-picker__key.is-on .key-picker__key-glyph{background:var(--c-accent);color:#fff}.key-picker__key-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.key-picker__platform{color:var(--c-neutral-light);font-size:11px;font-weight:400}.key-picker__key-check{color:var(--c-accent);flex-shrink:0}.key-picker__empty{padding:12px;text-align:center;color:var(--c-neutral);font-size:12.5px;font-style:italic}.macro-list{display:flex;flex-direction:column;gap:10px}.macro-event{display:flex;flex-direction:column;gap:6px;padding:10px;background:var(--c-surface-page);border:1px solid var(--c-surface-subtle);border-radius:var(--r-md)}.macro-event__head{display:flex;align-items:center;gap:6px}.macro-event__head>.ui-select{flex:1}.macro-event__head .icon-btn{width:28px;height:28px;color:var(--c-neutral)}.macro-event__head .icon-btn:hover{background:var(--c-surface-subtle);color:var(--c-error)}.mobile-bar{display:flex;align-items:stretch;background:var(--c-surface-card);border-top:1px solid var(--c-surface-subtle);padding-bottom:env(safe-area-inset-bottom);z-index:30}.mobile-bar__btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:10px 8px;color:var(--c-primary-dark);font-size:11px;font-weight:500;background:transparent;border:0;cursor:pointer;transition:background .15s ease}.mobile-bar__btn:active{background:var(--c-surface-subtle)}.mobile-bar__btn:disabled{color:var(--c-neutral-light);opacity:.6;cursor:not-allowed}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#050e1873;z-index:40;animation:drawer-fade .18s ease}.drawer{position:fixed;left:0;right:0;bottom:0;z-index:41;background:var(--c-surface-card);border-radius:18px 18px 0 0;box-shadow:0 -8px 30px #0a2e452e;max-height:85dvh;display:flex;flex-direction:column;animation:drawer-up .22s cubic-bezier(.2,.8,.2,1);padding-bottom:env(safe-area-inset-bottom)}@keyframes drawer-fade{0%{opacity:0}to{opacity:1}}@keyframes drawer-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.drawer__head{display:flex;align-items:center;gap:10px;padding:14px 16px 10px;border-bottom:1px solid var(--c-surface-subtle);position:relative;touch-action:none;cursor:grab;user-select:none;-webkit-user-select:none}.drawer__head:active{cursor:grabbing}.drawer{transition:transform .22s cubic-bezier(.2,.8,.2,1)}.drawer.is-dragging{transition:none}.drawer-backdrop{transition:opacity .18s ease}.drawer__head strong{font-size:14px}.drawer__grip{position:absolute;top:6px;left:50%;transform:translate(-50%);width:36px;height:4px;background:var(--c-border);border-radius:2px}.drawer__close{margin-left:auto;color:var(--c-neutral)}.drawer__body{overflow-y:auto;flex:1;min-height:0}.drawer__body .panel,.drawer__body .panel-right{border:0;background:transparent}.drawer-menu{padding:12px 16px 20px;display:flex;flex-direction:column;gap:18px}.drawer-section h3{margin:0 0 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--c-neutral)}.drawer-menu__grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.drawer-menu__grid .btn{justify-content:flex-start}.auth-gate{display:grid;place-items:center;min-height:100vh;padding:24px;background:radial-gradient(circle at 20% 0%,rgba(78,143,173,.18),transparent 50%),radial-gradient(circle at 80% 100%,rgba(46,48,112,.2),transparent 55%),linear-gradient(180deg,var(--c-primary-dark) 0%,var(--c-primary-intense) 100%);color:var(--c-bg-light)}.auth-card{width:min(480px,100%);background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);padding:28px;box-shadow:var(--s-elevated);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.auth-brand{display:flex;align-items:flex-start;gap:14px;margin-bottom:22px}.auth-mark{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--c-accent) 0%,var(--c-secondary) 100%);color:#fff;flex-shrink:0}.auth-card h1{margin:0 0 4px;font-size:18px;letter-spacing:.2px}.auth-sub{margin:0;font-size:13px;color:#ffffffb3}.auth-actions{display:flex;flex-direction:column;gap:10px;margin-top:4px}.auth-cta{width:100%;padding:12px 16px;font-size:14px;font-weight:600}.auth-secondary{width:100%;background:transparent;color:#ffffffd9;border:1px solid rgba(255,255,255,.18)}.auth-secondary:hover{background:#ffffff14}.auth-foot{margin:18px 0 0;font-size:12px;color:#ffffff8c;line-height:1.5}.auth-error{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;margin-bottom:14px;background:#ba1a1a2e;border:1px solid rgba(224,85,85,.4);border-radius:var(--r-md);color:#ffcdd2;font-size:13px}.auth-warning{display:flex;gap:10px;padding:14px;background:#f4ae101f;border:1px solid rgba(244,174,16,.4);border-radius:var(--r-md);color:#ffeac2;font-size:13px;line-height:1.55}.auth-warning strong{display:block;margin-bottom:4px;color:#ffd980}.auth-warning p{margin:0}.auth-warning code,.auth-error code,.auth-foot code{background:#0000004d;padding:1px 5px;border-radius:3px;font-family:var(--font-mono);font-size:11.5px;word-break:break-all}.kbd-list{margin:0;display:grid;grid-template-columns:auto 1fr;column-gap:12px;row-gap:8px;font-size:12px}.kbd-list dt{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.kbd-list dd{margin:0;color:var(--c-neutral);align-self:center;line-height:1.4}kbd{display:inline-flex;align-items:center;justify-content:center;min-width:22px;padding:2px 6px;font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--c-primary-dark);background:var(--c-surface-subtle);border:1px solid var(--c-border);border-bottom-width:2px;border-radius:4px}.toast{position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:var(--c-primary-dark);color:var(--c-bg-light);padding:10px 16px;border-radius:var(--r-md);font-size:13px;box-shadow:var(--s-elevated);z-index:60;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}
