*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:system-ui,Segoe UI,Roboto,sans-serif}#root{width:100%}.page{background:#f8f7f5;flex-direction:column;align-items:center;min-height:100svh;padding:0 16px 60px;display:flex}.header{text-align:center;width:100%;max-width:480px;padding:48px 0 32px}.logo{justify-content:center;align-items:center;gap:10px;margin-bottom:10px;display:flex}.logo-mark{color:#fff;letter-spacing:.05em;background:#1a1a1a;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.logo-text{color:#1a1a1a;letter-spacing:-.3px;font-size:20px;font-weight:600}.tagline{color:#888;letter-spacing:.1px;margin:0;font-size:14px}.main{width:100%;max-width:480px}.card{background:#fff;border-radius:20px;flex-direction:column;padding:36px 32px;display:flex;box-shadow:0 2px 24px #0000000f}.section-label{letter-spacing:.12em;color:#c084fc;margin-bottom:8px;font-size:11px;font-weight:700}.section-title{color:#1a1a1a;letter-spacing:-.5px;margin:0 0 10px;font-size:24px;font-weight:700;line-height:1.3}.section-desc{color:#888;margin:0 0 32px;font-size:14px;line-height:1.6}.field-group{flex-direction:column;gap:8px;display:flex}.field-label{color:#444;letter-spacing:.1px;font-size:13px;font-weight:600}.photo-upload{cursor:pointer;background:#faf9f7;border:2px dashed #e0ddd9;border-radius:16px;justify-content:center;align-items:center;height:260px;margin-bottom:28px;transition:border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.photo-upload:hover,.photo-upload.dragging{background:#faf5ff;border-color:#c084fc}.photo-upload.has-photo{border-style:solid;border-color:#e0ddd9}.photo-placeholder{flex-direction:column;align-items:center;gap:10px;padding:32px;display:flex}.upload-icon{color:#c084fc;opacity:.7;width:48px;height:48px}.upload-icon svg{width:100%;height:100%}.upload-text{color:#555;text-align:center;margin:0;font-size:14px;font-weight:500}.upload-hint{color:#aaa;text-align:center;margin:0;font-size:12px}.photo-preview{object-fit:cover;width:100%;height:100%}.photo-overlay{opacity:0;background:#0006;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.photo-upload.has-photo:hover .photo-overlay{opacity:1}.photo-overlay-text{color:#fff;font-size:14px;font-weight:600}.row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px;display:grid}.input-wrap{align-items:center;display:flex;position:relative}.input{color:#1a1a1a;box-sizing:border-box;-moz-appearance:textfield;background:#faf9f7;border:1.5px solid #e8e5e0;border-radius:12px;outline:none;width:100%;padding:14px 44px 14px 16px;font-size:17px;font-weight:500;transition:border-color .2s,background .2s}.input::-webkit-inner-spin-button{-webkit-appearance:none}.input::-webkit-outer-spin-button{-webkit-appearance:none}.input:focus{background:#fff;border-color:#c084fc}.input::placeholder{color:#ccc;font-weight:400}.input-unit{color:#aaa;pointer-events:none;font-size:13px;font-weight:500;position:absolute;right:14px}.btn-submit{cursor:not-allowed;color:#bbb;letter-spacing:-.1px;background:#e8e5e0;border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:16px;font-size:16px;font-weight:600;transition:background .25s,color .25s,transform .1s;display:flex}.btn-submit svg{width:18px;height:18px}.btn-submit.active{color:#fff;cursor:pointer;background:#1a1a1a}.btn-submit.active:hover{background:#2d2d2d}.btn-submit.active:active{transform:scale(.98)}.error-banner{color:#b91c1c;background:#fff1f1;border:1px solid #fca5a5;border-radius:10px;margin-bottom:20px;padding:12px 16px;font-size:13px;line-height:1.5}.page-center{justify-content:center}.loading-box{flex-direction:column;align-items:center;gap:20px;padding:48px 32px;display:flex}.spinner{border:3px solid #e8e5e0;border-top-color:#c084fc;border-radius:50%;width:48px;height:48px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{color:#1a1a1a;letter-spacing:-.3px;margin:0;font-size:18px;font-weight:600}.loading-sub{color:#888;text-align:center;margin:0;font-size:14px;line-height:1.7}.result-main{flex-direction:column;gap:12px;padding-bottom:60px;display:flex}.profile-banner{background:#1a1a1a;border-radius:20px;align-items:center;gap:16px;margin-bottom:4px;padding:20px 24px;display:flex}.profile-thumb{object-fit:cover;border-radius:12px;flex-shrink:0;width:64px;height:64px}.profile-info{flex-direction:column;gap:8px;display:flex}.profile-stats{color:#fff;align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.divider{color:#555}.profile-tags{flex-wrap:wrap;gap:8px;display:flex}.tag{letter-spacing:.02em;border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.tag-body{color:#c084fc;background:#c084fc33}.tag-color{color:#d97706;background:#fbbf2433}.report-card{background:#fff;border-radius:16px;flex-direction:column;gap:14px;padding:24px;display:flex;box-shadow:0 1px 12px #0000000d}.card-header{align-items:center;gap:8px;display:flex}.card-icon{font-size:18px;line-height:1}.card-header h3{color:#1a1a1a;letter-spacing:-.2px;margin:0;font-size:16px;font-weight:700}.card-text{color:#555;margin:0;font-size:14px;line-height:1.7}.color-row{flex-direction:column;gap:10px;display:flex}.color-label{color:#888;letter-spacing:.04em;text-transform:uppercase;margin:0;font-size:12px;font-weight:600}.color-label.avoid{color:#f87171}.color-swatches{flex-wrap:wrap;gap:12px;display:flex}.swatch-item{flex-direction:column;align-items:center;gap:6px;display:flex}.swatch{border:1px solid #00000014;border-radius:10px;width:40px;height:40px}.swatch-avoid{position:relative;overflow:hidden}.swatch-avoid:after{content:"";background:repeating-linear-gradient(-45deg,#0000,#0000 4px,#ffffff59 4px 5px);position:absolute;inset:0}.swatch-name{color:#888;text-align:center;max-width:48px;font-size:11px;line-height:1.3}.style-list{flex-direction:column;gap:16px;display:flex}.style-item{background:#f8f7f5;border-radius:12px;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.style-name{color:#1a1a1a;margin:0;font-size:14px;font-weight:700}.style-desc{color:#666;margin:0;font-size:13px;line-height:1.6}.item-tags{flex-wrap:wrap;gap:8px;display:flex}.item-tag{color:#7c3aed;background:#f0eefb;border-radius:20px;padding:6px 12px;font-size:13px;font-weight:500}.item-tag-key{color:#15803d;background:#f0fdf4}.item-tag-avoid{color:#be123c;background:#fff1f2}.summary-card{background:#1a1a1a}.summary-card .card-header h3{color:#fff}.summary-card .card-icon{filter:none}.summary-text{color:#ccc;margin:0;font-size:14px;line-height:1.8}.btn-retry{color:#fff;cursor:pointer;background:#1a1a1a;margin-top:8px}.btn-retry:hover{background:#2d2d2d}@media (width<=520px){.card{border-radius:16px;padding:28px 20px}.section-title{font-size:20px}.photo-upload{height:220px}.report-card{padding:20px 16px}}
