@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg: #FAFAF8;--bg-card: #FFFFFF;--bg-subtle: #F3F3F0;--primary: #2D6A4F;--primary-light:#3A8562;--primary-dark: #1B4332;--accent: #95D5B2;--accent-light: #B7E4C7;--score-high: #52B788;--score-mid: #F4A261;--score-low: #E76F51;--text: #1B1B1B;--text-muted: #6B7280;--text-light: #9CA3AF;--border: #E5E7EB;--border-subtle:#F0F0ED;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.05);--shadow-lg: 0 10px 40px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--transition: all .25s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;letter-spacing:-.03em;line-height:1.15}h2{font-size:clamp(1.25rem,3vw,1.75rem);font-weight:700;letter-spacing:-.02em}h3{font-size:1.1rem;font-weight:600}p{color:var(--text-muted);line-height:1.7}.app{min-height:100vh;background:linear-gradient(160deg,#f0faf4,#fafaf8 40%,#fdf8f4);display:flex;flex-direction:column}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:100}.header-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none}.header-logo-mark{width:36px;height:36px;background:linear-gradient(135deg,var(--primary) 0%,var(--score-high) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.header-logo-text{font-size:1.2rem;font-weight:800;color:var(--primary);letter-spacing:-.02em}.header-badge{font-size:.65rem;font-weight:600;color:var(--text-muted);background:var(--bg-subtle);padding:.25rem .6rem;border-radius:100px;letter-spacing:.05em;text-transform:uppercase}.main{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem 4rem}.container{width:100%;max-width:680px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.75rem;border-radius:var(--radius-md);font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:var(--transition);text-decoration:none;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;box-shadow:0 4px 14px #2d6a4f4d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #2d6a4f66}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-card);color:var(--primary);border:1.5px solid var(--border)}.btn-secondary:hover{background:var(--bg-subtle);border-color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--bg-subtle)}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-subtle);overflow:hidden}.card-body{padding:1.75rem}.card-header{padding:1.25rem 1.75rem;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.score-high{color:var(--score-high)}.score-mid{color:var(--score-mid)}.score-low{color:var(--score-low)}.score-high-bg{background:#52b7881a}.score-mid-bg{background:#f4a2611a}.score-low-bg{background:#e76f511a}.score-bar-wrap{margin-bottom:.9rem}.score-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.score-bar-label{font-size:.875rem;font-weight:500;color:var(--text)}.score-bar-value{font-size:.875rem;font-weight:700}.score-bar-track{height:8px;background:var(--bg-subtle);border-radius:100px;overflow:hidden}.score-bar-fill{height:100%;border-radius:100px;transition:width 1.2s cubic-bezier(.4,0,.2,1);width:0}.score-bar-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:100px;text-transform:uppercase;letter-spacing:.04em;margin-left:.5rem}.upload-hero{text-align:center;padding:2rem 0 1.5rem}.upload-tagline{color:var(--primary);font-weight:600;font-size:.9rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.75rem}.upload-title{color:var(--text);margin-bottom:.75rem}.upload-sub{font-size:1.05rem;max-width:420px;margin:0 auto}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-xl);padding:2.5rem 1.5rem;text-align:center;cursor:pointer;transition:var(--transition);background:var(--bg-card);position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(149,213,178,.08) 0%,transparent 60%);pointer-events:none}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary);background:#2d6a4f08;transform:scale(1.005)}.upload-zone.has-image{border-style:solid;border-color:var(--accent)}.upload-icon{font-size:3rem;margin-bottom:1rem;display:block}.upload-zone-title{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:.4rem}.upload-zone-sub{font-size:.875rem;color:var(--text-muted)}.upload-zone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.upload-preview{position:relative}.upload-preview img{width:100%;max-height:340px;object-fit:cover;border-radius:var(--radius-lg);display:block}.upload-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 60%,rgba(0,0,0,.4));border-radius:var(--radius-lg);display:flex;align-items:flex-end;padding:1rem}.upload-change-btn{font-size:.8rem;font-weight:600;color:#fff;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);border-radius:100px;padding:.3rem .8rem;cursor:pointer;transition:var(--transition)}.upload-change-btn:hover{background:#ffffff4d}.upload-tips{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin:1.25rem 0}.upload-tip{text-align:center;padding:.9rem .5rem;background:var(--bg-subtle);border-radius:var(--radius-md)}.upload-tip-icon{font-size:1.4rem;margin-bottom:.35rem}.upload-tip-text{font-size:.75rem;font-weight:500;color:var(--text-muted)}.trust-badges{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:1.5rem}.trust-badge{display:flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.trust-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--score-high)}.powered-by{text-align:center;margin-top:1.25rem;font-size:.75rem;color:var(--text-light);font-weight:500}.powered-by span{color:var(--primary);font-weight:700}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1.5rem;text-align:center;min-height:60vh}.loading-scan{position:relative;width:180px;height:180px;margin:0 auto 2rem}.loading-scan-img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:3px solid var(--border)}.loading-scan-ring{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:3px solid transparent;border-top-color:var(--primary);border-right-color:var(--accent);animation:spin 1.5s linear infinite}.loading-scan-ring-2{position:absolute;top:-16px;right:-16px;bottom:-16px;left:-16px;border-radius:50%;border:2px solid transparent;border-bottom-color:var(--accent-light);animation:spin 2.5s linear infinite reverse}@keyframes spin{to{transform:rotate(360deg)}}.loading-step{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:.5rem}.loading-sub{font-size:.9rem;color:var(--text-muted);margin-bottom:1.5rem}.loading-dots{display:flex;gap:.4rem;justify-content:center}.loading-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);animation:pulse-dot 1.4s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes pulse-dot{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.loading-progress{width:240px;height:4px;background:var(--bg-subtle);border-radius:100px;overflow:hidden;margin:1.5rem auto 0}.loading-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:100px;animation:progress-fill 3s ease-in-out forwards}@keyframes progress-fill{0%{width:5%}to{width:90%}}.analysis-hero{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.overall-score-circle{width:88px;height:88px;flex-shrink:0;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:conic-gradient(var(--primary) calc(var(--pct) * 1%),var(--bg-subtle) 0);position:relative}.overall-score-circle:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:50%;background:#fff}.overall-score-number{position:relative;z-index:1;font-size:1.5rem;font-weight:800;color:var(--primary);line-height:1}.overall-score-label{position:relative;z-index:1;font-size:.6rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.overall-score-text h2{margin-bottom:.3rem}.overall-score-text p{font-size:.9rem}.overlay-image-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1.25rem;background:var(--bg-subtle)}.overlay-image-wrap img{width:100%;display:block;max-height:320px;object-fit:cover}.overlay-label{position:absolute;bottom:.75rem;left:.75rem;font-size:.7rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.05em;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:.3rem .7rem;border-radius:100px}.section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.75rem}.concerns-grid{display:flex;flex-direction:column;gap:.1rem}.concern-section-title{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:.6rem 0 .3rem}.concern-section-title.needs-attention{color:var(--score-low)}.concern-section-title.healthy{color:var(--score-high)}.cta-simulation{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border-radius:var(--radius-xl);padding:1.75rem;text-align:center;margin-top:1.5rem;position:relative;overflow:hidden}.cta-simulation:before{content:"";position:absolute;top:-50%;right:-20%;width:200px;height:200px;background:#ffffff14;border-radius:50%}.cta-simulation h3{color:#fff;font-size:1.2rem;margin-bottom:.4rem}.cta-simulation p{color:#fffc;font-size:.9rem;margin-bottom:1.25rem}.cta-simulation .btn-white{background:#fff;color:var(--primary);font-weight:700;padding:.9rem 2rem;border-radius:var(--radius-md);box-shadow:0 4px 14px #00000026;border:none;cursor:pointer;font-family:inherit;font-size:1rem;display:inline-flex;align-items:center;gap:.5rem;transition:var(--transition)}.cta-simulation .btn-white:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0003}.simulation-header{text-align:center;margin-bottom:1.5rem}.simulation-header h2{margin-bottom:.4rem}.slider-container{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:ew-resize;-webkit-user-select:none;user-select:none;background:var(--bg-subtle);box-shadow:var(--shadow-lg);margin-bottom:1rem}.slider-before,.slider-after{position:absolute;top:0;right:0;bottom:0;left:0}.slider-before img,.slider-after img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.slider-after{clip-path:inset(0 var(--clip) 0 0)}.slider-handle{position:absolute;top:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;width:44px;transform:translate(-50%);pointer-events:none;z-index:10}.slider-handle-line{width:2px;flex:1;background:#fff;box-shadow:0 0 8px #0006}.slider-handle-btn{width:44px;height:44px;border-radius:50%;background:#fff;box-shadow:0 2px 12px #0000004d;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--primary);font-weight:700;flex-shrink:0}.slider-label-before,.slider-label-after{position:absolute;bottom:.75rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff;padding:.3rem .8rem;border-radius:100px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.slider-label-before{left:.75rem;background:#00000073}.slider-label-after{right:.75rem;background:#2d6a4fbf}.slider-hint{text-align:center;font-size:.8rem;color:var(--text-muted);margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;gap:.4rem}.slider-hint-arrow{animation:bounce-h 1.5s ease-in-out infinite;display:inline-block}@keyframes bounce-h{0%,to{transform:translate(0)}50%{transform:translate(6px)}}.products-section{margin-top:1.5rem}.products-section h3{margin-bottom:.25rem}.products-section>p{margin-bottom:1rem;font-size:.875rem}.product-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);padding:1.25rem;margin-bottom:.75rem;transition:var(--transition);animation:fade-up .5s ease both}.product-card:nth-child(2){animation-delay:.1s}.product-card:nth-child(3){animation-delay:.2s}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.product-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.product-card-header{display:flex;align-items:flex-start;gap:.875rem;margin-bottom:.75rem}.product-concern-badge{display:flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.3rem .65rem;border-radius:100px;white-space:nowrap;flex-shrink:0}.product-info{flex:1;min-width:0}.product-type{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.15rem}.product-ingredient{font-size:.8rem;color:var(--primary);font-weight:600}.product-explanation{font-size:.875rem;color:var(--text-muted);line-height:1.55;margin-bottom:.75rem}.product-usage-hint{font-size:.8rem;color:var(--text-muted);background:var(--bg-subtle);border-radius:var(--radius-sm);padding:.5rem .75rem;display:flex;align-items:flex-start;gap:.4rem}.product-usage-hint-icon{flex-shrink:0}.action-footer{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border-subtle)}.screen-enter{animation:screen-in .4s ease both}@keyframes screen-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.error-card{background:#e76f510f;border:1px solid rgba(231,111,81,.25);border-radius:var(--radius-md);padding:1.25rem;display:flex;gap:.75rem;align-items:flex-start;margin-bottom:1rem}.error-icon{font-size:1.25rem;flex-shrink:0}.error-text h4{font-size:.9rem;font-weight:600;color:var(--score-low);margin-bottom:.2rem}.error-text p{font-size:.85rem;color:var(--text-muted)}@media (max-width: 480px){.header{padding:.875rem 1rem}.main{padding:1.25rem .875rem 3rem}.card-body,.cta-simulation{padding:1.25rem}.upload-tips{grid-template-columns:repeat(3,1fr);gap:.5rem}}.chat-markdown table{width:100%;border-collapse:collapse;margin:.75rem 0;font-size:.85rem}.chat-markdown th,.chat-markdown td{border:1px solid var(--border);padding:.5rem;text-align:left}.chat-markdown th{background:var(--bg);font-weight:600}.chat-markdown p{margin-top:0;margin-bottom:.75rem}.chat-markdown p:last-child{margin-bottom:0}.chat-markdown ul,.chat-markdown ol{margin-top:0;margin-bottom:.75rem;padding-left:1.5rem}.chat-markdown li{margin-bottom:.25rem}.md-table{width:100%;border-collapse:collapse;font-size:.82rem;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.md-table th,.md-table td{border:1px solid var(--border);padding:.45rem .6rem;text-align:left;vertical-align:top}.md-table th{background:var(--bg);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.md-table tr:nth-child(2n) td{background:var(--bg-subtle)}.skin-age-badge{display:inline-flex;align-items:center;gap:.3rem;margin-top:.4rem;font-size:.8rem;font-weight:500;color:var(--primary);background:#2d6a4f14;padding:.25rem .65rem;border-radius:100px;border:1px solid rgba(45,106,79,.15)}.skin-age-badge strong{font-weight:700}.skin-summary-card{display:flex;align-items:flex-start;gap:.75rem;background:linear-gradient(135deg,#2d6a4f0d,#95d5b214);border:1px solid rgba(45,106,79,.12);border-radius:var(--radius-md);padding:1rem 1.1rem;margin-bottom:1.25rem}.skin-summary-icon{font-size:1.2rem;flex-shrink:0;margin-top:.1rem}.skin-summary-text{font-size:.875rem;color:var(--text);line-height:1.6;font-style:italic;margin:0}.routine-columns{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media (max-width: 420px){.routine-columns{grid-template-columns:1fr}}.routine-col-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:2px solid rgba(45,106,79,.1)}.routine-step{display:flex;align-items:flex-start;gap:.6rem;font-size:.82rem;color:var(--text-muted);line-height:1.5;margin-bottom:.55rem}.routine-step-num{width:20px;height:20px;border-radius:50%;background:#2d6a4f1f;color:var(--primary);font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.05rem}.overlay-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000b3;display:flex;align-items:flex-end;animation:backdrop-in .2s ease;padding:0}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.overlay-modal{width:100%;max-width:680px;margin:0 auto;background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;overflow:hidden;animation:modal-up .3s cubic-bezier(.4,0,.2,1);max-height:90vh;display:flex;flex-direction:column}@keyframes modal-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.overlay-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.overlay-modal-badge{display:inline-block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.3rem .7rem;border-radius:100px;border:1.5px solid currentColor;margin-bottom:.2rem}.overlay-modal-score{font-size:.85rem;color:var(--text-muted);font-weight:500}.overlay-modal-close{width:36px;height:36px;border-radius:50%;background:var(--bg-subtle);border:none;cursor:pointer;font-size:.9rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition)}.overlay-modal-close:hover{background:var(--border);color:var(--text)}.overlay-modal-body{padding:1.25rem;overflow-y:auto}.overlay-modal-img-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-subtle);aspect-ratio:4/3;margin-bottom:1rem}.overlay-modal-base-img,.overlay-modal-mask-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;transition:opacity .1s ease}.overlay-modal-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:.4rem;background:var(--bg-subtle)}.overlay-modal-labels{position:absolute;bottom:.75rem;left:0;right:0;display:flex;justify-content:space-between;padding:0 .75rem}.overlay-modal-labels span{font-size:.65rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.06em;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:.2rem .6rem;border-radius:100px;transition:opacity .1s ease}.overlay-modal-slider-wrap{margin-bottom:.75rem}.overlay-modal-slider-label{display:flex;align-items:center;gap:.75rem;font-size:.75rem;font-weight:600;color:var(--text-muted)}.overlay-modal-range{flex:1;accent-color:var(--primary);height:4px;cursor:pointer}.overlay-modal-hint{font-size:.78rem;color:var(--text-muted);text-align:center;line-height:1.5;margin:0}.overlay-modal-no-mask{text-align:center;padding:2rem 1rem}@media print{@page{margin:1cm}body{background:#fff;color:#000}.header,.cta-simulation,.action-footer,.slider-hint,.upload-tips{display:none!important}.main{padding:0!important}.container{max-width:100%!important;margin:0!important}.card{box-shadow:none!important;border:1px solid #ddd!important;break-inside:avoid;margin-bottom:20px!important}.simulation-header{margin-top:0!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}
