*,:before,:after{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{min-height:100svh}.page{background:#faf9fb;flex-direction:column;min-height:100svh;display:flex}.header{z-index:10;background:#fff;border-bottom:1px solid #ede9f4;align-items:center;gap:16px;padding:20px 32px;display:flex;position:sticky;top:0}.logo{color:#2d1b4e;letter-spacing:-.5px;align-items:center;gap:8px;font-size:21px;display:flex}.logo-icon{color:#aa3bff;font-size:18px}.logo strong{font-weight:700}.tagline{color:#9b8aaa;border-left:1px solid #e0d8ed;margin:0;padding-left:16px;font-size:13px}.back-btn{color:#7a6890;cursor:pointer;background:0 0;border:1px solid #d8cee8;border-radius:8px;margin-left:auto;padding:7px 14px;font-size:14px;transition:background .2s,color .2s}.back-btn:hover{color:#aa3bff;background:#f5f0ff}.main{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:32px;padding:48px 20px;display:flex}.main.main-result{justify-content:flex-start;padding:32px 20px 48px}.footer{text-align:center;background:#fff;border-top:1px solid #ede9f4;padding:18px 32px}.footer p{color:#b0a0c0;margin:0;font-size:13px}.card{background:#fff;border:1px solid #ede9f4;border-radius:20px;flex-direction:column;gap:24px;width:100%;max-width:480px;padding:36px 32px;display:flex;box-shadow:0 4px 24px #643cb412}.card-title h1{color:#1a0a33;letter-spacing:-.5px;margin:0 0 8px;font-size:26px;font-weight:700}.card-title p{color:#7a6890;margin:0;font-size:15px;line-height:1.5}.upload-zone{cursor:pointer;background:#faf8fd;border:2px dashed #d8cee8;border-radius:16px;justify-content:center;align-items:center;min-height:220px;transition:border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.upload-zone:hover{background:#f5f0ff;border-color:#aa3bff}.upload-zone.dragging{background:#f0e8ff;border-color:#aa3bff}.upload-zone.has-image{cursor:default;border-style:solid;border-color:#d8cee8;min-height:280px}.upload-prompt{flex-direction:column;align-items:center;gap:10px;padding:24px;display:flex}.upload-icon{color:#c4aee0;width:52px;height:52px}.upload-icon svg{width:100%;height:100%}.upload-main{color:#5a4070;margin:0;font-size:15px;font-weight:500}.upload-sub{color:#b0a0c0;margin:0;font-size:13px}.preview-wrap{width:100%;position:relative}.preview-img{object-fit:cover;border-radius:14px;width:100%;height:280px;display:block}.change-btn{color:#5a4070;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffe6;border:1px solid #d8cee8;border-radius:8px;padding:5px 12px;font-size:13px;transition:background .2s;position:absolute;top:10px;right:10px}.change-btn:hover{background:#fff}.file-input{display:none}.analyze-btn{letter-spacing:.2px;cursor:pointer;color:#fff;background:linear-gradient(135deg,#aa3bff 0%,#7b2be0 100%);border:none;border-radius:12px;width:100%;padding:15px;font-size:17px;font-weight:600;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 14px #aa3bff59}.analyze-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #aa3bff73}.analyze-btn:active:not(:disabled){transform:translateY(0)}.analyze-btn:disabled{color:#b0a0c0;box-shadow:none;cursor:not-allowed;background:#e8e0f0}.features{flex-wrap:wrap;justify-content:center;gap:10px;max-width:480px;margin:0;padding:0;list-style:none;display:flex}.features li{color:#5a4070;background:#fff;border:1px solid #ede9f4;border-radius:100px;align-items:center;gap:7px;padding:8px 16px;font-size:13px;display:flex}.feat-icon{font-size:15px}.loading-wrap{flex-direction:column;align-items:center;gap:16px;padding:80px 20px;display:flex}.spinner{border:4px solid #ede9f4;border-top-color:#aa3bff;border-radius:50%;width:52px;height:52px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{color:#1a0a33;margin:0;font-size:20px;font-weight:600}.loading-sub{color:#9b8aaa;margin:0;font-size:15px}.tint-photo{line-height:0;position:relative;overflow:hidden}.tint-photo img{object-fit:cover;width:100%;height:100%;display:block}.tint-layer{mix-blend-mode:soft-light;pointer-events:none;transition:background .35s,opacity .35s;position:absolute;inset:0}.result-wrap{flex-direction:column;gap:16px;width:100%;max-width:600px;display:flex}.res-card{background:#fff;border:1px solid #ede9f4;border-radius:18px;padding:24px;box-shadow:0 2px 16px #643cb40f}.res-section-title{color:#1a0a33;letter-spacing:-.2px;margin:0 0 6px;font-size:15px;font-weight:700}.res-section-sub{color:#9b8aaa;margin:0 0 16px;font-size:13px}.type-badge{border:2px solid #fff;border-radius:100px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-block}.type-badge.warm{color:#c06000;background:#fff3e0}.type-badge.cool{color:#7b2be0;background:#ede8ff}.res-hero{align-items:flex-start;gap:20px;display:flex}.rh-photo-col{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;display:flex}.rh-photo{border-radius:16px;width:120px;height:120px}.rh-info{flex:1;min-width:0}.rh-eyebrow{color:#9b8aaa;margin:0 0 4px;font-size:12px}.rh-title{color:#1a0a33;letter-spacing:-.4px;margin:0 0 12px;font-size:22px;font-weight:700}.score-row{align-items:center;gap:8px;margin-bottom:12px;display:flex}.score-label{color:#9b8aaa;white-space:nowrap;font-size:12px}.score-bar-wrap{background:#ede9f4;border-radius:100px;flex:1;height:6px;overflow:hidden}.score-bar{background:linear-gradient(90deg,#aa3bff,#7b2be0);border-radius:100px;height:100%;transition:width .8s}.score-num{color:#aa3bff;white-space:nowrap;font-size:13px;font-weight:700}.rh-desc{color:#6a5880;margin:0 0 12px;font-size:14px;line-height:1.6}.traits-row{flex-wrap:wrap;gap:6px;display:flex}.trait-chip{color:#7b2be0;background:#f0e8ff;border-radius:100px;padding:3px 10px;font-size:12px;font-weight:500}.analysis-list{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.an-row{align-items:center;gap:10px;display:flex}.an-icon{text-align:center;width:22px;font-size:16px}.an-label{color:#5a4070;flex-shrink:0;width:52px;font-size:13px}.an-bar-wrap{background:#ede9f4;border-radius:100px;flex:1;height:8px;overflow:hidden}.an-bar{border-radius:100px;height:100%;transition:width .8s}.an-bar[data-tone=warm]{background:linear-gradient(90deg,#ffb347,#ff7c00)}.an-bar[data-tone=cool]{background:linear-gradient(90deg,#aa3bff,#4169e1)}.an-num{color:#9b8aaa;text-align:right;width:36px;font-size:12px}.kw-row{flex-wrap:wrap;gap:6px;display:flex}.kw-chip{color:#5a4070;letter-spacing:.3px;background:#f5f5f5;border:1px solid #e8e0f0;border-radius:100px;padding:4px 12px;font-size:12px;font-weight:500}.tone-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.tone-item{border:2px solid #ede9f4;border-radius:14px;transition:border-color .2s,box-shadow .2s;overflow:hidden}.tone-item.is-mine{border-color:#aa3bff;box-shadow:0 0 0 3px #aa3bff26}.tone-photo{border-radius:0;width:100%;height:130px}.tone-label-wrap{background:#fff;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.mine-badge{color:#aa3bff;font-size:11px;font-weight:700}.tone-label{color:#3a2a50;font-size:13px;font-weight:500}.ip-wrap{flex-direction:column;gap:14px;display:flex}.ip-photo-box{border-radius:14px;position:relative;overflow:hidden}.ip-photo{border-radius:0;width:100%;height:260px}.ip-active-tag,.ip-hint-tag{white-space:nowrap;color:#3a2a50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffeb;border:1px solid #e0d8f0;border-radius:100px;align-items:center;gap:7px;padding:5px 14px;font-size:13px;font-weight:500;display:flex;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.ip-hint-tag{color:#9b8aaa}.ip-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.ip-swatch-grid{grid-template-columns:repeat(6,1fr);gap:10px;display:grid}.ip-swatch{aspect-ratio:1;cursor:pointer;border:2px solid #0000;border-radius:12px;flex-direction:column;padding:0;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;position:relative;overflow:visible}.ip-swatch:hover{transform:scale(1.08);box-shadow:0 4px 12px #0000002e}.ip-swatch.on{border-color:#fff;transform:scale(1.08);box-shadow:0 0 0 3px #aa3bff,0 4px 14px #aa3bff59}.ip-swatch-lbl{color:#fff;white-space:nowrap;pointer-events:none;opacity:0;background:#1a0a33;border-radius:6px;padding:3px 8px;font-size:11px;transition:opacity .15s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.ip-swatch:hover .ip-swatch-lbl,.ip-swatch.on .ip-swatch-lbl{opacity:1}.two-col{grid-template-columns:1fr auto 1fr;gap:20px;display:grid}.two-col-divider{background:#ede9f4;width:1px}.cg-row{flex-direction:column;gap:10px;margin-top:12px;display:flex}.cg-item{align-items:center;gap:10px;display:flex}.cg-swatch{border:1px solid #0000000f;border-radius:8px;flex-shrink:0;width:32px;height:32px;box-shadow:0 2px 6px #0000001a}.cg-swatch.avoid{opacity:.75}.cg-lbl{color:#3a2a50;font-size:13px}.mk-list{flex-direction:column;gap:14px;margin-top:12px;display:flex}.mk-item{align-items:flex-start;gap:14px;display:flex}.mk-swatch{border-radius:50%;flex-shrink:0;width:44px;height:44px;box-shadow:0 2px 8px #00000026}.mk-body{flex:1}.mk-header{align-items:center;gap:8px;margin-bottom:3px;display:flex}.mk-part{color:#9b8aaa;font-size:12px;font-weight:600}.mk-label{color:#1a0a33;font-size:14px;font-weight:600}.mk-tip{color:#7a6890;margin:0;font-size:13px;line-height:1.5}.fa-grid{grid-template-columns:repeat(6,1fr);gap:10px;margin-top:12px;display:grid}.fa-item{flex-direction:column;align-items:center;gap:6px;display:flex}.fa-swatch{aspect-ratio:1;border:1px solid #0000000f;border-radius:12px;width:100%;box-shadow:0 2px 6px #0000001a}.fa-lbl{color:#7a6890;text-align:center;font-size:11px;line-height:1.3}.tip-celeb-card{flex-direction:column;gap:16px;display:flex}.tip-box{background:#f5f0ff;border:1px solid #e0d8f4;border-radius:12px;align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.tip-icon{flex-shrink:0;margin-top:1px;font-size:18px}.tip-box p{color:#5a4070;margin:0;font-size:14px;line-height:1.6}.celeb-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.celeb-label{color:#9b8aaa;font-size:13px}.celeb-chip{color:#3a2a50;background:#fff;border:1px solid #ede9f4;border-radius:100px;padding:4px 12px;font-size:13px;font-weight:500}@media (width<=520px){.header{padding:14px 16px}.tagline{display:none}.card{border-radius:16px;padding:24px 18px}.card-title h1{font-size:22px}.main.main-result{padding:20px 12px 40px}.result-wrap{gap:12px}.res-card{border-radius:14px;padding:18px 16px}.res-hero{flex-direction:column}.rh-photo{border-radius:12px;width:100%;height:200px}.rh-photo-col{flex-direction:row;align-items:center;width:100%}.tone-grid{grid-template-columns:1fr 1fr;gap:8px}.tone-photo{height:100px}.ip-photo{height:200px}.ip-swatch-grid{grid-template-columns:repeat(6,1fr);gap:8px}.two-col{grid-template-columns:1fr;gap:16px}.two-col-divider{width:100%;height:1px}.fa-grid{grid-template-columns:repeat(3,1fr)}}
