*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f5f7;--surface:#fff;--surface-hover:#f0f0f2;--border:#e0e0e4;--text:#1a1a1a;--text-muted:#6b7280;--primary:#1a1a1a;--primary-hover:#333;--danger:#dc2626;--danger-hover:#b91c1c;--radius:10px;--shadow-sm:0 1px 2px #0000000f;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-md:0 4px 12px #00000014, 0 1px 3px #0000000f;--shadow-lg:0 8px 24px #0000001a, 0 2px 8px #0000000f;--font:"Inter", system-ui, -apple-system, sans-serif}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh}#root{min-height:100vh}.uploader{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--surface);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:48px 24px;transition:all .15s}.uploader:hover,.uploader.drag-over{border-color:var(--primary);background:#6366f10d}.uploader-icon{color:var(--text-muted);margin-bottom:12px}.uploader-text{margin-bottom:4px;font-size:15px;font-weight:500}.uploader-hint{color:var(--text-muted);font-size:13px}.settings{flex-direction:column;gap:16px;display:flex}.settings-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.settings-title{font-size:16px;font-weight:600}.reset-btn{color:var(--primary);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);background:0 0;border:none;border-radius:4px;padding:4px 8px;transition:background .15s}.reset-btn:hover{background:#6366f11a}.field{flex-direction:column;gap:6px;display:flex}.label{color:var(--text-muted);font-size:13px;font-weight:500}input[type=range]{appearance:none;background:var(--border);cursor:pointer;border-radius:3px;outline:none;width:100%;height:6px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:16px;height:16px}.toggle-group{border-radius:var(--radius);border:1px solid var(--border);display:flex;overflow:hidden}.toggle-btn{background:var(--surface);color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);border:none;flex:1;padding:8px;transition:all .15s}.toggle-btn.active{background:var(--primary);color:#fff}.crop-group{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}.crop-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);padding:8px;transition:all .15s}.crop-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.crop-btn:hover:not(.active){border-color:var(--primary)}.logo-display{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:12px}.logo-preview{object-fit:contain;width:100%;max-height:80px}.position-grid{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(3,1fr);gap:4px;padding:8px;display:grid}.pos-btn{aspect-ratio:16/9;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;transition:all .15s;display:flex}.pos-btn:hover{background:var(--surface-hover)}.pos-btn.active{border-color:var(--primary);background:#6366f126}.pos-dot{background:var(--text-muted);border-radius:50%;width:8px;height:8px}.pos-btn.active .pos-dot{background:var(--primary)}.preview-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.preview-card{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);transition:box-shadow .15s;position:relative;overflow:hidden}.preview-card:hover{box-shadow:var(--shadow-md)}.preview-canvas{aspect-ratio:auto;-webkit-user-select:none;user-select:none;width:100%;display:block}.preview-canvas.draggable{cursor:grab}.preview-canvas.draggable:active{cursor:grabbing}.preview-overlay{background:linear-gradient(#0000,#000000b3);justify-content:space-between;align-items:center;padding:8px 10px;display:flex;position:absolute;bottom:0;left:0;right:0}.preview-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;flex:1;margin-right:8px;font-size:12px;overflow:hidden}.preview-actions{flex-shrink:0;gap:6px;display:flex}.drag-hint{color:#fff9;font-size:10px;font-style:italic}.invert-btn{cursor:pointer;width:24px;height:24px;font-size:11px;font-weight:700;font-family:var(--font);color:#fff;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.invert-btn:hover{background:#ffffff4d}.invert-btn.inverted{color:#111;background:#ffffffd9}.remove-btn{cursor:pointer;color:#fff;background:#ffffff26;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;transition:background .15s;display:flex}.remove-btn:hover{background:var(--danger)}.empty-state{color:var(--text-muted);justify-content:center;align-items:center;padding:80px 20px;font-size:14px;display:flex}.plate-card{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);transition:box-shadow .15s;position:relative;overflow:hidden}.plate-card:hover{box-shadow:var(--shadow-md)}.plate-editor-container{line-height:0;position:relative}.plate-editor-img{-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;display:block}.plate-editor-overlay{cursor:default;width:100%;height:100%;position:absolute;top:0;left:0}.mask-polygon{fill:#00000073;stroke:none}.mask-polygon.active{fill:#6366f140}.mask-edge{stroke:#fff6;stroke-width:.3px;fill:none}.mask-edge.active{stroke:var(--primary);stroke-width:.4px}.mask-handle{fill:#fff9;stroke:#0006;stroke-width:.2px;cursor:grab}.mask-handle.active{fill:var(--primary);stroke:#fff;stroke-width:.3px}.mask-handle:active{cursor:grabbing}.zoom-loupe{border:2px solid var(--primary);pointer-events:none;z-index:20;border-radius:50%;position:absolute;overflow:hidden;box-shadow:0 2px 12px #00000080}.zoom-crosshair-h,.zoom-crosshair-v{background:#6366f180;position:absolute}.zoom-crosshair-h{height:1px;top:50%;left:0;right:0;transform:translateY(-.5px)}.zoom-crosshair-v{width:1px;top:0;bottom:0;left:50%;transform:translate(-.5px)}.mask-delete-btn{z-index:10;background:var(--danger);color:#fff;font-size:11px;font-weight:500;font-family:var(--font);cursor:pointer;opacity:.9;border:none;border-radius:4px;padding:4px 10px;transition:background .15s;position:absolute;bottom:8px;left:8px}.mask-delete-btn:hover{background:var(--danger-hover);opacity:1}.plate-card-footer{background:var(--surface);border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.plate-card-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.plate-add-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:11px;font-weight:500;font-family:var(--font);white-space:nowrap;background:0 0;border-radius:4px;padding:3px 8px;transition:all .15s}.plate-add-btn:hover{border-color:var(--primary);color:var(--primary)}.mask-instructions{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin-top:8px;padding:12px}.mask-instructions p{color:var(--text-muted);font-size:12px;line-height:1.5}.mask-instructions p+p{margin-top:4px}.plate-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.desc-type-toggle{border-radius:var(--radius);border:1px solid var(--border);display:flex;overflow:hidden}.desc-type-btn{background:var(--surface);color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);border:none;flex:1;padding:8px;transition:all .15s}.desc-type-btn.active{background:var(--primary);color:#fff}.desc-col{border-right:1px solid var(--border);background:var(--surface);flex:1;height:calc(100vh - 155px);padding:24px;overflow-y:auto}.desc-col:last-child{border-right:none}.desc-col-preview{flex-direction:column;padding:24px;display:flex}.desc-col-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.desc-col-header h3{font-size:16px;font-weight:600}.desc-form{flex-direction:column;gap:16px;display:flex}.desc-row{gap:12px;display:flex}.desc-field{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.label-hint{color:var(--text-muted);opacity:.6;font-weight:400}.desc-select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:14px;font-family:var(--font);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:8px 32px 8px 12px;transition:border-color .15s}.desc-select:focus{border-color:var(--primary)}.desc-select option{background:var(--surface);color:var(--text)}.desc-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:14px;font-family:var(--font);outline:none;padding:8px 12px;transition:border-color .15s,box-shadow .15s}.desc-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1a1a1a14}.desc-input::placeholder{color:var(--text-muted);opacity:.6}.desc-textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:14px;font-family:var(--font);resize:vertical;outline:none;padding:8px 12px;transition:border-color .15s,box-shadow .15s}.desc-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1a1a1a14}.desc-textarea::placeholder{color:var(--text-muted);opacity:.6}.desc-checkboxes{flex-direction:column;gap:8px;display:flex}.desc-checkbox{color:var(--text);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.desc-checkbox input[type=checkbox]{accent-color:var(--primary);cursor:pointer;width:16px;height:16px}.desc-preview{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-md);flex-direction:column;flex:1;display:flex;overflow:hidden}.desc-preview-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.desc-preview-header h3{font-size:14px;font-weight:600}.desc-copy-btn{width:auto;padding:6px 16px;font-size:13px}.desc-output{white-space:pre-wrap;word-wrap:break-word;color:var(--text);font-size:14px;line-height:1.6;font-family:var(--font);flex:1;min-height:200px;margin:0;padding:16px;overflow-y:auto}.desc-preview-footer{border-top:1px solid var(--border);justify-content:flex-end;padding:8px 12px;display:flex}.desc-regenerate-btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:6px 14px;transition:all .15s;display:flex}.desc-regenerate-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.desc-regenerate-btn:disabled{opacity:.4;cursor:not-allowed}@media (width<=1024px){.desc-layout{flex-direction:column}.desc-col{border-right:none;border-bottom:1px solid var(--border);height:auto}.desc-col:last-child{border-bottom:none}}@media (width<=768px){.desc-row{flex-direction:column}}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{border-bottom:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);z-index:5;justify-content:space-between;align-items:center;padding:20px 40px;display:flex;position:relative}.brand{align-items:center;gap:20px;display:flex}.app-nav{gap:4px;display:flex}.app-nav a{border-radius:var(--radius);color:var(--text-muted);padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s}.app-nav a:hover{color:var(--text);background:var(--surface-hover)}.app-nav a.active{color:#fff;background:var(--primary);box-shadow:var(--shadow-sm)}.brand-logo{width:auto;height:56px}.app-header h1{margin-bottom:2px;font-size:22px;font-weight:600}.subtitle{color:var(--text-muted);font-size:13px}.app-layout{flex:1;display:flex;overflow:hidden}.sidebar{border-right:1px solid var(--border);background:var(--surface);flex-direction:column;gap:16px;width:320px;min-width:320px;height:calc(100vh - 155px);padding:24px;display:flex;position:sticky;top:0;overflow-y:auto}.main-content{flex:1;height:calc(100vh - 155px);padding:24px;overflow-y:auto}.app-footer{border-top:1px solid var(--border);background:var(--surface);z-index:5;justify-content:space-between;align-items:center;padding:12px 40px;display:flex;position:relative;box-shadow:0 -2px 8px #0000000a}.footer-info{align-items:center;display:flex}.footer-count{color:var(--text-muted);font-size:13px}.footer-actions{gap:8px;display:flex}.footer-actions .btn{width:auto}.btn{border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--font);width:100%;box-shadow:var(--shadow-sm);border:none;padding:10px 20px;transition:all .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-danger{color:var(--danger);border:1px solid var(--danger);background:0 0}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}@media (width<=768px){.app-layout{flex-direction:column}.sidebar{width:100%;min-width:unset;border-right:none;border-bottom:1px solid var(--border);max-height:unset}.app-header{flex-direction:column;align-items:flex-start;gap:12px;padding:16px 20px}.brand-logo{height:40px}.app-header h1{font-size:18px}.main-content{padding:16px}.app-footer{padding:12px 20px}}
