:root{--bg-primary: #f8f7f4;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-elevated: #f3f2ef;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-muted: #8a8a8a;--female-color: #c2185b;--female-color-dim: rgba(194, 24, 91, .1);--male-color: #1565c0;--male-color-dim: rgba(21, 101, 192, .1);--accent-primary: #c2185b;--accent-primary-dim: rgba(194, 24, 91, .08);--accent-secondary: #1565c0;--accent-secondary-dim: rgba(21, 101, 192, .08);--accent-success: #2e7d32;--accent-success-dim: rgba(46, 125, 50, .1);--accent-warning: #f57c00;--accent-warning-dim: rgba(245, 124, 0, .1);--border-subtle: rgba(0, 0, 0, .06);--border-medium: rgba(0, 0, 0, .1);--font-display: "Playfair Display", Georgia, serif;--font-body: "Noto Sans KR", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.25, .46, .45, .94)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:100dvh;line-height:1.6;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;touch-action:manipulation}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(194,24,91,.03),transparent),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(21,101,192,.02),transparent);pointer-events:none;z-index:-1}body:after{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.015;pointer-events:none;z-index:-1}.app-container{max-width:600px;margin:0 auto;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:#ffffffe6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.back-btn{width:44px;height:44px;border-radius:var(--radius-full);background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal)}.back-btn:hover{background:var(--bg-card);border-color:var(--accent-primary);transform:translate(-2px)}.header-title{flex:1;font-family:var(--font-display);font-size:1.25rem;font-weight:500;letter-spacing:.02em}.title-accent{color:var(--accent-primary);font-weight:600}.header-badge{font-family:var(--font-mono);font-size:.65rem;font-weight:500;padding:4px 10px;background:var(--accent-secondary-dim);color:var(--accent-secondary);border-radius:var(--radius-full);letter-spacing:.1em}.main-content{flex:1;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xl);-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.section-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.step-indicator{font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--accent-primary);padding:6px 12px;background:var(--accent-primary-dim);border-radius:var(--radius-full);letter-spacing:.05em}.section-title{font-family:var(--font-display);font-size:1.5rem;font-weight:500;color:var(--text-primary)}.upload-area{position:relative;width:100%;aspect-ratio:1;max-width:320px;margin:0 auto var(--space-lg);border-radius:var(--radius-xl);background:var(--bg-card);border:2px dashed var(--border-medium);overflow:hidden;cursor:pointer;transition:all var(--transition-normal)}.upload-area:hover{border-color:var(--accent-primary);background:var(--bg-elevated)}.upload-area.has-image{border-style:solid;border-color:var(--accent-secondary)}.upload-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);color:var(--text-muted)}.upload-icon{width:80px;height:80px;border-radius:var(--radius-full);background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal)}.upload-area:hover .upload-icon{background:var(--accent-primary-dim);color:var(--accent-primary)}.upload-text{font-size:1rem;font-weight:500;color:var(--text-secondary)}.upload-hint{font-size:.85rem;color:var(--text-muted)}.preview-image,.face-canvas{width:100%;height:100%;object-fit:cover}.input-mode-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);background:var(--bg-card);padding:var(--space-xs);border-radius:var(--radius-lg)}.mode-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);font-family:var(--font-body);font-size:.9rem;cursor:pointer;transition:all var(--transition-normal)}.mode-tab:hover{color:var(--text-secondary);background:var(--bg-elevated)}.mode-tab.active{background:var(--accent-primary);color:#fff}.mode-tab svg{flex-shrink:0}.camera-area{position:relative;width:100%;aspect-ratio:4/3;max-width:100%;max-height:50vh;margin:0 auto var(--space-md);border-radius:var(--radius-lg);background:var(--bg-card);overflow:hidden}.camera-area video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.landmark-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;transform:scaleX(-1);opacity:.7}.silhouette-guide{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;z-index:5;transition:opacity .5s ease}.silhouette-guide.hidden{opacity:0}.silhouette-svg{width:60%;max-width:220px;height:auto;animation:silhouette-pulse 2s ease-in-out infinite}@keyframes silhouette-pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:.5;transform:scale(.98)}}.silhouette-hint{position:absolute;bottom:15%;font-size:.8rem;color:#fffc;background:#00000080;padding:6px 16px;border-radius:20px;text-shadow:0 1px 2px rgba(0,0,0,.5);animation:hint-fade 3s ease-in-out infinite}@keyframes hint-fade{0%,to{opacity:1}50%{opacity:.6}}.camera-area.face-detected .silhouette-guide{opacity:.2}.analyzing-overlay{position:absolute;inset:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.analyzing-text{color:var(--accent-primary);font-family:var(--font-mono);font-size:.9rem;margin-top:var(--space-md);animation:analyzing-pulse 1s ease-in-out infinite}@keyframes analyzing-pulse{0%,to{opacity:1}50%{opacity:.5}}.measurement-display{position:relative;padding:16px;margin:var(--space-sm) auto;background:linear-gradient(135deg,#14141ef2,#1e1e2df2);border:1px solid rgba(168,85,247,.3);border-radius:var(--radius-lg);box-shadow:0 0 20px #a855f726;max-width:500px}.measurement-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.measurement-item{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#a855f71a;border:1px solid rgba(168,85,247,.2);border-radius:var(--radius-md);transition:all .2s ease}.measurement-item:hover{background:#a855f733;border-color:#a855f766;transform:translateY(-2px)}.measurement-icon{font-size:1.2rem}.measurement-label{color:var(--text-secondary);font-size:.75rem;flex:1}.measurement-value{color:#22d3ee;font-weight:700;font-size:1rem;font-family:JetBrains Mono,monospace;text-shadow:0 0 10px rgba(34,211,238,.5)}.camera-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.camera-hint{position:absolute;bottom:60px;font-size:.85rem;color:var(--text-secondary);text-shadow:0 1px 4px rgba(0,0,0,.8)}.face-detected-indicator{position:absolute;top:var(--space-md);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-xs);padding:6px 14px;background:#4ade8033;border:1px solid var(--accent-success);border-radius:var(--radius-full);font-size:.8rem;color:var(--accent-success)}.indicator-dot{width:8px;height:8px;background:var(--accent-success);border-radius:50%;animation:pulse-dot 1.5s ease-in-out infinite}.indicator-dot.manual{background:#f59e0b}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.capture-btn{position:absolute;bottom:var(--space-md);left:50%;transform:translate(-50%);width:64px;height:64px;border-radius:50%;background:var(--accent-primary);border:4px solid rgba(255,255,255,.3);cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center}.capture-btn:disabled{background:var(--bg-elevated);border-color:var(--border-subtle);cursor:not-allowed}.capture-btn:not(:disabled):hover{transform:translate(-50%) scale(1.1);box-shadow:0 4px 20px #e91e6366}.capture-btn:not(:disabled):active{transform:translate(-50%) scale(.95)}.capture-icon{width:24px;height:24px;background:#fff;border-radius:50%}.capture-btn:disabled .capture-icon{background:var(--text-muted)}.camera-area .capture-btn{display:none}.capture-btn-container{display:flex;justify-content:center;margin-top:var(--space-md);margin-bottom:var(--space-md)}.capture-btn-outside{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-full);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 16px #c2185b4d}.capture-btn-outside:disabled{background:var(--bg-elevated);color:var(--text-muted);cursor:not-allowed;box-shadow:none}.capture-btn-outside:not(:disabled):hover{transform:scale(1.05);box-shadow:0 6px 24px #c2185b66}.capture-icon-large{width:20px;height:20px;background:#fff;border-radius:50%}.capture-btn-outside:disabled .capture-icon-large{background:var(--text-muted)}.gender-required-overlay{position:absolute;inset:0;background:#f8f7f4f2;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius-lg);opacity:1;transition:opacity .4s ease,visibility .4s ease}.gender-required-overlay p{font-size:1.1rem;font-weight:600;color:var(--accent-primary);text-align:center;padding:var(--space-lg);animation:pulse-text 2s ease-in-out infinite}@keyframes pulse-text{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.02)}}.gender-required-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.upload-area{position:relative}.upload-overlay{border-radius:var(--radius-lg)}.step-label{font-family:var(--font-mono);font-size:.7rem;font-weight:600;color:var(--accent-primary);letter-spacing:.1em;margin-bottom:var(--space-xs)}.gender-selection-first{text-align:center;padding:var(--space-lg);background:var(--bg-card);border:2px solid var(--accent-primary);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);box-shadow:0 2px 12px #c2185b1a}.gender-selection-first .gender-label{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md)}.photo-input-section{margin-bottom:var(--space-lg)}.photo-input-section .step-label{margin-bottom:var(--space-sm)}.gender-selection{text-align:center;margin-bottom:var(--space-lg)}.gender-label{font-size:.9rem;color:var(--text-secondary);margin-bottom:var(--space-md)}.gender-buttons{display:flex;gap:var(--space-md);justify-content:center}.gender-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-xl);background:var(--bg-card);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-normal);min-width:100px}.gender-btn:hover{border-color:var(--border-medium);background:var(--bg-elevated)}.gender-btn.active[data-gender=female]{border-color:#e91e63;background:#e91e631a;color:#e91e63}.gender-btn.active[data-gender=male]{border-color:#4a90e2;background:#4a90e21a;color:#4a90e2}.gender-icon{font-size:1.5rem}.analyze-btn{width:100%;max-width:320px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:linear-gradient(135deg,var(--accent-primary),#c2185b);border:none;border-radius:var(--radius-lg);font-family:var(--font-body);font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all var(--transition-normal)}.analyze-btn:disabled{background:var(--bg-elevated);color:var(--text-muted);cursor:not-allowed}.analyze-btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 8px 24px #e91e634d}.analyze-btn.loading .btn-text{display:none}.analyze-btn.loading .btn-loader{display:block}.btn-loader{display:none;width:20px;height:20px;border:2px solid var(--bg-primary);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.metrics-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-lg)}.metrics-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.metrics-header h3{font-family:var(--font-display);font-size:1.1rem;font-weight:500}.metrics-badge{font-family:var(--font-mono);font-size:.75rem;padding:6px 14px;background:var(--accent-secondary-dim);color:var(--accent-secondary);border-radius:var(--radius-full)}.metrics-grid{display:grid;gap:var(--space-md);margin-bottom:var(--space-lg)}.metric-item{display:grid;grid-template-columns:80px 60px 1fr;align-items:center;gap:var(--space-md)}.metric-label{font-size:.9rem;color:var(--text-secondary)}.metric-value{font-family:var(--font-mono);font-size:1rem;font-weight:500;color:var(--accent-primary);text-align:right}.metric-bar{height:6px;background:var(--bg-elevated);border-radius:var(--radius-full);overflow:hidden}.metric-fill{height:100%;background:linear-gradient(90deg,var(--accent-secondary),var(--accent-primary));border-radius:var(--radius-full);transition:width .8s cubic-bezier(.25,.46,.45,.94)}.metrics-detail{padding-top:var(--space-md);border-top:1px solid var(--border-subtle);display:grid;gap:var(--space-sm)}.detail-row{display:flex;justify-content:space-between;align-items:center}.detail-label{font-size:.85rem;color:var(--text-muted)}.detail-value{font-family:var(--font-mono);font-size:.9rem;color:var(--text-secondary)}.summary-card{background:linear-gradient(135deg,var(--bg-card),var(--bg-elevated));border:1px solid var(--accent-primary-dim);border-radius:var(--radius-xl);padding:var(--space-lg);text-align:center}.summary-icon{font-size:2rem;margin-bottom:var(--space-sm)}.summary-card h4{font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--accent-primary);margin-bottom:var(--space-md)}.summary-text{font-size:.95rem;color:var(--text-secondary);line-height:1.7}.prescription-section{margin-bottom:var(--space-xl)}.prescription-card{background:var(--bg-card);border:2px solid var(--accent-primary);border-radius:var(--radius-xl);padding:var(--space-xl);text-align:center;box-shadow:0 4px 20px #c2185b1a}.prescription-question{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-sm)}.prescription-hint{font-size:.9rem;color:var(--accent-primary);margin-bottom:var(--space-xl);font-weight:500}.prescription-buttons{display:flex;gap:var(--space-md);justify-content:center;margin-bottom:var(--space-xl);flex-wrap:wrap}.prescription-btn{flex:1;min-width:120px;max-width:160px;padding:var(--space-lg) var(--space-md);background:var(--bg-elevated);border:2px solid var(--border-medium);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.prescription-btn:hover{border-color:var(--accent-primary);background:var(--accent-primary-dim);transform:translateY(-2px)}.prescription-btn.active{border-color:var(--accent-primary);background:var(--accent-primary);color:#fff;box-shadow:0 4px 16px #c2185b4d}.prescription-btn.active .prescription-desc{color:#fffc}.prescription-icon{font-size:2rem}.prescription-label{font-size:1.1rem;font-weight:600}.prescription-desc{font-size:.75rem;color:var(--text-muted);line-height:1.3}.confirm-prescription-btn{width:100%;max-width:320px;padding:var(--space-md) var(--space-xl);background:linear-gradient(135deg,var(--accent-primary),#a01550);border:none;border-radius:var(--radius-lg);color:#fff;font-family:var(--font-body);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.confirm-prescription-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #c2185b4d}.current-prescription{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--accent-primary-dim);border-radius:var(--radius-lg)}.prescription-tag{font-weight:600;color:var(--accent-primary)}.change-prescription-btn{padding:var(--space-xs) var(--space-md);background:transparent;border:1px solid var(--accent-primary);border-radius:var(--radius-full);color:var(--accent-primary);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.change-prescription-btn:hover{background:var(--accent-primary);color:#fff}.recommendations-container{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg);-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.category-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 2px 12px #0000000f}.category-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle)}.category-name{font-family:var(--font-display);font-size:1.1rem;font-weight:500}.category-badge{font-family:var(--font-mono);font-size:.7rem;padding:4px 10px;background:var(--accent-purple-dim);color:var(--accent-purple);border-radius:var(--radius-full)}.category-reason{padding:var(--space-lg) var(--space-xl);font-size:.95rem;color:var(--text-secondary);line-height:1.8;border-bottom:1px solid var(--border-subtle);background:#e8c4a008;word-break:keep-all;overflow-wrap:break-word}.category-reason strong{color:var(--accent-primary)}.style-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);padding:var(--space-md)}.style-card{position:relative;background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-normal);border:1px solid var(--border-subtle)}.style-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--accent-primary);z-index:1}.style-card-rank{position:absolute;top:var(--space-sm);left:var(--space-sm);width:28px;height:28px;background:var(--accent-primary);color:#fff;border-radius:var(--radius-full);font-family:var(--font-mono);font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:0 2px 6px #c2185b4d}.style-card-name{position:absolute;top:var(--space-sm);right:var(--space-sm);background:#000000a6;backdrop-filter:blur(4px);padding:4px 8px;border-radius:var(--radius-sm);font-size:.7rem;color:#fff;z-index:2}.style-card img{width:100%;aspect-ratio:3/4;object-fit:cover}.style-card-info{display:flex;justify-content:center;align-items:center;padding:var(--space-md);background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle)}.style-score{font-family:var(--font-mono);font-size:1rem;font-weight:700;color:var(--accent-secondary);padding:8px 16px;background:linear-gradient(135deg,#4ecdc426,#4a90e21a);border-radius:var(--radius-md);white-space:nowrap}.style-card-reason{padding:var(--space-md);font-size:.8rem;color:var(--text-secondary);line-height:1.6;min-height:55px;background:linear-gradient(180deg,rgba(232,196,160,.05),transparent);word-break:keep-all;overflow-wrap:break-word}.style-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-sm)}.style-rank{position:absolute;top:var(--space-sm);left:var(--space-sm);width:24px;height:24px;background:var(--accent-primary);color:var(--bg-primary);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:.75rem;font-weight:600;display:flex;align-items:center;justify-content:center}.style-score{font-family:var(--font-mono);font-size:.9rem;font-weight:600;color:var(--accent-secondary);padding:4px 12px;background:#4ecdc41a;border-radius:var(--radius-sm)}.style-name{font-size:.7rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.score-reasons{padding:var(--space-sm) var(--space-lg) var(--space-md);display:flex;flex-wrap:wrap;gap:var(--space-xs)}.reason-tag{font-size:.75rem;padding:4px 10px;border-radius:var(--radius-full);display:inline-flex;align-items:center;gap:4px}.reason-tag.positive{background:#4ecdc41a;color:var(--accent-secondary)}.reason-tag.negative{background:#ff6b6b1a;color:var(--accent-coral)}.loading-overlay{position:fixed;inset:0;background:#0a0a0ff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;z-index:1000}.loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.2);border-top:3px solid var(--accent-secondary, #a855f7);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-logo{font-family:Bebas Neue,sans-serif;font-size:2.5rem;color:#fff;letter-spacing:.1em;margin-bottom:20px;text-shadow:0 0 20px rgba(168,85,247,.5)}.loading-text{font-family:var(--font-display);font-size:1.2rem;color:var(--text-primary);margin-bottom:var(--space-sm)}.loading-subtext{font-family:var(--font-mono);font-size:.8rem;color:var(--accent-secondary)}@media(min-width:768px){.app-container{max-width:900px}.recommendations-container{display:flex;flex-direction:column;gap:var(--space-xl)}.category-card{width:100%}.style-cards{grid-template-columns:repeat(3,1fr);gap:var(--space-md);padding:var(--space-lg)}.style-card-reason{font-size:.8rem;min-height:50px;word-break:keep-all}.category-reason{font-size:1rem;padding:var(--space-lg) var(--space-xl);word-break:keep-all}.analysis-section{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl)}.analysis-grid{grid-column:span 2}}@media(min-width:1200px){.app-container{max-width:1100px}.style-cards{grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}}@media(max-width:767px){.recommendations-container{display:flex;flex-direction:column;gap:var(--space-lg)}.style-cards{grid-template-columns:repeat(3,1fr);gap:var(--space-sm);padding:var(--space-md)}.style-card-reason{font-size:.75rem;min-height:45px;padding:var(--space-sm);word-break:keep-all}.category-reason{font-size:.9rem;padding:var(--space-md) var(--space-lg);word-break:keep-all}}@media(max-width:480px){.main-content{padding:var(--space-md)}.section-title{font-size:1.25rem}.upload-area{max-width:280px}.gender-btn{padding:var(--space-sm) var(--space-md);min-width:80px}.metric-item{grid-template-columns:70px 50px 1fr;gap:var(--space-sm)}.category-reason{font-size:.85rem;word-break:keep-all}.style-cards{grid-template-columns:repeat(3,1fr);gap:6px;padding:var(--space-sm)}.style-card-rank{width:22px;height:22px;font-size:.75rem}.style-card-name{font-size:.65rem;padding:3px 6px}.style-card-reason{font-size:.7rem;word-break:keep-all;min-height:40px}.style-score{font-size:.9rem;padding:6px 12px;white-space:nowrap}.style-card-info{padding:4px}.style-score{font-size:.7rem;padding:2px 6px}.style-card-reason{font-size:.55rem;min-height:30px;padding:4px 6px}.category-reason{padding:var(--space-sm) var(--space-md);font-size:.75rem}}body.light-theme{--bg-primary: #f8f9fa;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-elevated: #f3f4f6;--text-primary: #1f2937;--text-secondary: #4b5563;--text-muted: #9ca3af;--border-subtle: rgba(0, 0, 0, .06);--border-medium: rgba(0, 0, 0, .1);--accent-primary: #c2185b;--accent-primary-dim: rgba(194, 24, 91, .1);--accent-secondary: #1976d2;--accent-secondary-dim: rgba(25, 118, 210, .1)}body.light-theme:before{background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(233,30,99,.04),transparent),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(74,144,226,.03),transparent)}body.light-theme .metrics-card,body.light-theme .category-card{box-shadow:0 2px 8px #0000000d}.image-type-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);border:1px solid var(--border-subtle)}.image-type-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.image-type-header h4{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--text-primary);margin:0}.image-type-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;font-family:var(--font-body);transition:all .3s ease}.image-type-badge.warm{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100;border:1px solid rgba(230,81,0,.2)}.image-type-badge.neutral{background:linear-gradient(135deg,#f5f5f5,#e0e0e0);color:#424242;border:1px solid rgba(66,66,66,.2)}.image-type-badge.cool{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1565c0;border:1px solid rgba(21,101,192,.2)}.image-type-detail{display:flex;flex-direction:column;gap:8px}.image-type-detail .detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px dashed var(--border-subtle)}.image-type-detail .detail-row:last-child{border-bottom:none}.image-type-detail .detail-label{font-size:13px;color:var(--text-secondary)}.image-type-detail .detail-value{font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--text-primary)}.eyebrow-type-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);border:1px solid var(--border-subtle)}.eyebrow-type-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.eyebrow-type-header h4{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--text-primary);margin:0}.eyebrow-type-badge{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;font-family:var(--font-body);transition:all .3s ease}.eyebrow-type-badge.warm{background:linear-gradient(135deg,#fce4ec,#f8bbd9);color:#c2185b;border:1px solid rgba(194,24,91,.2)}.eyebrow-type-badge.neutral{background:linear-gradient(135deg,#f3e5f5,#e1bee7);color:#7b1fa2;border:1px solid rgba(123,31,162,.2)}.eyebrow-type-badge.cool{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32;border:1px solid rgba(46,125,50,.2)}.eyebrow-type-detail{display:flex;flex-direction:column;gap:8px}.eyebrow-type-detail .detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px dashed var(--border-subtle)}.eyebrow-type-detail .detail-row:last-child{border-bottom:none}.eyebrow-type-detail .detail-label{font-size:13px;color:var(--text-secondary)}.eyebrow-type-detail .detail-value{font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--text-primary)}.style-detail-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.style-modal-backdrop{position:absolute;inset:0;background:#000000d9;backdrop-filter:blur(10px)}.style-modal-content{position:relative;background:var(--bg-card);border-radius:var(--radius-xl);max-width:400px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;animation:modalSlideUp .3s ease}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.style-modal-close{position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:50%;background:#00000080;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all .2s ease}.style-modal-close:hover{background:#000000b3;transform:scale(1.1)}.style-modal-image-wrapper{width:100%;aspect-ratio:1/1;max-height:40vh;overflow:hidden;background:var(--bg-secondary)}.style-modal-image-wrapper img{width:100%;height:100%;object-fit:cover}.style-modal-info{padding:var(--space-lg);text-align:center}.style-modal-info h3{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.style-modal-category{font-size:13px;color:var(--accent-primary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em}.style-modal-reason{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.style-modal-actions{display:flex;gap:10px;padding:0 var(--space-lg) var(--space-lg)}.style-action-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border-radius:var(--radius-md);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.style-action-btn svg{opacity:.8}.style-action-btn:hover{transform:translateY(-2px)}.style-action-btn.lookbook,.style-action-btn.hairtry{background:linear-gradient(135deg,#e91e6333,#c2185b26);border:1px solid rgba(233,30,99,.5);color:#333}.style-action-btn.lookbook:hover,.style-action-btn.hairtry:hover{background:linear-gradient(135deg,#e91e6359,#c2185b40);border-color:#e91e63b3;box-shadow:0 4px 12px #e91e6340}.style-action-btn.lookbook:active,.style-action-btn.hairtry:active{transform:translateY(0);background:linear-gradient(135deg,#e91e6366,#c2185b4d)}.style-action-btn.recipe{background:transparent;border:1px solid rgba(100,100,100,.3);color:#666}.style-action-btn.recipe:hover{border-color:#64646480;color:#333;background:#64646414}.style-action-btn.recipe:active{background:#6464641f}
