@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap";:root{--bg: #f5f0eb;--surface: #ffffff;--surface-alt: #f9f5f0;--border: #ddd5cc;--text: #1a1410;--text-muted: #7a6e66;--accent-a: #e84040;--accent-b: #4060e8;--accent-c: #40c860;--accent-gold: #c8a040;--font-sans: "Inter", sans-serif;--font-mono: "Space Mono", monospace;--radius: 8px;--shadow: 0 2px 10px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:14px}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:var(--text);color:#fff;padding:12px 24px;display:flex;align-items:center;gap:16px;border-bottom:3px solid var(--accent-a)}.app-logo{display:flex;gap:5px;align-items:center}.logo-dot{width:14px;height:14px;border-radius:50%;display:block;opacity:.9}.app-title{font-family:var(--font-mono);font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.app-subtitle{font-size:.75rem;color:#aaa;margin-left:auto}.qa-toggle-btn{background:#333;color:#fff;border:1px solid #444;padding:4px 12px;border-radius:4px;font-size:.7rem;font-weight:700;cursor:pointer;transition:all .2s}.qa-toggle-btn.active{background:var(--accent-gold);color:#000;border-color:#fff;box-shadow:0 0 8px var(--accent-gold)}.app-main{display:flex;flex:1;overflow:hidden}.app-sidebar{width:280px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:24px}.sidebar-section{display:flex;flex-direction:column;gap:12px}.section-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding-bottom:8px;border-bottom:1px solid var(--border)}.uploader{border:2px dashed var(--border);border-radius:var(--radius);background:var(--surface-alt);transition:border-color .2s,background .2s;cursor:pointer}.uploader:hover{border-color:var(--accent-a);background:#fff8f8}.uploader-inner{padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted)}.uploader-title{font-weight:600;color:var(--text)}.uploader-sub{font-size:.75rem}.uploader-hint{font-size:.7rem;color:var(--text-muted)}.img-info{font-size:.7rem;color:var(--text-muted);word-break:break-all}.mode-selector{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.mode-btn{flex:1;padding:8px 4px;border:none;background:var(--surface-alt);color:var(--text-muted);font-family:var(--font-sans);font-size:.75rem;cursor:pointer;transition:all .15s}.mode-btn.active{background:var(--text);color:#fff;font-weight:600}.pick-colors{display:flex;flex-direction:column;gap:8px}.pick-color-row{display:flex;align-items:center;gap:10px;font-size:.8rem}.pick-color-row input[type=color]{width:40px;height:32px;border:none;border-radius:4px;cursor:pointer;padding:2px;background:none}.btn-run{width:100%;margin-top:4px}.app-content{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted);text-align:center;padding:60px 40px}.empty-hint{font-size:.8rem;max-width:480px;line-height:1.7}.tabs{display:flex;gap:2px;border-bottom:2px solid var(--border)}.tab-btn{padding:10px 20px;border:none;border-bottom:3px solid transparent;background:none;color:var(--text-muted);font-family:var(--font-sans);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;margin-bottom:-2px;border-radius:var(--radius) var(--radius) 0 0}.tab-btn:hover{background:var(--surface-alt);color:var(--text)}.tab-btn.active{background:var(--surface);color:var(--text);font-weight:700;border-bottom:3px solid var(--text)}.tab-content{background:var(--surface);border-radius:0 var(--radius) var(--radius) var(--radius);border:1px solid var(--border);padding:20px}.plate-panel{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto 1fr;gap:20px}.plate-config{grid-column:1 / -1;display:flex;gap:16px;flex-wrap:wrap}.face-selector{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;width:fit-content}.face-btn{padding:6px 16px;border:none;background:var(--surface-alt);color:var(--text-muted);font-family:var(--font-sans);font-size:.8rem;cursor:pointer;transition:all .15s}.face-btn.active{background:var(--text);color:#fff;font-weight:600}.filename-preview{font-family:var(--font-mono);font-size:.8rem;background:var(--surface-alt);border:1px solid var(--border);border-radius:4px;padding:6px 10px;color:var(--text);display:block;word-break:break-all}.ink-color-row{display:flex;align-items:center;gap:10px}.ink-color-picker{width:44px;height:36px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:2px;background:none;transition:border-color .15s}.ink-color-picker:hover{border-color:var(--text)}.ink-color-label{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}.plate-preview-wrap{width:300px;flex-shrink:0}.plate-preview-img{width:100%;border-radius:var(--radius);border:1px solid var(--border);display:block}.plate-preview-empty{width:100%;aspect-ratio:4/3;background:var(--surface-alt);border:2px dashed var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.8rem}.plate-preview-outer{width:100%;max-width:600px}.preview-controls-qa{display:flex;align-items:center;gap:8px;margin-bottom:8px;background:#eee;padding:6px 12px;border-radius:6px}.qa-label-mini{font-size:.65rem;font-weight:700;color:#666;text-transform:uppercase}.zoom-btn-qa{padding:2px 8px;background:#fff;border:1px solid #ccc;border-radius:3px;font-size:.7rem;font-weight:600;cursor:pointer}.zoom-btn-qa.active{background:var(--text);color:#fff;border-color:var(--text)}.plate-metadata-badge{margin-left:auto;display:flex;gap:10px}.meta-item{font-family:var(--font-mono);font-size:.65rem;color:#444;background:#fff;padding:2px 6px;border-radius:3px;border:1px solid #ddd}.qa-loupe{position:absolute;pointer-events:none;width:164px;height:164px;border-radius:50%;border:4px solid #fff;box-shadow:0 0 20px #0000004d;overflow:hidden;background:#000;z-index:100}.qa-checklist{background:#fff8f0;border:1px solid #ffe8cc;border-radius:6px;padding:12px;display:flex;flex-direction:column;gap:8px}.qa-checklist-title{font-size:.75rem;font-weight:700;color:#c05621;margin-bottom:4px;border-bottom:1px solid #ffe8cc}.qa-check{display:flex;align-items:center;gap:8px;font-size:.75rem;cursor:pointer;color:#7b341e}.qa-check:hover{color:#000}.adjustments{display:flex;flex-direction:column;gap:6px}.adj-title{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-top:12px}.adj-row{display:flex;align-items:center;gap:10px;font-size:.8rem}.adj-row label{width:80px;flex-shrink:0;color:var(--text-muted);white-space:pre-wrap;line-height:1.25}.adj-row input[type=range]{flex:1;accent-color:var(--text)}.adj-row span{width:36px;text-align:right;font-family:var(--font-mono);font-size:.7rem}.composite-controls{display:flex;align-items:center;gap:20px;margin-bottom:12px;flex-wrap:wrap}.composite-note{font-size:.75rem;color:var(--text-muted)}.composite-wrap{display:flex;justify-content:center}.composite-canvas{max-width:100%;border-radius:var(--radius);border:1px solid var(--border)}.export-section{display:flex;flex-direction:column;gap:12px}.export-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:16px}.export-info{background:#fffbf0;border:1px solid #e8d9a0;border-radius:var(--radius);padding:12px 14px;font-size:.8rem;line-height:1.7;color:var(--text)}.export-info code{font-family:var(--font-mono);background:#e8d9a0;border-radius:3px;padding:1px 4px}.export-project{flex-direction:column;gap:6px}.export-plates{display:flex;flex-direction:column;gap:8px}.export-plate-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--surface-alt);border-radius:var(--radius);border:1px solid var(--border)}.export-plate-swatch{width:24px;height:24px;border-radius:50%;border:2px solid rgba(0,0,0,.1);flex-shrink:0}.export-plate-info{flex:1;display:flex;flex-direction:column;gap:2px}.export-plate-label{font-weight:600;font-size:.85rem}.export-filename{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}.field-row{display:flex;flex-direction:column;gap:4px}.field-label{font-size:.75rem;font-weight:600;color:var(--text-muted)}.field-hint{font-weight:400;margin-left:6px;font-size:.7rem}.field-input{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-sans);font-size:.85rem;background:var(--surface);color:var(--text);width:100%;transition:border-color .15s}.field-input:focus{outline:none;border-color:var(--text)}.btn{padding:9px 18px;border:none;border-radius:var(--radius);font-family:var(--font-sans);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--text);color:#fff}.btn-primary:hover:not(:disabled){background:#2a2420;transform:translateY(-1px);box-shadow:var(--shadow)}.btn-secondary{background:var(--surface-alt);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-success{background:var(--accent-c);color:#fff}.btn-success:hover:not(:disabled){background:#32a84e;transform:translateY(-1px)}.btn-large{width:100%;padding:14px;font-size:.95rem;letter-spacing:.02em}.download-ready-box{background:#f0fff4;border:1px solid #c6f6d5;border-radius:var(--radius);padding:20px;text-align:center;animation:fadeIn .3s ease-out}.download-fallback-area{margin-top:16px;padding-top:16px;border-top:1px dashed #c6f6d5;display:flex;flex-direction:column;gap:8px;align-items:center}.download-hint{font-size:.8rem;color:#38a169;font-weight:500}.download-hint-sub{font-size:.7rem;color:var(--text-muted)}.fallback-link-prominent{display:inline-block;background:#fff;color:var(--accent-b);font-weight:700;text-decoration:none;padding:10px 20px;border-radius:6px;border:2px solid var(--accent-b);transition:all .2s}.fallback-link-prominent:hover{background:var(--accent-b);color:#fff;transform:scale(1.02)}@media(max-width:768px){.app-header{padding:10px 16px;flex-wrap:wrap}.app-logo{flex-shrink:0}.app-title{font-size:1.1rem;flex:1 1 100%}.app-main{flex-direction:column;overflow:auto}.app-sidebar{width:100%;border-right:none;border-bottom:2px solid var(--border);overflow-y:visible}.app-content{overflow-y:visible;padding:12px}.tabs{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:4px}.tab-btn{padding:10px 14px;font-size:.8rem}.plate-panel{grid-template-columns:1fr}.plate-preview-wrap{width:100%;order:-1}.plate-preview-outer{max-width:100%}.qa-loupe{width:100px;height:100px}.export-plate-row{flex-wrap:wrap}.export-plate-info{width:100%}}
