*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#222;background:#f5f5f5;height:100vh;font-family:system-ui,-apple-system,sans-serif;font-size:14px;overflow:hidden}#root{height:100vh;display:flex}button{font-family:inherit;font-size:inherit;cursor:pointer}input{font-family:inherit;font-size:inherit}.set-panel{background:#fff;border-right:1px solid #e0e0e0;flex-direction:column;width:220px;min-width:220px;height:100vh;display:flex;overflow:hidden}.set-panel-toolbar{border-bottom:1px solid #e0e0e0;flex-shrink:0;gap:4px;padding:8px;display:flex}.set-panel-toolbar button{background:#fafafa;border:1px solid #ccc;border-radius:4px;flex:1;padding:4px 6px;font-size:12px}.set-panel-toolbar button:hover{background:#f0f0f0}.set-list{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex;overflow-y:auto}.set-card{cursor:pointer;background:#fafafa;border:1px solid #e0e0e0;border-radius:6px;align-items:center;gap:8px;padding:8px;transition:background .1s;display:flex}.set-card:hover{background:#f0f0f0}.set-card--active{background:#eef4ff;border-color:#4f8ef7}.set-card--full{border-color:#4caf50}.set-card--partial{border-color:#ff9800}.set-card-info{flex-direction:column;flex:1;min-width:0;display:flex}.set-card-name{text-transform:capitalize;white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.set-card-count{color:#888;font-size:11px}.thumbnail-panel{background:#f5f5f5;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.thumbnail-toolbar{background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0;align-items:center;gap:8px;padding:8px 12px;display:flex}.thumbnail-set-name{text-transform:capitalize;flex:1;font-weight:600}.thumbnail-toolbar button{background:#fafafa;border:1px solid #ccc;border-radius:4px;padding:4px 10px;font-size:12px}.thumbnail-toolbar button:hover{background:#f0f0f0}.thumbnail-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));align-content:start;gap:8px;padding:12px;display:grid;overflow-y:auto}.tile{cursor:pointer;background:#fff;border:2px solid #e0e0e0;border-radius:8px;flex-direction:column;align-items:center;max-width:140px;transition:border-color .1s,box-shadow .1s;display:flex;overflow:hidden}.tile:hover{border-color:#aaa}.tile--selected{border-color:#4f8ef7;box-shadow:0 0 0 2px #4f8ef733}.tile-img-wrap{aspect-ratio:1;background:#fff;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.tile-img-wrap img{object-fit:contain;width:100%;height:100%;display:block}.tile-label{text-align:center;color:#444;white-space:nowrap;text-overflow:ellipsis;width:100%;padding:4px 6px;font-size:11px;overflow:hidden}.gen-panel{background:#fff;border-top:1px solid #e0e0e0;flex-shrink:0;align-items:center;gap:24px;padding:12px 16px;display:flex}.gen-stats{gap:20px;display:flex}.stat{flex-direction:column;align-items:center;min-width:56px;display:flex}.stat-value{color:#333;font-size:20px;font-weight:700;line-height:1.2}.stat-label{color:#888;text-transform:uppercase;letter-spacing:.05em;font-size:10px}.gen-controls{flex:1;align-items:center;gap:12px;display:flex}.gen-row{align-items:center;gap:6px;display:flex}.gen-row label{color:#555;white-space:nowrap;font-size:12px;font-weight:600}.seed-input-wrap{gap:4px;display:flex}.seed-input{border:1px solid #ccc;border-radius:4px;width:160px;padding:4px 8px;font-family:monospace;font-size:12px}.seed-input-wrap button{background:#fafafa;border:1px solid #ccc;border-radius:4px;padding:4px 8px}.seed-input-wrap button:hover{background:#f0f0f0}.card-count-wrap{align-items:center;gap:8px;display:flex}.card-count-wrap button{background:#fafafa;border:1px solid #ccc;border-radius:4px;justify-content:center;align-items:center;width:26px;height:26px;font-size:16px;line-height:1;display:flex}.card-count-wrap button:hover{background:#f0f0f0}.card-count-wrap span{text-align:center;min-width:24px;font-weight:700}.generate-btn{color:#fff;white-space:nowrap;background:#4f8ef7;border:none;border-radius:6px;padding:8px 20px;font-size:14px;font-weight:600;transition:background .15s}.generate-btn:hover:not(:disabled){background:#3a7be0}.generate-btn:disabled{cursor:not-allowed;background:#ccc}.gen-warning{color:#e57373;white-space:nowrap;font-size:11px}.gen-action{min-width:320px}.gen-progress{align-items:center;gap:8px;width:100%;display:flex}.progress-bar{background:#e0e0e0;border-radius:4px;flex:1;min-width:120px;height:8px;overflow:hidden}.progress-fill{background:#4f8ef7;border-radius:4px;height:100%;transition:width .2s}.progress-label{color:#555;white-space:nowrap;font-size:12px}.cancel-btn{background:#fafafa;border:1px solid #ccc;border-radius:4px;padding:4px 10px;font-size:12px}.cancel-btn:hover{color:#c62828;background:#fee;border-color:#e57373}
