:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:radial-gradient(circle at 50% 0,#dff8ee 0%,#f5f2ea 40%,#e9f2ee 100%);font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button{font:inherit}button:disabled{cursor:not-allowed;opacity:.55}img{max-width:100%;display:block}.app-shell{min-height:100vh;padding:max(18px, env(safe-area-inset-top)) 18px max(18px, env(safe-area-inset-bottom));place-items:center;display:grid}.phone-page{background:linear-gradient(#fff 0%,#f7fbf8 100%);border-radius:34px;width:min(100%,420px);min-height:760px;max-height:920px;padding:22px;position:relative;overflow:hidden;box-shadow:0 30px 90px #0e44302e}.topbar,.actions-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.eyebrow{color:#20a884;letter-spacing:.16em;margin:0;font-size:12px;font-weight:900}h1{margin:6px 0;font-size:30px;line-height:1.15}p{color:#667085}.text-link,.icon-button{color:#20a884;cursor:pointer;background:0 0;border:0;font-weight:800}.style-tabs{gap:8px;padding:14px 0 8px;display:flex;overflow-x:auto}.style-tabs button{color:#486159;background:#fff;border:1px solid #dce9e3;border-radius:999px;flex:none;padding:8px 12px;font-size:13px}.style-tabs button.active{color:#fff;background:#20a884;border-color:#20a884}.style-tabs span{margin-right:6px;font-weight:900}.hero-doll{perspective:800px;-webkit-user-select:none;user-select:none;background:linear-gradient(145deg,#e7fff5,#fff7e7);border:1px solid #d8eee5;border-radius:28px;place-items:center;height:250px;margin:18px auto;display:grid}.doll{color:#fff;width:148px;height:180px;transform-style:preserve-3d;background:linear-gradient(160deg,#20a884,#f5d36b);border-radius:36px 36px 24px 24px;place-items:center;font-size:34px;font-weight:900;transition:transform .18s;display:grid;box-shadow:0 28px 50px #20a8843d}.hero-doll span,.viewer-hint{margin-top:8px;font-size:12px;font-weight:700}.hero-doll span{color:#20a884}.viewer-hint{color:#ffffffb3}.upload-card{text-align:center;color:#172033;cursor:pointer;background:#f0fbf6;border:1px dashed #20a884;border-radius:24px;gap:6px;width:100%;padding:20px;display:grid}.upload-card strong{font-size:18px}.upload-card span,.upload-card small{color:#667085}.generating-page{color:#fff;flex-direction:column;overflow-y:auto;background:#c0bcba!important;padding:0!important;display:flex!important}.gen-header{flex-shrink:0;width:100%;padding-bottom:24px;position:relative;overflow:hidden}.gen-header-bg{pointer-events:none;background:linear-gradient(#281c14eb 0%,#3c2a1ce0 40%,#5a463299 70%,#c0bcba00 100%);position:absolute;inset:0}.gen-header-content{z-index:1;padding:max(56px, calc(env(safe-area-inset-top) + 32px)) 24px 0;text-align:center;flex-direction:column;align-items:center;display:flex;position:relative}.gen-title{color:#fff;letter-spacing:.02em;margin:0 0 8px;font-size:19px;font-weight:500;line-height:1.4}.gen-subtitle{font-weight:400;line-height:1.4;color:#fffc!important;margin:0 0 20px!important;font-size:12.6px!important}.gen-progress-track{background:linear-gradient(#785a3bbf 0%,#a7917eba 100%);border-radius:9.71px;width:min(310px,82%);height:19.74px;margin-bottom:4px;overflow:hidden}.gen-progress-fill{border-radius:inherit;background:linear-gradient(90deg,#008d7b 2%,#2dc596 49%,#5cff7c 98%);min-width:8px;height:100%;transition:width .25s}.gen-style-row{scrollbar-width:none;-ms-overflow-style:none;flex-shrink:0;gap:16px;padding:18px 24px 4px;display:flex;overflow-x:auto}.gen-style-row::-webkit-scrollbar{display:none}.gen-style-pill{color:#fff;opacity:.3;white-space:nowrap;background:#000;border-radius:200px;flex:none;align-items:center;padding:6px 18px;font-size:16px;font-weight:600;line-height:1.4;display:inline-flex}.gen-style-pill.active{opacity:1}.gen-photo-wrap{flex-shrink:0;width:208px;height:349px;margin:16px auto 0;position:relative}.gen-user-photo{object-fit:cover;border-radius:16px;width:100%;height:100%;display:block}.gen-photo-placeholder{background:#0003;border-radius:16px;width:100%;height:100%}.gen-sparkles{pointer-events:none;flex-wrap:wrap;justify-content:space-around;align-items:center;display:flex;position:absolute;inset:-20px}.gen-sparkles span{color:#ffffffb3;font-size:14px;animation:2.4s ease-in-out infinite sparkle-float}.gen-sparkles span:first-child{animation-delay:0s}.gen-sparkles span:nth-child(2){animation-delay:.4s}.gen-sparkles span:nth-child(3){animation-delay:.8s}.gen-sparkles span:nth-child(4){animation-delay:1.2s}.gen-sparkles span:nth-child(5){animation-delay:1.6s}.gen-sparkles span:nth-child(6){animation-delay:2s}@keyframes sparkle-float{0%,to{opacity:.3;transform:translateY(0)scale(.8)}50%{opacity:1;transform:translateY(-8px)scale(1.2)}}.gen-actions{padding:20px 24px max(32px, env(safe-area-inset-bottom));flex-direction:column;flex-shrink:0;align-items:center;gap:12px;margin-top:auto;display:flex}.gen-cancel-btn{cursor:pointer;color:#fffc!important;background:#00000040!important;border:0!important;border-radius:999px!important;padding:12px 32px!important;font-size:14px!important;font-weight:600!important}.gen-retry-btn{cursor:pointer;color:#fff!important;background:linear-gradient(90deg,#008d7b,#2dc596)!important;border:0!important;border-radius:999px!important;padding:12px 32px!important;font-size:14px!important;font-weight:700!important}@media (width<=430px){.generating-page{min-height:100svh!important}}button:not(.text-link):not(.icon-button):not(.history-item):not(.box-card):not(.tab-btn):not(.upload-card-new):not(.text-link-white){color:#fff;cursor:pointer;background:#20a884;border:0;border-radius:999px;padding:12px 20px;font-weight:800}.ghost-button{color:#1b6d59!important;background:#eef5f1!important}.ghost-button.small{font-size:13px;padding:8px 12px!important}.result-page{flex-direction:column;display:flex;box-shadow:none!important;background:#666!important;border-radius:0!important;padding:0!important}.result-capture{background:#666;border-radius:0;flex:1;place-items:center;min-height:280px;margin:0;display:grid;position:relative;overflow:hidden}.viewer{touch-action:none;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.viewer-content{flex:1;justify-content:center;align-items:center;width:100%;min-height:0;display:flex}.viewer-content img{object-fit:contain;filter:drop-shadow(0 24px 26px #0000004d);max-width:85%;max-height:85%}.viewer-model{width:100%;height:100%}.viewer-hint{flex-shrink:0;padding:12px 0 16px}.sealed-large{place-items:center;display:grid}.sealed-large svg{filter:drop-shadow(0 24px 32px #6428b440);width:200px;height:200px}.anim-shake .sealed-large svg{border-radius:40px;animation:.6s cubic-bezier(.36,.07,.19,.97) both unbox-shake,.6s ease-in-out both unbox-glow}@keyframes unbox-shake{0%,to{transform:rotate(0)scale(1)}10%{transform:rotate(-3deg)scale(1.02)}20%{transform:rotate(4deg)scale(1.03)}30%{transform:rotate(-5deg)scale(1.04)}40%{transform:rotate(6deg)scale(1.05)}50%{transform:rotate(-6deg)scale(1.06)}60%{transform:rotate(7deg)scale(1.05)}70%{transform:rotate(-7deg)scale(1.06)}80%{transform:rotate(8deg)scale(1.04)}90%{transform:rotate(-8deg)scale(1.05)}}@keyframes unbox-glow{0%{filter:drop-shadow(0 0 8px #e040fb33)}50%{filter:drop-shadow(0 0 40px #e040fbcc)drop-shadow(0 0 80px #ff9a5c80)}to{filter:drop-shadow(0 0 60px #e040fb)drop-shadow(0 0 100px #ff9a5cb3)}}.anim-explode .sealed-large svg{animation:.5s cubic-bezier(.55,.085,.68,.53) forwards unbox-burst}@keyframes unbox-burst{0%{opacity:1;transform:scale(1.06)}40%{opacity:.7;transform:scale(1.4)}to{opacity:0;transform:scale(0)}}.particles{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.particle{border-radius:3px;width:12px;height:12px;animation:.7s cubic-bezier(.25,.46,.45,.94) forwards particle-fly;position:absolute}.particle:nth-child(odd){border-radius:50%}.particle:nth-child(3n+1){background:#ff9a5c}.particle:nth-child(3n+2){background:#e040fb}.particle:nth-child(3n){background:#5c6bc0}.particle:nth-child(4n+1){width:8px;height:8px}.particle:nth-child(5n){background:#ffd54f;width:10px;height:10px}@keyframes particle-fly{0%{opacity:1;transform:translate(0)scale(1)}to{transform:translate(var(--tx), var(--ty)) scale(0);opacity:0}}.flash-center{background:radial-gradient(circle,#fff 0%,#fff0 70%);border-radius:50%;width:80px;height:80px;animation:.6s ease-out forwards flash-burst;position:absolute}@keyframes flash-burst{0%{opacity:1;transform:scale(0)}50%{opacity:.7;transform:scale(3)}to{opacity:0;transform:scale(5)}}.anim-reveal .viewer,.anim-reveal .viewer-model{animation:.6s cubic-bezier(.34,1.56,.64,1) both reveal-pop}@keyframes reveal-pop{0%{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}.result-capture.animating{pointer-events:none}.result-actions{align-items:center;gap:10px;margin-top:12px;display:flex}.result-actions .favorite-btn{margin-right:auto;font-size:12px;color:#fff!important}.result-actions .ghost-button{font-size:14px;color:#fff!important;background:0 0!important;border:1.5px solid #fff!important;padding:12px 20px!important}.result-actions button:not(.ghost-button):not(.text-link):not(.favorite-btn){flex:1;color:#000!important;background:#fff!important}.result-bottom-panel{background:#000;border-radius:20px 20px 0 0;padding:16px 18px 24px}.result-panel-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.result-panel-header .panel-title{color:#fff;font-size:14px;font-weight:600}.result-panel-header .text-link{color:#fff9;font-size:12px;background:0 0!important;padding:0!important}.result-bottom-panel .box-grid{gap:8px}.result-bottom-panel .box-card{background:#fff;border:2px solid #0000;border-radius:12px;align-items:center;gap:6px;min-height:44px;padding:8px 10px;display:flex}.result-bottom-panel .box-card.selected{background:#fff;border-color:#000;box-shadow:0 0 0 1px #000}.result-bottom-panel .box-card img,.result-bottom-panel .box-card svg{border-radius:6px;flex-shrink:0;width:28px;height:28px;margin:0}.result-bottom-panel .box-card strong{text-align:left;font-size:12px}.result-bottom-panel .box-card .spinner{flex-shrink:0;width:20px;height:20px;margin:0}.box-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.box-card{cursor:pointer;color:#172033;background:#f4f6f5;border:2px solid #0000;border-radius:16px;min-height:74px;padding:8px}.box-card.selected{background:#e9fbf4;border-color:#20a884}.box-card img,.box-card svg{object-fit:cover;border-radius:10px;width:32px;height:32px;margin:0 auto 4px;display:block}.box-card strong{font-size:12px;line-height:1.25;display:block}.box-card.generating{opacity:.7}.box-card .spinner{border:3px solid #e0e0e0;border-top-color:#e040fb;border-radius:50%;width:24px;height:24px;margin:4px auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.box-card.just-ready{animation:.5s cubic-bezier(.34,1.56,.64,1) card-bounce}@keyframes card-bounce{0%{transform:scale(1)}40%{transform:scale(1.12)}to{transform:scale(1)}}.lock{color:#667085;background:#d8dedb;border-radius:10px;place-items:center;width:36px;height:32px;margin:0 auto 4px;font-size:10px;font-weight:900;display:grid}.drawer-mask{z-index:20;background:#0f172a6b;place-items:end center;padding:18px;display:grid;position:fixed;inset:0}.history-drawer,.share-sheet{background:#fff;border-radius:28px;width:min(100%,420px);max-height:72vh;padding:22px;overflow:auto;box-shadow:0 -20px 70px #0f172a2e}.drawer-close{float:right;font-size:24px}.history-list{gap:10px;display:grid}.history-item{text-align:left;cursor:pointer;background:#f7faf8;border:0;border-radius:18px;grid-template-columns:56px 1fr auto;align-items:center;gap:12px;width:100%;padding:10px;display:grid}.history-item img{object-fit:cover;border-radius:14px;width:56px;height:56px}.history-item span,.empty-text{color:#667085;font-size:13px}.history-item em{color:#20a884;font-size:12px;font-style:normal;font-weight:800}.share-sheet{text-align:center}.share-sheet button{width:100%;margin-top:10px}.toast{z-index:50;color:#fff;text-align:center;background:#000000b8;border-radius:14px;max-width:calc(100vw - 48px);padding:12px 16px;font-size:14px;position:fixed;bottom:42px;left:50%;transform:translate(-50%)}.toast-success{background:#20a884eb}.toast-error{background:#d83f31eb}@media (width<=430px){.app-shell{background:#c0bcba;padding:0}.phone-page{border-radius:0;width:100vw;min-height:100vh;max-height:none}.home-page{min-height:100svh!important}}.home-page{color:#1a1a1a;flex-direction:column;min-height:760px;background:#c0bcba!important;padding:0!important;display:flex!important}.home-topbar{padding:max(48px, calc(env(safe-area-inset-top) + 24px)) 24px 0;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.home-title h1{color:#1a1a1a;margin:0;font-size:32px;font-weight:800;line-height:1.2}.home-subtitle{line-height:1.4;color:#00000080!important;margin:6px 0 0!important;font-size:13px!important}.text-link-white{color:#0009;cursor:pointer;background:0 0;border:0;flex-shrink:0;margin-top:10px;padding:0;font-size:13px;font-weight:400;line-height:1.4}.style-tabs-dark{scrollbar-width:none;-ms-overflow-style:none;gap:10px;padding:20px 24px 8px;display:flex;overflow-x:auto}.style-tabs-dark::-webkit-scrollbar{display:none}.tab-btn{cursor:pointer;flex:none;align-items:center;gap:6px;display:flex;color:#000000a6!important;background:#00000021!important;border:none!important;border-radius:999px!important;padding:8px 18px!important;font-size:14px!important;font-weight:600!important}.tab-btn.active{color:#fff!important;background:#1a1a1a!important}.tab-icon{font-size:14px;line-height:1}.hero-zone{-webkit-user-select:none;user-select:none;flex-direction:column;flex:none;align-items:center;height:min(380px,48vh);min-height:240px;padding:4px 0 6px;display:flex}.hero-zone model-viewer{--poster-color:#c0bcba;--progress-bar-color:#0000004d;--progress-bar-height:3px;background:0 0;flex:1;width:100%;min-height:0}.rotation-hint-dark{color:#00000073;flex-shrink:0;align-items:center;gap:5px;margin-top:10px;font-size:12px;display:flex}.mystery-placeholder{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;animation:3s ease-in-out infinite mystery-float;display:flex}.mystery-img{object-fit:contain;filter:drop-shadow(0 8px 24px #8250e640);width:180px;height:180px}.mystery-text{color:#0000008c;letter-spacing:2px;font-size:15px;font-weight:600}@keyframes mystery-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.upload-panel{padding:16px 18px max(40px, env(safe-area-inset-bottom));background:#8c8886;border-radius:0;flex-shrink:0;margin-top:auto}.upload-prompt-text{font-size:14px;font-weight:700;line-height:1.4;color:#fff!important;margin:0 0 12px!important}.upload-card-new{cursor:pointer;text-align:left;background:#fff;align-items:center;gap:14px;width:100%;color:#1a1a1a!important;border:none!important;border-radius:16px!important;padding:14px 16px!important;font-weight:400!important;display:flex!important}.upload-card-new:disabled{opacity:.6;cursor:not-allowed}.upload-example-wrap{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;display:flex}.upload-example-img{object-fit:cover;border-radius:10px;width:80px;height:100px}.upload-example-label{color:#000000b3;font-size:11px;font-weight:700}.upload-text-block{flex:1}.upload-text-block strong{color:#000000bf;margin-bottom:5px;font-size:15px;font-weight:700;display:block}.upload-text-block span{color:#0006;font-size:12px}.privacy-row{color:#ffffffb3;justify-content:center;align-items:center;gap:5px;margin-top:14px;font-size:12px;display:flex}.poster-offscreen{z-index:-1;pointer-events:none;position:fixed;top:0;left:-9999px}.poster-container{box-sizing:border-box;background:#6b6b6b;flex-direction:column;align-items:center;width:375px;min-height:667px;padding:40px 24px 32px;display:flex}.poster-header{text-align:center;margin-bottom:24px}.poster-title{color:#fff;letter-spacing:2px;margin:0 0 8px;font-size:36px;font-weight:900}.poster-subtitle{color:#ffffffb3;margin:0;font-size:14px}.poster-grid{grid-template-columns:1fr 1fr;gap:8px;width:100%;margin-bottom:28px;display:grid}.poster-card{aspect-ratio:1;background:#fff;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.poster-card img{object-fit:cover;width:100%;height:100%}.poster-card-label{color:#fff;text-align:center;background:linear-gradient(#0000,#00000080);padding:4px 6px;font-size:11px;font-weight:600;position:absolute;bottom:0;left:0;right:0}.poster-placeholder{background:#555}.poster-placeholder svg{width:60%;height:60%}.poster-footer{flex-direction:column;align-items:center;gap:6px;display:flex}.poster-qr{background:#fff;border-radius:4px;width:80px;height:80px;padding:4px}.poster-brand{color:#fff;font-size:14px;font-weight:700}
