*{box-sizing:border-box}:root{color:#2b2420;background:#f9f3e9;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Helvetica Neue,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}body{margin:0;min-width:320px;background:#f9f3e9}button,input,textarea,select{font:inherit}button{border:0;cursor:pointer}img{max-width:100%;display:block}.app-shell{min-height:100vh;max-width:540px;margin:0 auto;background:#f9f3e9}.app-shell.with-tabs{padding-bottom:92px}.page{min-height:100vh;padding:18px 18px 32px}.hero{min-height:260px;padding:42px 22px 24px;border-radius:0 0 34px 34px;background:linear-gradient(145deg,#33261f,#8c5345 48%,#f1b783);color:#fff8ee}.eyebrow{margin:0 0 12px;font-size:12px;letter-spacing:.18em;opacity:.76}h1{margin:0;font-family:Georgia,Times New Roman,serif;font-size:42px;line-height:1.08;letter-spacing:0}h2{margin:0;font-size:20px}p{line-height:1.65}.hero p:not(.eyebrow){margin:12px 0 22px;color:#fff8eed1}.search-box{height:48px;display:flex;align-items:center;gap:10px;padding:0 14px;border-radius:18px;background:#fff8eeeb;color:#7b675b}.search-box input{min-width:0;flex:1;height:46px;border:0;outline:0;background:transparent;color:#2b2420}.trial-card{position:relative;width:100%;min-height:150px;margin:-26px 0 26px;padding:24px;display:grid;gap:6px;text-align:left;border-radius:26px;background:#fffdf8;color:#2b2420;box-shadow:0 18px 52px #4a2d1f26}.trial-card span{color:#d46d58;font-size:12px;letter-spacing:.18em}.trial-card strong{font-family:Georgia,Times New Roman,serif;font-size:30px}.trial-card em{color:#7b675b;font-style:normal}.trial-card svg{position:absolute;right:20px;bottom:20px;color:#d46d58}.section-title{display:flex;align-items:baseline;justify-content:space-between;margin:26px 0 14px}.section-title span{color:#8d7a70;font-size:13px}.hot-row{display:grid;grid-auto-flow:column;grid-auto-columns:43%;gap:12px;overflow-x:auto;padding-bottom:4px}.template-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.template-grid.small{grid-template-columns:repeat(3,minmax(0,1fr))}.template-card{position:relative;min-height:226px;overflow:hidden;padding:0;border-radius:18px;background:#e6d8c8;color:#fff8ee;text-align:left;box-shadow:0 10px 28px #4a2d1f1f}.template-card img{width:100%;height:100%;min-height:226px;object-fit:cover}.template-card:after{content:"";position:absolute;inset:40% 0 0;background:linear-gradient(180deg,transparent,rgba(37,29,25,.82))}.template-card em,.template-card strong,.template-card small,.template-card .rank{position:absolute;z-index:1;left:12px;right:12px}.template-card em{top:12px;right:auto;min-height:26px;padding:5px 9px;border-radius:999px;background:#fff8eed6;color:#6f5145;font-size:12px;font-style:normal}.template-card .rank{top:12px;left:auto;right:12px;color:#2b2420;background:#ffdca6;border-radius:999px;padding:5px 9px;font-size:12px}.template-card strong{bottom:36px;font-size:16px}.template-card small{bottom:14px;color:#fff8eec7;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.category-row{display:flex;gap:10px;overflow-x:auto;margin:22px -18px 18px;padding:0 18px}.category-row.wrap{flex-wrap:wrap;overflow:visible;margin:18px 0;padding:0}.category-row button,.gender-row button{height:40px;white-space:nowrap;padding:0 16px;border-radius:999px;background:#fffdf8;color:#6d5a50;border:1px solid #eadfd3}.category-row button.active,.gender-row button.active{background:#2b2420;color:#fff8ee;border-color:#2b2420}.page-header{position:sticky;top:0;z-index:20;height:58px;display:grid;grid-template-columns:42px 1fr 42px;align-items:center;margin:-18px -18px 14px;padding:0 16px;background:#f9f3e9f0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.page-header button{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;background:#fffdf8;color:#2b2420}.page-header strong{text-align:center}.detail-cover{height:420px;margin:0 -18px;overflow:hidden;background:#e8ddce}.detail-cover img{width:100%;height:100%;object-fit:cover}.glass-card{position:relative;margin:-42px 0 28px;padding:24px;border-radius:26px;background:#fffdf8eb;box-shadow:0 18px 48px #4a2d1f2e}.glass-card .tag{display:inline-flex;margin-bottom:12px;padding:5px 10px;border-radius:999px;background:#f5ded6;color:#c85f4a;font-size:13px}.glass-card h1{font-size:34px}.glass-card p{margin:10px 0 0;color:#5f4e45}.metrics-line{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;color:#8a756b;font-size:13px}.metrics-line span{padding:7px 10px;border-radius:999px;background:#f6eadf}.detail-section{margin:28px 0}.detail-section p,.muted{color:#77665d}.preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.preview-grid img{aspect-ratio:3 / 4;border-radius:14px;object-fit:cover;background:#e8ddce}.sticky-action{position:sticky;bottom:0;margin:28px -18px -32px;padding:16px 18px calc(18px + env(safe-area-inset-bottom));background:#fffdf8f0;border-radius:24px 24px 0 0;box-shadow:0 -12px 40px #4a2d1f1a}.primary{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 18px;border-radius:16px;background:#d96f59;color:#fff8ee;text-decoration:none;font-weight:700}.primary.wide{width:100%}.selected-template{display:grid;grid-template-columns:72px 1fr auto;gap:12px;align-items:center;padding:12px;border-radius:18px;background:#fffdf8;border:1px solid #eadfd3}.selected-template img{width:72px;height:88px;border-radius:12px;object-fit:cover}.selected-template span{display:block;color:#8a756b;font-size:12px}.selected-template button{color:#d46d58;background:transparent}.upload-page h1{margin-top:28px;font-size:34px}.upload-box{width:100%;min-height:260px;display:grid;place-items:center;align-content:center;gap:12px;margin:20px 0;border:1px dashed #d9c8b7;border-radius:28px;background:#fffdf8;color:#6d5a50}.photo-preview{position:relative;margin:20px 0;overflow:hidden;border-radius:28px;background:#e8ddce}.photo-preview img{width:100%;aspect-ratio:3 / 4;object-fit:cover}.photo-preview button{position:absolute;left:14px;top:14px;height:36px;padding:0 13px;border-radius:999px;background:#fffdf8e6;color:#2b2420}.photo-chip{position:absolute;right:14px;top:14px;min-height:36px;padding:8px 13px;border-radius:999px;background:#2b2420b8;color:#fff8ee;font-size:13px}.photo-chip.ready{background:#346b33e6}.photo-chip.failed{background:#9b2d21e6}.gender-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0 24px}.generating-page{display:grid;align-content:start}.generating-card{display:grid;justify-items:center;gap:14px;margin-top:20px;padding:28px 22px;border-radius:30px;background:#fffdf8;text-align:center;box-shadow:0 18px 50px #4a2d1f1f}.generating-card img{width:180px;aspect-ratio:3 / 4;border-radius:24px;object-fit:cover}.spin{animation:spin 1s linear infinite;color:#d96f59}@keyframes spin{to{transform:rotate(360deg)}}.progress{width:100%;height:10px;overflow:hidden;border-radius:999px;background:#eadfd3}.progress span{display:block;height:100%;border-radius:inherit;background:#d96f59;transition:width .3s ease}.result-hero{position:relative;overflow:hidden;border-radius:30px;background:#e8ddce;box-shadow:0 18px 46px #4a2d1f24}.result-hero img{width:100%;aspect-ratio:3 / 4;object-fit:cover}.result-hero span,.result-hero strong{position:absolute;left:16px;color:#fff8ee;text-shadow:0 2px 12px rgba(0,0,0,.3)}.result-hero span{top:16px;padding:8px 12px;border-radius:999px;background:#251d1994}.result-hero strong{bottom:16px}.thumb-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:18px 0 24px}.thumb-row button{aspect-ratio:1;overflow:hidden;padding:0;border-radius:14px;border:3px solid transparent;background:#e6d8c8;color:#8a756b}.thumb-row button.active{border-color:#d96f59}.thumb-row img{width:100%;height:100%;object-fit:cover}.action-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.action-row button{border-radius:16px;background:#fffdf8;color:#2b2420;border:1px solid #eadfd3}.page-top{margin:14px 0 24px}.page-top h1{font-size:38px}.page-top span{display:block;margin-top:8px;color:#77665d}.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:13px}.work-grid button{overflow:hidden;padding:0 0 12px;border-radius:18px;background:#fffdf8;color:#2b2420;text-align:left;border:1px solid #eadfd3}.work-grid img{width:100%;aspect-ratio:3 / 4;object-fit:cover}.work-grid strong,.work-grid span{display:block;padding:10px 12px 0}.work-grid span{color:#8a756b;font-size:13px}.profile-card{display:grid;grid-template-columns:62px 1fr;gap:14px;align-items:center;padding:18px;border-radius:22px;background:#fffdf8;border:1px solid #eadfd3}.avatar{width:62px;height:62px;display:grid;place-items:center;overflow:hidden;border-radius:50%;background:#f5ded6;color:#d96f59}.avatar img{width:100%;height:100%;object-fit:cover}.profile-card strong,.profile-card span{display:block}.profile-card span{margin-top:6px;color:#77665d}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:16px 0}.metric{padding:16px 8px;border-radius:18px;background:#fffdf8;text-align:center;border:1px solid #eadfd3}.metric strong{display:block;font-size:24px}.metric span{color:#8a756b;font-size:13px}.menu-list{display:grid;gap:10px}.menu-list button{min-height:58px;display:grid;grid-template-columns:24px 1fr auto;align-items:center;gap:12px;padding:0 16px;border-radius:18px;background:#fffdf8;color:#2b2420;text-align:left;border:1px solid #eadfd3}.menu-list span{color:#d96f59}.login-page{display:grid;align-content:start;gap:18px}.login-hero{min-height:230px;padding:42px 24px 28px;border-radius:0 0 32px 32px;background:linear-gradient(145deg,#2b2420,#765045 52%,#df9b75);color:#fff8ee}.login-hero p:not(.eyebrow){margin:14px 0 0;color:#fff8eed1}.login-panel{display:grid;gap:14px;margin-top:-38px;padding:18px;border-radius:24px;background:#fffdf8;border:1px solid #eadfd3;box-shadow:0 18px 52px #4a2d1f26}.mode-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:5px;border-radius:16px;background:#f6eadf}.mode-switch button{height:42px;border-radius:12px;background:transparent;color:#7b675b}.mode-switch button.active{background:#2b2420;color:#fff8ee}.login-panel label{display:grid;gap:8px;color:#6d5a50;font-size:13px}.login-panel input{width:100%;height:50px;padding:0 14px;border:1px solid #eadfd3;border-radius:16px;background:#fffaf2;color:#2b2420;outline:0}.login-panel input:focus{border-color:#d96f59;box-shadow:0 0 0 3px #d96f591f}.invite-note{margin:0;padding:10px 12px;border-radius:14px;background:#f6eadf;color:#8a5548;font-size:13px}.feedback-page h1{font-size:32px;margin:16px 0}.feedback-page textarea,.feedback-page input{width:100%;margin:0 0 14px;border:1px solid #eadfd3;border-radius:18px;background:#fffdf8;color:#2b2420;outline:0}.feedback-page textarea{min-height:150px;padding:14px;resize:vertical;line-height:1.6}.feedback-page input{height:50px;padding:0 14px}.loading-block,.empty{min-height:260px;display:grid;place-items:center;align-content:center;gap:12px;text-align:center;color:#8a756b}.empty h2{color:#2b2420}.empty p{margin:0 0 6px;max-width:280px}.tabbar{position:fixed;left:50%;bottom:0;z-index:40;width:min(540px,100%);transform:translate(-50%);display:grid;grid-template-columns:repeat(3,1fr);padding:10px 18px calc(10px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0;background:#fffdf8f5;box-shadow:0 -14px 40px #4a2d1f1f}.tabbar button{display:grid;justify-items:center;gap:4px;background:transparent;color:#8a756b}.tabbar button.active{color:#d96f59}.tabbar span{font-size:12px}.toast{position:fixed;left:50%;bottom:96px;z-index:60;max-width:min(360px,calc(100% - 36px));transform:translate(-50%);padding:12px 16px;border-radius:999px;background:#251d19e0;color:#fff8ee;font-size:14px;box-shadow:0 10px 34px #251d1938}@media(max-width:380px){.template-grid.small{grid-template-columns:repeat(2,minmax(0,1fr))}h1{font-size:36px}.hot-row{grid-auto-columns:52%}}
