:root{color-scheme:light;font-family:IBM Plex Sans,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#1d1d1d;background:radial-gradient(circle at top left,rgba(255,227,196,.9),transparent 28%),radial-gradient(circle at top right,rgba(182,215,255,.8),transparent 32%),linear-gradient(180deg,#fffdf8,#f2efe6)}*{box-sizing:border-box}body{margin:0;min-width:320px}button,input{font:inherit}button{cursor:pointer}.shell{max-width:1400px;margin:0 auto;padding:40px 24px 72px}.auth-card{max-width:680px;margin:0 auto}.hero{padding:32px;border:1px solid rgba(0,0,0,.08);border-radius:28px;background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 24px 60px #4535181f}.eyebrow{margin:0 0 12px;text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;color:#9b5f12}.hero h1{margin:0;max-width:12ch;font-size:clamp(2.6rem,4vw,4.6rem);line-height:.97}.hero-copy{max-width:680px;margin:20px 0 0;font-size:1.08rem;color:#4f4a42}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.upload-button,.secondary-button,.auth-input{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 18px;border-radius:999px;border:1px solid transparent;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.upload-button{background:#1d1d1d;color:#fff;box-shadow:0 12px 24px #1d1d1d33}.upload-button:hover,.secondary-button:hover{transform:translateY(-1px)}.upload-button input{display:none}.auth-form{display:grid;gap:12px;max-width:420px;margin-top:28px}.auth-label{font-weight:600;color:#3e392f}.auth-input{width:100%;justify-content:flex-start;border-radius:18px;border:1px solid rgba(106,71,24,.22);background:#fffcf6;color:#1d1d1d}.secondary-button{background:#fff6e6;border-color:#9b5f1238;color:#6a4718}.secondary-button:disabled,.upload-button:has(input:disabled){cursor:not-allowed;opacity:.6;transform:none}.subtle{margin:18px 0 0;color:#6f6c66}.upload-progress{max-width:360px;margin-top:18px}.upload-progress-bar{overflow:hidden;height:12px;border-radius:999px;background:#6a471824;border:1px solid rgba(106,71,24,.12)}.upload-progress-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#9b5f12,#e1a34a);transition:width .14s ease}.upload-progress-label{margin:8px 0 0;color:#5a554c;font-size:.95rem}.error-banner,.card-error{color:#8d1d1d;background:#ffe6e6;border-radius:14px;padding:12px 14px}.error-banner{margin-top:18px}.stage-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:24px}.stage-card,.image-card,.empty-state{border-radius:24px;background:#ffffffe0;border:1px solid rgba(0,0,0,.07);box-shadow:0 18px 36px #40321414}.stage-card{padding:22px}.stage-card h2,.empty-state h2,.image-card h2{margin-top:0}.stage-card strong{display:block;margin-top:18px;font-size:2rem}.gallery{display:grid;gap:18px;margin-top:24px}.empty-state{padding:44px;text-align:center}.image-card{padding:22px}.card-header{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px}.status-badge{display:inline-flex;align-items:center;margin:8px 0 0;padding:6px 12px;border-radius:999px;font-size:.88rem;text-transform:capitalize}.status-queued{color:#6d5a30;background:#f9f0cf}.status-processing{color:#0f4f6b;background:#dff2fc}.status-done{color:#175220;background:#dff7df}.status-error{color:#842020;background:#ffe3e3}.preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.preview-grid figure{margin:0}.preview-grid img,.placeholder{width:100%;aspect-ratio:1 / 1;border-radius:20px;border:1px solid rgba(0,0,0,.08);background-image:linear-gradient(45deg,rgba(0,0,0,.05) 25%,transparent 25%),linear-gradient(-45deg,rgba(0,0,0,.05) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(0,0,0,.05) 75%),linear-gradient(-45deg,transparent 75%,rgba(0,0,0,.05) 75%);background-size:26px 26px;background-position:0 0,0 13px,13px -13px,-13px 0;object-fit:contain}.placeholder{display:grid;place-items:center;color:#716b61;background-color:#f4f1e9}.preview-grid figcaption{margin-top:10px;color:#5a554c}@media(max-width:900px){.stage-grid,.preview-grid{grid-template-columns:1fr}.card-header{align-items:flex-start;flex-direction:column}}
