@import"https://fonts.googleapis.com/css2?family=Satisfy&family=Poppins:wght@300;400;500;600;700&family=Playfair+Display:wght@400;600;700&family=Be+Vietnam+Pro:wght@400;500;600&display=swap";:root{--font-sans: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Satisfy", cursive;--font-serif: "Playfair Display", serif;--font-body: "Be Vietnam Pro", "Poppins", sans-serif;--primary: #9E0027;--primary-container: #C41E3A;--primary-fixed: #FFDAD9;--primary-fixed-dim: #FFB3B4;--primary-color: #E8578C;--primary-light: #F5A0BF;--primary-dark: #C4406E;--secondary: #AD285F;--secondary-container: #FC679C;--secondary-fixed: #FFD9E1;--tertiary: #5C4179;--tertiary-container: #755993;--tertiary-fixed: #EFDBFF;--tertiary-fixed-dim: #DAB9FA;--surface: #FFF8F8;--surface-container: #F6EBEE;--surface-container-low: #FCF1F4;--surface-container-high: #F0E5E8;--surface-container-highest: #EAE0E3;--surface-variant: #EAE0E3;--accent-rose: #F9E4EC;--accent-light: #FCF1F4;--success-color: #34C78B;--warning-color: #F5A623;--danger-color: #E8578C;--background-color: #FFF8F8;--text-color: #1F1A1D;--text-secondary: #5B4040;--text-muted: #8F6F6F;--card-bg: #FFFFFF;--border-color: rgba(227, 190, 189, .15);--outline-variant: #E3BEBD;--shadow-sm: 0 2px 8px rgba(31, 26, 29, .04);--shadow-md: 0 4px 16px rgba(31, 26, 29, .06);--shadow-lg: 0 12px 40px rgba(31, 26, 29, .06);--shadow-xl: 0 16px 48px rgba(31, 26, 29, .08);--radius-sm: 12px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 999px}*{box-sizing:border-box}body{margin:0;font-family:var(--font-body);background:var(--background-color);color:var(--text-color);line-height:1.6;font-size:15px;font-weight:400}#root{display:flex;flex-direction:column;min-height:100vh;max-width:500px;margin:0 auto;background:linear-gradient(180deg,#fff,#fff8f8 40%,#fcf1f4);position:relative;box-shadow:var(--shadow-xl)}.app-title{margin:0 0 .25rem;font-size:3.5rem;font-family:var(--font-display);font-weight:400;letter-spacing:1px;color:#c41e3a;text-align:center;position:relative;display:inline-block}.app-title:after{content:"✨";position:absolute;right:-1.5rem;top:-.3rem;font-size:.85rem;animation:sparkle 2s infinite}@keyframes sparkle{0%,to{opacity:.3;transform:scale(.8) rotate(0)}50%{opacity:1;transform:scale(1.2) rotate(180deg)}}.page{padding:1.5rem;flex-grow:1;display:flex;flex-direction:column;animation:fadeIn .4s ease;position:relative}.home-page{text-align:center;justify-content:flex-start}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-title{margin-top:0;margin-bottom:1rem;text-align:center;color:var(--secondary);font-family:var(--font-serif);font-size:1.75rem;font-weight:700;letter-spacing:-.3px}.hero-illustration{display:flex;justify-content:center;padding:1rem 0;position:relative;overflow:hidden;max-height:420px}.hero-illustration:before{content:"";position:absolute;top:1rem;right:2rem;bottom:1rem;left:2rem;background:#eae0e366;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.4);box-shadow:var(--shadow-lg)}.hero-lipstick-img{height:500px;width:auto;object-fit:contain;object-position:bottom;filter:drop-shadow(0 8px 24px rgba(0,0,0,.12));position:relative;z-index:1;margin-top:-80px}.profile-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:6rem}.profile-photo-wrapper{position:relative;width:180px;height:180px}.profile-photo-wrapper-lg{width:240px;height:240px}.profile-photo{width:100%;height:100%;border-radius:50%;object-fit:cover;border:3px solid var(--primary-fixed);box-shadow:var(--shadow-md)}.tips{background:var(--surface-container-low);border:none;padding:1.5rem;margin:1rem 0;border-radius:var(--radius-lg);text-align:left;box-shadow:var(--shadow-sm)}.tips ul{padding-left:0;margin:0;list-style:none}.tips li{margin:.6rem 0;color:var(--text-secondary);font-weight:400;font-size:.9rem;display:flex;align-items:flex-start;gap:.75rem}.tips li:before{content:"";width:8px;height:8px;min-width:8px;border-radius:50%;background:var(--secondary);margin-top:.45rem}.button-group{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.single-button-group{margin-top:1rem;margin-bottom:1rem}.btn{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;padding:1.15rem 2rem;font-size:1.05rem;font-weight:600;text-align:center;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .2s ease;text-decoration:none;color:#fff;box-shadow:var(--shadow-sm);font-family:var(--font-sans);position:relative;overflow:hidden;letter-spacing:.02em}.btn:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn:active{transform:scale(.97);box-shadow:var(--shadow-sm)}.btn svg{width:1.1em;height:1.1em}.btn-primary{background:linear-gradient(135deg,#c41e3a,#e8578c);color:#fff;box-shadow:0 8px 20px #c41e3a40}.btn-secondary{background:var(--secondary-fixed);color:var(--text-color);border:1px solid rgba(252,103,156,.4)}.btn-secondary:hover{border-color:var(--secondary-container);background:#ffe8ee}.btn-success{background:var(--success-color);box-shadow:0 6px 16px #34c78b33}.btn-danger{background:#ffdad6;color:#93000a}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.preview-container{display:flex;justify-content:center;align-items:center;gap:2.5rem;margin-bottom:1.5rem}.user-photo-preview{width:150px;height:150px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-fixed);box-shadow:var(--shadow-md);transition:transform .3s ease}.user-photo-preview:hover{transform:scale(1.03)}.lipstick-photo-preview{width:150px;height:150px;border-radius:50%;object-fit:cover;object-position:center 60%;border:2px dashed var(--secondary-container);box-shadow:var(--shadow-sm);transition:transform .3s ease;background:var(--surface-container-low)}.lipstick-photo-preview:hover{transform:scale(1.03)}.prompt-info{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem;font-weight:300;font-size:.95rem;padding:1.5rem;background:var(--surface-container-low);border-radius:var(--radius-lg)}.lipstick-page-info{margin-top:1rem;margin-bottom:1rem}.result-image-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}.gallery-item{text-align:center;cursor:zoom-in}.gallery-item img{width:100%;border-radius:var(--radius-md);border:none;margin-bottom:.5rem;aspect-ratio:3 / 4;object-fit:cover;box-shadow:var(--shadow-md);transition:all .3s ease}.gallery-item img:hover{transform:scale(1.02);box-shadow:var(--shadow-lg)}.gallery-item p{margin:0;font-weight:300;font-size:.75rem;color:var(--text-secondary);letter-spacing:.02em}.color-info-box,.recommendations-box{background:#eae0e366;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1rem;box-shadow:var(--shadow-lg)}.color-info-box h3,.recommendations-box h3{margin:0 0 .75rem;font-size:.65rem;color:var(--primary);text-align:left;font-family:var(--font-sans);font-weight:700;text-transform:uppercase;letter-spacing:.2em;padding-bottom:0;border-bottom:none}.lipstick-brand,.lipstick-name{margin:.4rem 0;font-size:.9rem;font-weight:400;color:var(--text-secondary)}.lipstick-brand span,.lipstick-name span{font-weight:600;color:var(--text-color)}.color-display{display:flex;justify-content:flex-start;align-items:center;gap:.75rem;margin-top:.75rem}.color-display .color-swatch{width:40px;height:40px;border-radius:50%;border:none;box-shadow:inset 0 2px 4px #0000001a;ring:4px solid rgba(255,255,255,.2);transition:transform .2s ease}.color-display .color-swatch:hover{transform:scale(1.1)}.color-display .color-hex{font-family:Courier New,monospace;font-size:.75rem;font-weight:500;color:var(--text-secondary)}.rec-section{margin-bottom:1.25rem;background:var(--surface-container-low);padding:1.25rem;border-radius:var(--radius-md)}.rec-section:last-child{margin-bottom:0}.rec-section-title{font-size:.8rem;font-weight:600;letter-spacing:.03em;color:var(--text-color);margin:0 0 .75rem}.rec-items{display:flex;flex-direction:column;gap:.6rem}.rec-item{display:flex;align-items:center;gap:.75rem;padding:0;background:none;border:none;border-radius:0}.rec-color-circle{width:32px;height:32px;min-width:32px;border-radius:50%;border:2px solid rgba(255,255,255,.3);box-shadow:0 1px 3px #0000001a}.rec-icon{width:32px;height:32px;min-width:32px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--primary);background:var(--primary-fixed);border-radius:50%}.rec-item-text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.rec-item-name{font-size:.85rem;font-weight:500;color:var(--text-color)}.rec-item-tip{font-size:.78rem;color:var(--text-secondary);line-height:1.3}.back-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:400;padding:.5rem 0;margin-bottom:1rem;align-self:flex-start;border-radius:0;transition:all .2s ease;font-family:var(--font-sans)}.back-button:hover{color:var(--primary)}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#fff8f8e6;display:flex;justify-content:center;align-items:center;z-index:1000;color:var(--text-color);flex-direction:column;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.spinner{border:3px solid var(--surface-container-high);border-radius:50%;border-top:3px solid var(--primary);width:48px;height:48px;animation:spin .8s linear infinite;margin-bottom:1.25rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-overlay p{font-size:1rem;font-weight:400;color:var(--text-secondary)}.disclaimer-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1f1a1d66;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s}.disclaimer-modal{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:90%;max-width:420px;overflow:hidden}.disclaimer-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem}.disclaimer-modal-header h3{margin:0;font-family:var(--font-serif);font-size:1.25rem;font-weight:700;color:var(--text-color)}.disclaimer-modal-content{padding:1.25rem 1.5rem;font-size:.85rem;color:var(--text-secondary)}.disclaimer-item{margin-bottom:.75rem}.disclaimer-item p{margin:.2rem 0 0;line-height:1.5}.disclaimer-item strong{color:var(--text-color);font-weight:600}.history-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1f1a1d66;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s}.history-modal{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:90%;max-width:420px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.history-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem}.history-modal-header h3{margin:0;font-family:var(--font-serif);font-size:1.25rem;font-weight:700;color:var(--text-color)}.close-btn{background:var(--surface-container-low);border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;line-height:1;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background:var(--surface-container-high);color:var(--primary)}.history-list{padding:1rem 1.5rem;overflow-y:auto;flex-grow:1}.history-empty{text-align:center;color:var(--text-muted);padding:2.5rem 1.5rem;font-style:italic}.history-item{display:flex;align-items:center;gap:.85rem;padding:.85rem;border-radius:var(--radius-md);background:var(--surface-container-low);margin-bottom:.6rem;transition:all .2s ease}.history-item:hover{background:var(--surface-container)}.history-item-swatch{width:44px;height:44px;border-radius:50%;border:none;flex-shrink:0;box-shadow:inset 0 2px 4px #0000001a}.history-item-info{display:flex;flex-direction:column;flex-grow:1;overflow:hidden}.history-item-info strong,.history-item-info span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-item-info strong{font-size:.9rem;color:var(--text-color);font-weight:600}.history-item-info span{font-size:.8rem;color:var(--text-muted);font-weight:400}.history-item .btn{flex-shrink:0;width:auto}.history-modal-footer{padding:1rem 1.5rem}.toast-container{position:fixed;top:80px;right:1rem;z-index:1001;display:flex;flex-direction:column;gap:.5rem;max-width:380px}.toast{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--radius-md);background:var(--card-bg);border:none;box-shadow:var(--shadow-lg);animation:slideIn .3s ease;cursor:pointer;transition:all .2s ease}.toast:hover{transform:translate(-4px)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-error{border-left:4px solid var(--danger-color)}.toast-error:before{content:"!";font-weight:700;color:var(--danger-color);font-size:1.1rem}.toast-success{border-left:4px solid var(--success-color)}.toast-success:before{content:"✓";font-weight:700;color:var(--success-color);font-size:1.1rem}.toast-info{border-left:4px solid var(--primary-color)}.toast-info:before{content:"i";font-weight:700;color:var(--primary-color);font-size:1.1rem;font-style:italic}.toast span{flex-grow:1;font-size:.85rem;font-weight:500;color:var(--text-color)}.toast-close{background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;line-height:1;padding:.2rem .4rem;border-radius:6px;transition:all .2s ease}.toast-close:hover{background:var(--surface-container-low);color:var(--primary)}@media(max-width:500px){.toast-container{left:1rem;right:1rem;max-width:none}.app-title{font-size:2rem}.page-title{font-size:1.5rem}.result-image-gallery{gap:.5rem}.user-photo-preview,.lipstick-photo-preview{width:130px;height:130px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--outline-variant);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--primary);color:#fff}::-moz-selection{background:var(--primary);color:#fff}.gallery-page{padding:1.5rem 1.5rem 6rem}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.back-icon-btn{background:none;border:none;color:var(--primary);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.back-icon-btn:hover{background:var(--surface-container-low);color:var(--primary-container)}.gallery-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:700;color:var(--primary-color);margin:0}.profile-placeholder{width:40px}.search-bar{display:flex;align-items:center;gap:.75rem;background:var(--surface-container-low);border:1px solid var(--border-color);border-radius:var(--radius-full);padding:.85rem 1.25rem;margin-bottom:1.25rem;transition:all .2s ease}.search-bar:focus-within{border-color:#9e002766;background:var(--surface-container)}.search-bar svg{stroke:var(--text-muted);flex-shrink:0}.search-bar input{border:none;background:transparent;font-family:var(--font-sans);font-size:.9rem;color:var(--text-color);width:100%;outline:none}.search-bar input::placeholder{color:#8f6f6f80}.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.gallery-empty{grid-column:1 / -1;text-align:center;color:var(--text-muted);padding:3rem 1rem;font-style:italic}.gallery-card{background:var(--card-bg);border:none;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all .3s ease;cursor:pointer}.gallery-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-lg)}.gallery-card-image{width:100%;aspect-ratio:3 / 4;overflow:hidden;background:var(--surface-container-low);cursor:zoom-in}.gallery-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-card:hover .gallery-card-image img{transform:scale(1.05)}.gallery-card-info{padding:.85rem}.gallery-card-title{margin:0 0 .15rem;font-size:.85rem;font-weight:500;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-card-date{margin:0;font-size:.7rem;color:var(--text-muted);font-weight:400}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:500px;background:#fff8f8cc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:none;border-radius:2rem 2rem 0 0;display:flex;justify-content:space-around;align-items:center;padding:.6rem 0 .8rem;z-index:99;box-shadow:0 -12px 40px #1f1a1d0f}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem 1rem;border-radius:var(--radius-full);transition:all .3s ease;font-family:var(--font-sans);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.nav-item svg{width:24px;height:24px;stroke:var(--text-muted);transition:all .3s ease}.nav-item.active{color:#fff;background:linear-gradient(135deg,#9e0027,#c41e3a);padding:.6rem 1.25rem;box-shadow:0 4px 12px #9e00274d}.nav-item.active svg{stroke:#fff}.nav-item:not(:disabled):hover:not(.active){color:var(--primary)}.nav-item:not(:disabled):hover:not(.active) svg{stroke:var(--primary)}.nav-item:disabled{opacity:.3;cursor:not-allowed}.nav-item span{margin:0}main{padding-bottom:5rem}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#1f1a1deb;display:flex;align-items:center;justify-content:center;animation:lightbox-fade-in .2s ease;cursor:zoom-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lightbox-overlay img{max-width:95vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md);cursor:default}.lightbox-close{position:absolute;top:12px;right:16px;background:none;border:none;color:#fff;font-size:2.5rem;cursor:pointer;line-height:1;opacity:.8;transition:opacity .2s}.lightbox-close:hover{opacity:1}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}
