@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@500&family=Manrope:wght@400;500;600;700&display=swap";:root{--color-bg: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);--color-surface: rgba(255, 255, 255, .86);--color-surface-raised: #ffffff;--color-surface-inset: #fcfdff;--color-surface-hover: #f8fafc;--color-text: #0f172a;--color-text-secondary: #475569;--color-text-muted: #64748b;--color-text-faint: #94a3b8;--color-border: #e2e8f0;--color-border-subtle: #eef2f7;--color-border-input: #dbe3ee;--color-primary-bg: #0f172a;--color-primary-text: #ffffff;--color-error-bg: #fff5f5;--color-error-border: #fecaca;--color-error-text: #991b1b;--color-error-text-body: #b91c1c;--color-success-bg: #ecfdf5;--color-success-border: #6ee7b7;--color-success-text: #065f46;--color-gutter-bg: #f8fafc;--color-active-line: rgba(226, 232, 240, .45);--color-active-line-focused: rgba(226, 232, 240, .55);--color-active-gutter-focused: rgba(226, 232, 240, .72);--color-selection: rgba(59, 130, 246, .3);--color-caret: #0f172a;--checker-color: rgba(148, 163, 184, .08);--shadow-panel: 0 18px 40px rgba(148, 163, 184, .12);--shadow-button: 0 1px 2px rgba(15, 23, 42, .08);--color-focus: #cbd5e1;font-family:Manrope,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light}[data-theme=dark]{--color-bg: linear-gradient(180deg, #0f172a 0%, #0c1322 100%);--color-surface: rgba(30, 41, 59, .86);--color-surface-raised: #1e293b;--color-surface-inset: #1a2332;--color-surface-hover: #334155;--color-text: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-text-faint: #475569;--color-border: #334155;--color-border-subtle: #293548;--color-border-input: #3b4d66;--color-primary-bg: #e2e8f0;--color-primary-text: #0f172a;--color-error-bg: #3b1111;--color-error-border: #7f1d1d;--color-error-text: #fca5a5;--color-error-text-body: #f87171;--color-success-bg: #052e16;--color-success-border: #166534;--color-success-text: #86efac;--color-gutter-bg: #1a2332;--color-active-line: rgba(51, 65, 85, .5);--color-active-line-focused: rgba(51, 65, 85, .7);--color-active-gutter-focused: rgba(51, 65, 85, .85);--color-selection: rgba(59, 130, 246, .35);--color-caret: #f1f5f9;--checker-color: rgba(148, 163, 184, .06);--shadow-panel: 0 18px 40px rgba(0, 0, 0, .3);--shadow-button: 0 1px 2px rgba(0, 0, 0, .3);--color-focus: #475569;color-scheme:dark}*{box-sizing:border-box}html{min-width:320px;height:100%}@media(max-width:1080px){html{height:auto;min-height:100%}}body{margin:0;min-width:320px;height:100%;overflow:hidden}@media(max-width:1080px){body{overflow:auto;height:auto;min-height:100%}}body,button,textarea{font-family:inherit}button{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,color .16s ease}button:hover{transform:translateY(-1px)}button:focus-visible,textarea:focus-visible{outline:2px solid var(--color-focus);outline-offset:2px}textarea::selection{background:var(--color-selection)}#root{height:100%}@media(max-width:1080px){#root{height:auto;min-height:100%}}.app-shell{height:100vh;padding:28px;overflow:hidden}@supports (height: 100dvh){.app-shell{height:100dvh}}.workspace{display:grid;height:100%;min-height:0;grid-template-columns:minmax(0,1.08fr) minmax(340px,.92fr);grid-template-rows:auto minmax(0,1fr);gap:20px}.workspace-header{grid-column:1 / -1;display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:16px;margin-bottom:-2px}.workspace-brand{display:inline-flex;align-items:center;gap:12px}.app-logo{width:42px;height:42px;flex:0 0 auto}.workspace-links{display:flex;align-items:center;gap:10px;justify-self:center}.workspace-github{display:grid;place-items:center;width:40px;height:40px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface-raised);color:var(--color-text-secondary);text-decoration:none}.workspace-github svg{width:18px;height:18px}.workspace-donate{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface-raised);color:var(--color-text-secondary);font-size:.82rem;font-weight:600;text-decoration:none}.workspace-donate svg{width:18px;height:18px;flex:0 0 auto}.workspace-header h1{margin:0;font-size:1rem;line-height:1.2;font-weight:600;letter-spacing:-.02em;color:var(--color-text)}.panel-kicker,.editor-label,.inspector-row span,.workspace-meta span{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.panel-kicker{color:var(--color-text-muted)}.workspace-meta{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;justify-self:end}.workspace-meta span{padding:7px 10px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface-raised);color:var(--color-text-secondary)}.panel,.editor-frame,.inspector,.preview-stage{border:1px solid var(--color-border);background:var(--color-surface)}.panel{min-height:0;padding:18px;border-radius:24px;box-shadow:var(--shadow-panel)}.panel-editor,.panel-preview{display:flex;flex-direction:column}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.panel-header h2{margin:4px 0 0;font-size:1.1rem;font-weight:600;color:var(--color-text)}.editor-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px}.mode-switch{display:inline-flex;padding:3px;border:1px solid var(--color-border-input);border-radius:999px;background:var(--color-surface-inset)}.mode-switch button{border:0;border-radius:999px;padding:7px 12px;background:transparent;color:var(--color-text-muted);font-weight:600}.mode-switch button.active{background:var(--color-surface-raised);color:var(--color-text);box-shadow:var(--shadow-button)}.format-button{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-border-input);border-radius:999px;padding:7px;background:var(--color-surface-raised);color:var(--color-text-secondary)}.undo-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--color-border-input);border-radius:999px;padding:7px;background:var(--color-surface-raised);color:var(--color-text-secondary)}.button-icon{width:16px;height:16px;flex:0 0 auto}.editor-frame{display:block;min-height:0;height:100%;padding:14px;border-radius:18px}.editor-label-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.editor-label{color:var(--color-text-faint)}.ai-panel{display:grid;align-content:start;gap:14px;min-height:0;height:100%}.ai-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.ai-model-badge{padding:7px 10px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface-raised);color:var(--color-text-muted);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}.ai-placeholder-title{margin:4px 0 0;font-size:1.05rem;font-weight:600;color:var(--color-text)}.ai-prompt-input{width:100%;min-height:180px;border:1px solid var(--color-border-subtle);border-radius:16px;padding:14px 16px;resize:none;background:var(--color-surface-inset);color:var(--color-text);font:inherit}.ai-prompt-wrapper{position:relative}.ai-prompt-wrapper .ai-prompt-input{padding-bottom:30px}.ai-prompt-counter{position:absolute;bottom:10px;right:14px;font-size:.72rem;font-variant-numeric:tabular-nums;color:var(--color-text-faint);pointer-events:none;transition:color .16s ease}.ai-prompt-counter-warn{color:#d97706}.ai-prompt-counter-over{color:var(--color-error-text-body);font-weight:600}.ai-shortcut-hint{margin:-6px 0 0;font-size:.72rem;color:var(--color-text-faint);text-align:center}.ai-generate-button{width:100%;border:1px solid var(--color-primary-bg);border-radius:14px;padding:12px 14px;background:var(--color-primary-bg);color:var(--color-primary-text);font-weight:600}.ai-generate-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.code-editor-shell{height:calc(100% - 34px);min-height:0;border:1px solid var(--color-border-subtle);border-radius:16px;overflow:hidden;background:var(--color-surface-inset)}.code-editor-shell .svg-code-editor{height:100%}.code-editor-shell .cm-editor{height:100%;background:var(--color-surface-inset)}.code-editor-shell .cm-scroller{overflow:auto;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;line-height:1.7}.code-editor-shell .cm-gutters{border-right:1px solid var(--color-border-subtle);background:var(--color-gutter-bg);color:var(--color-text-faint)}.code-editor-shell .cm-lineNumbers{min-width:36px}.code-editor-shell .cm-activeLine,.code-editor-shell .cm-activeLineGutter{background:var(--color-active-line)}.code-editor-shell .cm-content,.code-editor-shell .cm-line{padding-top:0}.code-editor-shell .cm-content{caret-color:var(--color-caret)}.code-editor-shell .cm-selectionBackground{background:var(--color-selection)!important}.code-editor-shell .cm-cursor,.code-editor-shell .cm-dropCursor{border-left:2px solid var(--color-caret)!important}.code-editor-shell .cm-focused .cm-activeLine{background:var(--color-active-line-focused)}.code-editor-shell .cm-focused .cm-activeLineGutter{background:var(--color-active-gutter-focused)}.editor-feedback{margin:12px 0 0;color:var(--color-error-text-body);font-size:.92rem}.preview-stage{display:flex;align-items:center;justify-content:center;flex:1;min-height:0;padding:24px;border-radius:18px;position:relative;overflow:hidden;background-image:linear-gradient(45deg,var(--checker-color) 25%,transparent 25%,transparent 75%,var(--checker-color) 75%),linear-gradient(45deg,var(--checker-color) 25%,transparent 25%,transparent 75%,var(--checker-color) 75%);background-position:0 0,12px 12px;background-size:24px 24px}.ai-scan-bar{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 0%,transparent 40%,rgba(249,115,22,.12) 50%,transparent 60%,transparent 100%);animation:ai-scan 1.6s ease-in-out infinite;pointer-events:none;z-index:1}@keyframes ai-scan{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.preview-canvas--generating{animation:ai-pulse 1.6s ease-in-out infinite}@keyframes ai-pulse{0%,to{opacity:1;filter:brightness(1)}50%{opacity:.55;filter:brightness(1.15) saturate(1.2)}}.ai-generating-label{display:inline-flex;align-items:baseline;gap:2px}.ai-generating-dots{display:inline-flex;gap:1px}.ai-generating-dots span{animation:ai-dot 1.2s ease-in-out infinite;opacity:0}.ai-generating-dots span:nth-child(1){animation-delay:0s}.ai-generating-dots span:nth-child(2){animation-delay:.2s}.ai-generating-dots span:nth-child(3){animation-delay:.4s}@keyframes ai-dot{0%,60%,to{opacity:0}30%{opacity:1}}.preview-canvas{display:grid;place-items:center;flex-shrink:0;width:min(100%,100%);max-width:340px;aspect-ratio:1;padding:28px;border:0;border-radius:0;background:transparent}.preview-canvas svg{display:block;width:100%;height:100%;margin:auto}.preview-error{max-width:320px;padding:18px;border:1px solid var(--color-error-border);border-radius:18px;background:var(--color-error-bg);color:var(--color-error-text)}.preview-error p{margin-bottom:0;color:var(--color-error-text-body)}.inspector{display:grid;gap:10px;margin-top:16px;padding:16px;border-radius:18px}.export-button{width:100%;border:1px solid var(--color-border-input);border-radius:14px;padding:12px 14px;background:var(--color-surface-raised);color:var(--color-text-secondary);font-weight:600;text-align:center}.export-button:disabled{cursor:not-allowed;opacity:.55;transform:none}.export-button-copy{transition:background-color .2s ease,border-color .2s ease,color .2s ease}.export-button-copied{background:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success-text)}.preview-header-actions{display:flex;align-items:center;gap:8px}.share-button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--color-border-input);border-radius:999px;background:var(--color-surface-raised);color:var(--color-text-secondary);flex:0 0 auto;transition:color .16s ease,border-color .16s ease,background-color .16s ease,transform .16s ease}.share-button:disabled{opacity:.45;cursor:not-allowed;transform:none}.share-button-copied{color:var(--color-success-text);border-color:var(--color-success-border);background:var(--color-success-bg)}.export-button-primary{background:var(--color-primary-bg);border-color:var(--color-primary-bg);color:var(--color-primary-text)}.theme-toggle{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--color-border-input);border-radius:999px;padding:5px 10px;background:var(--color-surface-raised);color:var(--color-text-secondary);font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.theme-toggle-track{position:relative;width:32px;height:18px;border-radius:999px;background:var(--color-border-input);transition:background-color .2s ease;flex:0 0 auto}.theme-toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--color-surface-raised);box-shadow:var(--shadow-button);transition:transform .2s ease}[data-theme=dark] .theme-toggle-track{background:#3b82f6}[data-theme=dark] .theme-toggle-track:after{transform:translate(14px)}.theme-toggle-icon{width:14px;height:14px;flex:0 0 auto}@media(max-width:1080px){.app-shell{height:auto;min-height:100vh;overflow:auto;-webkit-overflow-scrolling:touch}@supports (min-height: 100dvh){.app-shell{min-height:100dvh}}.workspace{grid-template-columns:1fr;grid-template-rows:auto auto auto;height:auto}.workspace-header{grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:center}.workspace-brand{justify-self:start}.workspace-links{justify-self:end}.workspace-meta{grid-column:1 / -1;justify-content:center}.panel-editor,.panel-preview{overflow:visible;min-height:420px}.preview-canvas{max-width:280px}}@media(max-width:720px){.app-shell{padding:16px}.workspace{gap:16px}.workspace-header{gap:10px}.workspace-meta{width:100%;justify-content:center;padding:10px 14px;border:1px solid var(--color-border);border-radius:16px;background:var(--color-surface)}.workspace-meta span{border:none;background:none;padding:4px 0}.panel{padding:16px;border-radius:20px;min-height:360px}.panel-header{flex-direction:column;margin-bottom:14px}.editor-actions{justify-content:flex-start}.mode-switch{order:-1}.mode-switch button{padding:9px 14px;font-size:.85rem}.preview-stage{padding:16px}.ai-prompt-input{min-height:120px}.ai-generate-button{padding:14px;font-size:1rem}.export-button{padding:14px;font-size:.95rem}.workspace-github,.undo-button,.format-button{min-width:44px;min-height:44px}.workspace-github{width:44px;height:44px}.theme-toggle{padding:8px 12px;min-height:44px}}@media(max-width:480px){.app-shell{padding:12px;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));padding-bottom:max(12px,env(safe-area-inset-bottom))}.workspace{gap:12px}.workspace-header{gap:10px}.workspace-brand h1{font-size:.9rem}.app-logo{width:36px;height:36px}.workspace-links{gap:8px}.workspace-donate span{display:none}.workspace-donate{width:44px;height:44px;padding:0;justify-content:center}.workspace-meta{gap:6px}.workspace-meta span{padding:5px 8px;font-size:.65rem}.panel{padding:14px;border-radius:18px;min-height:300px}.panel-header h2{font-size:1rem}.editor-frame{padding:10px;border-radius:14px}.preview-canvas{max-width:220px;padding:16px}.inspector{gap:8px;padding:12px;margin-top:12px}.code-editor-shell .cm-scroller{font-size:.82rem}.ai-prompt-input{min-height:100px;padding:12px;border-radius:12px;font-size:.95rem}.ai-panel-header{flex-direction:column}.ai-placeholder-title{font-size:.92rem}}.cm-preview-highlight{background-color:#f9731621!important;border-left:2px solid #F97316!important;transition:background-color .1s ease}.preview-canvas svg>*{cursor:crosshair}
