.app{max-width:1140px;margin:0 auto;padding:24px 16px 80px}.header{text-align:center;margin-bottom:32px}.header-badge{display:inline-block;padding:4px 12px;border-radius:20px;background:#7c5cfc26;border:1px solid rgba(124,92,252,.3);color:var(--accent);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}.header h1{font-size:clamp(28px,6vw,40px);font-weight:800;letter-spacing:-.02em;line-height:1.1}.header h1 span{background:linear-gradient(135deg,var(--accent),var(--cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header p{color:var(--text-muted);font-size:14px;margin-top:8px;max-width:400px;margin-inline:auto}.top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.moggs-balance{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;font-size:14px;font-weight:600}.moggs-balance .count{color:var(--accent);font-size:16px}.buy-btn{padding:8px 16px;background:linear-gradient(135deg,var(--accent),#5b3fd4);color:#fff;border-radius:100px;font-size:13px;font-weight:600;transition:transform .15s,box-shadow .15s}.buy-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow)}.tabs{display:flex;gap:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:4px;margin-bottom:24px}.tab{flex:1;padding:12px;border-radius:calc(var(--radius) - 4px);font-size:14px;font-weight:600;color:var(--text-muted);transition:all .2s}.tab.active{background:#7c5cfc33;color:var(--text);box-shadow:0 0 0 1px #7c5cfc4d}.tab:hover:not(.active){color:var(--text);background:var(--bg-card-hover)}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-card);position:relative;overflow:hidden}.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent);background:#7c5cfc0d}.upload-zone.has-image{padding:0;border-style:solid}.upload-zone img{width:100%;max-height:400px;object-fit:contain;border-radius:calc(var(--radius) - 2px)}.upload-icon{font-size:48px;margin-bottom:12px;opacity:.6}.upload-zone h3{font-size:16px;font-weight:600;margin-bottom:4px}.upload-zone p{font-size:13px;color:var(--text-muted)}.upload-zone input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.battle-uploads{display:grid;grid-template-columns:1fr 1fr;gap:12px}.battle-uploads .upload-zone{padding:32px 16px}.battle-uploads .upload-zone.has-image{padding:0}.battle-vs{display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:var(--accent);margin:12px 0}.analyze-btn{width:100%;margin-top:16px;padding:16px;background:linear-gradient(135deg,var(--accent),#5b3fd4);color:#fff;border-radius:var(--radius);font-size:16px;font-weight:700;transition:all .2s}.analyze-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.analyze-btn:disabled{opacity:.5;cursor:not-allowed}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#07070dd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;gap:20px}.loader-ring{width:56px;height:56px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:15px;color:var(--text-muted)}.loading-steps{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-muted)}.loading-steps .done{color:var(--green)}.results{animation:fadeUp .4s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.score-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center;margin-bottom:16px;position:relative;overflow:hidden}.score-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 0%,var(--rank-glow, var(--accent-glow)),transparent 70%);pointer-events:none}.score-rank{font-size:14px;font-weight:700;letter-spacing:.1em;color:var(--rank-color, var(--accent));margin-bottom:4px}.score-value{font-size:56px;font-weight:800;line-height:1;letter-spacing:-.03em}.score-value small{font-size:24px;color:var(--text-muted);font-weight:500}.score-label{font-size:13px;color:var(--text-muted);margin-top:4px}.phi-badge{display:inline-block;margin-top:12px;padding:4px 12px;background:#22d3ee1a;border:1px solid rgba(34,211,238,.2);border-radius:100px;font-size:12px;color:var(--cyan)}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}.metric-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px}.metric-name{font-size:12px;color:var(--text-muted);margin-bottom:4px}.metric-score{font-size:20px;font-weight:700}.metric-bar{height:4px;background:#ffffff0f;border-radius:2px;margin-top:6px;overflow:hidden}.metric-bar-fill{height:100%;border-radius:2px;transition:width .6s ease}.verdict-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.verdict-card h3{font-size:14px;font-weight:600;margin-bottom:8px;color:var(--accent)}.verdict-card p{font-size:14px;color:var(--text-muted);line-height:1.6}.advice-section{margin-bottom:12px}.advice-section h4{font-size:13px;font-weight:600;margin-bottom:8px}.advice-tags{display:flex;flex-wrap:wrap;gap:6px}.advice-tag{padding:4px 10px;border-radius:100px;font-size:12px;font-weight:500}.advice-tag.strength{background:#22c55e1f;color:var(--green);border:1px solid rgba(34,197,94,.2)}.advice-tag.weakness{background:#ef44441f;color:var(--red);border:1px solid rgba(239,68,68,.2)}.tips-list{list-style:none;display:flex;flex-direction:column;gap:8px}.tips-list li{font-size:13px;color:var(--text-muted);padding-left:16px;position:relative}.tips-list li:before{content:"→";position:absolute;left:0;color:var(--accent)}.reset-btn{width:100%;padding:14px;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:14px;font-weight:500;transition:all .2s}.reset-btn:hover{border-color:var(--accent);color:var(--text)}.battle-header{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;margin-bottom:20px}.battle-face{text-align:center;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.battle-face.winner{border-color:var(--green);box-shadow:0 0 20px #22c55e26}.battle-face .label{font-size:12px;color:var(--text-muted);margin-bottom:4px}.battle-face .score{font-size:32px;font-weight:800}.battle-face .rank{font-size:13px;font-weight:600;margin-top:2px}.battle-center{font-size:24px;font-weight:800;color:var(--accent)}.comparison-row{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.comparison-row .name{text-align:center;color:var(--text-muted);font-size:12px}.comparison-row .score{font-weight:700}.comparison-row .score.win{color:var(--green)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:16px}@media(min-width:500px){.modal-overlay{align-items:center}}.modal{background:#111118;border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;padding:24px;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal h2{font-size:20px;font-weight:700;margin-bottom:4px}.modal-sub{font-size:13px;color:var(--text-muted);margin-bottom:20px}.package-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.package-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.package-item:hover,.package-item.selected{border-color:var(--accent);background:#7c5cfc14}.package-item .left{display:flex;align-items:center;gap:10px}.package-badge{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.05em}.package-badge.sale{background:#f9731633;color:var(--orange)}.package-badge.meme{background:#7c5cfc33;color:var(--accent)}.package-price{font-size:16px;font-weight:700}.modal-pay-btn{width:100%;padding:16px;background:linear-gradient(135deg,var(--accent),#5b3fd4);color:#fff;border-radius:var(--radius-sm);font-size:16px;font-weight:700}.modal-close{width:100%;margin-top:8px;padding:12px;color:var(--text-muted);font-size:14px}.modal-note{font-size:11px;color:var(--text-muted);text-align:center;margin-top:12px}.error-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#ef4444e6;color:#fff;padding:12px 24px;border-radius:100px;font-size:14px;font-weight:500;z-index:300;animation:fadeUp .3s ease}.footer-note{text-align:center;margin-top:32px;font-size:12px;color:var(--text-muted)}.top-bar-actions{display:flex;gap:8px;align-items:center}.history-btn{padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;font-size:13px;font-weight:600;color:var(--text-muted);transition:all .15s}.history-btn:hover{border-color:var(--accent);color:var(--text)}.profile-paragraph{font-size:14px;color:var(--text-muted);line-height:1.7;margin-bottom:12px}.profile-paragraph:last-child{margin-bottom:0}.training-btn{width:100%;margin-bottom:12px;padding:16px;background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border-radius:var(--radius);font-size:15px;font-weight:700;transition:all .2s}.training-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #f9731659}.modal-wide{max-width:520px;max-height:85vh;overflow-y:auto}.training-preview{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.training-preview-item{padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;color:var(--text-muted)}.training-weeks{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.training-week h4{font-size:14px;font-weight:600;color:var(--accent);margin-bottom:8px}.modal-error{color:var(--red);font-size:13px;margin-bottom:12px;text-align:center}.history-panel h3{font-size:20px;font-weight:700;margin-bottom:16px}.history-empty{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:14px}.history-trend{text-align:center;padding:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:16px;font-size:14px}.trend-up{color:var(--green);font-weight:700}.trend-down{color:var(--red);font-weight:700}.history-chart{display:flex;align-items:flex-end;justify-content:center;gap:8px;height:120px;margin-bottom:20px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.history-bar-wrap{display:flex;flex-direction:column;align-items:center;flex:1;max-width:40px;height:100%;justify-content:flex-end}.history-bar{width:100%;min-height:4px;border-radius:4px 4px 0 0;transition:height .4s ease}.history-bar-label{font-size:11px;color:var(--text-muted);margin-top:4px}.history-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.history-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm)}.history-item-left{display:flex;flex-direction:column;gap:2px}.history-type{font-size:14px;font-weight:600}.history-date{font-size:12px;color:var(--text-muted)}.history-item-right{text-align:right}.history-score{font-size:18px;font-weight:800;display:block}.history-rank{font-size:12px;font-weight:600}.footer-offer{text-align:center;margin-top:8px}.offer-link{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;text-decoration:underline;padding:0}.offer-link:hover{color:var(--text-secondary)}.offer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:1000;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:20px}.offer-container{background:#12121a;border:1px solid rgba(255,255,255,.1);border-radius:16px;max-width:760px;width:100%;padding:40px;position:relative;margin:auto}.offer-close{position:sticky;top:0;float:right;background:#ffffff14;border:none;color:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:13px;margin-bottom:16px}.offer-close:hover{background:#ffffff26}.offer-content h1{font-size:24px;font-weight:800;margin-bottom:4px}.offer-date{color:var(--text-muted);font-size:13px;margin-bottom:24px}.offer-content h2{font-size:16px;font-weight:700;margin:24px 0 8px;color:#a78bfa}.offer-content p,.offer-content li{font-size:14px;line-height:1.7;color:var(--text-secondary);margin-bottom:8px}.offer-content ul{padding-left:20px}.results-dashboard-wrap{width:100%;max-width:1100px;margin:0 auto}.results-actions-top{display:flex;justify-content:flex-end;margin-bottom:12px}.export-btn{padding:10px 20px;background:linear-gradient(135deg,#a855f7,#7c3aed);color:#fff;border-radius:100px;font-size:13px;font-weight:600;transition:all .2s}.export-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #a855f766}.export-btn:disabled{opacity:.6;cursor:wait}.report-card{background:#0b0b0e;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:24px;color:#f0f0f5}.report-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.06)}.report-title{font-size:22px;font-weight:800;letter-spacing:.06em;color:#fff}.report-subtitle{font-size:11px;color:#8888a0;letter-spacing:.12em;margin-top:4px}.report-brand{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.1em;color:#a855f7}.brand-logo{font-size:16px}.report-grid{display:grid;grid-template-columns:240px 1fr 280px;gap:20px;margin-bottom:20px}.report-col{display:flex;flex-direction:column;gap:16px}.face-scan-photo{border-radius:8px;overflow:hidden;border:1px solid rgba(168,85,247,.25);background:#111}.face-scan-img{width:100%;display:block;object-fit:cover;max-height:320px}.overall-score-block{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:16px;text-align:center}.overall-label{font-size:10px;font-weight:700;letter-spacing:.1em;color:#8888a0;margin-bottom:8px}.overall-value{font-size:42px;font-weight:800;color:#22d3ee;line-height:1}.overall-value span{font-size:18px;color:#8888a0;font-weight:500}.rank-badge{display:inline-block;padding:4px 16px;border-radius:6px;font-size:14px;font-weight:800;letter-spacing:.1em;margin:8px auto}.star-rating{display:flex;justify-content:center;gap:2px;margin-bottom:10px}.star{color:#a855f7;font-size:16px}.overall-summary{font-size:11px;color:#8888a0;line-height:1.5;text-align:left}.report-section{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:14px}.report-section h3{font-size:10px;font-weight:700;letter-spacing:.08em;color:#8888a0;margin-bottom:12px}.report-section h3 span{color:#666}.trait-list{display:flex;flex-direction:column;gap:6px}.trait-row{display:grid;grid-template-columns:110px 1fr 36px;align-items:center;gap:8px;font-size:12px}.trait-name{color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trait-bar-wrap{height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.trait-bar{height:100%;background:linear-gradient(90deg,#7c3aed,#a855f7);border-radius:3px;transition:width .5s ease}.trait-score{font-weight:700;color:#a855f7;text-align:right;font-size:12px}.proportion-list{display:flex;flex-direction:column;gap:8px}.proportion-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.proportion-info{display:flex;flex-direction:column;gap:1px;min-width:0}.proportion-name{font-size:11px;color:#aaa}.proportion-value{font-size:13px;font-weight:700;color:#fff}.proportion-tag{font-size:9px;font-weight:700;padding:2px 8px;border:1px solid;border-radius:4px;white-space:nowrap;letter-spacing:.04em}.character-text{font-size:11px;color:#999;line-height:1.6;margin-bottom:10px}.character-traits{display:flex;flex-direction:column;gap:5px}.char-trait-row{display:grid;grid-template-columns:100px 1fr 32px;align-items:center;gap:6px;font-size:11px;color:#bbb}.radar-chart{width:100%;max-width:200px;margin:0 auto;display:block}.radar-label{font-size:7px;fill:#8888a0;font-family:Inter,sans-serif}.report-bottom{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}.bottom-card{min-height:160px}.age-ring-wrap{display:flex;justify-content:center;margin:8px 0}.age-ring{width:90px;height:90px}.age-ring-text{font-size:18px;font-weight:800;fill:#a855f7;font-family:Inter,sans-serif}.age-text{font-size:11px;color:#888;line-height:1.5;text-align:center}.bullet-list{list-style:none;display:flex;flex-direction:column;gap:8px}.bullet-list li{font-size:11px;color:#aaa;line-height:1.4;display:flex;gap:8px;align-items:flex-start}.bullet-icon{flex-shrink:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:9px}.check-list .bullet-icon{background:#22c55e26;color:#22c55e}.bolt-list .bullet-icon{background:#a855f726;color:#a855f7}.haircuts-section{margin-top:16px}.haircuts-shape-tag{margin-left:10px;font-size:10px;background:#a855f71f;color:#c084fc;padding:2px 10px;border-radius:4px;font-weight:600;letter-spacing:.04em;text-transform:none;border:1px solid rgba(168,85,247,.25)}.haircuts-goal{font-size:12px;color:#888;margin-bottom:12px;font-style:italic}.haircuts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}@media(min-width:600px){.haircuts-grid{grid-template-columns:repeat(4,1fr)}}.haircut-card{background:#a855f712;border:1px solid rgba(168,85,247,.18);border-radius:8px;padding:12px;transition:border-color .2s}.haircut-card:hover{border-color:#a855f773}.haircut-name{font-size:12px;font-weight:700;color:#c084fc;margin-bottom:4px}.haircut-desc{font-size:11px;color:#888;line-height:1.4}.haircuts-avoid{display:flex;gap:8px;align-items:flex-start;font-size:11px;color:#888;background:#ef44440f;border:1px solid rgba(239,68,68,.15);border-radius:6px;padding:8px 12px}.avoid-icon{color:#ef4444;font-size:12px;font-weight:700;flex-shrink:0}.report-footer{display:flex;justify-content:space-between;font-size:10px;color:#555;letter-spacing:.06em;padding-top:12px;border-top:1px solid rgba(255,255,255,.04);margin-top:16px}@media(max-width:900px){.report-grid,.report-bottom{grid-template-columns:1fr}.trait-row{grid-template-columns:90px 1fr 32px}}@media(max-width:720px){.app{max-width:100%;padding:16px 12px 60px}.report-card{padding:16px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #07070d;--bg-card: rgba(255, 255, 255, .03);--bg-card-hover: rgba(255, 255, 255, .06);--border: rgba(255, 255, 255, .08);--text: #f0f0f5;--text-muted: #8888a0;--accent: #7c5cfc;--accent-glow: rgba(124, 92, 252, .35);--cyan: #22d3ee;--green: #22c55e;--red: #ef4444;--orange: #f97316;--radius: 16px;--radius-sm: 10px}html,body,#root{min-height:100vh}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(124,92,252,.15),transparent),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(34,211,238,.08),transparent);pointer-events:none;z-index:0}#root{position:relative;z-index:1}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}
