.upload-step{display:flex;justify-content:center;align-items:center;min-height:60vh}.upload-container{background:#fff;padding:3rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;text-align:center;max-width:600px;width:100%}.upload-container h2{margin-bottom:1rem;color:#2c3e50}.description{color:#666;margin-bottom:2rem;line-height:1.6}.upload-area{margin:2rem 0}.upload-button{display:inline-block;padding:1rem 2rem;background:#3498db;color:#fff;border-radius:6px;cursor:pointer;font-size:1.1rem;transition:background .3s}.upload-button:hover{background:#2980b9}.upload-button:disabled{background:#95a5a6;cursor:not-allowed}.error-message{margin-top:1rem;padding:1rem;background:#e74c3c;color:#fff;border-radius:4px}.qr-mapping-step{display:flex;flex-direction:column;gap:1.5rem}.mapping-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.mapping-header h2{color:#2c3e50}.controls{display:flex;gap:.5rem}.mapping-content{display:grid;grid-template-columns:350px 1fr;gap:2rem}.mapping-config{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:fit-content}.mapping-config h3{margin-bottom:1rem;color:#2c3e50}.grid-inputs{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.grid-inputs label{display:flex;flex-direction:column;gap:.5rem}.grid-inputs input{padding:.5rem;border:1px solid #ddd;border-radius:4px}.grid-spacing-config,.grid-padding-config{margin-top:1.5rem;padding:1rem;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.grid-spacing-config h4,.grid-padding-config h4{margin-bottom:.75rem;color:#2c3e50;font-size:.95rem}.spacing-inputs,.padding-inputs{display:flex;flex-direction:column;gap:.75rem}.spacing-inputs label,.padding-inputs label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem}.spacing-inputs input,.padding-inputs input{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.spacing-inputs input:focus,.padding-inputs input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db1a}.mapping-canvas{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.areas-list{margin-top:1.5rem}.areas-list h4{margin-bottom:.5rem;color:#2c3e50}.areas-grid{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.area-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#f5f5f5;border-radius:4px}.btn-remove{background:#e74c3c;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:1.2rem;line-height:1}.btn-remove:hover{background:#c0392b}.btn-primary,.btn-secondary{padding:.6rem 1.2rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .3s}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover{background:#2980b9}.btn-primary:disabled{background:#95a5a6;cursor:not-allowed}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d}.btn-large{width:100%;margin-top:1rem;padding:1rem;font-size:1.1rem}.detection-progress{margin-top:1rem;padding:1rem;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.progress-bar-container{width:100%;height:24px;background:#e9ecef;border-radius:12px;overflow:hidden;margin-bottom:.5rem;position:relative}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3498db,#2980b9);border-radius:12px;transition:width .3s ease;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.progress-text{text-align:center;font-size:.9rem;color:#495057;font-weight:500}.detection-result{margin-top:1rem;padding:.75rem 1rem;border-radius:6px;font-size:.9rem;text-align:center;font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.detection-result.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.detection-result.warning{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.detection-result.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@media (max-width: 1024px){.mapping-content{grid-template-columns:1fr}}.art-editor-step{display:flex;flex-direction:column;gap:1.5rem}.art-editor-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.art-editor-header h2{color:#2c3e50}.art-editor-content{display:grid;grid-template-columns:350px 1fr;gap:2rem}.art-config{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:fit-content}.art-config h3{margin-bottom:1rem;color:#2c3e50}.file-info{margin-top:1rem;padding:1rem;background:#f5f5f5;border-radius:4px}.file-info p{margin:.5rem 0;font-size:.9rem}.area-info{margin-top:1.5rem;padding:1rem;background:#e8f5e9;border-radius:4px;border-left:4px solid #4caf50}.area-info h4{margin-bottom:.5rem;color:#2c3e50}.area-info p{margin:.3rem 0;font-size:.9rem}.btn-small{margin-top:.5rem;padding:.4rem .8rem;font-size:.9rem}.instructions{margin-top:1.5rem;padding:1rem;background:#fff3cd;border-radius:4px;border-left:4px solid #ffc107}.instructions h4{margin-bottom:.5rem;color:#2c3e50}.instructions ol{margin-left:1.5rem;line-height:1.8}.instructions li{margin:.5rem 0}.art-canvas{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.canvas-wrapper{border:2px solid #ddd;border-radius:4px;overflow:auto;max-height:70vh;display:flex;justify-content:center;background:#f9f9f9}.canvas-hint{margin-top:1rem;text-align:center;color:#666;font-size:.9rem}.empty-canvas{display:flex;align-items:center;justify-content:center;min-height:400px;background:#f9f9f9;border:2px dashed #ddd;border-radius:4px}.empty-canvas p{color:#999;font-size:1.1rem}@media (max-width: 1024px){.art-editor-content{grid-template-columns:1fr}}.layout-config-step{display:flex;flex-direction:column;gap:2rem;max-width:1400px;margin:0 auto;padding:0 1rem}.layout-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;padding-bottom:1.5rem;border-bottom:2px solid #e0e0e0}.header-content h2{color:#2c3e50;margin:0 0 .5rem;font-size:1.75rem;font-weight:600}.header-subtitle{color:#666;margin:0;font-size:.95rem}.layout-content{display:grid;grid-template-columns:450px 1fr;gap:2rem;align-items:start}.config-panel{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #00000012;height:fit-content;position:sticky;top:2rem}.config-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e8e8e8}.config-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.section-title{display:flex;align-items:center;gap:.5rem;margin:0 0 1.5rem;font-size:1.1rem;font-weight:600;color:#2c3e50}.section-icon{font-size:1.3rem}.config-group{margin-bottom:1.5rem}.config-group:last-child{margin-bottom:0}.config-group label{display:flex;flex-direction:column;gap:.5rem}.label-text{font-weight:500;color:#2c3e50;font-size:.95rem;display:flex;align-items:center;gap:.5rem}.badge{background:#3498db;color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.config-input{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:all .2s ease;background:#fafafa}.config-input:hover{border-color:#bdbdbd;background:#fff}.config-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;background:#fff}.orientation-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.orientation-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500;color:#666}.orientation-btn:hover{border-color:#3498db;background:#f0f8ff;color:#3498db}.orientation-btn.active{border-color:#3498db;background:#e3f2fd;color:#1976d2;font-weight:600}.orientation-icon{font-size:1.5rem}.input-with-buttons{display:flex;gap:.5rem;align-items:stretch}.input-with-buttons .config-input{flex:1}.quick-buttons{display:flex;gap:.25rem}.quick-btn{padding:.5rem .75rem;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:.85rem;transition:all .2s ease;color:#666}.quick-btn:hover{border-color:#3498db;color:#3498db;background:#f0f8ff}.hint{font-size:.85rem;color:#666;margin:.25rem 0 0;line-height:1.4}.config-actions{margin-top:2rem;padding-top:2rem;border-top:2px solid #e8e8e8}.btn-large{width:100%;padding:1rem 1.5rem;font-size:1.1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-icon{font-size:1.2rem}.preview-panel{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #00000012;display:flex;flex-direction:column}.preview-header{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e8e8e8}.preview-header h3{margin:0 0 .75rem;color:#2c3e50;font-size:1.3rem;font-weight:600}.preview-info{display:flex;gap:1.5rem;flex-wrap:wrap}.info-item{font-size:.9rem;color:#666}.info-item strong{color:#2c3e50;font-weight:600}.preview-visualization{display:flex;justify-content:center;align-items:center;min-height:500px;background:linear-gradient(135deg,#f5f7fa,#e8ecf1);border-radius:8px;padding:2rem;margin-bottom:1rem}.preview-page{background:#fff;border:3px solid #2c3e50;border-radius:4px;padding:var(--margin, 20px);display:grid;gap:var(--spacing, 10px);box-shadow:0 8px 16px #00000026;transition:all .3s ease;grid-template-rows:repeat(var(--grid-rows, 1),1fr);grid-template-columns:repeat(var(--grid-cols, 1),1fr)}.preview-page[data-orientation=portrait]{width:240px;height:340px}.preview-page[data-orientation=landscape]{width:340px;height:240px}.preview-art{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60px;position:relative;transition:all .2s ease}.preview-art:hover{transform:scale(1.02);box-shadow:0 4px 8px #2196f34d}.preview-art-number{font-size:1.5rem;font-weight:700;color:#1976d2;margin-bottom:.25rem}.preview-art-label{font-size:.75rem;color:#1565c0;font-weight:500}.preview-footer{margin-top:auto;padding-top:1rem;border-top:1px solid #e8e8e8}.preview-note{margin:0;text-align:center;color:#666;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:.5rem;line-height:1.5}.note-icon{font-size:1.1rem}.btn-secondary{padding:.75rem 1.5rem;background:#fff;border:2px solid #ddd;border-radius:6px;color:#666;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{border-color:#999;color:#333;background:#f9f9f9}.btn-primary{padding:.75rem 1.5rem;background:#3498db;border:none;border-radius:6px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary:hover{background:#2980b9;transform:translateY(-1px);box-shadow:0 4px 8px #3498db4d}.btn-primary:active{transform:translateY(0)}@media (max-width: 1024px){.layout-content{grid-template-columns:1fr}.config-panel{position:static}.preview-visualization{min-height:400px}}.config-actions{margin-top:2rem;padding-top:2rem;border-top:2px solid #e8e8e8;display:flex;flex-direction:column;gap:.75rem}.btn-preview{padding:1rem 1.5rem;background:#9b59b6;border:none;border-radius:6px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1.1rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-preview:hover:not(:disabled){background:#8e44ad;transform:translateY(-1px);box-shadow:0 4px 8px #9b59b64d}.btn-preview:disabled{opacity:.6;cursor:not-allowed}.preview-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-modal{background:#fff;border-radius:12px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:modalFadeIn .3s ease}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.preview-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #e8e8e8}.preview-modal-header h3{margin:0;color:#2c3e50;font-size:1.3rem}.preview-modal-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;line-height:1}.preview-modal-close:hover{background:#f0f0f0;color:#333}.preview-modal-content{padding:2rem;overflow:auto;flex:1;display:flex;align-items:center;justify-content:center}.preview-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem}.spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#3498db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preview-image-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;max-width:100%}.preview-image{max-width:100%;max-height:70vh;border:2px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026}.preview-actions{display:flex;gap:1rem}.btn-download{padding:.75rem 1.5rem;background:#27ae60;color:#fff;text-decoration:none;border-radius:6px;font-weight:600;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-download:hover{background:#229954;transform:translateY(-1px);box-shadow:0 4px 8px #27ae604d}@media (max-width: 768px){.layout-header{flex-direction:column}.orientation-buttons{grid-template-columns:1fr}.preview-page[data-orientation=portrait],.preview-page[data-orientation=landscape]{width:100%;max-width:300px;height:auto;aspect-ratio:210 / 297}.preview-info{flex-direction:column;gap:.5rem}.preview-modal{max-width:95vw;max-height:95vh}.preview-modal-header,.preview-modal-content{padding:1rem}}.export-step{display:flex;flex-direction:column;gap:1.5rem}.export-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.export-header h2{color:#2c3e50}.export-content{display:grid;grid-template-columns:400px 1fr;gap:2rem}.export-summary{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:fit-content}.export-summary h3{margin-bottom:1.5rem;color:#2c3e50}.summary-item{padding:.8rem 0;border-bottom:1px solid #eee;display:flex;justify-content:space-between}.summary-item:last-of-type{border-bottom:none}.summary-item strong{color:#2c3e50}.export-actions{margin-top:2rem}.progress-container{margin-top:1rem;display:flex;align-items:center;gap:1rem}.progress-bar{flex:1;height:24px;background:#e0e0e0;border-radius:12px;overflow:hidden}.progress-fill{height:100%;background:#3498db;transition:width .3s;border-radius:12px}.progress-text{font-weight:700;color:#2c3e50;min-width:50px;text-align:right}.export-preview{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.export-preview h3{margin-bottom:1.5rem;color:#2c3e50}.preview-art-container{position:relative;border:2px solid #ddd;border-radius:4px;overflow:hidden;background:#f9f9f9;max-width:100%}.preview-art-image{width:100%;height:auto;display:block}.preview-qr-area{position:absolute;border:3px dashed #3498db;background:#3498db1a;display:flex;align-items:center;justify-content:center}.preview-qr-area span{background:#3498db;color:#fff;padding:.3rem .6rem;border-radius:4px;font-size:.85rem;font-weight:700}.preview-note{margin-top:1rem;text-align:center;color:#666;font-size:.9rem;font-style:italic}@media (max-width: 1024px){.export-content{grid-template-columns:1fr}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#2c3e50;color:#fff;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a}.app-header h1{font-size:1.8rem;margin-bottom:1rem}.step-indicator{display:flex;gap:1rem;flex-wrap:wrap}.step{padding:.5rem 1rem;background:#ffffff1a;border-radius:4px;font-size:.9rem;transition:all .3s}.step.active{background:#3498db;font-weight:700}.app-main{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.4;font-weight:400;color:#0f172a;background-color:#f5f6fa}body{margin:0;background-color:#f5f6fa}*{box-sizing:border-box}#root{min-height:100vh}.app-shell{max-width:1280px;margin:0 auto;padding:32px 24px 64px;display:flex;flex-direction:column;gap:24px}.card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 20px 45px #0f172a14;border:1px solid #e2e8f0}.section-title{margin:0 0 12px;font-size:1.2rem;font-weight:600;color:#0f172a}.inputs-row{display:flex;flex-wrap:wrap;gap:12px}.input-field{display:flex;flex-direction:column;gap:4px;flex:1;min-width:150px}.input-field label{font-size:.85rem;color:#475569}.input-field input,.input-field select{padding:8px 10px;border:1px solid #cbd5f5;border-radius:8px;font-size:1rem}.button{padding:10px 18px;border-radius:10px;border:none;cursor:pointer;background:#2563eb;color:#fff;font-weight:600;transition:opacity .2s ease}.button:disabled{opacity:.5;cursor:not-allowed}.preview-wrapper{position:relative;width:100%;max-width:640px;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff}.preview-wrapper img{display:block;width:100%}.grid-overlay{border:2px solid #10b981;background:#10b9811a;width:100%;height:100%}.grid-overlay:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px dashed rgba(16,185,129,.5);pointer-events:none}.status-pill{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;border-radius:999px;padding:4px 10px;background:#ecfeff;color:#0e7490;border:1px solid #a5f3fc}.template-preview{position:relative;width:100%;max-width:480px;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff}.slot-overlay{border:2px dashed #ef4444;background:#ef44441a}.composer-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.composer-preview canvas{width:100%;border:1px solid #e2e8f0;border-radius:12px;background:#fff}
