*{box-sizing:border-box;margin:0;padding:0}:root{--bg-dark:#1a1a1a;--bg-panel:#242424;--bg-section:#2e2e2e;--bg-hover:#363636;--text-primary:#e0e0e0;--text-secondary:#999;--accent:#4a90d9;--accent-hover:#5ba0e9;--danger:#d94a4a;--border:#3a3a3a;--radius:6px}body{background:var(--bg-dark);color:var(--text-primary);height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}#root{height:100vh}.app{flex-direction:column;height:100vh;display:flex}.app-header{background:var(--bg-panel);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;min-height:48px;padding:8px 16px;display:flex}.header-left{align-items:center;gap:12px;display:flex}.app-logo{color:var(--accent);border-radius:var(--radius);background:#4a90d926;padding:4px 8px;font-size:18px;font-weight:900}.project-name-input{color:var(--text-primary);border-radius:var(--radius);background:0 0;border:1px solid #0000;outline:none;min-width:200px;padding:4px 8px;font-size:14px;font-weight:600}.project-name-input:focus{border-color:var(--border);background:var(--bg-section)}.header-right{gap:8px;display:flex}.header-btn{background:var(--bg-section);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius);cursor:pointer;padding:6px 14px;font-size:13px;transition:all .15s}.header-btn:hover{background:var(--bg-hover)}.header-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.header-btn.primary:hover{background:var(--accent-hover)}.app-body{flex:1;display:flex;overflow:hidden}.toolbar{background:var(--bg-panel);border-right:1px solid var(--border);width:220px;min-width:220px;padding:12px;overflow-y:auto}.toolbar-section{margin-bottom:16px}.toolbar-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:8px;font-size:11px;font-weight:700}.toolbar-btn{background:var(--bg-section);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:var(--radius);cursor:pointer;text-align:left;margin-bottom:4px;padding:8px 12px;font-size:13px;transition:all .15s;display:block}.toolbar-btn:hover{background:var(--bg-hover)}.toolbar-btn.small{padding:4px 8px;font-size:12px}.toolbar-row{gap:4px;margin-bottom:4px;display:flex}.toolbar-btn.half{text-align:center;flex:1}.toolbar-btn:disabled{opacity:.35;cursor:not-allowed}.toolbar-btn.danger{color:var(--danger);border-color:#d94a4a4d}.toolbar-btn.danger:hover{background:#d94a4a26}.emoji-grid{grid-template-columns:repeat(6,1fr);gap:2px;display:grid}.emoji-btn{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;padding:4px;font-size:20px;transition:all .15s}.emoji-btn:hover{background:var(--bg-hover);border-color:var(--border)}.canvas-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.canvas-container{background:#222 radial-gradient(circle,#333 1px,#0000 1px) 0 0/20px 20px;flex:1;position:relative;overflow:hidden}.canvas-info{color:#666;z-index:10;pointer-events:none;font-size:11px;position:absolute;top:8px;left:8px}.properties-panel{background:var(--bg-panel);border-left:1px solid var(--border);width:260px;min-width:260px;padding:12px;overflow-y:auto}.panel-section{border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:16px}.panel-section:last-child{border-bottom:none}.panel-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:8px;font-size:11px;font-weight:700}.panel-hint{color:var(--text-secondary);text-align:center;padding:24px 12px;font-size:13px}.prop-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.prop-row label{color:var(--text-secondary);white-space:nowrap;min-width:24px;font-size:12px}.prop-row input[type=range]{accent-color:var(--accent);flex:1;height:4px}.prop-value{color:var(--text-secondary);text-align:right;min-width:36px;font-size:11px}.prop-col{flex-direction:column;gap:4px;margin-bottom:8px;display:flex}.prop-col label{color:var(--text-secondary);font-size:12px}.text-content-input{background:var(--bg-section);border:1px solid var(--border);width:100%;color:var(--text-primary);resize:vertical;border-radius:4px;outline:none;min-height:60px;padding:8px;font-family:inherit;font-size:13px;line-height:1.4}.text-content-input:focus{border-color:var(--accent)}.prop-input-sm{background:var(--bg-section);border:1px solid var(--border);width:60px;color:var(--text-primary);border-radius:4px;outline:none;padding:4px 6px;font-size:12px}.prop-input-sm:focus{border-color:var(--accent)}.prop-select{background:var(--bg-section);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;outline:none;flex:1;padding:6px 8px;font-size:12px}.prop-select:focus{border-color:var(--accent)}.bg-type-row{gap:4px;margin-bottom:12px;display:flex}.bg-type-btn{background:var(--bg-section);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:4px;flex:1;padding:6px 4px;font-size:11px;transition:all .15s}.bg-type-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.bg-type-btn:hover:not(.active){background:var(--bg-hover)}.preset-row{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.preset-btn{background:var(--bg-section);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:4px;padding:4px 8px;font-size:10px;transition:all .15s}.preset-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.preset-btn:hover:not(.active){background:var(--bg-hover)}.color-control{align-items:center;gap:8px;margin-bottom:8px;display:flex;position:relative}.color-control.inline{margin-bottom:0}.color-swatch{border:2px solid var(--border);cursor:pointer;border-radius:4px;flex-shrink:0;width:28px;height:28px}.color-input{background:var(--bg-section);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;outline:none;flex:1;min-width:0;padding:4px 8px;font-family:monospace;font-size:12px}.color-input:focus{border-color:var(--accent)}.color-picker-popover{z-index:1000;background:var(--bg-panel);border:1px solid var(--border);border-radius:8px;padding:8px;position:absolute;top:36px;left:0;box-shadow:0 8px 24px #0006}.color-picker-popover .react-colorful{width:180px;height:150px}.align-btns{gap:4px;display:flex}.align-btn{background:var(--bg-section);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:32px;height:28px;font-size:14px;transition:all .15s;display:flex}.align-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-panel);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:520px;max-width:90vw;max-height:80vh;display:flex;box-shadow:0 16px 48px #00000080}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{font-size:16px;font-weight:700}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:4px;font-size:18px}.modal-body{flex:1;padding:16px 20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.export-group{margin-bottom:16px}.export-group-header{margin-bottom:8px}.export-group-header label{cursor:pointer;align-items:center;gap:8px;font-size:14px;display:flex}.export-formats{flex-direction:column;gap:4px;padding-left:24px;display:flex}.export-format{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.export-modal{width:640px}.export-previews{border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:16px}.export-preview-grid{gap:12px;padding:4px 0;display:flex;overflow-x:auto}.export-preview-item{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;display:flex}.format-preview-canvas{border-radius:4px;display:block}.export-preview-label{color:var(--text-secondary);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:70px;font-size:9px;overflow:hidden}.export-format-default{color:var(--text-primary);font-weight:500}.export-tag{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);background:#4a90d926;border-radius:3px;margin-left:4px;padding:1px 5px;font-size:9px;font-weight:700}.export-count{color:var(--text-secondary);font-size:13px}.export-btn{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:8px 20px;font-size:14px;font-weight:600;transition:all .15s}.export-btn:hover:not(:disabled){background:var(--accent-hover)}.export-btn:disabled{opacity:.5;cursor:not-allowed}.export-btn.secondary{background:var(--bg-section);border:1px solid var(--border);color:var(--text-primary)}.export-btn.secondary:hover{background:var(--bg-hover)}.modal-footer-actions{gap:8px;display:flex}.project-list{flex-direction:column;gap:8px;display:flex}.project-item{background:var(--bg-section);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.project-item.active{border-color:var(--accent)}.project-name{font-size:14px;font-weight:600}.project-date{color:var(--text-secondary);font-size:11px}.project-actions{gap:6px;display:flex}.small-btn{background:var(--bg-hover);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:4px;padding:4px 10px;font-size:12px}.small-btn.danger{color:var(--danger)}.project-current-tag{text-transform:uppercase;color:var(--accent);vertical-align:middle;background:#4a90d926;border-radius:3px;margin-left:6px;padding:1px 5px;font-size:9px;font-weight:700}.project-item.empty{opacity:.6}.zoom-bar{background:var(--bg-panel);border:1px solid var(--border);z-index:10;white-space:nowrap;border-radius:8px;align-items:center;gap:16px;padding:6px 14px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0000004d}.zoom-controls{align-items:center;gap:4px;display:flex}.zoom-btn{background:var(--bg-section);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;transition:all .15s;display:flex}.zoom-btn:hover{background:var(--bg-hover)}.zoom-btn.fit{width:auto;padding:0 8px;font-size:11px;font-weight:600}.zoom-level{color:var(--text-secondary);text-align:center;font-variant-numeric:tabular-nums;min-width:40px;font-size:11px}.zoom-legend{color:#666;align-items:center;gap:6px;font-size:11px;display:flex}.legend-item{align-items:center;gap:3px;display:flex}.legend-sep{color:#444}.zoom-legend kbd{background:var(--bg-section);border:1px solid var(--border);color:var(--text-secondary);border-radius:3px;padding:1px 4px;font-family:inherit;font-size:10px;line-height:1.4;display:inline-block}.slide-indicator{color:var(--text-secondary);background:var(--bg-section);border-radius:4px;padding:2px 8px;font-size:12px}.toolbar-hint{color:var(--text-secondary);margin-top:4px;font-size:11px;line-height:1.3}.toolbar-btn.primary-btn{background:var(--accent);border-color:var(--accent);color:#fff;text-align:center;font-weight:600}.toolbar-btn.primary-btn:hover{background:var(--accent-hover)}.export-summary{color:var(--text-secondary);background:var(--bg-section);border-radius:var(--radius);margin-bottom:16px;padding:8px 12px;font-size:13px}.export-progress-overlay{z-index:2000;background:#000000bf}.export-progress-card{background:var(--bg-panel);border:1px solid var(--border);text-align:center;border-radius:12px;min-width:380px;padding:32px 40px;box-shadow:0 16px 48px #00000080}.export-progress-title{margin-bottom:8px;font-size:18px;font-weight:700}.export-progress-detail{color:var(--text-secondary);margin-bottom:20px;font-size:13px}.export-progress-bar-wrap{background:var(--bg-section);border-radius:4px;height:8px;margin-bottom:12px;overflow:hidden}.export-progress-bar-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .15s ease-out}.export-progress-count{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:12px}.frame-picker-modal{width:680px;max-width:95vw;max-height:85vh}.frame-group{margin-bottom:20px}.frame-group-title{color:var(--text-primary);border-bottom:1px solid var(--border);margin-bottom:10px;padding-bottom:4px;font-size:13px;font-weight:700}.frame-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;display:grid}.frame-card{background:var(--bg-section);border:2px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:6px;padding:10px 4px 8px;transition:all .15s;display:flex}.frame-card:hover{background:var(--bg-hover);border-color:#555}.frame-card.selected{border-color:var(--accent);background:#4a90d91a}.frame-preview-canvas{display:block}.frame-card-name{color:var(--text-secondary);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:10px;line-height:1.2;overflow:hidden}.no-frame-card{justify-content:center;min-height:140px}.no-frame-icon{opacity:.5}.current-frame-row{background:var(--bg-section);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:8px;margin-bottom:8px;padding:6px 8px;display:flex}.current-frame-swatch{border-radius:5px;flex-shrink:0;width:24px;height:42px}.current-frame-info{flex:1;min-width:0}.current-frame-name{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#555}
