:root{color-scheme:light;--bg: #FFF3E8;--surface: rgba(255, 246, 239, .75);--surface-strong: rgba(255, 246, 239, .95);--surface-border: rgba(255, 255, 255, .8);--text: #2c2c2c;--muted: #8a8886;--primary: #FD8B36;--primary-soft: rgba(253, 139, 54, .16);--secondary: #f7bb2c;--success: #00dbe9;--panel-shadow: 0 12px 40px rgba(0, 0, 0, .04);--font-display: "Space Grotesk", sans-serif;--font-body: "Inter", sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;color:var(--text);font-family:var(--font-body);background:radial-gradient(circle at 10% 20%,rgba(253,139,54,.08),transparent 35%),radial-gradient(circle at 90% 80%,rgba(247,187,44,.12),transparent 45%),radial-gradient(circle at 50% 0%,rgba(255,255,255,.8),transparent 50%),var(--bg)}body.modal-open{overflow:hidden}button,input{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}#root{min-height:100vh}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;line-height:1}.material-symbols-outlined.filled{font-variation-settings:"FILL" 1,"wght" 500,"GRAD" 0,"opsz" 24}.app-shell{width:min(1280px,calc(100% - 24px));margin:0 auto;padding:84px 0 40px}.topbar{position:fixed;inset:0 0 auto 0;z-index:50;display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 24px;border-bottom:1px solid rgba(0,0,0,.08);background:#fff3e8b3;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar-left,.topbar-right{display:flex;align-items:center;gap:16px}.topbar h1{margin:0;font-family:var(--font-display);font-size:2.35rem;font-weight:900;letter-spacing:-.04em;color:var(--primary);text-shadow:none;width:100%;text-align:center}.topbar-history-button{position:absolute;right:24px}.topbar-nav{display:flex;gap:24px}.topbar-nav a{font-family:var(--font-display);font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#ffffff8c;transition:color .16s ease,transform .16s ease}.topbar-nav a.is-active,.topbar-nav a:hover{color:var(--primary);transform:scale(1.04)}.avatar-shell{display:grid;place-items:center;width:34px;height:34px;border-radius:999px;border:1px solid var(--primary);color:var(--primary);background:var(--surface)}.studio-grid{display:grid;grid-template-columns:minmax(320px,.92fr) minmax(0,1.08fr);grid-template-areas:"scanner templates" "processing result";gap:28px}.studio-panel{min-width:0}.studio-panel-scanner{grid-area:scanner}.studio-panel-templates{grid-area:templates}.studio-panel-processing{grid-area:processing}.studio-panel-result{grid-area:result}.glass-surface,.glass-floating{border-radius:18px;background:var(--surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--panel-shadow)}.glass-floating{background:var(--surface-strong);border-color:var(--surface-border);-webkit-backdrop-filter:blur(28px);backdrop-filter:blur(28px)}.scanner-section,.processing-section{padding:24px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.section-title{margin:0;font-family:var(--font-display);font-size:1.45rem;font-weight:500;color:var(--text)}.section-step{color:var(--primary);margin-right:8px}.section-chip{padding:6px 10px;border-radius:999px;background:#ffffff0d;color:var(--muted);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.scanner-frame{position:relative;aspect-ratio:1 / 1;overflow:hidden;border-radius:20px;border:1px dashed rgba(253,139,54,.3);background:#fff6}.scanner-image{width:100%;height:100%;object-fit:cover;opacity:1}.source-preview-image{background:#111;image-orientation:from-image;object-fit:contain}.scanner-placeholder{top:0;right:0;bottom:0;left:0;display:grid;place-items:center;align-content:center;gap:12px;color:var(--muted);text-align:center;padding:24px;font-weight:500}.scanner-placeholder .material-symbols-outlined{font-size:3rem;color:var(--primary)}.scanner-guides{position:absolute;top:16px;right:16px;bottom:16px;left:16px;border:2px dashed rgba(253,139,54,.2);border-radius:16px;pointer-events:none}.scanning-line{position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent);animation:scan 3s linear infinite}.scanner-actions-wrap{left:0;right:0;bottom:16px;padding:0 16px}.capture-actions{display:flex;flex-wrap:nowrap;gap:10px;justify-content:center}.primary-button,.ghost-button,.icon-button,.regenerate-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:12px 18px;transition:transform .16s ease,background .16s ease,opacity .16s ease}.primary-button{border:0;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 4px 16px #fd8b3659;font-weight:600}.ghost-button,.icon-button{background:#fff;color:var(--text);box-shadow:0 4px 12px #0000000a;border:1px solid rgba(0,0,0,.05);font-weight:500}.ghost-button{position:relative;overflow:hidden}.ghost-button input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.primary-button:hover,.ghost-button:hover,.icon-button:hover,.regenerate-button:hover,.template-card:hover{transform:translateY(-1px)}.primary-button:disabled,.ghost-button.is-disabled,.icon-action:disabled,.regenerate-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.field-hint{margin:12px 0 0;color:var(--muted);font-size:.9rem;line-height:1.5}.field-error{color:#ff9ba3}.processing-stack{display:flex;flex-direction:column;gap:16px}.processing-generate-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;border:0;border-radius:14px;padding:14px 18px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;font-family:var(--font-display);font-size:1rem;font-weight:700;box-shadow:0 8px 28px #fd8b3647;transition:transform .16s ease,opacity .16s ease}.processing-generate-button:hover{transform:translateY(-1px)}.processing-generate-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.processing-row{display:flex;align-items:center;justify-content:space-between;color:var(--primary);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em}.processing-bar{height:2px;overflow:hidden;border-radius:999px;background:#ffffff1a}.processing-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));box-shadow:0 0 14px #bc13fe80}.processing-copy{margin:0;color:var(--muted);font-style:italic}.templates-section,.result-section{display:flex;flex-direction:column;gap:16px}.templates-section{min-width:0}.section-arrows{display:flex;gap:8px}.section-arrows button{display:grid;place-items:center;width:36px;height:36px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:var(--surface);color:#fff9}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.template-card{position:relative;padding:0;overflow:hidden;border:1px solid rgba(255,255,255,.06);border-radius:18px;background:transparent;text-align:left}.template-card.is-selected{border:2px solid var(--primary)}.template-visual{position:relative;overflow:hidden}.template-original{width:100%;height:100%;transition:transform .5s ease}.template-card:hover .template-original{transform:scale(1.08)}.profile-type-panel{margin-bottom:24px}.profile-type-toggle{display:inline-grid;grid-template-columns:repeat(2,minmax(96px,1fr));gap:6px;padding:6px;border-radius:999px;background:#ffffff9e;border:1px solid rgba(0,0,0,.06)}.profile-type-button{border:0;border-radius:999px;padding:10px 18px;background:transparent;color:var(--muted);font-weight:700;transition:background .16s ease,color .16s ease,box-shadow .16s ease}.profile-type-button.is-selected{background:#fff;color:var(--primary);box-shadow:0 4px 14px #fd8b3629}.hair-color-panel{margin-top:24px}.hair-color-grid{display:flex;flex-wrap:wrap;gap:10px}.style-search-input{width:100%;min-height:46px;margin-bottom:8px;border:1px solid rgba(0,0,0,.08);border-radius:14px;padding:12px 14px;background:#ffffffc2;color:var(--text)}.men-only-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,#fd8b3629,#f7bb2c14);border:1px solid rgba(253,139,54,.14)}.men-only-banner .field-hint{margin:0}.style-option-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px}.single-style-option{max-width:320px;margin:0 auto;text-align:center;align-items:center;padding:18px 16px}.style-option-button{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-height:88px;border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:14px;background:#ffffffb8;color:var(--text);text-align:left;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.style-option-button:hover{transform:translateY(-2px)}.style-option-button.is-selected{border-color:var(--primary);box-shadow:0 10px 22px #fd8b362e;background:linear-gradient(180deg,#ffffffe0,#fff7efeb)}.style-option-title{font-weight:700}.style-option-meta{color:var(--muted);font-size:.82rem;word-break:break-word}.hair-color-button{display:inline-flex;align-items:center;gap:8px;min-height:42px;border:1px solid rgba(0,0,0,.08);border-radius:999px;padding:8px 12px;background:#ffffffb8;color:var(--text);font-size:.9rem;font-weight:600;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.hair-color-button:hover{transform:translateY(-1px)}.hair-color-button.is-selected{border-color:var(--primary);box-shadow:0 4px 16px #fd8b362e}.hair-color-swatch{width:22px;height:22px;flex:0 0 22px;border:2px solid rgba(255,255,255,.88);border-radius:999px;box-shadow:0 1px 5px #00000029}.template-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 10%,rgba(0,0,0,.4) 100%)}.template-copy{position:absolute;left:12px;bottom:12px}.template-copy h3{margin:0;font-size:.95rem;font-weight:600;color:#fff}.template-selected-badge{position:absolute;right:12px;bottom:12px;z-index:2;padding:6px 10px;border-radius:999px;background:var(--primary);color:#fff;font-family:var(--font-display);font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.result-shell{padding:16px;width:min(1100px,100%);margin:0 auto}.result-pair-grid,.history-pair-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.result-preview-card,.history-image-block{display:flex;flex-direction:column;gap:8px}.result-preview{position:relative;width:100%;min-height:340px;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:14px;background:#000}.result-preview img{width:100%;height:100%;object-fit:contain}.result-floating-actions{position:absolute;top:16px;right:16px;z-index:3}.result-download-button{background:#1a1a1e85;border:1px solid rgba(255,255,255,.14);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.result-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;align-content:center;gap:12px;padding:24px;text-align:center;color:var(--muted);background:linear-gradient(180deg,#ffffff05,#0000004d)}.scan-rings{position:relative;width:120px;height:120px}.scan-rings span{position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid rgba(188,19,254,.35);border-radius:999px;animation:pulse-ring 2.4s infinite ease-out}.scan-rings span:nth-child(2){animation-delay:.4s}.scan-rings span:nth-child(3){animation-delay:.8s}.result-caption-card{margin-top:14px;padding:14px 16px;border-radius:14px;background:#ffffffbd;border:1px solid rgba(0,0,0,.06)}.result-kicker{margin:0 0 4px;color:var(--muted);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.16em}.result-caption-card h3{margin:0;color:var(--text);font-family:var(--font-display);font-size:1.05rem;font-weight:700}.history-image-label{color:var(--muted);font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.history-view{display:flex;flex-direction:column;gap:18px}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:18px}.history-card{padding:16px}.history-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.history-card-header h3{margin:0;font-family:var(--font-display);font-size:1rem}.history-card-actions{display:flex;align-items:center;gap:8px}.history-image-frame{overflow:hidden;border-radius:14px;background:#111;min-height:280px}.history-image-frame img{width:100%;height:100%;display:block;object-fit:contain}.history-empty-state{padding:24px}.icon-action{display:grid;place-items:center;width:46px;height:46px;border:0;border-radius:999px;background:#ffffff1a;color:#fff}.history-action-button{background:#111111b8}.history-delete-button{background:#9a2b2bd1}.icon-action:disabled{opacity:.45}.result-error{margin-top:16px}.camera-shell{width:min(820px,100%);max-height:calc(100dvh - 40px);padding:20px;border-radius:20px;background:#111216;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;overflow:auto}.camera-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.camera-header h3{margin:0;font-family:var(--font-display)}.camera-content{display:flex;flex-direction:column;gap:16px;flex:1 1 auto;min-height:0}.camera-frame{position:relative;overflow:hidden;border-radius:16px;background:#000;aspect-ratio:4 / 3;flex:1 1 auto;min-height:280px;max-height:62dvh}.camera-frame video{width:100%;height:100%;object-fit:cover;background:#000}.camera-preview-video{transform:scaleX(-1)}.camera-simple-frame{overflow:hidden;background:#111}.camera-simple-actions{position:absolute;inset:auto 0 24px 0;display:flex;justify-content:center;gap:12px;z-index:10}.history-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:24px;background:#0a0a0aa8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.history-modal{width:min(1100px,100%);max-height:calc(100vh - 48px);overflow:auto;padding:20px;border-radius:24px;background:#fff6eff5;border:1px solid rgba(255,255,255,.9);box-shadow:0 24px 80px #00000038}.history-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.history-modal-header h3{margin:0;font-family:var(--font-display)}.history-modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.history-modal-frame{overflow:hidden;border-radius:18px;background:#111;min-height:420px}.history-modal-frame img{width:100%;height:100%;display:block;object-fit:contain}.face-shape-guide{position:absolute;left:50%;top:48%;width:min(48%,225px);aspect-ratio:.76;border:3px dotted rgba(255,255,255,.78);border-radius:50% 50% 46% 46%/42% 42% 58% 58%;transform:translate(-50%,-50%);pointer-events:none;z-index:4;box-shadow:0 0 0 999px #00000014}.face-guide{position:absolute;border:2px dashed rgba(253,139,54,.6);border-radius:50% 50% 45% 45%/40% 40% 60% 60%;pointer-events:none;z-index:5}.pose-status{position:absolute;left:50%;bottom:92px;z-index:10;display:inline-flex;align-items:center;gap:8px;max-width:calc(100% - 32px);min-height:40px;padding:8px 14px;border-radius:999px;background:#000000a3;color:#fff;font-size:.85rem;font-weight:600;text-align:center;transform:translate(-50%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pose-status .material-symbols-outlined{font-size:1.1rem}.pose-status.is-ready{color:var(--secondary)}.camera-toolbar{display:flex;justify-content:flex-end;gap:12px;margin-top:0;position:sticky;bottom:0;z-index:3;padding-top:12px;background:linear-gradient(180deg,#11121600,#111216 24%)}@keyframes scan{0%{top:0;opacity:0}50%{opacity:1}to{top:100%;opacity:0}}@keyframes pulse-ring{0%{transform:scale(.72);opacity:0}24%{opacity:1}to{transform:scale(1.16);opacity:0}}@media (max-width: 1100px){.studio-grid{grid-template-columns:1fr;grid-template-areas:"scanner" "templates" "processing" "result";gap:22px}.template-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 760px){.app-shell{width:100%;padding:72px 10px 18px}.topbar{height:58px;padding:0 10px}.topbar-history-button{right:10px;min-width:92px;padding:10px 14px}.topbar h1{font-size:1.3rem;text-align:left;padding-right:108px}.studio-grid{gap:18px}.scanner-section,.processing-section,.result-shell{padding:14px 12px}.topbar-right{gap:8px}.topbar-nav{display:none}.avatar-shell{width:30px;height:30px}.capture-actions,.camera-toolbar{flex-direction:column}.primary-button,.ghost-button,.icon-button,.processing-generate-button{width:100%;min-height:50px}.template-grid{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.template-grid::-webkit-scrollbar{display:none}.template-card{flex:0 0 min(76vw,100px);scroll-snap-align:start}.section-chip{font-size:.62rem;padding:5px 8px;max-width:96px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-card{border-radius:16px}.template-copy{left:10px;right:82px;bottom:10px}.template-copy h3{font-size:.9rem}.template-selected-badge{right:10px;bottom:10px;font-size:.62rem;padding:5px 8px}.hair-color-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.hair-color-button{justify-content:flex-start;width:100%;min-height:48px;padding:10px 12px;border-radius:16px}.profile-type-toggle{width:100%}.men-only-banner{flex-direction:column;align-items:flex-start}.section-arrows{display:none}.source-preview-image{object-fit:contain}.scanner-frame{aspect-ratio:3 / 4;border-radius:18px}.camera-simple-frame{min-height:68svh!important}.section-header{margin-bottom:12px;align-items:flex-start;gap:10px}.section-title{font-size:1.15rem;line-height:1.15}.scanner-actions-wrap{bottom:12px;padding:0 12px}.scanner-placeholder{padding:16px}.scanner-placeholder .material-symbols-outlined{font-size:2.5rem}.result-shell{padding:14px;width:100%;border-radius:20px}.result-pair-grid,.history-pair-grid{grid-template-columns:1fr;gap:14px}.result-preview{min-height:260px;border-radius:16px}.history-grid{grid-template-columns:1fr;gap:14px}.history-image-frame{min-height:220px}.history-modal-grid{grid-template-columns:1fr}.history-modal-frame{min-height:240px}.history-card{padding:14px 12px;border-radius:18px}.history-card-header{flex-direction:column;align-items:stretch}.history-card-actions{justify-content:flex-end}.history-modal-backdrop{padding:10px}.history-modal{padding:14px 12px;border-radius:20px;max-height:calc(100vh - 20px)}.history-modal-header{flex-direction:column;align-items:stretch;gap:10px}.history-modal-header .ghost-button{width:100%}.style-option-grid{grid-template-columns:1fr}.single-style-option{max-width:100%;min-height:78px;padding:16px 14px}.profile-type-panel{margin-bottom:18px}.field-hint{font-size:.88rem;line-height:1.45}.processing-generate-button{min-height:64px}.camera-shell{width:100%;min-height:100dvh;max-height:none;border-radius:0;padding:16px 16px calc(16px + env(safe-area-inset-bottom,0px));overflow:hidden;background:#111216}.camera-header{margin-bottom:14px;align-items:flex-start;flex-wrap:wrap}.camera-header .eyebrow{display:none}.camera-header h3{font-size:1.05rem;line-height:1.25;max-width:10ch}.camera-header .icon-button{width:100%;min-width:0}.camera-frame{aspect-ratio:auto;min-height:0;height:min(48dvh,380px);flex:0 0 auto;max-height:none}.camera-toolbar{position:sticky;z-index:3;margin-top:auto;padding-top:14px;background:linear-gradient(180deg,#11121600,#111216 22%)}.camera-toolbar .ghost-button,.camera-toolbar .primary-button{width:100%}}@media (max-width: 480px){.app-shell{width:100%;padding:70px 8px 16px}.studio-grid{gap:16px}.topbar{padding:0 8px}.topbar h1{font-size:1.18rem;padding-right:96px}.topbar-history-button{right:8px;min-width:84px;padding:9px 12px;font-size:.92rem}.avatar-shell{width:28px;height:28px}.capture-actions{gap:8px}.primary-button,.ghost-button{padding:11px 14px;font-size:.92rem}.scanner-section,.processing-section,.result-shell{padding:12px 10px}.template-grid{gap:10px}.template-card{flex-basis:22vw}.section-title{font-size:1.05rem}.section-step{margin-right:6px}.result-caption-card{margin-top:12px;padding:12px}.result-caption-card h3{font-size:1rem}.result-floating-actions{top:12px;right:12px}.icon-action{width:40px;height:40px}.hair-color-grid{grid-template-columns:1fr}.camera-simple-actions{inset:auto 10px 14px 10px;flex-direction:column}.camera-simple-actions .primary-button,.camera-simple-actions .ghost-button{width:100%}.camera-shell{padding:12px 12px calc(12px + env(safe-area-inset-bottom,0px))}.camera-header{gap:12px;flex-direction:column}.camera-header h3{font-size:1rem;max-width:none}.camera-frame{height:min(42dvh,320px)}.camera-toolbar{gap:10px}}.wizard-container,.step-2-container{display:flex;flex-direction:column;gap:24px;animation:fadeIn .4s ease-out forwards}.wizard-panel{animation:fadeIn .5s ease-out forwards;width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce-jump{0%,to{transform:translateY(0) scale(1.05,.95)}50%{transform:translateY(-24px) scale(.95,1.05)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
