:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--text-primary: #212529;--text-secondary: #495057;--text-muted: #868e96;--accent-primary: #ff6b00;--accent-secondary: #228be6;--accent-success: #40c057;--accent-warning: #fab005;--accent-danger: #fa5252;--border-color: #dee2e6;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--font-xs: 12px;--font-sm: 14px;--font-md: 16px;--font-lg: 18px;--font-xl: 20px;--font-2xl: 24px;--font-3xl: 30px}[data-theme=dark]{--bg-primary: #1a1b1e;--bg-secondary: #25262b;--bg-tertiary: #2c2e33;--text-primary: #c1c2c5;--text-secondary: #909296;--text-muted: #5c5f66;--border-color: #373a40}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:var(--font-3xl)}h2{font-size:var(--font-2xl)}h3{font-size:var(--font-xl)}h4{font-size:var(--font-lg)}p{color:var(--text-secondary)}a{color:var(--accent-secondary);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-sm);font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:#e65c00}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-color)}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-outline:hover{background:var(--bg-secondary)}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-md)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-xs)}.btn-icon{padding:var(--spacing-sm)}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.card-header{padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-md)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-md);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #ff6b001a}.form-textarea{min-height:100px;resize:vertical}.container{max-width:100%;padding:var(--spacing-md)}.page{min-height:100vh;padding-bottom:80px}.page-header{padding:var(--spacing-md) 0;margin-bottom:var(--spacing-md)}.page-title{font-size:var(--font-2xl);margin-bottom:var(--spacing-xs)}.page-subtitle{color:var(--text-muted);font-size:var(--font-sm)}.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-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-sm{font-size:var(--font-sm)}.text-lg{font-size:var(--font-lg)}.font-bold{font-weight:600}.loading{display:flex;align-items:center;justify-content:center;min-height:200px}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-xs);font-weight:500;border-radius:var(--radius-full)}.badge-draft{background:var(--bg-tertiary);color:var(--text-secondary)}.badge-uploaded{background:#e7f5ff;color:#1971c2}.badge-processing{background:#fff3bf;color:#e67700}.badge-ready{background:#d3f9d8;color:#2f9e44}.badge-exported{background:#e5dbff;color:#7048e8}.badge-failed{background:#ffe3e3;color:#c92a2a}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-muted)}.empty-state-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.tabs{display:flex;border-bottom:1px solid var(--border-color);margin-bottom:var(--spacing-md);overflow-x:auto}.tab{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-sm);font-weight:500;color:var(--text-muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;cursor:pointer;transition:all .2s}.dropzone:hover,.dropzone.active{border-color:var(--accent-primary);background:#ff6b000d}.dropzone-icon{font-size:48px;color:var(--text-muted);margin-bottom:var(--spacing-md)}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-sm)}.image-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-tertiary)}.image-item img{width:100%;height:100%;object-fit:cover}.image-item-actions{position:absolute;top:var(--spacing-xs);right:var(--spacing-xs);display:flex;gap:var(--spacing-xs)}.stepper{display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg)}.step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.step:after{content:"";position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--border-color)}.step:last-child:after{display:none}.step-number{width:28px;height:28px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:var(--font-sm);font-weight:600;position:relative;z-index:1}.step.active .step-number{background:var(--accent-primary);color:#fff}.step.completed .step-number{background:var(--accent-success);color:#fff}.step-label{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--spacing-xs);text-align:center}.step.active .step-label{color:var(--text-primary);font-weight:500}.step.clickable{cursor:pointer;transition:transform .2s}.step.clickable:hover{transform:translateY(-2px)}.step.clickable:hover .step-number{box-shadow:0 2px 8px #00000026}.step.clickable:hover .step-label{color:var(--accent-primary)}.template-card{border:2px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .2s}.template-card:hover{border-color:var(--accent-secondary)}.template-card.selected{border-color:var(--accent-primary);box-shadow:0 0 0 3px #ff6b0033}.template-preview{aspect-ratio:1;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.template-info{padding:var(--spacing-sm)}.template-name{font-weight:500;font-size:var(--font-sm)}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--text-primary);color:var(--bg-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-sm);box-shadow:var(--shadow-lg);z-index:1000;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}
