@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/inter-latin-400-normal.woff2) format("woff2")}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/inter-latin-700-normal.woff2) format("woff2")}@font-face{font-family:Anton;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/anton-latin-400-normal.woff2) format("woff2")}@font-face{font-family:Fira Sans;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/fira-sans-latin-400-normal.woff2) format("woff2")}@font-face{font-family:Fira Sans;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/fira-sans-latin-700-normal.woff2) format("woff2")}@font-face{font-family:Lora;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/lora-latin-400-normal.woff2) format("woff2")}@font-face{font-family:Lora;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/lora-latin-700-normal.woff2) format("woff2")}@font-face{font-family:Comic Neue;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/comic-neue-latin-400-normal.woff2) format("woff2")}@font-face{font-family:Comic Neue;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/comic-neue-latin-700-normal.woff2) format("woff2")}@font-face{font-family:Cousine;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/cousine-latin-400-normal.woff2) format("woff2")}@font-face{font-family:Cousine;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/cousine-latin-700-normal.woff2) format("woff2")}:root{--bg: #0b1120;--surface: #111827;--surface-2: #1e293b;--surface-3: #334155;--border: #243149;--text: #e5e7eb;--muted: #94a3b8;--accent: #2563eb;--accent-2: #3b82f6;--danger: #ef4444;--stage-glow: #16223a;--checker-a: #0f172a;--checker-b: #1e293b;--radius: 14px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}:root[data-theme=light]{--bg: #eef2f7;--surface: #ffffff;--surface-2: #f1f5f9;--surface-3: #e2e8f0;--border: #cbd5e1;--text: #0f172a;--muted: #64748b;--accent: #2563eb;--accent-2: #1d4ed8;--danger: #dc2626;--stage-glow: #dbe4ee;--checker-a: #e2e8f0;--checker-b: #f8fafc}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}html,body,#root{margin:0;height:100%;width:100%;overflow:hidden}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);overscroll-behavior:none;touch-action:none;-webkit-user-select:none;user-select:none}.app{display:flex;flex-direction:column;min-width:0;max-width:100vw;overflow:hidden;height:100vh;height:100dvh;height:var(--app-h, 100dvh);width:100vw}.topbar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:calc(8px + var(--safe-top)) 12px 8px;background:var(--surface);border-bottom:1px solid var(--border);z-index:30;min-width:0;overflow:visible}.topbar-left,.topbar-center,.topbar-right{flex:0 0 auto}.topbar-left,.topbar-center,.topbar-right{display:flex;align-items:center;gap:4px}.brand{font-weight:800;font-size:20px;letter-spacing:-.02em;background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent;padding-right:6px}.zoom-label{font-size:12px;color:var(--muted);min-width:44px;height:40px;text-align:center;background:none;border:none;cursor:pointer;flex:0 0 auto}.zoom-label:hover{color:var(--text)}.zoom-label:disabled{opacity:.35;cursor:default}.zoom-label:disabled:hover{color:var(--muted)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:none;background:transparent;color:var(--text);cursor:pointer;transition:background .15s}.icon-btn:hover{background:var(--surface-2)}.icon-btn:disabled{opacity:.35;cursor:default}.icon-btn.small{width:32px;height:32px}.icon-btn.active{color:var(--accent-2)}.icon-btn.danger:hover{background:#ef444426;color:var(--danger)}.btn{padding:8px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:14px;cursor:pointer}.btn:hover{background:var(--surface-3)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-2)}.menu-wrap{position:relative}.dropdown{position:absolute;right:0;top:46px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;overflow:hidden;min-width:170px;z-index:60;box-shadow:0 12px 28px #00000073}.dropdown button{display:block;width:100%;text-align:left;padding:12px 14px;background:transparent;border:none;color:var(--text);font-size:14px;cursor:pointer}.dropdown button:hover{background:var(--surface-3)}.dropdown button:disabled{opacity:.4;cursor:default}.menu-sep{height:1px;background:var(--border);margin:4px 0}.stage-area{position:relative;flex:1;min-height:0;background:radial-gradient(circle at 50% 40%,var(--stage-glow) 0%,var(--bg) 70%)}.editor-container{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;-webkit-touch-callout:none}.home{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;overflow-y:auto;padding:24px 16px calc(24px + var(--safe-bottom))}.home-inner{width:min(440px,100%);text-align:center}.home-title{margin:0;font-size:44px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}.home-sub{margin:6px 0 28px;color:var(--muted);font-size:15px}.home-options{display:flex;flex-direction:column;gap:12px}.home-option{display:flex;align-items:center;gap:16px;width:100%;padding:16px 18px;text-align:left;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s,transform .05s}.home-option:hover{background:var(--surface-3);border-color:var(--accent)}.home-option:active{transform:scale(.99)}.home-option:disabled{opacity:.5;cursor:default}.home-option-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;flex:none;border-radius:12px;background:#2563eb29;color:var(--accent-2)}.home-option-text{display:flex;flex-direction:column;gap:2px;min-width:0}.home-option-title{font-size:16px;font-weight:600}.home-option-desc{font-size:13px;color:var(--muted)}.toolbar{background:var(--surface);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);z-index:20;display:flex;justify-content:center}.toolbar-scroll{display:flex;gap:2px;overflow-x:auto;padding:6px 8px;scrollbar-width:none;max-width:100%;min-width:0}.toolbar-scroll::-webkit-scrollbar{display:none}.tool-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-width:60px;height:56px;border:none;border-radius:12px;background:transparent;color:var(--muted);cursor:pointer;flex:0 0 auto;transition:all .15s}.tool-btn:hover{background:var(--surface-2);color:var(--text)}.tool-btn.active{background:var(--accent);color:#fff}.tool-label{font-size:11px;font-weight:500}.context-toolbar{position:absolute;left:50%;bottom:12px;transform:translate(-50%);max-width:calc(100% - 16px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 12px 30px #00000080;z-index:15}.ctx-scroll{display:flex;align-items:center;gap:6px;padding:8px 10px;overflow-x:auto;scrollbar-width:none}.ctx-scroll::-webkit-scrollbar{display:none}.ctx-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:9px;border:none;background:var(--surface-2);color:var(--text);cursor:pointer;flex:0 0 auto}.ctx-btn.active{background:var(--accent);color:#fff}.ctx-btn.done{background:#16a34a;color:#fff}.ctx-btn.danger{background:var(--surface-2);color:var(--danger)}.ctx-btn.danger:hover:not(:disabled){background:#ef44442e}.ctx-btn:disabled{opacity:.4;cursor:not-allowed}.ctx-select{height:38px;border-radius:9px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);padding:0 8px;font-size:14px}.ctx-stepper{display:inline-flex;align-items:center;background:var(--surface-2);border-radius:9px;height:38px;flex:0 0 auto}.ctx-stepper button{width:34px;height:38px;border:none;background:transparent;color:var(--text);font-size:20px;cursor:pointer}.ctx-stepper span{min-width:30px;text-align:center;font-size:13px}.ctx-color{position:relative;display:inline-flex;width:38px;height:38px;border-radius:9px;overflow:hidden;flex:0 0 auto;border:1px solid var(--border)}.ctx-color input{width:150%;height:150%;margin:-25%;border:none;padding:0;background:none;cursor:pointer}.ctx-color-glyph{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;font-size:17px;font-weight:800;line-height:1;color:#fff;text-shadow:0 0 2px #000,1px 1px 0 #000,-1px 1px 0 #000,1px -1px 0 #000,-1px -1px 0 #000}.ctx-align,.ctx-seg2{display:inline-flex;gap:4px;flex:0 0 auto}.ctx-seg2 button{width:38px;height:38px;border:none;border-radius:9px;background:var(--surface-2);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.ctx-seg2 button.active{background:var(--accent);color:#fff}.ctx-divider{width:1px;height:28px;background:var(--border);flex:0 0 auto;margin:0 2px}.ctx-swatch{display:inline-flex;align-items:center;gap:6px;height:38px;padding:0 8px;border-radius:9px;background:var(--surface-2);flex:0 0 auto;cursor:pointer;font-size:13px;color:var(--text)}.ctx-swatch input[type=color]{width:24px;height:24px;border:1px solid var(--border);border-radius:6px;padding:0;background:none;cursor:pointer}.ctx-range{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 10px;border-radius:9px;background:var(--surface-2);flex:0 0 auto;font-size:13px;color:var(--text)}.ctx-range input[type=range]{width:clamp(56px,18vw,90px);accent-color:var(--accent)}.ctx-hint{font-size:12px;color:var(--muted);padding:0 6px;white-space:nowrap;flex:0 0 auto}.ctx-btn.wide{width:auto;gap:6px;padding:0 12px;font-size:14px;font-weight:600}.style-scroll{overflow-y:auto;flex:1;padding:6px 14px 16px}.sp-textarea{margin:10px 14px 4px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2);color:var(--text);font-family:inherit;font-size:16px;line-height:1.4;resize:none;min-height:64px;max-height:28vh;overflow-y:auto;outline:none}.sp-textarea:focus{border-color:var(--accent)}.sp-section{margin:14px 0 6px;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-2);border-bottom:1px solid var(--border);padding-bottom:4px}.sp-row{display:flex;align-items:center;gap:12px;padding:7px 0;min-height:40px}.sp-label{width:96px;flex:0 0 auto;font-size:13px;color:var(--muted)}.sp-control{flex:1;display:flex;align-items:center;gap:10px;min-width:0}.sp-control input[type=range]{flex:1;accent-color:var(--accent);min-width:0}.sp-value{font-size:12px;color:var(--text);min-width:34px;text-align:right}.sp-color{width:40px;height:30px;border:1px solid var(--border);border-radius:8px;background:none;padding:0;cursor:pointer}.sp-seg{display:flex;gap:4px;flex-wrap:wrap}.sp-seg button{flex:1 1 auto;min-width:40px;height:34px;padding:0 10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:8px;font-size:13px;cursor:pointer}.sp-seg button.active{background:var(--accent);border-color:var(--accent);color:#fff}.sp-seg-icon{display:flex;align-items:center;justify-content:center}.sp-seg-icon svg{display:block}.btn svg{vertical-align:-2px;margin-right:4px}.panel{position:absolute;z-index:30;background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;left:0;right:0;bottom:0;max-height:70vh;border-radius:18px 18px 0 0;padding-bottom:var(--safe-bottom);animation:slideUp .2s ease;box-shadow:0 -12px 30px #00000080}@keyframes slideUp{0%{transform:translateY(100%)}}.style-panel{max-height:50vh}@media (max-width: 899.98px){.style-panel.editing{max-height:66vh;bottom:var(--kb-inset, 0px)}html.kb-open .style-panel.editing{max-height:none}html.kb-open .style-panel.editing .style-scroll{display:none}}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.panel-head h2{margin:0;font-size:16px}.panel-head-actions{display:flex;align-items:center;gap:8px}.sp-done{padding:6px 14px}.sp-format{padding:6px 12px}.panel-section{padding:12px 16px;border-top:1px solid var(--border)}.layer-toolbar{padding:10px 12px;border-bottom:1px solid var(--border)}.layer-toolbar .btn{display:inline-flex;align-items:center;gap:8px;width:100%;justify-content:center}.layer-list{overflow-y:auto;flex:1}.layer-row{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer}.layer-row.selected{background:#2563eb2e}.layer-type{color:var(--muted);display:inline-flex}.layer-name{flex:1;min-width:0;background:transparent;border:1px solid transparent;color:var(--text);font-size:14px;padding:4px 6px;border-radius:6px}.layer-name:focus{border-color:var(--border);background:var(--surface-2);outline:none}.layer-actions{display:flex;gap:2px}.row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.row.gap{gap:8px}.row label{font-size:13px;color:var(--muted);min-width:64px}.row input[type=range]{flex:1;accent-color:var(--accent)}.clip-scroll{overflow-y:auto;flex:1;padding:8px 12px 16px}.clip-section{font-size:13px;font-weight:600;color:var(--muted);margin:12px 4px 8px;text-transform:uppercase;letter-spacing:.04em}.clip-cat{margin-bottom:4px}.clip-cat-head{display:flex;align-items:center;gap:8px;width:100%;padding:10px 6px;background:transparent;border:none;border-top:1px solid var(--border);color:var(--text);cursor:pointer;font-size:14px;font-weight:600}.clip-cat-name{flex:1;text-align:left}.clip-cat-count{font-size:12px;color:var(--muted);background:var(--surface-2);border-radius:999px;padding:1px 8px}.clip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:10px}.clip-card{position:relative;aspect-ratio:1;border:1px solid var(--border);border-radius:12px;background:var(--checker-a) repeating-conic-gradient(var(--checker-b) 0% 25%,var(--checker-a) 0% 50%) 50% / 16px 16px;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:border-color .15s,transform .1s}.clip-card:hover{border-color:var(--accent)}.clip-card:active{transform:scale(.95)}.clip-thumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:8px}.clip-thumb img{max-width:100%;max-height:100%;object-fit:contain}.clip-del{position:absolute;top:2px;right:2px;background:#0f172ab3}.clip-del:hover{background:#ef4444e6;color:#fff}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:4px;padding:4px 0 8px}.emoji-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:22px;line-height:1;border:1px solid transparent;border-radius:6px;background:transparent;cursor:pointer;padding:0;transition:background .1s,transform .1s}.emoji-cell:hover{background:var(--surface2);border-color:var(--border)}.emoji-cell:active{transform:scale(.88)}.shapes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;padding:4px 0 8px}.shape-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;aspect-ratio:1;padding:8px;border:1px solid var(--border);border-radius:12px;background:var(--surface-2);color:var(--text);cursor:pointer;transition:border-color .15s,transform .1s}.shape-card:hover{border-color:var(--accent)}.shape-card:active{transform:scale(.95)}.shape-label{font-size:12px;color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}.modal{width:min(640px,100%);max-height:80vh;background:var(--surface);border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:16px}.modal-body{padding:16px;overflow-y:auto}.comp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.comp-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;background:var(--surface-2)}.comp-card:hover{border-color:var(--accent)}.comp-thumb{aspect-ratio:1;background:var(--checker-a) repeating-conic-gradient(var(--checker-b) 0% 25%,var(--checker-a) 0% 50%) 50% / 20px 20px;display:flex;align-items:center;justify-content:center}.comp-thumb img{max-width:100%;max-height:100%;object-fit:contain}.comp-meta{display:flex;align-items:center;justify-content:space-between;padding:6px 8px}.comp-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ctx-menu{position:fixed;z-index:1000;min-width:160px;padding:6px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px #00000080;display:flex;flex-direction:column;gap:2px}.ctx-menu-item{display:flex;align-items:center;width:100%;padding:10px 12px;font-size:14px;text-align:left;background:transparent;border:none;border-radius:8px;color:var(--text);cursor:pointer}.ctx-menu-item:hover{background:var(--surface-2)}.ctx-menu-item.danger{color:var(--danger)}.ctx-menu-item.danger:hover{background:#ef444426}.ctx-menu-item:disabled{opacity:.4;cursor:default}.seg{display:inline-flex;gap:2px;padding:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px}.seg-btn{padding:7px 16px;font-size:13px;font-weight:600;background:transparent;border:none;border-radius:7px;color:var(--muted);cursor:pointer}.seg-btn:hover{color:var(--text)}.seg-btn.active{background:var(--accent);color:#fff}.help-body{line-height:1.5}.help-h{margin:18px 0 6px;font-size:14px;font-weight:700;color:var(--text)}.help-list{margin:0;padding-left:18px;color:var(--muted);font-size:14px}.help-list li{margin-bottom:6px}.help-list b{color:var(--text)}.help-licenses{margin:4px 0 0;padding-left:18px;font-size:13px;color:var(--muted)}.help-licenses li{margin-bottom:3px}.help-body a{color:var(--accent-2)}.help-notice{margin:6px 0 0;font-size:11px;line-height:1.45;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.save-form{display:flex;flex-direction:column;gap:14px}.save-preview{align-self:center;width:160px;height:160px;border-radius:12px;border:1px solid var(--border);overflow:hidden;background:var(--checker-a) repeating-conic-gradient(var(--checker-b) 0% 25%,var(--checker-a) 0% 50%) 50% / 20px 20px;display:flex;align-items:center;justify-content:center}.save-preview img{max-width:100%;max-height:100%;object-fit:contain}.save-field{display:flex;flex-direction:column;gap:6px}.save-field-label{font-size:13px;color:var(--muted)}.save-input{width:100%;padding:10px 12px;font-size:15px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;color:var(--text)}.save-input:focus{outline:none;border-color:var(--accent)}.muted{color:var(--muted);font-size:14px}.pad{padding:16px}.toast{position:fixed;bottom:90px;left:50%;translate:-50% 10px;background:var(--surface-3);color:#fff;padding:10px 18px;border-radius:999px;font-size:14px;z-index:80;opacity:0;transition:opacity .25s,translate .25s;pointer-events:none}.toast.show{opacity:1;translate:-50% 0}.update-banner{position:fixed;left:50%;bottom:calc(84px + var(--safe-bottom, 0px));transform:translate(-50%);z-index:70;display:flex;flex-direction:column;align-items:stretch;gap:10px;width:max-content;max-width:calc(100% - 24px);background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:10px 12px 10px 16px;box-shadow:0 10px 30px #00000059;animation:banner-rise .25s ease}@keyframes banner-rise{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.update-banner-text{font-size:14px}.update-banner-actions{display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}@media (min-width: 480px){.update-banner{flex-direction:row;align-items:center;gap:14px}}@media (min-width: 900px){.panel{top:0;bottom:0;left:auto;right:0;width:340px;max-height:none;border-radius:0;border-left:1px solid var(--border);animation:slideRight .2s ease}@keyframes slideRight{0%{transform:translate(100%)}}.tool-btn{min-width:68px}}
