:root{font-family:Noto Sans KR,Apple SD Gothic Neo,Segoe UI,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;background:linear-gradient(140deg,#efe3d5,#f8f2e8 45%,#eadacb)}:root{--background: #f5efe5;--panel: #fffdf9;--text-primary: #1f1712;--text-secondary: #5a4b42;--line: #d8c8ba;--accent: #c2512b;--accent-strong: #7f2d14}#root{min-height:100vh}.page{position:relative;min-height:100vh;display:grid;place-items:center;padding:24px;overflow-x:hidden;overflow-y:auto}.profile-card{position:relative;z-index:2;width:min(100%,540px);background:var(--panel);border:1px solid var(--line);border-radius:24px;padding:32px;box-shadow:0 20px 60px #291a1026}.heading-group{margin-bottom:24px}.top-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.eyebrow{margin:0;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:700}.language-switcher{display:inline-flex;gap:6px;border:1px solid #ebd8c9;border-radius:999px;padding:4px;background:#fff7ef}.language-button{border:0;background:transparent;color:#7d5f50;border-radius:999px;padding:5px 10px;font-size:.76rem;font-weight:700;cursor:pointer}.language-button.active{background:#fff;color:var(--accent-strong);box-shadow:0 3px 8px #3621151f}h1{margin:6px 0 10px;font-size:clamp(1.6rem,4vw,2rem);line-height:1.2;color:var(--text-primary)}.promo-banner{margin-bottom:18px;border:1px solid #f0c8b5;border-radius:18px;background:linear-gradient(140deg,#fff3e6,#ffe4d6 45%,#ffd7c4);padding:14px;box-shadow:0 12px 26px #9d4f2d29}.promo-badge{display:inline-block;border-radius:999px;padding:4px 8px;background:#7f2d14;color:#fff;font-size:.72rem;font-weight:700;margin-bottom:8px}.promo-banner h2{margin:0 0 6px;font-size:1.05rem;color:#4e200f}.promo-banner p{margin:0;color:#6a4333;font-size:.86rem}.promo-footer{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.promo-price-label{display:block;color:#8e4b31;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.promo-footer strong{display:block;color:#3a1608;font-size:1.5rem;line-height:1.1}.promo-period{display:block;color:#7a4f3e;font-size:.74rem}.promo-cta{border-radius:999px;padding:9px 14px;border:1px solid #9e3d1f;background:#a93d1a;color:#fff;text-decoration:none;font-size:.78rem;font-weight:700;white-space:nowrap}.promo-cta:hover{background:#8a2f14}.subtext{margin:0;color:var(--text-secondary);font-size:.95rem}.gender-field{margin-bottom:18px}.gender-toggle{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.gender-option{border:1px solid var(--line);background:#fff;color:var(--text-primary);border-radius:12px;padding:10px 12px;font-size:.95rem;font-weight:700;cursor:pointer}.gender-option.active{border-color:var(--accent);background:#fff3e8;color:var(--accent-strong)}.gender-option.simple{padding:0;min-height:42px;display:grid;place-items:center}.gender-option.simple input{position:absolute;opacity:0;pointer-events:none}.gender-option.simple span{font-size:.9rem;letter-spacing:.02em}.base-guide{margin:8px 0 0;color:var(--text-secondary);font-size:.82rem}.photo-field{margin-bottom:20px}.photo-slot-bar,.photo-slot-optional-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.photo-slot-tab{border:1px solid #dcc5b2;border-radius:999px;background:#fff7ef;color:#6f4f40;padding:7px 12px;font-size:.78rem;font-weight:700;cursor:pointer}.photo-slot-tab.active{border-color:var(--accent);background:#ffe8db;color:#8a2f14}.photo-slot-tab.optional{border-style:dashed}.photo-slot-tab.small{font-size:.74rem;padding:6px 10px}.photo-rich-hint{margin:0 0 10px;color:#7a5d4e;font-size:.79rem;line-height:1.4}.section-label{display:block;font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.photo-dropzone{display:grid;place-items:center;border:2px dashed #cda98f;border-radius:18px;background:#fff8f2;min-height:220px;padding:16px;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.photo-dropzone:hover{border-color:var(--accent);transform:translateY(-1px)}.photo-dropzone.is-dragging{border-color:var(--accent);background:#fff3e8;transform:translateY(-1px);box-shadow:inset 0 0 0 2px #c2512b26}.editor-root{width:100%;position:relative}.editor-frame{width:100%;aspect-ratio:3 / 4;border-radius:12px;overflow:hidden;background:#f3e4d8;position:relative;touch-action:none;cursor:grab}.editor-frame:active{cursor:grabbing}.editor-image{width:100%;height:100%;object-fit:cover;transform-origin:center center;-webkit-user-select:none;user-select:none;pointer-events:none}.editor-hint{margin:8px 0 0;font-size:.78rem;color:#7a5d4e;text-align:center}.photo-preview{width:100%;max-height:300px;object-fit:cover;border-radius:12px}.preview-wrap{position:relative;width:100%}.photo-delete-button{position:absolute;top:10px;right:10px;width:32px;height:32px;border:0;border-radius:999px;background:#26160ebf;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;opacity:0;transform:translateY(-3px);transition:opacity .2s ease,transform .2s ease}.preview-wrap:hover .photo-delete-button{opacity:1;transform:translateY(0)}.photo-delete-button.fixed{opacity:1;transform:none}.placeholder-content{display:grid;gap:8px;text-align:center}.placeholder-title{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.placeholder-hint{font-size:.86rem;color:var(--text-secondary)}input[type=file]{display:none}.file-name{margin:10px 0 0;font-size:.86rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.file-likelihood{display:inline-flex;align-items:center;gap:6px}.file-likelihood-value{color:var(--text-primary);font-weight:700}.input-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:22px}.input-field input{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-size:1rem;background:#fff;color:var(--text-primary)}.input-field input:focus{outline:2px solid rgba(194,81,43,.3);border-color:var(--accent)}.submit-button{width:100%;border:0;border-radius:14px;padding:14px 18px;background:linear-gradient(135deg,#d66e44,#b44621);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.submit-button:disabled{cursor:wait;opacity:.7;transform:none;box-shadow:none}.submit-button:hover{transform:translateY(-2px);box-shadow:0 12px 26px #9b371859}.error-message{margin:12px 0 0;color:#a1280a;font-size:.9rem;font-weight:600}.report-section{margin-top:16px;border-top:1px solid var(--line);padding-top:16px}.report-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.report-section h2{margin:0;font-size:1.05rem;color:var(--text-primary)}.tone-chip{border-radius:999px;padding:6px 10px;background:#ffe9da;color:#8a3418;font-size:.8rem;font-weight:700}.report-overview{margin:0 0 12px;white-space:pre-wrap;color:var(--text-secondary);font-size:.95rem}.likelihood-chip{border-radius:999px;padding:5px 10px;font-size:.78rem;font-weight:700}.likelihood-low{background:#e9f7ee;color:#256b3f}.likelihood-medium{background:#fff4de;color:#9b5a00}.likelihood-high{background:#ffe5df;color:#9b2c1d}.likelihood-pending{background:#ece9e4;color:#5f584f}.loading-spinner{width:16px;height:16px;border-radius:999px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.report-tabs{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}.report-tab-button{border:1px solid #e5d2c2;background:#fffaf5;color:#6d5142;border-radius:999px;padding:6px 12px;font-size:.82rem;font-weight:700;cursor:pointer}.report-tab-button.active{border-color:var(--accent);background:#ffece0;color:#8a3418}.report-carousel{max-height:74vh;overflow-y:auto;padding-right:4px;scroll-snap-type:y mandatory;scroll-padding-top:64px}.stacked-titles{position:sticky;top:8px;z-index:12;display:grid;gap:6px;margin-bottom:10px}.stack-chip{width:fit-content;border:1px solid #efdccf;border-radius:10px;padding:5px 10px;background:#fffdf9f5;color:#7f2d14;font-size:.8rem;font-weight:700;box-shadow:0 6px 14px #5734221a}.stack-chip-0{margin-left:0}.stack-chip-1{margin-left:8px}.stack-chip-2{margin-left:16px}.stack-chip-3{margin-left:24px}.stack-chip-4{margin-left:32px}.stack-chip-5{margin-left:40px}.stack-chip-6{margin-left:48px}.stack-chip-7{margin-left:56px}.stack-chip-8{margin-left:64px}.stack-chip-9{margin-left:72px}.slide-title{position:sticky;top:8px;background:#fffdf9;border:1px solid #f1e3d8;border-radius:10px;padding:6px 10px;z-index:5}.report-card{border:1px solid #eadbce;border-radius:14px;padding:12px;background:#fff;margin-bottom:10px}.report-slide{min-height:54vh;scroll-snap-align:start}.report-card h3{margin:0 0 10px;font-size:.96rem;color:var(--text-primary)}.report-card ul{margin:0;padding-left:18px;display:grid;gap:6px}.report-card li{color:var(--text-secondary);font-size:.9rem}.tone-line{margin:0 0 8px;font-size:.88rem;font-weight:700;color:#8a3418}.chip-wrap{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 10px}.color-chip{padding:4px 9px;border-radius:999px;background:#f4ece4;color:#5f4739;font-size:.8rem;font-weight:600}.outfit-grid{display:grid;gap:8px}.outfit-item{border:1px solid #efe2d7;border-radius:10px;padding:10px;background:#fffcf8}.outfit-item h4{margin:0 0 4px;font-size:.88rem;color:var(--text-primary)}.outfit-item p{margin:0 0 4px;font-size:.86rem;color:var(--text-secondary)}.outfit-item span{font-size:.82rem;color:#8a5b48}.hair-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.hair-card{border:1px solid #efe2d7;border-radius:12px;overflow:hidden;background:#fffdf9}.hair-card img{width:100%;height:120px;object-fit:cover;display:block}.hair-card h4{margin:8px 8px 4px;font-size:.86rem;color:var(--text-primary)}.hair-card p{margin:0 8px 10px;font-size:.82rem;color:var(--text-secondary)}.bg-orb{position:absolute;border-radius:50%;filter:blur(4px);z-index:1}.bg-orb-left{width:320px;height:320px;left:-80px;top:-80px;background:radial-gradient(circle,#e6905780,#e6905700)}.bg-orb-right{width:360px;height:360px;right:-100px;bottom:-120px;background:radial-gradient(circle,#d2583159,#d2583100)}@media(max-width:640px){.page{padding:16px}.profile-card{padding:22px;border-radius:18px}.photo-dropzone{min-height:180px}.top-controls{align-items:flex-start;flex-direction:column}.promo-footer{flex-direction:column;align-items:flex-start}.promo-cta{width:100%;text-align:center}.input-grid{grid-template-columns:1fr}.report-carousel{max-height:70vh}.report-slide{min-height:48vh}.stacked-titles{gap:4px}.stack-chip{font-size:.76rem}.hair-grid{grid-template-columns:1fr}}
