*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0d0d;--surface: #1a1a1a;--surface-2: #242424;--border: #2e2e2e;--accent: #f97316;--accent-hover: #fb923c;--text: #e5e5e5;--text-muted: #737373;--text-dim: #525252;--success: #22c55e;--error: #ef4444;--warning: #eab308;--radius: 10px;--radius-sm: 6px}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.5}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{padding:28px 32px 20px;border-bottom:1px solid var(--border)}.app-header h1{font-size:22px;font-weight:700;letter-spacing:-.5px;color:var(--text)}.subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.app-main{flex:1;max-width:1000px;width:100%;margin:0 auto;padding:32px 24px 64px;display:flex;flex-direction:column;gap:28px}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:80px 40px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;display:flex;flex-direction:column;align-items:center;gap:10px;-webkit-user-select:none;user-select:none}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:#f973160d}.upload-zone.uploading{pointer-events:none;opacity:.7}.upload-icon{font-size:48px;color:var(--text-muted);line-height:1}.upload-primary{font-size:18px;font-weight:600;color:var(--text)}.upload-secondary{font-size:14px;color:var(--text-muted)}.upload-hint{font-size:12px;color:var(--text-dim);margin-top:4px}.upload-warning{font-size:13px;color:var(--warning);margin-top:8px;max-width:480px}.arrange-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.arrange-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.meta-count{font-size:14px;font-weight:600;color:var(--text)}.meta-warning{font-size:13px;color:var(--warning)}.photo-grid{display:flex;flex-direction:column;gap:4px}.grid-hint{font-size:12px;color:var(--text-dim);margin-bottom:12px}.photo-group{display:flex;flex-direction:column;gap:6px;padding:14px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border)}.photo-group.partial{border-color:var(--warning);background:#eab3080a}.group-label{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.group-remove-btn{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--warning);background:none;border:none;cursor:pointer;padding:0;opacity:.7}.group-remove-btn:hover{opacity:1}.photo-group.partial .group-label{color:var(--warning)}.photo-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-card{aspect-ratio:1 / 1;border-radius:var(--radius-sm);background:var(--surface-2);cursor:grab;position:relative;touch-action:none;transition:box-shadow .12s;perspective:600px}.card-flipper{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .55s ease}.card-flipper.flipped{transform:rotateY(180deg)}.card-flipper.revealing{animation:card-reveal .55s ease var(--reveal-delay, 0ms) both}@keyframes card-reveal{0%{transform:rotateY(180deg)}to{transform:rotateY(0)}}.card-front,.card-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius-sm);overflow:hidden}.card-back{transform:rotateY(180deg);background:var(--surface-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.card-back-spinner{width:26px;height:26px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.card-back-filename{font-size:10px;color:var(--text-dim);padding:0 10px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.photo-card:active{cursor:grabbing}.photo-card.dragging{box-shadow:0 12px 40px #0009;border-radius:var(--radius)}.photo-card.excluded{opacity:.45}.photo-card img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.excluded-badge{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--warning);background:#00000080}.photo-card.photo-selected{outline:2.5px solid var(--accent);outline-offset:-2px}.photo-check-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#f9731640;display:flex;align-items:center;justify-content:center;pointer-events:none}.photo-checkmark{width:28px;height:28px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff;font-weight:700;line-height:1}.photo-delete-btn{position:absolute;top:5px;right:5px;width:22px;height:22px;background:#0009;border:none;border-radius:50%;color:#fff;font-size:11px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;touch-action:manipulation}.photo-delete-btn:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px}.photo-delete-btn:hover{background:var(--error)}.photo-card-placeholder{border:2px dashed var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s}.photo-card-placeholder:hover,.photo-card-placeholder.drag-over{border-color:var(--accent);background:#f973160f}.placeholder-icon{font-size:28px;color:var(--border);line-height:1;transition:color .15s;pointer-events:none}.photo-card-placeholder:hover .placeholder-icon,.photo-card-placeholder.drag-over .placeholder-icon{color:var(--accent)}.add-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:20px;border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s;margin-top:4px}.add-drop-zone:hover,.add-drop-zone.active{border-color:var(--accent);background:#f973160f}.add-drop-zone-icon{font-size:24px;color:var(--text-dim);line-height:1;transition:color .15s}.add-drop-zone:hover .add-drop-zone-icon,.add-drop-zone.active .add-drop-zone-icon{color:var(--accent)}.add-drop-zone-text{font-size:13px;font-weight:600;color:var(--text-muted)}.add-drop-zone-hint{font-size:11px;color:var(--text-dim)}.selection-toolbar{position:sticky;bottom:16px;display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 24px #00000080;margin-top:12px;flex-wrap:wrap}.selection-count{font-size:14px;font-weight:600;color:var(--accent);flex:1;white-space:nowrap}.selection-actions{display:flex;gap:8px;flex-wrap:wrap}.sel-btn{padding:7px 16px;border-radius:var(--radius-sm);border:none;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.sel-replace{background:var(--accent);color:#fff}.sel-replace:hover{background:var(--accent-hover)}.sel-delete{background:var(--error);color:#fff}.sel-delete:hover{background:#dc2626}.sel-cancel{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.sel-cancel:hover{color:var(--text);border-color:var(--text-muted)}.photo-filename{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;font-size:10px;color:#ffffffb3;background:linear-gradient(transparent,#000000a6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.options-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;display:flex;flex-direction:column;gap:20px;max-width:440px}.options-title{font-size:14px;font-weight:600;color:var(--text)}.option-section{display:flex;flex-direction:column;gap:8px}.option-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim)}.option-pair-row{display:flex;gap:20px;align-items:stretch}.option-pair-row .option-section{flex:1;display:flex;flex-direction:column}.option-cards-row{display:flex;gap:8px}.option-card-compact{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:8px 10px;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s,background .15s;color:var(--text);-webkit-user-select:none;user-select:none}.option-card-compact:hover{border-color:var(--text-muted)}.option-card-compact.selected{border-color:var(--accent);background:#f973160f}.compact-label{font-size:11px;color:var(--text-muted)}.duration-row{display:flex;align-items:center;gap:12px}.duration-slider{width:130px;accent-color:var(--accent);cursor:pointer}.duration-number{width:62px;padding:5px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;text-align:center}.duration-number:focus{outline:none;border-color:var(--accent)}.unit{font-size:13px;color:var(--text-muted)}.option-card-wide{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 10px;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s,background .15s;-webkit-user-select:none;user-select:none}.option-card-wide:hover{border-color:var(--text-muted)}.option-card-wide.selected{border-color:var(--accent);background:#f973160f}.option-section-full{flex:1}.card-status{font-size:11px;color:var(--text-dim);transition:color .25s}.card-status.on{color:var(--accent)}.logo-tile-thumb{height:36px;width:auto;object-fit:contain;opacity:.3;transition:opacity .25s}.logo-tile-thumb.on{opacity:1}.logo-change-btn{font-size:11px;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;text-decoration:underline;margin-top:2px}@keyframes s1-down{0%{transform:translate(40px);animation-timing-function:ease-out}14%{transform:translate(0);animation-timing-function:linear}46%{transform:translate(0);animation-timing-function:ease-in}59%{transform:translateY(52px)}60%{transform:translate(40px)}to{transform:translate(40px)}}@keyframes s2-down{0%{transform:translate(40px)}5%{transform:translate(40px);animation-timing-function:ease-out}19%{transform:translate(0);animation-timing-function:linear}50%{transform:translate(0);animation-timing-function:ease-in}64%{transform:translateY(52px)}65%{transform:translate(40px)}to{transform:translate(40px)}}@keyframes s3-down{0%{transform:translate(40px)}10%{transform:translate(40px);animation-timing-function:ease-out}24%{transform:translate(0);animation-timing-function:linear}54%{transform:translate(0);animation-timing-function:ease-in}69%{transform:translateY(52px)}70%{transform:translate(40px)}to{transform:translate(40px)}}@keyframes s1-up{0%{transform:translate(40px);animation-timing-function:ease-out}14%{transform:translate(0);animation-timing-function:linear}46%{transform:translate(0);animation-timing-function:ease-in}59%{transform:translateY(-52px)}60%{transform:translate(40px)}to{transform:translate(40px)}}@keyframes s2-up{0%{transform:translate(40px)}5%{transform:translate(40px);animation-timing-function:ease-out}19%{transform:translate(0);animation-timing-function:linear}50%{transform:translate(0);animation-timing-function:ease-in}64%{transform:translateY(-52px)}65%{transform:translate(40px)}to{transform:translate(40px)}}@keyframes s3-up{0%{transform:translate(40px)}10%{transform:translate(40px);animation-timing-function:ease-out}24%{transform:translate(0);animation-timing-function:linear}54%{transform:translate(0);animation-timing-function:ease-in}69%{transform:translateY(-52px)}70%{transform:translate(40px)}to{transform:translate(40px)}}.s1-down{animation:s1-down 2.8s linear infinite}.s2-down{animation:s2-down 2.8s linear infinite}.s3-down{animation:s3-down 2.8s linear infinite}.s1-up{animation:s1-up 2.8s linear infinite}.s2-up{animation:s2-up 2.8s linear infinite}.s3-up{animation:s3-up 2.8s linear infinite}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.arrange-bottom{display:flex;align-items:flex-start;gap:16px}.generate-area{display:flex;flex-direction:column;align-items:center;gap:10px;align-self:stretch}.btn-generate{flex:1;width:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:18px;font-weight:700;line-height:1.25;text-align:center;cursor:pointer;transition:background .15s,opacity .15s;min-height:120px}.btn-generate:hover:not(:disabled){background:var(--accent-hover)}.btn-generate:disabled{opacity:.35;cursor:not-allowed}.btn-generate-icon{font-size:28px;line-height:1}.action-hint{font-size:12px;color:var(--text-dim);text-align:center;max-width:120px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:10px 28px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s;white-space:nowrap}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;cursor:pointer;text-decoration:none;transition:color .15s,border-color .15s;white-space:nowrap}.btn-ghost:hover{color:var(--text);border-color:var(--text-muted)}.status-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:80px 40px;text-align:center}.status-panel p{font-size:17px;font-weight:500}.status-sub{font-size:13px!important;font-weight:400!important;color:var(--text-muted)}.success-icon{font-size:48px;color:var(--success);line-height:1}.error-icon{font-size:48px;color:var(--error);line-height:1}.error-title{color:var(--error)!important}.error-detail{font-size:12px;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;max-width:600px;white-space:pre-wrap;word-break:break-all;text-align:left;max-height:200px;overflow-y:auto}.done-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
