:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-primary:#b57ba6;--color-primary-dark:#9a5f8a;--color-primary-soft:#b57ba61f;--color-primary-light:#b57ba614;--color-secondary:#fcfcfb;--color-secondary-warm:#fafaf9;--color-accent:#6b3a5c;--color-accent-light:#6b3a5c26;--color-bg:#fefefd;--color-text-main:#5a5a5a;--color-text-heading:#6a5a5a;--color-text-secondary:#6b7280;--color-text-warm:#6a5a5a;--color-text-muted:#8b7d7d;--color-border:#e5e7eb;--color-border-warm:#d4c4c4;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:var(--color-text-main,#213547);background-color:var(--color-bg,#faf8f6)}body{background-color:var(--color-bg,#faf8f6)}a:hover{color:var(--color-primary,#b57ba6)}button{background-color:#f9f9f9}}.info-section{flex-direction:column;gap:.75rem;width:100%;max-width:600px;display:flex}.info-item{border:1px solid var(--color-border,#e5e7eb);background:#fff;border-radius:.5rem;transition:all .2s;overflow:hidden;box-shadow:0 1px 3px #0000000d}.info-item:hover{box-shadow:0 4px 6px #00000014}.info-item__header{cursor:pointer;text-align:left;background:0 0;border:none;outline:none;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.25rem;transition:background-color .2s;display:flex}.info-item__header:focus{outline:none}.info-item__header--open{background-color:#0000}.info-item__title{color:var(--color-text-heading,#6a5a5a);font-size:1rem;font-weight:600}.info-item__icon{color:var(--color-primary,#b57ba6);flex-shrink:0;margin-left:1rem;font-size:1.25rem;font-weight:400;line-height:1;transition:opacity .2s}.info-item__content{color:var(--color-text-main,#5a5a5a);margin-top:.5rem;padding:0 1.25rem 1.25rem;font-size:.95rem;line-height:1.6;animation:.8s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.info-section{max-width:100%}.info-item__header{padding:.875rem 1rem}.info-item__title{font-size:.9375rem}.info-item__content{padding:0 1rem 1rem;font-size:.875rem}}.home-page{text-align:center;flex-direction:column;justify-content:flex-start;align-items:center;gap:2rem;max-width:90%;min-height:calc(100vh - 160px);margin:0 auto;padding:24px 16px;display:flex}.home-page h1{color:var(--color-text-heading,#5a4a4a);margin-bottom:1rem;font-size:2.5rem}.home-page p{color:#6b7280;margin-bottom:2rem;font-size:1.2rem}@media (max-width:480px){.home-page h1{font-size:2rem}.home-page p{font-size:1rem}}.face-analysis-page{flex-direction:column;align-items:center;min-height:calc(100vh - 160px);padding:24px 12px 16px;display:flex}.face-analysis-page__content{width:95%;max-width:90%;margin:0 auto}.face-analysis-page__header{text-align:left;margin-bottom:2rem}.face-analysis-page__header h1{color:var(--color-text-heading,#5a4a4a);margin-bottom:.5rem;font-size:2rem}.face-analysis-page__header p{color:#6b7280;font-size:1rem}@media (max-width:480px){.face-analysis-page{padding-top:24px}.face-analysis-page__content{max-width:100%}.face-analysis-page__header{margin-bottom:1.5rem}.face-analysis-page__header h1{font-size:1.75rem}}.input-group{text-align:left;margin-bottom:1.5rem}.input-label{color:var(--color-text-heading,#5a4a4a);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.required{color:#ef4444;margin-left:.25rem}.input-field{border:2px solid var(--color-border,#e5e7eb);box-sizing:border-box;background-color:#fff;border-radius:.5rem;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .2s}.input-field::placeholder{color:var(--color-text-warm,#5a4a4a);opacity:.6}.input-field--multiline{resize:vertical;min-height:160px;line-height:1.5}.input-field:focus{border-color:var(--color-primary,#b57ba6);box-shadow:0 0 0 3px var(--color-primary-light,#b57ba614);outline:none}.input-field.error{border-color:#dc2626}.input-field.error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.input-field:disabled{color:#6b7280;cursor:not-allowed;background-color:#f9fafb}.error-message{color:#dc2626;margin-top:.25rem;font-size:.75rem;font-weight:500;display:block}@media (max-width:480px){.input-field{padding:.625rem .875rem;font-size:.875rem}.input-label{font-size:.8125rem}}.btn{cursor:pointer;border:none;border-radius:.5rem;justify-content:center;align-items:center;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:var(--color-primary,#b57ba6);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark,#9a5f8a);transform:translateY(-1px);box-shadow:0 4px 12px #b57ba64d}.btn-secondary{color:#fff;background-color:#6b7280}.btn-secondary:hover:not(:disabled){background-color:#4b5563;transform:translateY(-1px);box-shadow:0 4px 12px #6b72804d}.btn-outline{color:var(--color-primary,#b57ba6);border:2px solid var(--color-primary,#b57ba6);background-color:#0000}.btn-outline:hover:not(:disabled){background-color:var(--color-primary,#b57ba6);color:#fff;transform:translateY(-1px)}.btn-ghost{color:#6b7280;background-color:#0000}.btn-ghost:hover:not(:disabled){color:#374151;background-color:#f3f4f6}.btn-danger{color:#fff;background-color:#dc2626}.btn-danger:hover:not(:disabled){background-color:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.btn-small{padding:.5rem 1rem;font-size:.875rem}.btn-medium{padding:.75rem 1.5rem;font-size:1rem}.btn-large{padding:1rem 2rem;font-size:1.125rem}.btn-full-width{width:100%}.btn-loading{align-items:center;gap:.5rem;display:flex}.spinner{border:2px solid #0000;border-top-color:currentColor;border-radius:50%;width:1rem;height:1rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:480px){.btn-medium{padding:.625rem 1.25rem;font-size:.875rem}.btn-large{padding:.875rem 1.75rem;font-size:1rem}}.face-form{flex-direction:column;gap:2rem;width:100%;display:flex}.face-form__section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;box-shadow:0 12px 30px #0f172a0a}.face-form__section-header h2{color:var(--color-text-heading,#5a4a4a);margin:0;font-size:1.15rem;font-weight:600}.face-form__section-header p{color:#6b7280;margin:.25rem 0 1.25rem;font-size:.95rem}.face-form__category-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;display:grid}.face-category{text-align:left;cursor:pointer;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;transition:border-color .2s,box-shadow .2s,background .2s}.face-category h3{color:var(--color-text-heading,#5a4a4a);margin:0 0 .5rem;font-size:1rem}.face-category p{color:#6b7280;margin:0;font-size:.9rem;line-height:1.4}.face-category--active{background:#fff;border-color:#6366f1;box-shadow:0 8px 20px #4f46e526}.face-photo-upload{text-align:center;cursor:pointer;border:2px dashed #d1d5db;border-radius:.75rem;justify-content:center;align-items:center;min-height:200px;padding:2rem 1.5rem;transition:border-color .2s,background .2s;display:flex}.face-photo-upload:hover{background:#f5f5ff;border-color:#6366f1}.face-photo-upload input{display:none}.face-photo-upload__action{color:var(--color-text-heading,#5a4a4a);margin-bottom:.25rem;font-weight:600;display:block}.face-photo-upload__filename{color:var(--color-text-heading,#5a4a4a);font-weight:600;display:block}.face-photo-upload__hint{color:#6b7280;font-size:.9rem}.face-photo-upload__content{flex-direction:column;align-items:center;gap:.35rem;display:flex}.face-photo-upload__icon{color:#4f46e5;margin-bottom:.5rem;font-size:2.5rem}.face-form__price-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.face-form__error{color:#dc2626;margin-top:.75rem;font-size:.85rem;font-weight:500;display:block}@media (max-width:480px){.face-form__section{padding:1.25rem}.face-form__category-grid,.face-form__price-grid{grid-template-columns:1fr}}.face-suggestion{width:100%;margin-top:2rem}.face-suggestion__title{color:var(--color-primary,#b57ba6);margin-bottom:1rem;font-size:1.5rem;font-weight:600}.face-suggestion__card{background:var(--color-secondary,#faf8f6);border:1px solid var(--color-border-warm,#d4c4c4);border-radius:.85rem;padding:1.75rem;box-shadow:0 16px 35px #b57ba614}.face-suggestion__badge{background:var(--color-accent-light,#6b3a5c26);color:var(--color-accent,#6b3a5c);text-transform:capitalize;border-radius:999px;align-items:center;margin-bottom:.75rem;padding:.35rem .75rem;font-size:.85rem;font-weight:600;display:inline-flex}.face-suggestion__name{color:var(--color-primary,#b57ba6);margin:0 0 1rem;font-size:1.2rem}.face-suggestion__description{color:#6b7280;margin:0 0 1rem;font-size:.95rem;line-height:1.6}.face-suggestion__tips{color:#4b5563;margin:0 0 1rem;font-size:.95rem}.face-suggestion__price{color:var(--color-text-main,#4a4a4a);font-weight:600}.face-suggestion__products{margin-top:1rem}.face-suggestion__products strong{color:var(--color-text-main,#4a4a4a);margin-bottom:.75rem;font-size:.95rem;display:block}.face-suggestion__products-list{margin:0;padding:0;list-style:none}.face-suggestion__products-item{border-bottom:1px solid var(--color-border-warm,#d4c4c4);color:#6b7280;padding:.5rem 0;font-size:.9rem;line-height:1.5}.face-suggestion__products-item:last-child{border-bottom:none}@media (max-width:480px){.face-suggestion{margin-top:1.5rem}.face-suggestion__card{padding:1.25rem}}.perfume-prompt-page{flex-direction:column;justify-content:flex-start;align-items:center;min-height:calc(100vh - 160px);padding:24px 12px 16px;display:flex}.perfume-prompt-page__content{width:95%;max-width:90%;margin:0 auto}.perfume-prompt-page__header{text-align:left;margin-bottom:2rem}.perfume-prompt-page__header h1{color:var(--color-text-heading,#5a4a4a);margin-bottom:.5rem;font-size:2rem}.perfume-prompt-page__header p{color:#6b7280;font-size:1rem}@media (max-width:480px){.perfume-prompt-page{padding-top:24px}.perfume-prompt-page__content{max-width:100%}.perfume-prompt-page__header{margin-bottom:1.25rem}.perfume-prompt-page__header h1{font-size:1.6rem}.perfume-prompt-page__header p{font-size:.95rem}}.perfume-form{flex-direction:column;align-items:flex-start;gap:1.25rem;width:100%;display:flex}.perfume-form__field{width:100%}@media (max-width:480px){.perfume-form{gap:1rem}}.perfume-suggestion{text-align:left;width:100%;margin-top:2rem}.perfume-suggestion__title{color:var(--color-primary,#b57ba6);margin-bottom:1rem;font-size:1.5rem;font-weight:600}.perfume-suggestion__card{background:var(--color-secondary,#faf8f6);border:1px solid var(--color-border-warm,#d4c4c4);border-radius:.75rem;margin-bottom:1rem;padding:1.5rem;box-shadow:0 10px 25px #b57ba614}.perfume-suggestion__name{color:var(--color-primary,#b57ba6);margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.perfume-suggestion__notes{color:var(--color-text-main,#4a4a4a);margin-bottom:.75rem;font-size:.95rem;line-height:1.6}.perfume-suggestion__line{color:var(--color-text-main,#4a4a4a);margin-bottom:.35rem;font-size:.9rem}.perfume-suggestion__line span{font-weight:600}.perfume-suggestion__tags{color:var(--color-accent,#6b3a5c);font-size:.85rem;font-weight:500}.perfume-suggestion__brand-gender{color:var(--color-primary,#b57ba6);margin-bottom:.5rem;font-size:.9rem;font-weight:600}.perfume-suggestion__prompt{color:var(--color-text-main,#4a4a4a);margin-bottom:.75rem;font-size:.9rem}.perfume-suggestion__prompt span{font-weight:500}.perfume-suggestion__list{flex-direction:column;gap:.75rem;display:flex}@media (max-width:480px){.perfume-suggestion{margin-top:1.5rem}.perfume-suggestion__card{padding:1.25rem}}.modal-overlay{z-index:2000;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:#fff;border-radius:.5rem;width:100%;max-width:400px;padding:0;animation:.2s ease-out slideUp;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid #e5e7eb;padding:1.5rem 1.5rem 1rem}.modal-title{color:var(--color-text-heading,#5a4a4a);letter-spacing:-.025em;margin:0;font-size:1.25rem;font-weight:600}.modal-body{padding:1.5rem}.modal-message{color:#6b7280;margin:0;font-size:1rem;line-height:1.5}.modal-footer{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.5rem;display:flex}@media (max-width:480px){.modal-container{max-width:calc(100vw - 2rem)}.modal-header{padding:1.25rem 1.25rem .75rem}.modal-title{font-size:1.125rem}.modal-body{padding:1.25rem}.modal-message{font-size:.875rem}.modal-footer{flex-direction:column-reverse;padding:.75rem 1.25rem 1.25rem}.modal-footer .btn{width:100%}}.profile-page{flex-direction:column;align-items:center;min-height:calc(100vh - 160px);padding:24px 12px 16px;display:flex}.profile-loading{color:#6b7280;justify-content:center;align-items:center;min-height:calc(100vh - 160px);display:flex}.profile-page__content{width:95%;max-width:90%;margin:0 auto}.profile-header{text-align:center;margin-bottom:2rem;padding:2rem 0}.profile-avatar{background:var(--color-primary,#b57ba6);border:2px solid var(--color-border-warm,#d4c4c4);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1rem;display:flex}.profile-avatar span{color:#fff;font-size:2rem;font-weight:600}.profile-name{color:var(--color-text-heading,#5a4a4a);margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.profile-email{color:#6b7280;margin:0;font-size:.875rem}.profile-content{width:100%}.profile-section{margin-bottom:2rem}.profile-section-title{color:var(--color-text-heading,#5a4a4a);margin:0 0 1rem;font-size:1.125rem;font-weight:600}.profile-info{flex-direction:column;gap:1rem;display:flex}.profile-info-item{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;justify-content:space-between;align-items:center;padding:1rem;display:flex}.profile-info-label{color:#6b7280;font-size:.875rem;font-weight:500}.profile-info-value{color:var(--color-text-main,#4a4a4a);text-align:right;font-size:.875rem;font-weight:600}.profile-actions{margin-top:2rem}@media (max-width:480px){.profile-page{padding-top:24px;padding-left:1rem;padding-right:1rem}.profile-header{margin-bottom:1.5rem;padding:1.5rem 0}.profile-avatar{width:64px;height:64px}.profile-avatar span{font-size:1.5rem}.profile-name{font-size:1.25rem}.profile-info-item{flex-direction:column;align-items:flex-start;gap:.5rem}.profile-info-value{text-align:left}}.auth-page{background:#fff;justify-content:center;align-items:center;width:100%;min-height:100vh;margin:0;padding:0;display:flex;position:fixed;inset:0}.auth-container{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;width:100%;max-width:400px;margin:1rem;padding:2.5rem;position:relative}.auth-header{text-align:center;margin-bottom:2rem}.auth-title{color:var(--color-text-heading,#5a4a4a);letter-spacing:-.025em;margin:0 0 .5rem;font-size:2rem;font-weight:600}.auth-subtitle{color:#6b7280;margin:0;font-size:1rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-footer{text-align:center;border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:1.5rem}.auth-link{color:var(--color-primary,#b57ba6);font-weight:500;text-decoration:none;transition:color .2s}.auth-link:hover{color:var(--color-primary-dark,#9a5f8a);text-decoration:underline}.auth-divider{color:#6b7280;align-items:center;margin:1.5rem 0;font-size:.875rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#e5e7eb;flex:1;height:1px}.auth-divider span{padding:0 1rem}.auth-error{color:#dc2626;text-align:center;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;margin-bottom:1rem;padding:.75rem;font-size:.875rem}.auth-row{gap:1rem;display:flex}.auth-row .input-group{flex:1;margin-bottom:1rem}.auth-checkbox{color:var(--color-text-main,#4a4a4a);align-items:flex-start;gap:.5rem;margin-bottom:1rem;font-size:.875rem;display:flex}.auth-checkbox input[type=checkbox]{margin:.125rem 0 0}.auth-checkbox label{cursor:pointer;line-height:1.4}@media (max-width:480px){.auth-page{margin:0;padding:0}.auth-container{border-radius:.375rem;max-width:calc(100vw - 1rem);margin:.5rem;padding:2rem 1.5rem}.auth-title{font-size:1.75rem}.auth-subtitle{font-size:.875rem}.auth-row{flex-direction:column;gap:0}}.header{z-index:1000;background:#fff;border-bottom:1px solid #e5e7eb;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 10px #0000001a}.header-content{justify-content:center;align-items:center;max-width:100%;padding:20px 16px;display:flex}.app-title{color:var(--color-primary,#b57ba6);letter-spacing:-.025em;margin:0;font-size:2rem;font-weight:700}@media (max-width:480px){.header-content{padding:18px 12px}.app-title{font-size:1.75rem}}.app{padding-top:80px;padding-bottom:80px}.bottom-navigation{z-index:1000;background:#fff;border-top:1px solid #e5e7eb;justify-content:space-around;align-items:center;padding:8px 0;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 10px #0000001a}.nav-item{color:#6b7280;border-radius:8px;flex-direction:column;align-items:center;min-width:60px;padding:8px 12px;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:#374151;background-color:#f9fafb}.nav-item.active{color:var(--color-primary,#b57ba6);background-color:var(--color-primary-soft,#b57ba61f);position:relative}.nav-item.active:after{content:"";background-color:var(--color-accent,#6b3a5c);border-radius:2px 2px 0 0;width:60%;height:2px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.nav-icon{margin-bottom:4px;font-size:24px;transition:all .2s}.nav-label{text-align:center;font-size:12px;font-weight:500}@media (max-width:480px){.nav-item{min-width:50px;padding:6px 8px}.nav-icon{font-size:22px}.nav-label{font-size:11px}}.app{padding-bottom:80px}#root{text-align:center;background-color:var(--color-bg,#faf8f6);width:100%;min-height:100vh;margin:0 auto;padding:0}.logo{will-change:filter;height:6em;padding:1.5em;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:20s linear infinite logo-spin}}.card{padding:2em}.read-the-docs{color:#888}
