@import"https://api.fontshare.com/v2/css?f[]=switzer@300,400,500,600,700&display=swap";@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700&display=swap";.app-container{display:flex;height:100vh;width:100vw;overflow:hidden}.sidebar{width:280px;background-color:var(--bg-secondary);border-right:1px solid var(--line-soft);display:flex;flex-direction:column;flex-shrink:0}.properties-panel{width:320px;background-color:var(--bg-secondary);border-left:1px solid var(--line-soft);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-header{padding:1.5rem 1rem;border-bottom:1px solid var(--line-soft)}.sidebar-header h1{font-size:1rem;font-weight:500;letter-spacing:-.01em;margin-bottom:.25rem}.sidebar-header p{font-size:.875rem;color:var(--text-secondary)}.sidebar-content{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1.25rem}.sidebar-section{display:flex;flex-direction:column;padding-bottom:1.25rem;border-bottom:1px solid var(--line-soft)}.sidebar-section:last-child{border-bottom:none;padding-bottom:0}.section-title{font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin:0 0 .75rem}.main-content{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;background-color:var(--bg-primary);position:relative}.toolbar{height:60px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;background-color:var(--bg-primary);z-index:10}.toolbar-group{display:flex;align-items:center;gap:1rem}.canvas-area{flex:1;min-width:0;min-height:0;overflow:hidden;background-color:var(--bg-tertiary)}.canvas-container{width:100%;max-width:800px;min-height:500px;background-color:var(--bg-primary);border-radius:var(--r-card);padding:2rem;display:flex;flex-direction:column;transition:background-color .22s ease}.canvas-float-bar{background-color:var(--bg-secondary);border:1px solid var(--border-muted);border-radius:var(--r-card);padding:.375rem .5rem}.canvas-float-bar .btn-secondary{border-color:transparent}.canvas-float-bar .btn-secondary:hover{background-color:var(--ink-2);border-color:transparent;color:var(--text-0)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1.1rem;border-radius:var(--r-btn);font-size:14px;font-weight:500;line-height:1.2;border:var(--bw) solid transparent;transition:transform 80ms ease,background .12s ease,border-color .12s ease,color .12s ease;cursor:pointer}.btn-primary{background-color:var(--accent);color:var(--accent-on);border-color:var(--accent)}.btn-primary:hover:not(:disabled){background-color:var(--accent-soft);border-color:var(--accent-soft)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{background-color:transparent;color:var(--text-1);border:var(--bw) solid var(--border-muted)}.btn-secondary:hover:not(:disabled){background-color:transparent;color:var(--text-0);border-color:var(--text-0)}.btn-icon{padding:.4rem;border-radius:var(--r-btn);color:var(--text-secondary);transition:background-color .15s,color .15s}.btn-icon:hover{background-color:var(--ink-2);color:var(--text-primary)}.input,.textarea{width:100%;padding:.55rem .75rem;border-radius:var(--r-btn);border:1px solid var(--border-muted);background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;transition:border-color .15s,background-color .15s}.input:hover,.textarea:hover{border-color:var(--text-2)}.input:focus,.textarea:focus{outline:none;border-color:var(--accent);background-color:var(--ink-1)}.textarea{min-height:80px;resize:vertical}.label{display:block;font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;color:var(--text-secondary)}.form-group{margin-bottom:1rem}.badge{padding:.2rem .55rem;border-radius:var(--r-chip);font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;background-color:transparent;color:var(--text-secondary);border:1px solid var(--line-soft)}.badge.active{background-color:var(--accent);color:var(--accent-on);border-color:var(--accent)}:root{--ink-0: #d8dbdf;--ink-1: #e1e3e6;--ink-2: #cbced2;--ink-3: #b5b9be;--line: #121316;--line-soft: #b5b9be;--border-muted: #a6aaaf;--text-0: #121316;--text-1: #2e3136;--text-2: #5a5e63;--text-3: #5e6266;--accent: #121316;--accent-soft: #2e3136;--accent-on: #d8dbdf;--syn-tag: #3a4a5a;--syn-attr: #8a6b1f;--syn-str: #2f6b48;--r-card: 4px;--r-btn: 3px;--r-chip: 2px;--r-frame: 3px;--bw: 1.5px;--bw-rule: 1.5px;--shadow-card: none;--bg-primary: var(--ink-0);--bg-secondary: var(--ink-1);--bg-tertiary: var(--ink-2);--text-primary: var(--text-0);--text-secondary: var(--text-2);--text-tertiary: var(--text-3);--accent-primary: var(--accent);--accent-hover: var(--accent-soft);--sc-selection: #2f81f7;--border-color: var(--border-muted);--error: #8d2a2a;--success: #2f6b48;--warning: #8a6b1f;--shadow-sm: none;--shadow-md: none;--shadow-lg: 0 0 0 var(--bw) var(--line);--radius-sm: var(--r-chip);--radius-md: var(--r-btn);--radius-lg: var(--r-card);--radius-xl: var(--r-card);--radius-full: 999px;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--font-sans: "Switzer", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-display: var(--font-sans)}@media (prefers-color-scheme: dark){:root{--ink-0: #121316;--ink-1: #181a1e;--ink-2: #1f2226;--ink-3: #2a2d32;--line: #efe9dc;--line-soft: #292c31;--border-muted: #3a3d42;--text-0: #efe9dc;--text-1: #c4bfb3;--text-2: #908e85;--text-3: #898680;--accent: #efe9dc;--accent-soft: #d4cebf;--accent-on: #0a0806;--error: #cc9090;--success: #a8c8b0;--warning: #d8c888;--syn-tag: #b8c0d0;--syn-attr: #d8c888;--syn-str: #a8c8b0;--shadow-lg: 0 0 0 var(--bw) var(--line)}}*{margin:0;padding:0;box-sizing:border-box}html{background-color:var(--bg-primary)}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .22s ease,color .22s ease}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;letter-spacing:-.025em;color:var(--text-primary)}h1{letter-spacing:-.035em}h2{letter-spacing:-.03em}button{font-family:inherit;border:none;background:none;cursor:pointer}input,textarea,select{font-family:inherit}.checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;border:var(--bw) solid var(--line);border-radius:var(--r-chip);background:var(--bg-primary);cursor:pointer;display:inline-grid;place-content:center;flex-shrink:0;transition:background-color .12s ease,border-color .12s ease}.checkbox:hover:not(:disabled){border-color:var(--accent-primary)}.checkbox:checked{background:var(--accent-primary);border-color:var(--accent-primary)}.checkbox:checked:after{content:"";width:8px;height:4px;border-left:1.5px solid var(--accent-on);border-bottom:1.5px solid var(--accent-on);transform:translateY(-1px) rotate(-45deg)}.checkbox:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.checkbox:disabled{cursor:not-allowed;opacity:.45}#root{min-height:100vh;display:flex;flex-direction:column}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.w-full{width:100%}.h-full{height:100%}.h-screen{height:100vh}.p-4{padding:1rem}.p-6{padding:1.5rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-medium{font-weight:500}.text-secondary{color:var(--text-secondary)}.admin-page{padding:3rem;max-width:1200px;margin:0 auto;width:100%}@media (max-width: 768px){.admin-page{padding:1.25rem}}@media (max-width: 480px){.admin-page{padding:1rem}}.admin-page-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}@media (max-width: 768px){.admin-page-header{flex-direction:column;align-items:stretch;gap:1rem}}.responsive-row{display:flex;gap:1rem}@media (max-width: 768px){.responsive-row{flex-direction:column;gap:1rem}}.card-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(min(240px,100%),1fr))}.import-detail-grid{display:grid;gap:2rem;grid-template-columns:minmax(0,1fr) 360px}@media (max-width: 768px){.import-detail-grid{grid-template-columns:1fr}}.modal-card{width:min(560px,calc(100vw - 2rem));max-height:calc(100vh - 2rem);overflow:auto}*{scrollbar-width:thin;scrollbar-color:transparent transparent}*:hover{scrollbar-color:var(--text-3) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:transparent;border-radius:10px;border:2px solid transparent;background-clip:content-box;-webkit-transition:background-color .2s ease;transition:background-color .2s ease}*:hover::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb:hover,::-webkit-scrollbar-thumb:active{background-color:var(--text-3)}body.placement-mode,body.placement-mode *{cursor:crosshair!important}body.comment-placement-mode,body.comment-placement-mode *{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 15 15' fill='none'><g transform='scale(1,-1) translate(0,-15)'><path fill='%23ffffff' stroke='%23000000' stroke-width='0.8' d='M1.5 3a1.5 1.5 0 0 1 1.5-1.5h9A1.5 1.5 0 0 1 13.5 3v6a1.5 1.5 0 0 1-1.5 1.5H7.5l-3.5 3V10.5H3A1.5 1.5 0 0 1 1.5 9V3z'/></g></svg>") 6 2,pointer!important}body.sticky-placement-mode,body.sticky-placement-mode *{cursor:crosshair!important}@keyframes codeFlash{0%{opacity:.3}60%{opacity:.22}to{opacity:0}}.code-flash{position:absolute;left:0;right:0;background-color:var(--accent);pointer-events:none;z-index:2;animation:codeFlash .6s ease-out forwards;border-radius:2px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin .9s linear infinite;transform-origin:center}.code-editor-textarea+pre,.code-editor-textarea{color:var(--text-0)}.token.plain-text{color:var(--text-0)}.token.tag .token.tag,.token.class-name,.token.keyword,.token.operator{color:var(--syn-tag)}.token.attr-name{color:var(--syn-attr)}.token.string,.token.attr-value,.token.attr-value .token.punctuation{color:var(--syn-str)}.token.attr-value .token.attr-equals,.token.attr-value .token.punctuation.attr-equals{color:var(--text-3)}.token.number,.token.boolean{color:var(--syn-attr)}.token.punctuation,.token.script-punctuation{color:var(--text-3)}.token.comment{color:var(--text-3);font-style:italic}.token.function{color:var(--text-0)}
