.marketing-nav{position:sticky;top:0;z-index:50;height:56px;background:#232327;border-bottom:1px solid #3a3a40}.marketing-nav__inner{display:flex;align-items:center;justify-content:space-between;max-width:1100px;margin:0 auto;padding:0 48px;height:100%}.marketing-nav__left{display:flex;align-items:center;gap:32px}.marketing-nav__logo-link{display:flex;align-items:center;text-decoration:none}.marketing-nav__logo{display:block}.marketing-nav__links{display:flex;align-items:center;gap:24px}.marketing-nav__link{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;font-weight:400;color:#8e8e99;text-decoration:none;transition:color .15s}.marketing-nav__link:hover{color:#e8e8ed}.marketing-nav__right{display:flex;align-items:center}.marketing-nav__cta{display:inline-block;background:#8b5cf6;color:#fff;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;font-weight:700;padding:8px 20px;border-radius:6px;text-decoration:none;transition:background .15s;min-height:44px;display:flex;align-items:center}.marketing-nav__cta:hover{background:#7c3aed}@media(max-width:768px){.marketing-nav__inner{padding:0 24px}.marketing-nav__links{display:none}}.marketing-footer{background:#19191d;padding:48px 0 32px}.marketing-footer__inner{display:flex;align-items:flex-start;justify-content:space-between;gap:32px;max-width:1100px;margin:0 auto;padding:0 48px}.marketing-footer__col{display:flex;flex-direction:column;gap:12px}.marketing-footer__col--brand{flex:1}.marketing-footer__col--links{gap:8px}.marketing-footer__col--legal{align-items:flex-end}.marketing-footer__logo{display:block}.marketing-footer__tagline{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;font-weight:400;color:#8e8e99;margin:0;line-height:1.4}.marketing-footer__link{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;font-weight:400;color:#8e8e99;text-decoration:none;transition:color .15s;min-height:44px;display:flex;align-items:center}.marketing-footer__link:hover{color:#e8e8ed}.marketing-footer__copyright{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;font-weight:400;color:#5a5a66;line-height:1.4}@media(max-width:768px){.marketing-footer__inner{flex-direction:column;padding:0 24px;align-items:flex-start}.marketing-footer__col--legal{align-items:flex-start}}.hero-section{padding:96px 0 80px;text-align:center}@media(max-width:768px){.hero-section{padding:64px 0 48px}}.hero-tagline{font-size:16px;font-weight:400;color:#8e8e99;line-height:1.6;margin-top:16px;max-width:680px;margin-left:auto;margin-right:auto}.btn-cta-ghost{background:transparent;border:2px solid #8b5cf6;color:#8b5cf6;font-size:16px;font-weight:700;padding:12px 32px;border-radius:8px;min-width:160px;min-height:44px;cursor:pointer;transition:background .15s,color .15s;display:inline-flex;align-items:center;justify-content:center;font-family:Inter,system-ui,-apple-system,sans-serif}.features-section{padding:64px 0}.how-it-works-section{padding:64px 0}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative}@media(max-width:768px){.steps-grid{grid-template-columns:1fr}}.ai-showcase-section{padding:64px 0;text-align:center}.showcase-cta-link{display:inline-block;margin-top:24px;color:#8b5cf6;font-size:16px;font-weight:600;text-decoration:none;transition:text-decoration .15s}.showcase-cta-link:hover{text-decoration:underline}.marketing-page{font-size:16px;font-family:Inter,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}.about-hero{padding:64px 0 48px;text-align:center}.about-hero h1{font-size:48px;font-weight:700;line-height:1.1;letter-spacing:-.02em;color:#e8e8ed;margin:0}@media(max-width:768px){.about-hero h1{font-size:32px}}.about-hero .hero-tagline{font-size:16px;color:#8e8e99;margin-top:16px;max-width:680px;margin-left:auto;margin-right:auto;line-height:1.6}.about-overview{padding:64px 0}.about-overview h2{font-size:28px;font-weight:700;line-height:1.2;margin-bottom:24px;margin-top:0;color:#19191d}.about-overview p{font-size:16px;line-height:1.6;color:#4a4a5a;max-width:680px;margin-bottom:16px;margin-top:0}.about-capabilities{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:24px}.about-capability{background:#f4f4f8;border-radius:8px;padding:16px;font-size:16px;color:#19191d;line-height:1.4}.about-founder{padding:64px 0}.founder-content{display:flex;gap:32px;align-items:flex-start;max-width:680px}@media(max-width:768px){.founder-content{flex-direction:column;align-items:center;text-align:center}}.founder-photo{width:120px;height:120px;border-radius:50%;object-fit:cover;flex-shrink:0}.founder-text h2{font-size:28px;font-weight:700;line-height:1.2;margin-top:0;margin-bottom:16px;color:#19191d}.founder-text p{font-size:16px;line-height:1.6;color:#4a4a5a;margin-top:0;margin-bottom:12px}.about-contact{padding:64px 0}.about-contact h2{font-size:28px;font-weight:700;line-height:1.2;margin-top:0;margin-bottom:8px;color:#19191d}.about-contact .contact-description{font-size:16px;color:#4a4a5a;margin-top:0;margin-bottom:32px}.contact-form{max-width:480px;display:flex;flex-direction:column;gap:20px}.form-field label{display:block;font-size:14px;font-weight:700;color:#19191d;margin-bottom:6px}.form-field input,.form-field textarea{width:100%;background:#fff;border:1px solid #d0d0e0;border-radius:4px;padding:10px 12px;font-size:16px;font-family:inherit;color:#19191d;transition:border-color .15s;box-sizing:border-box}.form-field input:focus,.form-field textarea:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf626}.form-field textarea{min-height:120px;resize:vertical}.form-field .field-error{font-size:14px;color:#ef4444;margin-top:4px}.btn-submit{background:#8b5cf6;color:#fff;font-size:16px;font-weight:700;padding:12px 32px;border-radius:8px;border:none;cursor:pointer;min-height:44px;transition:background .15s;align-self:flex-start}.btn-submit:hover{background:#7c3aed}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.contact-success{background:#f0fdf4;border:1px solid #10b981;border-radius:8px;padding:24px;color:#19191d;font-size:16px;max-width:480px}.contact-error{background:#fef2f2;border:1px solid #ef4444;border-radius:8px;padding:24px;color:#19191d;font-size:16px;max-width:480px}.contact-error a{color:#8b5cf6}.section--dark{background:#19191d;color:#e8e8ed}.section--light{background:#fff;color:#19191d}.section--light-alt{background:#f4f4f8;color:#19191d}.section--accent{background:#8b5cf6;color:#fff}[id]{scroll-margin-top:72px}.display-heading{font-size:48px;font-weight:700;line-height:1.1;letter-spacing:-.02em;color:#e8e8ed;margin:0}@media(max-width:768px){.display-heading{font-size:32px}}.section-eyebrow{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#8b5cf6;margin-bottom:8px;text-align:center}.section-heading{font-size:28px;font-weight:700;line-height:1.2;text-align:center;margin-bottom:32px;margin-top:0}.btn-cta-primary{background:#8b5cf6;color:#fff;font-size:16px;font-weight:700;padding:12px 32px;border-radius:8px;min-width:160px;min-height:44px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:background .15s}.btn-cta-primary:hover{background:#7c3aed}.btn-cta-ghost{background:transparent;border:2px solid #8b5cf6;color:#8b5cf6;font-size:16px;font-weight:700;padding:12px 32px;border-radius:8px;min-width:160px;min-height:44px;cursor:pointer;transition:background .15s,color .15s;display:inline-flex;align-items:center;justify-content:center;font-family:Inter,system-ui,-apple-system,sans-serif;text-decoration:none}.btn-cta-ghost:hover{background:#8b5cf61f}.btn-cta-inverted{background:#fff;color:#8b5cf6;font-size:16px;font-weight:700;padding:12px 32px;border-radius:8px;border:none;cursor:pointer;margin-top:24px;text-decoration:none;display:inline-block;transition:background .15s;min-height:44px;line-height:1.2;vertical-align:middle}.btn-cta-inverted:hover{background:#ffffffe6}.cta-group{margin-top:32px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.landing-hero{padding:96px 0 80px;text-align:center}@media(max-width:768px){.landing-hero{padding:64px 0 48px}}.landing-hero__tagline{font-size:16px;font-weight:400;color:#8e8e99;line-height:1.6;margin-top:16px;max-width:680px;margin-left:auto;margin-right:auto}.landing-how-it-works-section{padding:64px 0}.landing-steps-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-top:32px}@media(max-width:768px){.landing-steps-grid{grid-template-columns:1fr}}.step-card{text-align:center}.step-number{width:32px;height:32px;background:#8b5cf6;color:#fff;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;margin:0 auto 16px}.step-title{font-size:20px;font-weight:700;margin-bottom:8px;margin-top:0}.step-desc{font-size:16px;font-weight:400;line-height:1.6;margin:0}.landing-showcase-section{padding:64px 0;text-align:center}.showcase-panels{display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:center;margin-top:32px}@media(max-width:768px){.showcase-panels{grid-template-columns:1fr}}.showcase-panel{background:#232327;border-radius:12px;padding:24px;text-align:center}.showcase-label{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#8b5cf6;margin-bottom:12px;display:block}.showcase-placeholder{border:2px dashed #3a3a40;border-radius:8px;padding:40px 24px;color:#5a5a66;font-size:14px;min-height:120px;display:flex;align-items:center;justify-content:center}.showcase-font-preview{font-size:32px;font-weight:700;color:#e8e8ed;letter-spacing:.05em;padding:24px;font-style:italic;min-height:120px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#19191d}.showcase-arrow{font-size:32px;color:#8e8e99;display:flex;align-items:center;justify-content:center;flex-shrink:0}@media(max-width:768px){.showcase-arrow{display:none}}.landing-showcase-note{font-size:14px;color:#8e8e99;text-align:center;margin-top:16px;margin-bottom:0}.landing-value-section{padding:64px 0}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:32px}.feature-card{background:#f4f4f8;border-radius:12px;padding:24px;border:1px solid #e8e8f0}.feature-card__icon{width:40px;height:40px;background:#8b5cf61a;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#8b5cf6}.feature-card__title{font-size:18px;font-weight:700;color:#19191d;margin-top:16px;margin-bottom:0}.feature-card__body{font-size:16px;font-weight:400;color:#4a4a5a;line-height:1.6;margin-top:8px;margin-bottom:0}.landing-pricing-note{font-size:16px;text-align:center;margin-top:24px;color:#4a4a5a}.cta-banner-section{padding:56px 0;text-align:center}.cta-banner__headline{font-size:28px;font-weight:700;color:#fff;margin:0}.cta-banner__subtext{font-size:16px;font-weight:400;color:#ffffffd9;max-width:600px;margin:12px auto 0}.blog-index{background:#fff;color:#19191d;padding:64px 0 80px}.blog-index h1{font-size:36px;font-weight:700;line-height:1.2;margin:0 0 8px;color:#19191d}.blog-index__subtitle{font-size:17px;color:#4a4a5a;line-height:1.6;margin:0 0 40px;max-width:600px}.article-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:24px;max-width:800px}.article-card{background:#fff;border:1px solid #e8e8f0;border-radius:12px;transition:box-shadow .15s,border-color .15s}.article-card:hover{box-shadow:0 4px 12px #00000014;border-color:#d0d0e0}.article-card__link{text-decoration:none;color:inherit;display:block;padding:24px}.article-card__title{font-size:22px;font-weight:700;color:#19191d;margin:0;line-height:1.25;transition:color .15s}.article-card:hover .article-card__title{color:#8b5cf6}.article-card__date{display:block;font-size:14px;color:#8e8e99;margin-top:6px}.article-card__desc{font-size:16px;color:#4a4a5a;line-height:1.6;margin:8px 0 0}.article-card__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.article-card__tag{font-size:12px;background:#f4f4f8;color:#8b5cf6;padding:4px 10px;border-radius:16px;font-weight:500}@media(max-width:768px){.blog-index{padding:48px 0 64px}.blog-index h1{font-size:28px}.article-card__title{font-size:19px}}.marketing-page{font-size:16px;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}.marketing-container{max-width:1100px;margin:0 auto;padding:0 48px}@media(max-width:768px){.marketing-container{padding:0 24px}}.blog-post-page{background:#fff;min-height:100vh}.blog-post-article{max-width:720px;margin:0 auto;padding:48px 24px 64px}.blog-post-back{margin-bottom:24px}.blog-post-back a{color:#8b5cf6;text-decoration:none;font-size:15px;font-weight:500;transition:text-decoration .15s}.blog-post-back a:hover{text-decoration:underline}.blog-post-article h1{font-size:36px;font-weight:700;line-height:1.2;margin-bottom:8px;margin-top:0;color:#19191d}.blog-post-article h2{font-size:24px;font-weight:700;line-height:1.3;margin-top:40px;margin-bottom:12px;color:#19191d}.blog-post-article h3{font-size:20px;font-weight:600;line-height:1.35;margin-top:28px;margin-bottom:8px;color:#19191d}.blog-post-article h4{font-size:17px;font-weight:700;margin-top:20px;margin-bottom:6px;color:#19191d}.blog-post-article p{font-size:17px;line-height:1.7;color:#2a2a3a;margin:16px 0}.blog-post-article ul,.blog-post-article ol{padding-left:24px;margin:16px 0}.blog-post-article li{font-size:17px;line-height:1.7;color:#2a2a3a;margin:4px 0}.blog-post-article strong{font-weight:700;color:#19191d}.blog-post-article em{font-style:italic}.blog-post-article a{color:#8b5cf6;text-decoration:underline}.blog-post-article a:hover{color:#7c3aed}.blog-post-article blockquote{border-left:3px solid #8b5cf6;padding:4px 0 4px 16px;margin:24px 0;font-style:italic;color:#4a4a5a}.blog-post-article blockquote p{margin:0;color:#4a4a5a}.blog-post-article code{background:#f4f4f8;padding:2px 6px;border-radius:4px;font-size:15px;font-family:JetBrains Mono,Fira Code,Courier New,monospace;color:#8b5cf6}.blog-post-article pre{background:#19191d;color:#e8e8ed;padding:16px 20px;border-radius:8px;overflow-x:auto;margin:24px 0;font-size:14px;line-height:1.6}.blog-post-article pre code{background:none;padding:0;color:inherit;font-size:inherit;border-radius:0}.blog-post-article hr{border:none;border-top:1px solid #e8e8f0;margin:32px 0}@media(max-width:768px){.blog-post-article{padding:32px 0 48px}.blog-post-article h1{font-size:28px}.blog-post-article h2{font-size:21px}}:root{--color-canvas-bg: #1a1a1e;--color-canvas-outline-fill: #ffffff;--color-panel-bg: #232327;--color-panel-border: #3a3a40;--color-panel-header-bg: #1e1e22;--color-bg: #19191d;--color-surface: #2a2a2f;--color-surface-hover: #32323a;--color-accent: #8b5cf6;--color-accent-hover: #7c3aed;--color-accent-subtle: rgba(139, 92, 246, .15);--color-text-primary: #e8e8ed;--color-text-secondary: #8e8e99;--color-text-placeholder: #5a5a66;--color-text-disabled: #44444e;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-guide-baseline: #4a9eff;--color-guide-cap-height: #ff6b6b;--color-guide-x-height: #ffd166;--color-guide-ascender: #06d6a0;--color-guide-descender: #c77dff;--panel-left-width: 240px;--panel-right-width: 260px;--toolbar-height: 40px;--font-ui: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Courier New", monospace;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--shadow-dialog: 0 20px 60px rgba(0, 0, 0, .7), 0 4px 16px rgba(0, 0, 0, .5);--shadow-panel: 1px 0 0 var(--color-panel-border)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;font-family:var(--font-ui);font-size:13px;background-color:var(--color-bg);color:var(--color-text-primary);-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;padding-bottom:env(safe-area-inset-bottom,0px)}.app-toolbar{height:var(--toolbar-height);background:var(--color-panel-bg);border-bottom:1px solid var(--color-panel-border);display:flex;align-items:center;padding:0 12px;gap:8px;flex-shrink:0;z-index:10}.app-toolbar-title{font-size:13px;font-weight:600;color:var(--color-text-primary);letter-spacing:.02em}.app-toolbar-logo{height:20px;width:auto;display:block;margin-right:26px}.app-workspace{display:flex;flex:1;overflow:hidden}.left-panel{width:var(--panel-left-width);background:var(--color-panel-bg);border-right:1px solid var(--color-panel-border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.left-panel-section{padding:8px;border-bottom:1px solid var(--color-panel-border)}.left-panel-section-title{font-size:11px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;padding:4px 4px 8px}.tool-section-label{font-size:10px;font-weight:500;color:var(--color-text-placeholder);text-transform:uppercase;letter-spacing:.05em;padding:6px 4px 2px}.tool-palette{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:2px}.tool-button{aspect-ratio:1;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;padding:6px;transition:background .1s,color .1s}.tool-button:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.tool-button.active{background:var(--color-accent-subtle);border-color:var(--color-accent);color:var(--color-accent)}.tool-param-row{display:flex;align-items:center;gap:6px;padding:4px 4px 2px}.tool-param-label{font-size:10px;color:var(--color-text-secondary);min-width:36px}.tool-param-input{width:48px;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:2px 4px;font-size:11px;font-family:var(--font-mono);text-align:center}.tool-param-input:focus{outline:none;border-color:var(--color-accent)}.tool-param-range{flex:1;height:4px;appearance:none;background:var(--color-panel-border);border-radius:2px;outline:none}.tool-param-range::-webkit-slider-thumb{appearance:none;width:12px;height:12px;border-radius:50%;background:var(--color-accent);cursor:pointer}.tool-param-value{font-size:10px;color:var(--color-text-secondary);font-family:var(--font-mono);min-width:30px;text-align:right}.glyph-list{flex:1;overflow-y:auto;padding:8px}.glyph-add-tooltip{position:absolute;top:calc(100% + 8px);right:-8px;white-space:nowrap;background:var(--color-accent, #7c3aed);color:#fff;font-size:12px;font-weight:500;padding:6px 10px;border-radius:6px;pointer-events:none;animation:tooltip-bounce 1.5s ease-in-out infinite;z-index:10}.glyph-add-tooltip:before{content:"";position:absolute;bottom:100%;right:14px;border:5px solid transparent;border-bottom-color:var(--color-accent, #7c3aed)}@keyframes tooltip-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.glyph-list-empty{color:var(--color-text-placeholder);font-size:12px;text-align:center;padding:24px 12px;line-height:1.5}.left-panel-footer{flex-shrink:0;margin-top:auto;border-top:1px solid var(--color-panel-border);display:flex;align-items:center;justify-content:space-between}.support-link{padding:8px 12px;color:var(--color-accent, #7c3aed);font-size:12px;text-decoration:none}.support-link:hover{color:var(--color-text-primary)}.canvas-panel{flex:1;background:var(--color-canvas-bg);position:relative;overflow:hidden}.canvas-panel[data-tool=select] canvas{cursor:default}.canvas-panel[data-tool=pen] canvas{cursor:crosshair}.canvas-panel[data-tool=line] canvas{cursor:crosshair}.canvas-panel[data-tool=rectangle] canvas{cursor:crosshair}.canvas-panel[data-tool=ellipse] canvas{cursor:crosshair}.canvas-panel[data-tool=triangle] canvas{cursor:crosshair}.canvas-panel[data-tool=polygon] canvas{cursor:crosshair}.canvas-panel[data-tool=star] canvas{cursor:crosshair}.canvas-panel[data-tool=knife] canvas{cursor:crosshair}.canvas-panel[data-tool=hand] canvas{cursor:grab}.canvas-panel[data-tool=hand].dragging canvas{cursor:grabbing}.canvas-empty-state{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-placeholder);font-size:13px;pointer-events:none}.right-panel{width:var(--panel-right-width);background:var(--color-panel-bg);border-left:1px solid var(--color-panel-border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.right-panel-section{padding:12px;border-bottom:1px solid var(--color-panel-border)}.right-panel-section-title{font-size:11px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.inspector-empty{color:var(--color-text-placeholder);font-size:12px;padding:16px 12px;line-height:1.5}.dialog-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(4px)}.dialog{background:var(--color-panel-bg);border:1px solid var(--color-panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-dialog);padding:24px;width:480px;max-width:calc(100vw - 48px)}.dialog-logo{height:32px;width:auto;display:block;margin-bottom:6px}.dialog-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.dialog-subtitle{font-size:13px;color:var(--color-text-secondary);margin:0 0 20px}.form-field{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:500;color:var(--color-text-secondary);margin-bottom:6px}.form-input{width:100%;background:var(--color-surface);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-ui);font-size:13px;padding:7px 10px;transition:border-color .15s;outline:none}.form-input:focus{border-color:var(--color-accent)}.form-hint{font-size:11px;color:var(--color-text-placeholder);margin-top:4px;line-height:1.4}.upm-options{display:grid;grid-template-columns:1fr 1fr;gap:8px}.upm-option{border:1px solid var(--color-panel-border);border-radius:var(--radius-md);cursor:pointer;padding:12px;text-align:left;background:var(--color-surface);transition:border-color .15s,background .15s}.upm-option:hover{background:var(--color-surface-hover)}.upm-option.selected{border-color:var(--color-accent);background:var(--color-accent-subtle)}.upm-option-value{font-size:18px;font-weight:600;color:var(--color-text-primary);display:block;margin-bottom:2px}.upm-option-label{font-size:11px;color:var(--color-text-secondary)}.btn{border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-ui);font-size:13px;font-weight:500;padding:8px 16px;transition:background .1s,border-color .1s;border:1px solid transparent}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;border-color:var(--color-panel-border);color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.dialog-path-selector{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.dialog-path-btn{padding:16px;border:1px solid var(--color-panel-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.dialog-path-btn:hover,.dialog-path-btn.active{border-color:var(--color-accent);background:var(--color-accent-subtle)}.dialog-path-btn-icon{font-size:20px;display:block;margin-bottom:6px}.dialog-path-btn-title{font-size:13px;font-weight:600;color:var(--color-text-primary);display:block;margin-bottom:2px}.dialog-path-btn-desc{font-size:11px;color:var(--color-text-secondary)}.dialog-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.ai-intro-confirmation{text-align:center;padding:16px 0}.ai-intro-confirmation-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 0 8px}.ai-intro-confirmation-body{font-size:13px;color:var(--color-text-secondary);line-height:1.5;margin:0 0 24px}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-panel-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.preview-panel{background:var(--color-panel-bg);border-top:1px solid var(--color-panel-border);padding:16px 24px;display:flex;flex-direction:column;gap:12px;max-height:300px;min-height:80px;flex-shrink:1;overflow:hidden}.preview-panel-header{display:flex;align-items:center;justify-content:space-between}.preview-panel-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.preview-font-size{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--color-text-secondary)}.preview-font-size-input{width:50px;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:2px 4px;font-size:11px;text-align:center}.preview-render{padding:16px 0;color:var(--color-text-primary);word-break:break-word;white-space:pre-wrap;overflow:visible;font-kerning:normal;font-feature-settings:"kern" 1;text-rendering:optimizeLegibility}.preview-textarea{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;font-family:var(--font-mono);resize:vertical;min-height:40px}.preview-textarea::placeholder{color:var(--color-text-secondary);opacity:.6}.toolbar-button{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:4px 12px;font-size:12px;cursor:pointer;transition:background .15s}.toolbar-button:hover{background:var(--color-accent);color:#fff}.toolbar-button[aria-pressed=true]{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.metadata-panel{display:flex;flex-direction:column}.metadata-form{display:flex;flex-direction:column;gap:6px}.metadata-field{display:flex;align-items:center;justify-content:space-between;gap:8px}.metadata-label{font-size:11px;color:var(--color-text-secondary);white-space:nowrap;min-width:70px}.metadata-input{flex:1;background:var(--color-surface);color:var(--color-text-primary);border:1px solid transparent;border-radius:var(--radius-sm);padding:3px 6px;font-size:12px;font-family:var(--font-ui);min-width:0;transition:border-color .15s}.metadata-input:focus{outline:none;border-color:var(--color-accent)}.metadata-input-number{width:70px;flex:none;text-align:right;font-family:var(--font-mono);font-size:11px}.metadata-value-readonly{font-size:12px;color:var(--color-text-primary);font-family:var(--font-mono)}.toolbar-menu-wrapper{position:relative}.toolbar-dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--color-panel-bg);border:1px solid var(--color-panel-border);border-radius:var(--radius-md);box-shadow:var(--shadow-dialog);z-index:100;min-width:180px;overflow:hidden;padding:4px 0}.toolbar-dropdown-item{display:block;width:100%;background:none;border:none;color:var(--color-text-primary);font-size:12px;font-family:var(--font-ui);padding:6px 14px;text-align:left;cursor:pointer;transition:background .1s}.toolbar-dropdown-item:hover{background:var(--color-surface-hover)}.toolbar-dropdown-divider{height:1px;background:var(--color-panel-border);margin:4px 0}.paste-svg-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.paste-svg-modal{background:var(--color-panel-bg);border:1px solid var(--color-panel-border);border-radius:var(--radius-lg, 8px);box-shadow:var(--shadow-dialog);padding:24px;width:480px;max-width:90vw}.paste-svg-title{margin:0 0 8px;font-size:16px;color:var(--color-text-primary)}.paste-svg-desc{margin:0 0 16px;font-size:12px;color:var(--color-text-secondary);line-height:1.5}.paste-svg-textarea{width:100%;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:8px;font-family:var(--font-mono);font-size:12px;resize:vertical;box-sizing:border-box}.paste-svg-textarea:focus{outline:none;border-color:var(--color-accent)}.paste-svg-error{margin:8px 0 0;font-size:12px;color:#ef4444}.paste-svg-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.paste-svg-import-btn{background:var(--color-accent)!important;color:#fff!important}.glyph-grid-container{flex:1;overflow-y:auto;background:var(--color-bg);padding:24px}.glyph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:4px;max-width:1200px;margin:0 auto}.glyph-thumb{display:flex;flex-direction:column;align-items:center;background:var(--color-panel-bg);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);cursor:pointer;padding:0;overflow:hidden;transition:border-color .15s,background .15s;color:var(--color-text-primary)}.glyph-thumb:hover{border-color:var(--color-accent);background:var(--color-surface-hover)}.glyph-thumb-active{border-color:var(--color-accent);background:var(--color-accent-subtle)}.glyph-thumb-empty{opacity:.5}.glyph-thumb-empty:hover{opacity:.8}.glyph-thumb-preview{width:80px;height:72px;display:flex;align-items:center;justify-content:center;overflow:hidden}.glyph-thumb-svg{display:block}.glyph-thumb-fallback{font-size:28px;color:var(--color-text-placeholder);font-family:var(--font-ui);line-height:1;user-select:none}.glyph-thumb-label{font-size:10px;color:var(--color-text-secondary);padding:2px 4px 4px;text-align:center;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-top:1px solid var(--color-panel-border);background:var(--color-surface)}.spacing-form{display:flex;flex-direction:column;gap:6px}.kern-add-form{display:flex;gap:4px;align-items:center;margin-bottom:8px}.kern-char-input{width:28px;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:3px 4px;font-size:13px;font-family:var(--font-ui);text-align:center}.kern-char-input:focus{outline:none;border-color:var(--color-accent)}.kern-value-input{width:56px;background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:3px 4px;font-size:11px;font-family:var(--font-mono);text-align:right}.kern-value-input:focus{outline:none;border-color:var(--color-accent)}.kern-add-btn{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:3px 8px;font-size:14px;cursor:pointer;line-height:1;transition:background .1s,color .1s}.kern-add-btn:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.kern-error{font-size:11px;color:var(--color-error);margin:0 0 6px}.kern-empty{font-size:11px;color:var(--color-text-placeholder);margin:4px 0}.kern-pairs-list{display:flex;flex-direction:column;gap:3px;max-height:200px;overflow-y:auto}.kern-pair-row{display:flex;align-items:center;gap:6px}.kern-pair-chars{font-size:13px;font-weight:600;color:var(--color-text-primary);min-width:30px;text-align:center;letter-spacing:-.05em}.kern-remove-btn{background:none;border:none;color:var(--color-text-placeholder);cursor:pointer;font-size:11px;padding:2px 4px;line-height:1;transition:color .1s}.kern-remove-btn:hover{color:var(--color-error)}.grid-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.grid-toggle-btn{padding:2px 10px;border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);font-size:11px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.grid-toggle-btn:hover{background:var(--color-surface-hover)}.grid-toggle-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.trace-panel{padding:8px 12px}.trace-btn{width:100%;padding:6px 12px;border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);font-size:12px;font-family:var(--font-ui);cursor:pointer;transition:background .15s}.trace-btn:hover:not(:disabled){background:var(--color-surface-hover)}.trace-btn:disabled{opacity:.5;cursor:not-allowed}.trace-btn-accept{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.trace-btn-accept:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.trace-param{margin:8px 0}.trace-param label{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--color-text-secondary);margin-bottom:4px}.trace-param-value{color:var(--color-text-primary);font-variant-numeric:tabular-nums}.trace-param input[type=range]{width:100%;height:4px;appearance:none;background:var(--color-panel-border);border-radius:2px;outline:none}.trace-param input[type=range]::-webkit-slider-thumb{appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-accent);cursor:pointer}.trace-status{font-size:11px;color:var(--color-text-secondary);padding:4px 0}.trace-section-label{font-size:10px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:10px 0 4px;padding-bottom:3px;border-bottom:1px solid var(--color-panel-border)}.trace-actions{display:flex;flex-direction:column;gap:6px;margin-top:8px}.welcome-page{flex:1;overflow-y:auto;background:var(--color-bg);display:flex;flex-direction:column;align-items:center}.welcome-topbar{width:100%;height:var(--toolbar-height);background:var(--color-panel-bg);border-bottom:1px solid var(--color-panel-border);display:flex;align-items:center;padding:0 16px;flex-shrink:0}.welcome-back-btn{background:none;border:none;color:var(--color-text-secondary);font-size:13px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:color .15s}.welcome-back-btn:hover{color:var(--color-text-primary)}.welcome-content{width:100%;max-width:700px;padding:0 24px 60px}.welcome-hero{text-align:center;padding:60px 0 40px}.welcome-wordmark{font-size:48px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px;letter-spacing:-.02em}.welcome-logo{height:56px;width:auto;margin-bottom:12px}.welcome-tagline{font-size:16px;color:var(--color-text-secondary);line-height:1.6;margin:0}.welcome-get-started{display:flex;justify-content:center;gap:12px;margin-bottom:48px}.welcome-cta{padding:10px 28px;font-size:14px}.welcome-section{margin-bottom:40px}.welcome-section-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 0 12px}.welcome-body{font-size:14px;color:var(--color-text-secondary);line-height:1.7;margin:0 0 10px}.welcome-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.welcome-step{display:flex;align-items:flex-start;gap:14px}.welcome-step-num{width:28px;height:28px;border-radius:50%;background:var(--color-accent);color:#fff;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.welcome-step-title{font-size:14px;color:var(--color-text-primary);display:block;margin-bottom:2px}.welcome-step-desc{font-size:13px;color:var(--color-text-secondary)}.welcome-bio{display:flex;align-items:flex-start;gap:20px}.welcome-bio-photo{width:88px;height:88px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--color-panel-border)}.welcome-callout{border-left:3px solid var(--color-accent);background:var(--color-surface);border-radius:0 var(--radius-md) var(--radius-md) 0;padding:20px 24px;margin-bottom:40px}.welcome-callout-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent);margin:0 0 8px}.welcome-callout-text{font-size:14px;font-style:italic;color:var(--color-text-secondary);line-height:1.7;margin:0}.welcome-oss-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.welcome-oss-card{display:flex;align-items:center;justify-content:space-between;background:var(--color-surface);border:1px solid var(--color-panel-border);border-radius:var(--radius-md);padding:12px 14px}.welcome-oss-name{font-size:13px;font-weight:600;color:var(--color-text-primary);display:block}.welcome-oss-desc{font-size:11px;color:var(--color-text-secondary);display:block}.welcome-oss-license{font-size:10px;color:var(--color-text-secondary);border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:2px 6px;white-space:nowrap}.welcome-sponsor{text-align:center;background:var(--color-surface);border:1px solid var(--color-panel-border);border-radius:var(--radius-md);padding:24px}.welcome-sponsor .welcome-section-title{margin-bottom:8px}.welcome-sponsor-btn{margin-top:12px;display:inline-block}.welcome-footer{text-align:center;padding-top:32px;border-top:1px solid var(--color-panel-border);margin-top:20px}.welcome-footer-text{font-size:13px;color:var(--color-text-secondary);margin:0 0 16px}.welcome-footer-links{display:flex;justify-content:center;gap:12px;margin-bottom:24px}.welcome-footer-btn{padding:8px 20px}.welcome-copyright{font-size:11px;color:var(--color-text-placeholder);margin:0}.welcome-overlay-box{background:var(--color-bg);border:1px solid var(--color-panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-dialog);width:760px;max-width:calc(100vw - 48px);max-height:calc(100vh - 80px);max-height:calc(100dvh - 80px);overflow:hidden;display:flex;flex-direction:column}.welcome-overlay-box .welcome-page{overflow-y:auto;max-height:calc(100vh - 80px);max-height:calc(100dvh - 80px)}.welcome-overlay-box .welcome-hero{padding:40px 0 28px}.welcome-overlay-box .welcome-logo{height:44px}.dialog-about-link{background:none;border:none;color:var(--color-accent);font-size:12px;font-family:var(--font-ui);cursor:pointer;padding:0;margin-right:auto;text-decoration:none;transition:color .15s}.dialog-about-link:hover{color:var(--color-accent-hover)}.app-toolbar-title-link{cursor:pointer;transition:color .15s}.app-toolbar-title-link:hover{color:var(--color-accent)}.contour-role-buttons{display:flex;gap:2px}.contour-role-btn{flex:1;padding:3px 6px;font-size:10px;font-weight:500;border:1px solid var(--color-border);border-radius:3px;background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;transition:background .1s,color .1s}.contour-role-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.contour-role-btn.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.alignment-toolbar{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:2px;background:var(--color-panel-bg, #232327);border:1px solid var(--color-panel-border, #35353a);border-radius:6px;padding:3px;box-shadow:0 4px 12px #0000004d;z-index:100}.alignment-toolbar-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:4px;color:var(--color-text-primary, #f9fafb);font-size:14px;cursor:pointer}.alignment-toolbar-btn:hover{background:var(--color-accent, #7c3aed);color:#fff}.alignment-toolbar-btn:disabled{opacity:.3;pointer-events:none}.alignment-toolbar-divider{width:1px;height:20px;background:var(--color-panel-border, #35353a);margin:0 2px}.boolean-toolbar{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:4px;padding:4px;background:var(--color-panel-bg, #1e1e22);border:1px solid var(--color-panel-border, #35353a);border-radius:6px;box-shadow:0 4px 12px #0000004d;z-index:100}.boolean-toolbar-btn{height:28px;padding:0 10px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-secondary, #9ca3af);border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap}.boolean-toolbar-btn:hover{background:var(--color-accent, #7c3aed);color:#fff}.context-menu{background:var(--color-panel-bg, #232327);border:1px solid var(--color-panel-border, #35353a);border-radius:6px;padding:4px 0;min-width:160px;box-shadow:0 8px 24px #0006}.context-menu-item{display:block;width:100%;padding:10px 16px;background:none;border:none;color:var(--color-text-primary, #f9fafb);font-size:13px;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.context-menu-item:hover,.context-menu-item:active{background:var(--color-accent, #7c3aed);color:#fff}.context-menu-item:disabled{opacity:.4;pointer-events:none}.floating-toolbar{position:absolute;bottom:calc(16px + env(safe-area-inset-bottom,0px));right:16px;display:flex;align-items:center;gap:2px;background:var(--color-panel-bg, #232327);border:1px solid var(--color-panel-border, #35353a);border-radius:8px;padding:4px;box-shadow:0 4px 16px #0000004d;z-index:100;-webkit-tap-highlight-color:transparent}.floating-toolbar-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:6px;color:var(--color-text-primary, #f9fafb);font-size:18px;cursor:pointer;-webkit-tap-highlight-color:transparent}.floating-toolbar-btn:active{background:var(--color-accent, #7c3aed)}.floating-toolbar-btn.active{background:var(--color-accent, #7c3aed);color:#fff}.floating-toolbar-btn:disabled{opacity:.3}.floating-toolbar-divider{width:1px;height:24px;background:var(--color-panel-border, #35353a);margin:0 2px}.ai-workflow-dialog{background:var(--color-panel-bg);border:1px solid var(--color-panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-dialog);padding:24px;min-width:420px;max-width:560px;width:90vw;max-height:85vh;overflow-y:auto;position:relative}.ai-workflow-step-indicator{font-size:13px;color:var(--color-text-secondary);margin-bottom:16px;text-align:center}.ai-workflow-title{font-size:18px;font-weight:600;margin-bottom:16px;text-align:center}.ai-upload-area{border:2px dashed var(--color-panel-border);border-radius:var(--radius-md);padding:32px;text-align:center;cursor:pointer;transition:border-color .15s}.ai-upload-area:hover{border-color:var(--color-accent)}.ai-upload-preview{max-width:100%;max-height:300px;border-radius:var(--radius-md);margin:16px auto;display:block}.ai-upload-status{font-size:13px;color:var(--color-text-secondary);margin-top:8px}.ai-payment-info{text-align:center;margin-bottom:16px;font-size:15px}.ai-payment-amount{font-size:24px;font-weight:700;margin:8px 0}.ai-payment-error{color:var(--color-error, #e53e3e);font-size:13px;margin-bottom:12px;text-align:center}.ai-processing-placeholder{text-align:center;padding:32px 16px;font-size:15px;color:var(--color-text-secondary)}.ai-workflow-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--color-panel-border)}.toolbar-button-ai{background:var(--color-accent, #7c3aed);color:#fff;border-radius:var(--radius-md);font-weight:600}.toolbar-button-ai:hover{opacity:.9}.ai-processing-wrapper{position:relative;display:block;border-radius:var(--radius-md);overflow:hidden;margin:0 auto;text-align:center}.ai-processing-image{max-width:100%;max-height:280px;border-radius:var(--radius-md);display:block;margin:0 auto}.ai-scan-line{position:absolute;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,var(--color-accent) 50%,transparent 100%);animation:scan-sweep 1.8s ease-in-out infinite;box-shadow:0 0 12px var(--color-accent);pointer-events:none}@keyframes scan-sweep{0%{top:0%;opacity:0}5%{opacity:1}95%{opacity:1}to{top:100%;opacity:0}}.ai-processing-status{text-align:center;margin-top:12px;font-size:14px;color:var(--color-text-secondary)}.ai-workflow-dialog--wide{max-width:840px;width:95vw}.ai-review-panel{display:flex;flex-direction:column;gap:16px}.ai-review-toggle{background:none;border:1px solid var(--color-panel-border);border-radius:var(--radius-sm);padding:6px 12px;font-size:13px;color:var(--color-text-secondary);cursor:pointer;align-self:flex-start}.ai-review-toggle:hover{border-color:var(--color-accent);color:var(--color-text-primary)}.ai-review-original{max-width:100%;max-height:200px;border-radius:var(--radius-md);margin:0 auto;display:block}.ai-glyph-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}.ai-glyph-card{background:var(--color-panel-bg);border:2px solid var(--color-panel-border);border-radius:var(--radius-md);padding:6px;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;transition:border-color .15s}.ai-glyph-card--flagged{border-color:var(--color-error, #e53e3e)}.ai-glyph-card--confirmed{border-color:var(--color-success, #38a169)}.ai-glyph-card--duplicate{border-color:var(--color-warning, #d69e2e)}.ai-glyph-crop{width:64px;height:64px;object-fit:contain;border-radius:var(--radius-sm);background:var(--color-canvas-bg, #1a1a2e)}.ai-glyph-crop-placeholder{width:64px;height:64px;border-radius:var(--radius-sm);background:var(--color-canvas-bg, #1a1a2e)}.ai-glyph-label{background:none;border:1px solid transparent;font-size:16px;font-weight:600;cursor:pointer;padding:2px 8px;border-radius:var(--radius-sm);min-width:32px;text-align:center;color:var(--color-text-primary)}.ai-glyph-label:hover{border-color:var(--color-accent)}.ai-glyph-label-input{width:40px;text-align:center;font-size:16px;font-weight:600;padding:2px;border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:var(--color-panel-bg);color:var(--color-text-primary)}.ai-glyph-check{font-size:12px;color:var(--color-success, #38a169)}.ai-glyph-badge-duplicate{font-size:10px;background:var(--color-warning, #d69e2e);color:#000;padding:1px 5px;border-radius:8px}.ai-glyph-delete{position:absolute;top:2px;right:2px;background:none;border:none;font-size:14px;cursor:pointer;color:var(--color-text-secondary);padding:2px;line-height:1}.ai-glyph-delete:hover{color:var(--color-error, #e53e3e)}.ai-review-footer{display:flex;flex-direction:column;gap:8px;align-items:stretch}.ai-font-name-input{padding:8px 12px;border:1px solid var(--color-panel-border);border-radius:var(--radius-md);background:var(--color-panel-bg);color:var(--color-text-primary);font-size:14px}.ai-font-name-input:focus{border-color:var(--color-accent);outline:none}.ai-review-gate-hint{font-size:13px;color:var(--color-warning, #d69e2e);text-align:center;margin:0}.ai-processing-error{text-align:center;padding:16px}.ai-processing-error-code{font-family:monospace;font-size:13px;color:var(--color-text-secondary);margin:8px 0}.ai-processing-error-message{font-size:14px;color:var(--color-text-primary);margin-bottom:12px}.ai-recovery-toggle{background:none;border:none;color:#999;font-size:13px;cursor:pointer;text-decoration:underline;margin-top:12px;padding:0}.ai-recovery-form{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #333}.ai-recovery-label{font-size:13px;color:#aaa;margin:0}.ai-recovery-input{padding:8px 12px;border-radius:6px;border:1px solid #444;background:#1a1a1a;color:#eee;font-size:14px;font-family:monospace}.ai-low-count-warning{background:#f59e0b21;border:1px solid var(--color-warning, #d69e2e);border-radius:var(--radius-md);padding:12px 16px;text-align:center;font-size:14px}.ai-low-count-warning-actions{display:flex;gap:8px;justify-content:center;margin-top:8px}.ai-done-screen{text-align:center;padding:24px 16px}.ai-done-title{font-size:20px;font-weight:700;margin-bottom:8px}.ai-done-subtitle{font-size:14px;color:var(--color-text-secondary);margin-bottom:20px}.ai-done-actions{display:flex;gap:12px;justify-content:center}
